:root {
  --teal:         #5bb8b0;
  --teal-d:       #3a9e96;
  --teal-l:       #c8ece9;
  --teal-s:       #edf9f8;
  --teal-ss:      #f5fcfb;
  --purple:       #7b5ea7;
  --purple-d:     #5c4280;
  --purple-l:     #e8e1f5;
  --purple-s:     #f4f1fb;
  --pink:         #e84393;
  --pink-d:       #c42d79;
  --pink-l:       #fbd5ea;
  --pink-s:       #fef0f8;
  --rose:         #ff7eb3;
  --grad:         linear-gradient(135deg,#5bb8b0 0%,#7b5ea7 52%,#e84393 100%);
  --grad-r:       linear-gradient(135deg,#e84393 0%,#7b5ea7 52%,#5bb8b0 100%);
  --grad-h:       linear-gradient(90deg,#7b5ea7 0%,#e84393 100%);
  --grad-warm:    linear-gradient(135deg,#fef0f8 0%,#f4f1fb 50%,#edf9f8 100%);
  --bg:           #fdfbfe;
  --bg2:          #ffffff;
  --bg3:          #fef8fc;
  --text:         #18121f;
  --text2:        #2d1f3a;
  --muted:        #72667e;
  --muted2:       #a89db8;
  --border:       rgba(123,94,167,0.1);
  --border-t:     rgba(91,184,176,0.18);
  --border-p:     rgba(232,67,147,0.15);
  --shadow-sm:    0 2px 16px rgba(123,94,167,.08);
  --shadow-md:    0 8px 40px rgba(123,94,167,.12);
  --shadow-lg:    0 24px 80px rgba(123,94,167,.16);
}

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

/* ── CURSOR ── */
*,a,button{cursor:none!important;}
#cur{position:fixed;width:10px;height:10px;background:var(--pink);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:multiply;transition:transform .15s,background .2s;}
#cur-r{position:fixed;width:34px;height:34px;border:1.5px solid var(--pink);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.45;transition:width .3s,height .3s,opacity .3s,border-color .3s;}
body:has(a:hover) #cur-r,body:has(button:hover) #cur-r{width:54px;height:54px;opacity:.9;border-color:var(--purple);}

/* ══════════════════════════
   HERO
══════════════════════════ */
.hero{min-height:100vh;
background:var(--bg2);
display:grid;
grid-template-columns:1fr 1fr;
position:relative;
overflow:hidden;}

/* soft organic blobs */
.blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:blobPulse 10s ease-in-out infinite;}
.b1{width:600px;height:600px;background:rgba(232,67,147,.07);top:-200px;right:-100px;}
.b2{width:450px;height:450px;background:rgba(91,184,176,.08);bottom:-150px;left:-80px;animation-delay:3s;}
.b3{width:300px;height:300px;background:rgba(123,94,167,.06);top:35%;left:35%;animation-delay:6s;}
@keyframes blobPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.15);opacity:.7;}}

/* subtle petal pattern */
.hero-pattern{position:absolute;
inset:0;
pointer-events:none;
background-image:
    radial-gradient(circle at 1px 1px, rgba(232,67,147,.08) 1px, transparent 0);
background-size:36px 36px;
-webkit-mask-image:radial-gradient(ellipse 70% 70% at 65% 50%,black 0%,transparent 75%);
mask-image:radial-gradient(ellipse 70% 70% at 65% 50%,black 0%,transparent 75%);}

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

/* eyebrow */
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:2rem;opacity:0;animation:fadeUp .7s .05s ease forwards;}
.ew-hearts{display:flex;gap:3px;}
.heart{width:8px;height:8px;background:var(--pink);transform:rotate(45deg);position:relative;border-radius:1px;}
.heart::before,.heart::after{content:'';position:absolute;width:8px;height:8px;border-radius:50%;background:var(--pink);}
.heart::before{top:-4px;left:0;}
.heart::after{top:0;left:-4px;}
.ew-h1,.ew-h2,.ew-h3{animation:heartbeat 2.4s ease-in-out infinite;}
.ew-h2{animation-delay:.2s;}.ew-h3{animation-delay:.4s;}
@keyframes heartbeat{0%,100%{transform:rotate(45deg) scale(1);}50%{transform:rotate(45deg) scale(1.3);}}

.ew-text{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--pink);background:var(--pink-s);padding:5px 16px;border-radius:100px;border:1px solid var(--border-p);}
.ew-loc{font-size:.7rem;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:5px;}
.ew-loc::before{content:'📍';font-size:.75rem;}

/* hero headline */
.hero-h{font-family:'Fraunces',serif;
font-size:clamp(3.8rem,6.5vw,7rem);
font-weight:300;
line-height:1.0;
letter-spacing:-.025em;
margin-bottom:1.8rem;
opacity:0;
animation:fadeUp .9s .2s ease forwards;}
.hero-h strong{font-weight:700;display:block;}
.hero-h .it{font-style:italic;
font-weight:300;
display:block;
background:var(--grad-h);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;}

.hero-desc{font-size:1.02rem;
color:var(--muted);
line-height:1.8;
max-width:430px;
font-weight:300;
margin-bottom:2.5rem;
opacity:0;
animation:fadeUp .9s .32s ease forwards;}

/* experience badges */
.exp-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s .42s ease forwards;}
.exp-badge{display:inline-flex;
align-items:center;
gap:7px;
padding:8px 16px;
border-radius:100px;
font-size:.76rem;
font-weight:600;
background:var(--bg2);
border:1px solid var(--border);
color:var(--text2);
box-shadow:var(--shadow-sm);
transition:all .25s;}
.exp-badge:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,67,147,.15);}

/* CTA buttons */
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:3rem;opacity:0;animation:fadeUp .9s .5s ease forwards;}

.btn-main{background:var(--grad-h);
color: #fff !important;
padding:15px 32px;
border-radius:100px;
font-family:'Outfit',sans-serif;
font-weight:700;
font-size:.88rem;
letter-spacing:.04em;
text-decoration:none;
border:none;
display:inline-flex;
align-items:center;
gap:9px;
box-shadow:0 8px 30px rgba(232,67,147,.3);
transition:transform .25s,box-shadow .25s;}
.btn-main:hover{transform:translateY(-3px);box-shadow:0 14px 42px rgba(232,67,147,.4);}

.btn-sec{background:transparent;
color:var(--purple);
padding:15px 32px;
border-radius:100px;
font-family:'Outfit',sans-serif;
font-weight:600;
font-size:.88rem;
letter-spacing:.04em;
text-decoration:none;
border:2px solid var(--purple);
display:inline-flex;
align-items:center;
gap:9px;
transition:all .25s;}
.btn-sec:hover{background:var(--purple);color: #fff !important;}

.btn-teal{background:var(--teal);
color: #fff !important;
padding:15px 32px;
border-radius:100px;
font-family:'Outfit',sans-serif;
font-weight:700;
font-size:.88rem;
letter-spacing:.04em;
text-decoration:none;
border:none;
display:inline-flex;
align-items:center;
gap:9px;
box-shadow:0 8px 30px rgba(91,184,176,.28);
transition:transform .25s,box-shadow .25s;}
.btn-teal:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(91,184,176,.4);}

/* trust row */
.trust-row{display:flex;gap:1.5rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .6s ease forwards;}
.tc{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--muted);font-weight:500;}
.tc-dot{width:7px;height:7px;border-radius:50%;background:var(--grad-h);flex-shrink:0;}

/* ── HERO RIGHT — romantic image collage ── */
.hero-right{position:relative;overflow:hidden;z-index:2;}

.img-main{position:absolute;
width:300px;
height:400px;
object-fit:cover;
border-radius:30px 30px 30px 8px;
top:50%;
left:50%;
transform:translate(-60%,-52%);
box-shadow:0 30px 80px rgba(123,94,167,.18);
animation:imgFloat 6s ease-in-out infinite;
opacity:0;
animation:fadeScaleIn .9s .3s ease forwards, imgFloat 6s 1.2s ease-in-out infinite;}
.img-side{position:absolute;
width:190px;
height:230px;
object-fit:cover;
border-radius:24px 24px 8px 24px;
top:50%;
left:50%;
transform:translate(12%,-65%);
box-shadow:0 20px 60px rgba(232,67,147,.14);
border:5px solid white;
animation:fadeScaleSide .9s .5s ease forwards, imgFloat 6s 1.5s ease-in-out infinite;
opacity:0;}
.img-bot{position:absolute;
width:170px;
height:165px;
object-fit:cover;
border-radius:24px 8px 24px 24px;
top:50%;
left:50%;
transform:translate(7%,14%);
box-shadow:0 20px 60px rgba(91,184,176,.14);
border:5px solid white;
animation:fadeScaleBot .9s .7s ease forwards, imgFloat 6s 2s ease-in-out infinite;
opacity:0;}
@keyframes fadeScaleIn{from{opacity:0;transform:translate(-60%,-52%) scale(.9);}to{opacity:1;transform:translate(-60%,-52%) scale(1);}}
@keyframes fadeScaleSide{from{opacity:0;transform:translate(12%,-65%) scale(.9);}to{opacity:1;transform:translate(12%,-65%) scale(1);}}
@keyframes fadeScaleBot{from{opacity:0;transform:translate(7%,14%) scale(.9);}to{opacity:1;transform:translate(7%,14%) scale(1);}}
@keyframes imgFloat{0%,100%{margin-top:0;}50%{margin-top:-12px;}}

/* floating mini cards */
.fc{position:absolute;
z-index:10;
background:rgba(255,255,255,.95);
backdrop-filter:blur(16px);
border-radius:18px;
padding:1rem 1.3rem;
box-shadow:var(--shadow-md);
border:1px solid var(--border-p);
opacity:0;}
.fc1{top:12%;left:4%;animation:fcIn .8s .9s ease forwards,floatA 5s 1.7s ease-in-out infinite;}
.fc2{bottom:18%;right:3%;animation:fcIn .8s 1.1s ease forwards,floatB 5s 2s ease-in-out infinite;}
.fc3{top:55%;left:7%;animation:fcIn .8s 1.3s ease forwards,floatA 5s 2.3s ease-in-out infinite;}

@keyframes fcIn{from{opacity:0;transform:scale(.85) translateY(10px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes floatA{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
@keyframes floatB{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}

.fc-tag{font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--pink);margin-bottom:4px;}
.fc-val{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.2;}
.fc-sub{font-size:.68rem;color:var(--muted);margin-top:2px;}
.fc-stars{font-size:.85rem;color:#f59e0b;letter-spacing:2px;}

/* scroll hint */
.scroll-h{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:7px;color:var(--muted2);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;opacity:0;animation:fadeUp .8s 1.4s ease forwards;}
.s-line{width:1px;height:44px;background:linear-gradient(to bottom,var(--pink),transparent);animation:sAnim 2.2s ease-in-out infinite;}
@keyframes sAnim{0%{transform:scaleY(0);transform-origin:top;}55%{transform:scaleY(1);}100%{transform:scaleY(0);transform-origin:bottom;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}

/* ══════════════════════════
   GRADIENT TICKER
══════════════════════════ */
.ticker{background:var(--grad);padding:14px 0;overflow:hidden;}
.ticker-inner{display:flex;gap:2.5rem;width:max-content;animation:tickRun 28s linear infinite;}
.ti{display:flex;align-items:center;gap:8px;color: rgba(255,255,255,.9) !important;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
.ti-sep{color: rgba(255,255,255,.35) !important;}
@keyframes tickRun{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ══════════════════════════
   SECTIONS
══════════════════════════ */
.s{padding:6rem 7rem;}
.s-w{background:var(--bg2);}
.s-warm{background:var(--bg3);}
.s-teal{background:var(--teal-ss);}
.s-purple{background:var(--purple-s);}
.s-pink{background:var(--pink-s);}

.s-tag{display:inline-flex;
align-items:center;
gap:8px;
font-size:.65rem;
font-weight:700;
letter-spacing:.18em;
text-transform:uppercase;
color:var(--pink);
margin-bottom:.9rem;}
.s-tag::before{content:'';width:26px;height:2px;border-radius:2px;background:var(--grad-h);}

.s-h{font-family:'Fraunces',serif;
font-size:clamp(2.4rem,3.8vw,4rem);
font-weight:600;
line-height:1.05;
letter-spacing:-.02em;
margin-bottom:1rem;
color:var(--text);}
.s-h em{font-style:italic;font-weight:300;background:var(--grad-h);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.s-sub{color:var(--muted);font-size:.98rem;line-height:1.78;max-width:520px;font-weight:300;}

/* ══════════════════════════
   STEPS — flowing timeline
══════════════════════════ */
.steps-flow{display:grid;
grid-template-columns:repeat(4,1fr);
position:relative;
margin-top:3.5rem;
gap:0;}
.steps-flow::before{content:'';
position:absolute;
top:36px;
left:13%;
right:13%;
height:1px;
background:linear-gradient(90deg,var(--teal),var(--purple),var(--pink));}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 1.2rem;position:relative;z-index:1;}
.step-bub{width:72px;
height:72px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
font-size:1.5rem;
margin-bottom:1.5rem;
flex-shrink:0;
background:var(--bg2);
border:2px solid var(--border-p);
box-shadow:var(--shadow-sm);
transition:transform .3s,box-shadow .3s;}
.step:hover .step-bub{transform:scale(1.12);box-shadow:var(--shadow-md);}
.step h4{font-weight:700;font-size:.92rem;margin-bottom:.45rem;color:var(--text);}
.step p{font-size:.8rem;color:var(--muted);line-height:1.6;font-weight:300;}

/* ══════════════════════════
   ROMANTIC SPOTS
══════════════════════════ */
.spots-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:start;margin-top:3.5rem;}

.spot-list{display:flex;flex-direction:column;gap:.9rem;}
.spot-card{display:flex;
align-items:center;
gap:1.2rem;
padding:1.3rem 1.6rem;
border-radius:16px;
background:var(--bg2);
border:1px solid var(--border);
transition:all .3s;
cursor:default;}
.spot-card:hover{border-color:var(--border-p);
transform:translateX(8px);
box-shadow:0 8px 32px rgba(232,67,147,.1);}
.spot-num{font-family:'Fraunces',serif;
font-size:2rem;
font-weight:700;
color:rgba(232,67,147,.15);
min-width:40px;
line-height:1;
transition:color .3s;}
.spot-card:hover .spot-num{color:var(--pink);}
.spot-ico{font-size:1.3rem;flex-shrink:0;}
.spot-info h4{font-weight:700;font-size:.92rem;margin-bottom:3px;color:var(--text);}
.spot-info p{font-size:.76rem;color:var(--muted);font-weight:300;}
.spot-tag{margin-left:auto;
padding:4px 14px;
border-radius:100px;
font-size:.65rem;
font-weight:700;
letter-spacing:.08em;
text-transform:uppercase;
background:var(--pink-s);
color:var(--pink);
border:1px solid var(--border-p);
white-space:nowrap;
flex-shrink:0;}

/* right col — tall image */
.spot-visual{border-radius:28px;overflow:hidden;height:550px;position:relative;}
.spot-visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.88) saturate(1.15);transition:transform .6s;}
.spot-visual:hover img{transform:scale(1.04);}
.spot-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,18,31,.75) 0%,transparent 50%);}
.spot-caption{position:absolute;bottom:0;left:0;right:0;padding:2rem;}
.spot-caption h3{font-family:'Fraunces',serif;font-size:2rem;font-weight:600;color: white !important;line-height:1.1;margin-bottom:.5rem;font-style:italic;}
.spot-caption p{color: rgba(255,255,255,.65) !important;font-size:.8rem;font-weight:300;}

/* ══════════════════════════
   PHOTO MOSAIC
══════════════════════════ */
.mosaic{display:grid;
grid-template-columns:1.3fr 1fr 1fr;
grid-template-rows:230px 230px;
gap:10px;
margin-top:3rem;
border-radius:28px;
overflow:hidden;}
.mc{overflow:hidden;position:relative;border-radius:12px;}
.mc:first-child{grid-row:span 2;border-radius:12px;}
.mc img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s ease;filter:brightness(.9) saturate(1.1);}
.mc:hover img{transform:scale(1.06);filter:brightness(.82) saturate(1.3);}
/* soft pink tint overlay on hover */
.mc::after{content:'';position:absolute;inset:0;background:rgba(232,67,147,0);transition:background .4s;}
.mc:hover::after{background:rgba(232,67,147,.06);}

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

.why-vis{position:relative;}
.why-img{width:100%;height:580px;object-fit:cover;border-radius:28px;filter:brightness(.9) saturate(1.1);box-shadow:var(--shadow-lg);}

/* decorative ring */
.why-vis::before{content:'';
position:absolute;
top:-16px;
left:-16px;
right:16px;
bottom:16px;
border:2px dashed rgba(232,67,147,.2);
border-radius:32px;
pointer-events:none;}

.why-corner{position:absolute;
bottom:-24px;
right:-24px;
width:200px;
height:200px;
object-fit:cover;
border-radius:20px;
border:6px solid var(--bg2);
box-shadow:0 20px 50px rgba(123,94,167,.15);
animation:floatA 5.5s ease-in-out infinite;}
.why-badge{position:absolute;
top:24px;
left:-24px;
background:var(--bg2);
border:1px solid var(--border-p);
border-radius:20px;
padding:1.1rem 1.5rem;
box-shadow:var(--shadow-md);
animation:floatB 5.5s 1s ease-in-out infinite;
text-align:center;
min-width:130px;}
.wb-emoji{font-size:2rem;display:block;margin-bottom:4px;}
.wb-val{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:700;line-height:1;background:var(--grad-h);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.wb-label{font-size:.62rem;color:var(--muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase;}

/* feature rows */
.feat-rows{display:flex;flex-direction:column;gap:0;margin-top:2.5rem;border:1px solid var(--border);border-radius:20px;overflow:hidden;}
.fr{display:flex;
align-items:flex-start;
gap:1.2rem;
padding:1.5rem 1.8rem;
background:var(--bg2);
border-bottom:1px solid var(--border);
transition:all .3s;}
.fr:last-child{border-bottom:none;}
.fr:hover{background:var(--pink-s);}
.fr-ico{width:46px;
height:46px;
border-radius:14px;
display:flex;
align-items:center;
justify-content:center;
font-size:1.2rem;
flex-shrink:0;
border:1px solid var(--border);
transition:all .3s;}
.fr:nth-child(1) .fr-ico{background:var(--pink-s);border-color:var(--border-p);}
.fr:nth-child(2) .fr-ico{background:var(--purple-s);border-color:rgba(123,94,167,.2);}
.fr:nth-child(3) .fr-ico{background:var(--teal-s);border-color:var(--border-t);}
.fr:nth-child(4) .fr-ico{background:var(--pink-s);border-color:var(--border-p);}
.fr:hover .fr-ico{transform:scale(1.08);}
.fr-txt h4{font-weight:700;font-size:.92rem;margin-bottom:4px;color:var(--text);}
.fr-txt p{font-size:.8rem;color:var(--muted);line-height:1.55;font-weight:300;}
.fr-arr{margin-left:auto;color:var(--muted2);font-size:1rem;transition:all .3s;padding-top:2px;}
.fr:hover .fr-arr{color:var(--pink);transform:translateX(5px);}

/* ══════════════════════════
   DATE VIBES — cards with images
══════════════════════════ */
.vibes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem;}

.vibe-card{border-radius:22px;
overflow:hidden;
background:var(--bg2);
border:1px solid var(--border);
transition:all .38s;
position:relative;}
/* gradient top reveal */
.vibe-card::after{content:'';
position:absolute;
top:0;
left:0;
right:0;
height:3px;
background:var(--grad);
transform:scaleX(0);
transform-origin:left;
transition:transform .38s;}
.vibe-card:hover::after{transform:scaleX(1);}
.vibe-card:hover{transform:translateY(-8px);
box-shadow:0 24px 64px rgba(232,67,147,.14);
border-color:var(--border-p);}
.vibe-img{width:100%;
height:190px;
object-fit:cover;
display:block;
transition:transform .5s ease;}
.vibe-card:hover .vibe-img{transform:scale(1.06);}
.vibe-body{padding:1.4rem;}
.vibe-body h4{font-weight:700;font-size:.93rem;margin-bottom:6px;color:var(--text);}
.vibe-body p{font-size:.8rem;color:var(--muted);line-height:1.55;font-weight:300;}
.vibe-pill{display:inline-flex;
align-items:center;
gap:6px;
margin-top:12px;
padding:4px 14px;
border-radius:100px;
font-size:.63rem;
font-weight:700;
letter-spacing:.1em;
text-transform:uppercase;
background:var(--pink-l);
color:var(--pink-d);}
.vibe-card:nth-child(2) .vibe-pill{background:var(--purple-l);color:var(--purple-d);}
.vibe-card:nth-child(3) .vibe-pill{background:var(--teal-l);color:var(--teal-d);}
.vibe-card:nth-child(4) .vibe-pill{background:var(--pink-l);color:var(--pink-d);}
.vibe-card:nth-child(5) .vibe-pill{background:var(--purple-l);color:var(--purple-d);}
.vibe-card:nth-child(6) .vibe-pill{background:var(--teal-l);color:var(--teal-d);}

/* ══════════════════════════
   TRUST STRIP
══════════════════════════ */
.trust-strip{display:grid;
grid-template-columns:repeat(4,1fr);
background:var(--bg2);
border-top:1px solid var(--border);
border-bottom:1px solid var(--border);
margin-top:4rem;}
.tsc{padding:2.2rem 1.5rem;
border-right:1px solid var(--border);
text-align:center;
transition:background .3s;}
.tsc:last-child{border-right:none;}
.tsc:hover{background:var(--pink-s);}
.tsc-num{font-family:'Fraunces',serif;
font-size:3rem;
font-weight:700;
line-height:1;
background:var(--grad-h);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;
margin-bottom:.3rem;}
.tsc h4{font-weight:700;font-size:.88rem;margin-bottom:.4rem;color:var(--text);}
.tsc p{font-size:.74rem;color:var(--muted);line-height:1.5;}

/* ══════════════════════════
   TESTIMONIAL STRIP
══════════════════════════ */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem;}
.tcard{background:var(--bg2);
border:1px solid var(--border);
border-radius:20px;
padding:1.8rem;
transition:all .3s;
position:relative;
overflow:hidden;}
.tcard::before{content:'"';position:absolute;top:-10px;right:18px;font-family:'Fraunces',serif;font-size:8rem;color:var(--pink-l);line-height:1;pointer-events:none;}
.tcard:hover{border-color:var(--border-p);box-shadow:0 12px 40px rgba(232,67,147,.1);transform:translateY(-4px);}
.tcard-stars{font-size:.9rem;color:#f59e0b;letter-spacing:3px;margin-bottom:.8rem;}
.tcard p{font-size:.85rem;color:var(--muted);line-height:1.7;font-weight:300;position:relative;z-index:1;}
.tcard-author{display:flex;align-items:center;gap:10px;margin-top:1.2rem;}
.tcard-avatar{width:38px;
height:38px;
border-radius:50%;
background:var(--grad);
display:flex;
align-items:center;
justify-content:center;
font-size:.85rem;
font-weight:700;
color: white !important;
flex-shrink:0;}
.tcard-name{font-weight:700;font-size:.82rem;color:var(--text);}
.tcard-loc{font-size:.7rem;color:var(--muted);}

/* ══════════════════════════
   CTA BANNER
══════════════════════════ */
.cta-s{padding:6rem 7rem;background:var(--bg);}
.cta-box{border-radius:32px;
overflow:hidden;
position:relative;
display:grid;
grid-template-columns:1fr 1fr;
min-height:440px;
background:var(--bg2);
border:1px solid var(--border-p);
box-shadow:var(--shadow-lg);}
/* gradient top border */
.cta-box::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad);}
/* dot pattern */
.cta-box::after{content:'';
position:absolute;
inset:0;
background-image:radial-gradient(circle,rgba(232,67,147,.08) 1px,transparent 1px);
background-size:26px 26px;
-webkit-mask-image:radial-gradient(ellipse 80% 90% at 30% 50%,black 20%,transparent 75%);
mask-image:radial-gradient(ellipse 80% 90% at 30% 50%,black 20%,transparent 75%);
pointer-events:none;}
.cta-content{padding:4.5rem;position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;}
.cta-content h2{font-family:'Fraunces',serif;font-size:3.5rem;font-weight:600;line-height:1.05;letter-spacing:-.02em;color:var(--text);margin-bottom:1rem;}
.cta-content h2 em{font-style:italic;font-weight:300;background:var(--grad-h);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cta-content p{color:var(--muted);font-size:.98rem;font-weight:300;margin-bottom:2.2rem;line-height:1.75;max-width:400px;}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap;}
.cta-img{position:relative;overflow:hidden;}
.cta-img img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.85) saturate(1.2);}
.cta-img::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to right,var(--bg2) 0%,transparent 42%);}

/* ══════════════════════════
   SCROLL REVEAL
══════════════════════════ */
.rev{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s 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-left{padding:5rem 3rem 3rem;}
  .hero-right{display:none;}
  .s,.cta-s{padding:4rem 3rem;}
  .steps-flow{grid-template-columns:repeat(2,1fr);gap:2rem;}
  .steps-flow::before{display:none;}
  .spots-layout{grid-template-columns:1fr;}
  .why-layout{grid-template-columns:1fr;}
  .vibes-grid{grid-template-columns:repeat(2,1fr);}
  .trust-strip{grid-template-columns:repeat(2,1fr);}
  .testimonials{grid-template-columns:1fr;}
  .cta-box{grid-template-columns:1fr;}
  .cta-img{height:280px;}
}
@media(max-width:640px){
  .hero-left{padding:4rem 1.5rem 3rem;}
  .s,.cta-s{padding:3rem 1.5rem;}
  .steps-flow,.vibes-grid,.trust-strip{grid-template-columns:1fr;}
  .mosaic{grid-template-columns:1fr 1fr;grid-template-rows:180px 180px;}
  .mosaic .mc:first-child{grid-row:span 1;}
  .mosaic .mc:nth-child(n+4){display:none;}
  .trust-strip .tsc{border-right:none;border-bottom:1px solid var(--border);}
  #cur,#cur-r{display:none;}
}