:root {
  --teal:       #5bb8b0;
  --teal-d:     #3a9e96;
  --teal-xl:    #eaf7f6;
  --teal-l:     #c5eae7;
  --purple:     #7b5ea7;
  --purple-d:   #5c4280;
  --purple-xl:  #f0ecf9;
  --purple-l:   #d8cff0;
  --pink:       #e84393;
  --pink-d:     #c42d79;
  --pink-xl:    #fdeef7;
  --pink-l:     #f5b8d8;
  --grad:       linear-gradient(135deg,#5bb8b0 0%,#7b5ea7 55%,#e84393 100%);
  --grad-h:     linear-gradient(90deg,#7b5ea7 0%,#e84393 100%);
  --grad-t:     linear-gradient(90deg,#5bb8b0 0%,#7b5ea7 100%);
  --white:      #ffffff;
  --off:        #f9f9fb;
  --text:       #0f0e17;
  --text2:      #1e1b2e;
  --muted:      #6e6882;
  --muted2:     #b0aabf;
  --line:       rgba(0,0,0,0.07);
  --line2:      rgba(123,94,167,0.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Manrope',sans-serif;background:#fff;color:var(--text);overflow-x:hidden;}

/* ── CURSOR ── */
*,a,button{cursor:none!important;}
#dot{position:fixed;width:8px;height:8px;background:var(--pink);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;}
#ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--teal);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;transition:all .3s;}
body:has(a:hover) #dot,body:has(button:hover) #dot{width:14px;height:14px;background:var(--purple);}
body:has(a:hover) #ring,body:has(button:hover) #ring{width:52px;height:52px;opacity:1;border-color:var(--pink);}

/* ════════════════════════════
   HERO — split asymmetric
════════════════════════════ */
.hero{min-height:100vh;
display:grid;
grid-template-columns:58% 42%;
background:#fff;
position:relative;
overflow:hidden;}

/* thin diagonal accent line */
.hero::before{content:'';
position:absolute;
top:0;
bottom:0;
left:57%;
width:1px;
background:linear-gradient(to bottom,transparent 5%,var(--teal-l) 30%,var(--purple-l) 70%,transparent 95%);
z-index:1;}

/* top gradient bar */
.top-bar{position:absolute;
top:0;
left:0;
right:0;
height:3px;
background:var(--grad);
z-index:10;}

.hero-left{padding:6rem 4rem 6rem 7rem;
display:flex;
flex-direction:column;
justify-content:center;
position:relative;
z-index:3;}

/* pill tag */
.pill-tag{display:inline-flex;
align-items:center;
gap:10px;
background:var(--teal-xl);
border:1px solid var(--teal-l);
padding:7px 18px;
border-radius:100px;
width:fit-content;
margin-bottom:2.2rem;
opacity:0;
animation:au .6s .05s ease forwards;}
.pill-tag span{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-d);}
.pt-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:ptblink 2s infinite;}
@keyframes ptblink{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.3;transform:scale(.7);}}

/* big headline — mixed serif + sans */
.hero-title{font-size:clamp(3.6rem,6vw,7rem);
line-height:.96;
letter-spacing:-.03em;
margin-bottom:1.8rem;
opacity:0;
animation:au .9s .18s ease forwards;}
.hero-title .sans{font-family:'Manrope',sans-serif;
font-weight:800;
display:block;
color:var(--text);}
.hero-title .serif{font-family:'Instrument Serif',serif;
font-style:italic;
font-weight:400;
display:block;
background:var(--grad);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}
.hero-title .thin{font-family:'Manrope',sans-serif;
font-weight:300;
display:block;
color:var(--muted);
font-size:70%;
letter-spacing:0;}

.hero-desc{font-size:1rem;
color:var(--muted);
line-height:1.8;
max-width:420px;
font-weight:400;
margin-bottom:2.8rem;
opacity:0;
animation:au .9s .3s ease forwards;
padding-left:1rem;
border-left:2px solid var(--teal-l);}

/* tag chips */
.tag-chips{display:flex;
gap:8px;
flex-wrap:wrap;
margin-bottom:2.5rem;
opacity:0;
animation:au .9s .4s ease forwards;}
.chip{padding:7px 16px;
border-radius:8px;
font-size:.75rem;
font-weight:600;
border:1px solid var(--line2);
background:#fff;
color:var(--text2);
transition:all .22s;}
.chip:hover{background:var(--purple-xl);border-color:var(--purple-l);color:var(--purple);}

.hero-btns{display:flex;
gap:12px;
flex-wrap:wrap;
margin-bottom:3rem;
opacity:0;
animation:au .9s .5s ease forwards;}

.btn-a{background:var(--grad-h);
color: #fff !important;
padding:14px 30px;
border-radius:10px;
font-family:'Manrope',sans-serif;
font-weight:700;
font-size:.85rem;
letter-spacing:.04em;
text-decoration:none;
border:none;
display:inline-flex;
align-items:center;
gap:9px;
box-shadow:0 6px 28px rgba(123,94,167,.28);
transition:transform .22s,box-shadow .22s;}
.btn-a:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(123,94,167,.38);}

.btn-b{background:#fff;
color:var(--teal-d);
padding:14px 30px;
border-radius:10px;
font-family:'Manrope',sans-serif;
font-weight:700;
font-size:.85rem;
letter-spacing:.04em;
text-decoration:none;
border:1.5px solid var(--teal);
display:inline-flex;
align-items:center;
gap:9px;
transition:all .22s;}
.btn-b:hover{background:var(--teal);color: #fff !important;}

.btn-c{background:#fff;
color:var(--purple);
padding:14px 30px;
border-radius:10px;
font-family:'Manrope',sans-serif;
font-weight:700;
font-size:.85rem;
letter-spacing:.04em;
text-decoration:none;
border:1.5px solid var(--purple);
display:inline-flex;
align-items:center;
gap:9px;
transition:all .22s;}
.btn-c:hover{background:var(--purple);color: #fff !important;}

/* stat row */
.stat-row{display:flex;
gap:2rem;
opacity:0;
animation:au .9s .6s ease forwards;
padding-top:2rem;
border-top:1px solid var(--line);}
.stat{display:flex;flex-direction:column;gap:3px;}
.stat-n{font-family:'Instrument Serif',serif;
font-size:2.2rem;
font-weight:400;
line-height:1;
background:var(--grad);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}
.stat-l{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);}

/* ── hero right: stacked image collage ── */
.hero-right{position:relative;
overflow:hidden;
background:var(--off);}

.hr-main{position:absolute;
width:75%;
height:65%;
object-fit:cover;
top:8%;
left:6%;
border-radius:24px;
box-shadow:0 24px 64px rgba(0,0,0,.14);
opacity:0;
animation:imgA .9s .3s ease forwards;}
.hr-sm1{position:absolute;
width:44%;
height:38%;
object-fit:cover;
bottom:5%;
right:2%;
border-radius:18px;
border:4px solid #fff;
box-shadow:0 16px 48px rgba(0,0,0,.12);
opacity:0;
animation:imgB .9s .55s ease forwards;}
.hr-sm2{position:absolute;
width:36%;
height:32%;
object-fit:cover;
bottom:28%;
left:2%;
border-radius:18px;
border:4px solid #fff;
box-shadow:0 16px 48px rgba(0,0,0,.12);
opacity:0;
animation:imgC .9s .75s ease forwards;}

@keyframes imgA{from{opacity:0;transform:scale(.93) translateY(12px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes imgB{from{opacity:0;transform:scale(.9) translateX(14px);}to{opacity:1;transform:scale(1) translateX(0);}}
@keyframes imgC{from{opacity:0;transform:scale(.9) translateX(-14px);}to{opacity:1;transform:scale(1) translateX(0);}}

/* floating chips on hero-right */
.hchip{position:absolute;
z-index:5;
background:#fff;
border-radius:14px;
padding:.85rem 1.1rem;
box-shadow:0 8px 32px rgba(0,0,0,.1);
border:1px solid var(--line);}
.hc1{top:6%;right:3%;animation:fc1 5s ease-in-out infinite;}
.hc2{bottom:4%;left:4%;animation:fc2 5s 1s ease-in-out infinite;}
@keyframes fc1{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
@keyframes fc2{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
.hchip-tag{font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pink);margin-bottom:3px;}
.hchip-val{font-size:.85rem;font-weight:700;color:var(--text);}
.hchip-sub{font-size:.66rem;color:var(--muted);margin-top:1px;}

/* color accent dot on right bg */
.hero-right::after{content:'';
position:absolute;
width:300px;
height:300px;
border-radius:50%;
background:radial-gradient(circle,rgba(91,184,176,.12) 0%,transparent 70%);
bottom:-80px;
right:-80px;
pointer-events:none;}

@keyframes au{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}

/* scroll hint */
.scroll-h{position:absolute;
bottom:2rem;
left:7rem;
z-index:5;
display:flex;
align-items:center;
gap:10px;
color:var(--muted2);
font-size:.62rem;
letter-spacing:.15em;
text-transform:uppercase;
font-weight:700;
opacity:0;
animation:au .8s 1.2s ease forwards;}
.sbar{width:48px;
height:1px;
background:linear-gradient(to right,var(--teal),var(--purple));
position:relative;
overflow:hidden;}
.sbar::after{content:'';
position:absolute;
top:0;
left:-100%;
height:100%;
width:100%;
background:#fff;
animation:sbr 2s ease-in-out infinite;}
@keyframes sbr{0%{left:-100%;}100%{left:100%;}}

/* ════════════════════════════
   BRAND STRIP
════════════════════════════ */
.strip{background:var(--grad);
padding:13px 0;
overflow:hidden;}
.strip-inner{display:flex;
gap:2.5rem;
width:max-content;
animation:stripRun 28s linear infinite;}
.si{display:flex;align-items:center;gap:8px;color: rgba(255,255,255,.88) !important;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
.sx{color: rgba(255,255,255,.3) !important;}
@keyframes stripRun{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ════════════════════════════
   SECTION UTILITIES
════════════════════════════ */
.sec{padding:6rem 7rem;}
.sec-w{background:#fff;}
.sec-off{background:var(--off);}
.sec-tl{background:var(--teal-xl);}
.sec-pp{background:var(--purple-xl);}

.stag{display:inline-flex;
align-items:center;
gap:9px;
font-size:.64rem;
font-weight:800;
letter-spacing:.2em;
text-transform:uppercase;
color:var(--teal-d);
margin-bottom:1rem;}
.stag::before{content:'';width:24px;height:2px;background:var(--grad-t);border-radius:2px;}

.sh{font-size:clamp(2.2rem,3.5vw,3.6rem);
line-height:1.05;
letter-spacing:-.025em;
margin-bottom:1rem;
font-weight:800;
color:var(--text);}
.sh .serif{font-family:'Instrument Serif',serif;
font-style:italic;
font-weight:400;
background:var(--grad-h);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}

.ssub{font-size:.96rem;color:var(--muted);line-height:1.78;max-width:520px;font-weight:400;}

/* ════════════════════════════
   STEPS — card row
════════════════════════════ */
.steps-row{display:grid;
grid-template-columns:repeat(4,1fr);
gap:1px;
background:var(--line);
border:1px solid var(--line);
border-radius:20px;
overflow:hidden;
margin-top:3.5rem;}
.sc{background:#fff;
padding:2.2rem 1.8rem;
position:relative;
overflow:hidden;
transition:background .3s;}
.sc:hover{background:var(--teal-xl);}

/* number watermark */
.sc-num{position:absolute;
top:-10px;
right:12px;
font-family:'Instrument Serif',serif;
font-size:6rem;
font-weight:400;
font-style:italic;
color:rgba(91,184,176,.08);
line-height:1;
pointer-events:none;
transition:color .3s;}
.sc:hover .sc-num{color:rgba(91,184,176,.18);}

.sc-ico{width:48px;
height:48px;
border-radius:14px;
display:flex;
align-items:center;
justify-content:center;
font-size:1.3rem;
margin-bottom:1.2rem;
border:1px solid var(--line);
background:#fff;
position:relative;
z-index:1;
transition:all .3s;}
.sc:hover .sc-ico{background:var(--teal-xl);border-color:var(--teal-l);transform:scale(1.08);}

.sc h4{font-weight:700;font-size:.92rem;margin-bottom:.5rem;color:var(--text);position:relative;z-index:1;}
.sc p{font-size:.8rem;color:var(--muted);line-height:1.6;position:relative;z-index:1;}

/* step connector */
.steps-row .sc:not(:last-child)::after{content:'→';
position:absolute;
top:50%;
right:-1px;
transform:translateY(-50%);
font-size:1rem;
color:var(--teal-l);
z-index:5;}

/* ════════════════════════════
   OUTING TYPES — BENTO GRID
════════════════════════════ */
.bento{display:grid;
grid-template-columns:repeat(3,1fr);
grid-template-rows:280px 280px;
gap:14px;
margin-top:3.5rem;}

.bc{border-radius:20px;
overflow:hidden;
position:relative;
cursor:default;}
.bc:first-child{grid-column:span 2;}
.bc:nth-child(5){grid-column:span 2;}

.bc img{width:100%;
height:100%;
object-fit:cover;
display:block;
filter:brightness(.82) saturate(1.15);
transition:transform .6s ease,filter .5s;}
.bc:hover img{transform:scale(1.06);filter:brightness(.7) saturate(1.35);}

.bc-ov{position:absolute;
inset:0;
background:linear-gradient(to top,rgba(15,14,23,.85) 0%,rgba(15,14,23,.05) 55%,transparent 100%);}
/* top accent line reveal */
.bc::before{content:'';
position:absolute;
top:0;
left:0;
right:0;
height:3px;
background:var(--grad);
z-index:3;
transform:scaleX(0);
transform-origin:left;
transition:transform .4s;}
.bc:hover::before{transform:scaleX(1);}

.bc-info{position:absolute;
bottom:0;
left:0;
right:0;
padding:1.6rem;
z-index:2;
transform:translateY(5px);
transition:transform .3s;}
.bc:hover .bc-info{transform:translateY(0);}

.bc-cat{font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-l);margin-bottom:5px;}
.bc-title{font-family:'Instrument Serif',serif;font-size:1.8rem;font-style:italic;color: #fff !important;line-height:1.1;margin-bottom:5px;}
.bc:first-child .bc-title{font-size:2.5rem;}
.bc:nth-child(5) .bc-title{font-size:2.2rem;}
.bc-desc{font-size:.76rem;color: rgba(255,255,255,.65) !important;line-height:1.5;max-height:0;overflow:hidden;transition:max-height .35s;}
.bc:hover .bc-desc{max-height:60px;}

/* ════════════════════════════
   MARQUEE — big outlined type
════════════════════════════ */
.marquee-s{padding:2.5rem 0;
overflow:hidden;
background:#fff;
border-top:1px solid var(--line);
border-bottom:1px solid var(--line);}
.mi{display:flex;width:max-content;animation:mr 22s linear infinite;}
.mw{font-family:'Instrument Serif',serif;
font-size:5.5rem;
font-style:italic;
padding:0 1.5rem;
white-space:nowrap;
color:transparent;
-webkit-text-stroke:1px rgba(123,94,167,.18);
line-height:1;}
.mw.on{-webkit-text-stroke:0;
background:var(--grad);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}
.msep{font-size:1.8rem;line-height:5.5rem;padding:0 .5rem;color:var(--teal);}
@keyframes mr{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ════════════════════════════
   WHY SPLIT — reverse layout
════════════════════════════ */
.why-wrap{display:grid;
grid-template-columns:1fr 1fr;
gap:5rem;
align-items:center;}

/* text left */
.why-right{} /* text side */

/* image right with layered cards */
.why-left{position:relative;}
.wi-main{width:100%;
height:540px;
object-fit:cover;
border-radius:24px;
box-shadow:0 32px 80px rgba(0,0,0,.1);}
.wi-card{position:absolute;
background:#fff;
border-radius:16px;
box-shadow:0 12px 40px rgba(0,0,0,.1);
border:1px solid var(--line);
padding:1.1rem 1.4rem;}
.wi-c1{bottom:-24px;left:-24px;animation:wf1 5s ease-in-out infinite;min-width:160px;}
.wi-c2{top:24px;right:-28px;animation:wf2 5s 1.2s ease-in-out infinite;min-width:140px;}
@keyframes wf1{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
@keyframes wf2{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.wc-ico{font-size:1.6rem;display:block;margin-bottom:4px;}
.wc-n{font-family:'Instrument Serif',serif;font-size:1.8rem;font-style:italic;line-height:1;background:var(--grad-h);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.wc-l{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}

/* feature accordion rows */
.frows{display:flex;flex-direction:column;gap:0;margin-top:2.5rem;}
.fr{display:flex;
align-items:flex-start;
gap:1.2rem;
padding:1.4rem 0;
border-bottom:1px solid var(--line);
transition:all .25s;}
.fr:last-child{border-bottom:none;}
.fr:hover .fr-ico-wrap{transform:scale(1.08);}
.fr-ico-wrap{width:44px;
height:44px;
border-radius:12px;
display:flex;
align-items:center;
justify-content:center;
font-size:1.1rem;
flex-shrink:0;
transition:transform .25s;}
.fr:nth-child(1) .fr-ico-wrap{background:var(--teal-xl);}
.fr:nth-child(2) .fr-ico-wrap{background:var(--purple-xl);}
.fr:nth-child(3) .fr-ico-wrap{background:var(--pink-xl);}
.fr:nth-child(4) .fr-ico-wrap{background:var(--teal-xl);}
.fr-txt h4{font-weight:700;font-size:.91rem;margin-bottom:3px;color:var(--text);}
.fr-txt p{font-size:.79rem;color:var(--muted);line-height:1.55;}
.fr-arr{margin-left:auto;color:var(--muted2);font-size:1.1rem;padding-top:2px;transition:all .25s;flex-shrink:0;}
.fr:hover .fr-arr{color:var(--teal-d);transform:translateX(5px);}

/* ════════════════════════════
   EXPERIENCES — horizontal scroll cards
════════════════════════════ */
.exp-scroll{display:grid;
grid-template-columns:repeat(3,1fr);
gap:1.2rem;
margin-top:3rem;}
.ec{border-radius:20px;
overflow:hidden;
background:#fff;
border:1px solid var(--line);
transition:all .35s;
position:relative;}
.ec::after{content:'';
position:absolute;
inset:0;
border-radius:20px;
border:2px solid transparent;
transition:border-color .35s;
pointer-events:none;}
.ec:hover::after{border-color:var(--teal-l);}
.ec:hover{transform:translateY(-7px);box-shadow:0 20px 56px rgba(91,184,176,.14);}
.ec-img{width:100%;height:180px;object-fit:cover;display:block;transition:transform .5s;}
.ec:hover .ec-img{transform:scale(1.05);}
.ec-body{padding:1.4rem;}
.ec-body h4{font-weight:700;font-size:.92rem;margin-bottom:5px;color:var(--text);}
.ec-body p{font-size:.79rem;color:var(--muted);line-height:1.55;}
.ec-pill{display:inline-flex;
align-items:center;
gap:5px;
margin-top:11px;
padding:4px 13px;
border-radius:100px;
font-size:.62rem;
font-weight:700;
letter-spacing:.09em;
text-transform:uppercase;}
.ec:nth-child(1) .ec-pill{background:var(--teal-xl);color:var(--teal-d);}
.ec:nth-child(2) .ec-pill{background:var(--purple-xl);color:var(--purple-d);}
.ec:nth-child(3) .ec-pill{background:var(--pink-xl);color:var(--pink-d);}
.ec:nth-child(4) .ec-pill{background:var(--teal-xl);color:var(--teal-d);}
.ec:nth-child(5) .ec-pill{background:var(--purple-xl);color:var(--purple-d);}
.ec:nth-child(6) .ec-pill{background:var(--pink-xl);color:var(--pink-d);}

/* ════════════════════════════
   STATS — big number row
════════════════════════════ */
.stats-big{display:grid;
grid-template-columns:repeat(4,1fr);
border-top:1px solid var(--line);
border-bottom:1px solid var(--line);
margin-top:4rem;}
.sb{padding:2.5rem 2rem;
text-align:center;
border-right:1px solid var(--line);
transition:background .3s;}
.sb:last-child{border-right:none;}
.sb:hover{background:var(--teal-xl);}
.sb-n{font-family:'Instrument Serif',serif;
font-size:3.5rem;
font-style:italic;
line-height:1;
background:var(--grad);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;
margin-bottom:.3rem;
display:block;}
.sb h4{font-weight:700;font-size:.86rem;margin-bottom:.3rem;color:var(--text);}
.sb p{font-size:.72rem;color:var(--muted);line-height:1.45;}

/* ════════════════════════════
   CTA — full width dramatic
════════════════════════════ */
.cta-full{padding:6rem 7rem;
background:#fff;}
.cta-inner{border-radius:28px;
overflow:hidden;
position:relative;
display:grid;
grid-template-columns:1fr 1fr;
min-height:460px;
border:1px solid var(--line2);
box-shadow:0 24px 80px rgba(123,94,167,.1);}

/* decorative teal circle bg */
.cta-inner::before{content:'';
position:absolute;
width:500px;
height:500px;
border-radius:50%;
background:radial-gradient(circle,rgba(91,184,176,.08) 0%,transparent 70%);
top:-100px;
left:-100px;
pointer-events:none;
z-index:0;}

/* grid dots */
.cta-inner::after{content:'';
position:absolute;
inset:0;
background-image:radial-gradient(circle,rgba(123,94,167,.07) 1px,transparent 1px);
background-size:24px 24px;
-webkit-mask-image:radial-gradient(ellipse 80% 90% at 35% 50%,black 20%,transparent 75%);
mask-image:radial-gradient(ellipse 80% 90% at 35% 50%,black 20%,transparent 75%);
pointer-events:none;}

.cta-left{padding:4.5rem;
position:relative;
z-index:2;
display:flex;
flex-direction:column;
justify-content:center;
background:#fff;}
/* gradient top-left corner accent */
.cta-left::before{content:'';
position:absolute;
top:0;
left:0;
right:0;
height:4px;
background:var(--grad);}

.cta-left h2{font-size:3.2rem;
font-weight:800;
line-height:1;
letter-spacing:-.025em;
color:var(--text);
margin-bottom:.9rem;}
.cta-left h2 .serif{font-family:'Instrument Serif',serif;
font-style:italic;
font-weight:400;
background:var(--grad-h);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}
.cta-left p{color:var(--muted);font-size:.96rem;font-weight:400;margin-bottom:2rem;line-height:1.72;max-width:380px;}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap;}

.cta-right{position:relative;overflow:hidden;}
.cta-right img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.88) saturate(1.15);}
.cta-right::before{content:'';
position:absolute;
inset:0;
z-index:1;
background:linear-gradient(to right,#fff 0%,transparent 40%);}

/* ════════════════════════════
   SCROLL REVEAL
════════════════════════════ */
.rev{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease;}
.rev.on{opacity:1;transform:translateY(0);}
.rev.d1{transition-delay:.1s;}.rev.d2{transition-delay:.2s;}.rev.d3{transition-delay:.3s;}

/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero::before{display:none;}
  .hero-left{padding:5rem 3rem 3rem;}
  .hero-right{height:400px;}
  .sec,.cta-full{padding:4rem 3rem;}
  .steps-row{grid-template-columns:repeat(2,1fr);}
  .bento{grid-template-columns:1fr 1fr;grid-template-rows:220px 220px;}
  .bento .bc:first-child,.bento .bc:nth-child(5){grid-column:span 1;}
  .why-wrap{grid-template-columns:1fr;}
  .exp-scroll{grid-template-columns:repeat(2,1fr);}
  .stats-big{grid-template-columns:repeat(2,1fr);}
  .cta-inner{grid-template-columns:1fr;}
  .cta-right{height:260px;}
}
@media(max-width:640px){
  .hero-left{padding:4rem 1.5rem 2rem;}
  .hero-right{height:300px;}
  .sec,.cta-full{padding:3rem 1.5rem;}
  .steps-row,.exp-scroll,.stats-big{grid-template-columns:1fr;}
  .bento{grid-template-columns:1fr;grid-template-rows:200px;}
  .bento .bc:nth-child(n+4){display:none;}
  .stats-big .sb{border-right:none;border-bottom:1px solid var(--line);}
  #dot,#ring{display:none;}
}