/* ============================================================
   Loveworld Affiliated Healthcare Institutions Network
   Design tokens
   ============================================================ */
:root{
  --deep-blue:#0D47A1;
  --deep-blue-dark:#082a63;
  --purple:#5E35B1;
  --emerald:#00A86B;
  --gold:#C9A44C;
  --ink:#0B1526;
  --ink-soft:#3C4A63;
  --paper:#F6F8FC;
  --paper-alt:#EEF2F9;
  --white:#FFFFFF;
  --line:#E3E8F2;

  --grad-hero: radial-gradient(120% 120% at 15% 10%, #12306e 0%, #0d1c47 42%, #0a1030 100%);
  --grad-brand: linear-gradient(120deg, var(--deep-blue) 0%, var(--purple) 55%, var(--emerald) 100%);
  --grad-gold: linear-gradient(120deg, #E4C98A 0%, var(--gold) 60%, #8f7130 100%);

  --shadow-sm: 0 2px 10px rgba(13,20,40,.06);
  --shadow-md: 0 12px 32px rgba(13,20,40,.10);
  --shadow-lg: 0 24px 60px rgba(13,20,40,.16);

  --radius-s: 12px;
  --radius-m: 20px;
  --radius-l: 28px;

  --font-display:'Poppins',sans-serif;
  --font-body:'Inter',sans-serif;

  --container: 1240px;
  --nav-h: 84px;
}

html[data-theme="dark"]{
  --paper:#0A1024;
  --paper-alt:#0F1730;
  --white:#111A33;
  --ink:#EDF1FA;
  --ink-soft:#AAB6D1;
  --line:#233052;
  --shadow-sm: 0 2px 10px rgba(0,0,0,.35);
  --shadow-md: 0 12px 32px rgba(0,0,0,.45);
  --shadow-lg: 0 24px 60px rgba(0,0,0,.55);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--white);margin:0;line-height:1.12;letter-spacing:-.02em;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}
ul{list-style:none;margin:0;padding:0;}
::selection{background:var(--gold);color:#1a1200;}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:6px;}

.container{max-width:var(--container);margin:0 auto;padding:0 28px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--purple);
  margin-bottom:16px;
}
html[data-theme="dark"] .eyebrow{color:#B9A6FF;}
.eyebrow::before{content:"";width:20px;height:2px;background:var(--gold);display:inline-block;}

.section{padding:120px 0;position:relative;}
.section-tight{padding:80px 0;}
.section-head{max-width:680px;margin-bottom:64px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:600;}
.section-head .lede{margin-top:18px;color:var(--ink-soft);font-size:1.08rem;max-width:56ch;}
.section-head.center .lede{margin-left:auto;margin-right:auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 28px;border-radius:100px;border:none;font-weight:600;font-size:.95rem;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, background .35s ease, color .35s ease;
  white-space:nowrap;
}
.btn-primary{
  background:var(--grad-brand);background-size:180% 180%;background-position:0% 50%;
  color:#fff;box-shadow:var(--shadow-md);
}
.btn-primary:hover{background-position:100% 50%;transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-ghost{
  background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.35);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-2px);}
.btn-outline{
  background:transparent;color:var(--deep-blue);border:1.5px solid var(--line);
}
html[data-theme="dark"] .btn-outline{color:var(--ink);}
.btn-outline:hover{border-color:var(--purple);color:var(--purple);transform:translateY(-2px);}
.btn-gold{background:var(--grad-gold);color:#241a03;box-shadow:var(--shadow-md);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-block{width:100%;}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none !important;}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .4s ease, box-shadow .4s ease, backdrop-filter .4s ease, height .3s ease;
}
.nav-inner{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav.is-scrolled{
  background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(160%);
  box-shadow:var(--shadow-sm); height:72px;
}
html[data-theme="dark"] .nav.is-scrolled{background:rgba(10,16,36,.72);}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:600;font-size:1.02rem;color:#fff;}
.nav.is-scrolled .brand{color:var(--ink);}
.brand-mark{
  width:38px;height:38px;border-radius:11px;background:var(--grad-brand);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 4px 14px rgba(94,53,177,.35);
}
.brand-mark svg{width:20px;height:20px;}
.brand small{display:block;font-family:var(--font-body);font-weight:400;font-size:.68rem;color:rgba(255,255,255,.7);letter-spacing:.02em;}
.nav.is-scrolled .brand small{color:var(--ink-soft);}

.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{
  padding:10px 16px;border-radius:100px;font-size:.92rem;font-weight:500;color:rgba(255,255,255,.85);
  transition:background .25s, color .25s;
}
.nav.is-scrolled .nav-links a{color:var(--ink-soft);}
.nav-links a:hover{background:rgba(255,255,255,.12);color:#fff;}
.nav.is-scrolled .nav-links a:hover{background:var(--paper-alt);color:var(--ink);}
.nav-actions{display:flex;align-items:center;gap:10px;}
.theme-toggle{
  width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;
  transition:all .3s;
}
.nav.is-scrolled .theme-toggle{border-color:var(--line);color:var(--ink);background:var(--paper-alt);}
.theme-toggle:hover{transform:rotate(20deg);}
.theme-toggle svg{width:18px;height:18px;}
.nav-burger{display:none;width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);align-items:center;justify-content:center;color:#fff;}
.nav.is-scrolled .nav-burger{color:var(--ink);border-color:var(--line);}

@media (max-width:980px){
  .nav-links{display:none;}
  .nav-burger{display:flex;}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:var(--grad-hero);overflow:hidden;color:#fff;padding-top:var(--nav-h);
}
.hero canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.55;}
.hero::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 80% 20%, rgba(0,168,107,.28), transparent 70%),
             radial-gradient(50% 40% at 10% 85%, rgba(201,164,76,.18), transparent 70%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;padding:80px 0 120px;}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:100px;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(10px);
  font-size:.82rem;font-weight:500;letter-spacing:.03em;margin-bottom:28px;color:#fff;
}
.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 4px rgba(0,168,107,.25);animation:pulse-dot 2s infinite;}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(0,168,107,.25);}50%{box-shadow:0 0 0 8px rgba(0,168,107,.06);}}
.hero h1{
  font-size:clamp(2.4rem,5.4vw,4.4rem);font-weight:600;max-width:16ch;letter-spacing:-.03em;
}
.hero h1 em{font-style:normal;background:linear-gradient(120deg,#8FD9BE,#C9A44C 60%,#B9A6FF);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-sub{margin-top:26px;max-width:56ch;font-size:1.12rem;color:rgba(255,255,255,.82);}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:42px;}

.hero-stats{
  position:relative;z-index:2;margin-top:88px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-m);overflow:hidden;backdrop-filter:blur(14px);
}
.hero-stat{background:rgba(10,16,36,.35);padding:26px 22px;}
.hero-stat .num{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.3rem);font-weight:600;color:#fff;display:flex;align-items:baseline;gap:2px;}
.hero-stat .label{margin-top:6px;font-size:.84rem;color:rgba(255,255,255,.68);}
@media (max-width:820px){.hero-stats{grid-template-columns:repeat(2,1fr);}}

.scroll-cue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.6);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
}
.scroll-cue .stem{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:stem 1.8s ease-in-out infinite;}
@keyframes stem{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}51%{transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

/* ---------- About / split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:40px;}}
.split.reverse .split-media{order:2;}
.split-media{position:relative;border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3.2;}
.split-media img{width:100%;height:100%;object-fit:cover;}
.split-media::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,rgba(13,71,161,.25),transparent 55%);}
.split-badge{
  position:absolute;left:20px;bottom:20px;z-index:2;
  background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-radius:var(--radius-s);
  padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;
}
html[data-theme="dark"] .split-badge{background:rgba(15,23,48,.85);}
.split-badge .ico{width:38px;height:38px;border-radius:10px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.split-badge .ico svg{width:19px;height:19px;color:#fff;}
.split-badge strong{display:block;font-size:1rem;}
.split-badge span{font-size:.8rem;color:var(--ink-soft);}

.pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.pill{
  padding:9px 16px;border-radius:100px;background:var(--paper-alt);border:1px solid var(--line);
  font-size:.85rem;font-weight:500;color:var(--ink-soft);
}

/* ---------- Cards / benefits ---------- */
.grid-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
@media (max-width:1080px){.grid-cards{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.grid-cards{grid-template-columns:1fr;}}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease, border-color .4s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.card .ico{
  width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  background:var(--paper-alt);color:var(--deep-blue);
}
.card:nth-child(4n+2) .ico{color:var(--purple);}
.card:nth-child(4n+3) .ico{color:var(--emerald);}
.card:nth-child(4n+4) .ico{color:var(--gold);}
.card .ico svg{width:24px;height:24px;}
.card h3{font-size:1.08rem;font-weight:600;margin-bottom:10px;}
.card p{color:var(--ink-soft);font-size:.92rem;}

/* ---------- Directory ---------- */
.directory-shell{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  padding:36px;box-shadow:var(--shadow-md);
}
.directory-toolbar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:26px;}
.search-box{
  flex:1;min-width:240px;display:flex;align-items:center;gap:10px;
  background:var(--paper-alt);border:1px solid var(--line);border-radius:100px;padding:12px 18px;
}
.search-box svg{width:18px;height:18px;color:var(--ink-soft);flex-shrink:0;}
.search-box input{border:none;background:none;outline:none;width:100%;font-size:.95rem;color:var(--ink);font-family:inherit;}
.filter-chips{display:flex;gap:8px;flex-wrap:wrap;}
.chip{
  padding:9px 16px;border-radius:100px;border:1px solid var(--line);background:var(--white);
  font-size:.82rem;font-weight:600;color:var(--ink-soft);transition:all .25s;
}
.chip.is-active,.chip:hover{background:var(--grad-brand);color:#fff;border-color:transparent;}

.map-wrap{position:relative;border-radius:var(--radius-m);overflow:hidden;background:var(--paper-alt);margin-bottom:28px;border:1px solid var(--line);}
.map-wrap svg{width:100%;height:auto;display:block;}
.map-pin{cursor:pointer;transform-box:fill-box;transform-origin:center;transition:transform .25s;}
.map-pin:hover, .map-pin.active{transform:scale(1.5);}
.map-pin circle.core{fill:var(--emerald);}
.map-pin circle.pulse{fill:var(--emerald);opacity:.35;animation:pin-pulse 2.4s ease-out infinite;}
@keyframes pin-pulse{0%{r:3;opacity:.5;}100%{r:12;opacity:0;}}

.directory-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width:900px){.directory-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.directory-grid{grid-template-columns:1fr;}}
.inst-card{
  border:1px solid var(--line);border-radius:var(--radius-s);padding:20px;background:var(--paper);
  transition:box-shadow .3s, transform .3s;
}
.inst-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.inst-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.inst-logo{
  width:44px;height:44px;border-radius:12px;background:var(--grad-brand);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:.95rem;flex-shrink:0;
}
.inst-top strong{display:block;font-size:.98rem;}
.inst-top span{font-size:.78rem;color:var(--ink-soft);}
.inst-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.inst-tags span{font-size:.72rem;padding:4px 10px;border-radius:100px;background:var(--paper-alt);color:var(--ink-soft);}
.inst-card p{font-size:.86rem;color:var(--ink-soft);margin-bottom:14px;}
.inst-link{font-size:.84rem;font-weight:600;color:var(--deep-blue);display:inline-flex;align-items:center;gap:6px;}
html[data-theme="dark"] .inst-link{color:#8FB4FF;}
.directory-empty{display:none;text-align:center;padding:60px 20px;color:var(--ink-soft);}

/* ---------- Timeline ---------- */
.timeline{position:relative;max-width:920px;margin:0 auto;}
.timeline::before{content:"";position:absolute;left:28px;top:0;bottom:0;width:2px;background:var(--line);}
@media (max-width:700px){.timeline::before{left:20px;}}
.t-item{position:relative;padding-left:80px;margin-bottom:50px;}
@media (max-width:700px){.t-item{padding-left:56px;}}
.t-item:last-child{margin-bottom:0;}
.t-dot{
  position:absolute;left:14px;top:2px;width:30px;height:30px;border-radius:50%;
  background:var(--white);border:2px solid var(--line);display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);z-index:1;
}
@media (max-width:700px){.t-dot{left:6px;width:28px;height:28px;}}
.t-dot svg{width:14px;height:14px;color:var(--deep-blue);}
.t-item.in-view .t-dot{background:var(--grad-brand);border-color:transparent;}
.t-item.in-view .t-dot svg{color:#fff;}
.t-item h3{font-size:1.12rem;font-weight:600;margin-bottom:8px;}
.t-item p{color:var(--ink-soft);font-size:.92rem;max-width:60ch;}

/* ---------- Enrollment form ---------- */
.form-shell{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  padding:48px;box-shadow:var(--shadow-lg);
}
@media (max-width:640px){.form-shell{padding:28px;}}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media (max-width:700px){.form-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{font-size:.84rem;font-weight:600;color:var(--ink-soft);}
.field input,.field select,.field textarea{
  border:1.5px solid var(--line);border-radius:var(--radius-s);padding:13px 16px;
  font-family:inherit;font-size:.95rem;background:var(--paper);color:var(--ink);
  transition:border-color .25s, box-shadow .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--purple);box-shadow:0 0 0 4px rgba(94,53,177,.12);
}
.field textarea{resize:vertical;min-height:110px;}
.file-drop{
  border:1.5px dashed var(--line);border-radius:var(--radius-s);padding:22px;text-align:center;
  color:var(--ink-soft);font-size:.86rem;background:var(--paper-alt);transition:border-color .25s,background .25s;
  cursor:pointer;
}
.file-drop:hover{border-color:var(--purple);}
.file-drop svg{width:22px;height:22px;margin-bottom:8px;color:var(--purple);}
.form-note{margin-top:18px;font-size:.8rem;color:var(--ink-soft);}
.form-success{
  display:none;text-align:center;padding:50px 20px;
}
.form-success .ico{
  width:64px;height:64px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;
  justify-content:center;margin:0 auto 20px;
}
.form-success .ico svg{width:30px;height:30px;color:#fff;}

/* ---------- Testimonials ---------- */
.t-carousel{position:relative;overflow:hidden;}
.t-track{display:flex;gap:24px;transition:transform .6s cubic-bezier(.2,.8,.2,1);}
.t-card{
  flex:0 0 calc(33.333% - 16px);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);
  padding:30px;box-shadow:var(--shadow-sm);
}
@media (max-width:980px){.t-card{flex:0 0 calc(50% - 12px);}}
@media (max-width:640px){.t-card{flex:0 0 100%;}}
.t-quote{font-size:.98rem;color:var(--ink);margin-bottom:22px;}
.t-quote::before{content:"“";color:var(--gold);font-size:2rem;font-family:var(--font-display);line-height:0;display:inline-block;vertical-align:-8px;margin-right:2px;}
.t-person{display:flex;align-items:center;gap:12px;}
.t-avatar{width:46px;height:46px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:600;flex-shrink:0;}
.t-person strong{display:block;font-size:.92rem;}
.t-person span{font-size:.8rem;color:var(--ink-soft);}
.t-controls{display:flex;justify-content:center;gap:10px;margin-top:32px;}
.t-controls button{
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--white);
  display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all .25s;
}
.t-controls button:hover{background:var(--grad-brand);color:#fff;border-color:transparent;}
.t-controls button svg{width:18px;height:18px;}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:24px 4px;background:none;border:none;text-align:left;font-family:var(--font-display);
  font-size:1.02rem;font-weight:500;color:var(--ink);
}
.faq-q .plus{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);flex-shrink:0;position:relative;transition:transform .35s,border-color .35s;}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--ink-soft);top:50%;left:50%;transition:transform .35s, background .35s;}
.faq-q .plus::before{width:10px;height:1.5px;transform:translate(-50%,-50%);}
.faq-q .plus::after{width:1.5px;height:10px;transform:translate(-50%,-50%);}
.faq-item.is-open .plus{transform:rotate(135deg);border-color:var(--purple);}
.faq-item.is-open .plus::before,.faq-item.is-open .plus::after{background:var(--purple);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.2,.8,.2,1);}
.faq-a-inner{padding:0 4px 26px;color:var(--ink-soft);font-size:.94rem;max-width:70ch;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr;}}
.contact-list{display:flex;flex-direction:column;gap:18px;margin-top:30px;}
.contact-row{display:flex;align-items:flex-start;gap:16px;padding:18px;border:1px solid var(--line);border-radius:var(--radius-s);background:var(--white);}
.contact-row .ico{width:42px;height:42px;border-radius:12px;background:var(--paper-alt);color:var(--deep-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-row .ico svg{width:20px;height:20px;}
.contact-row strong{display:block;font-size:.92rem;margin-bottom:3px;}
.contact-row span{font-size:.86rem;color:var(--ink-soft);}
.social-row{display:flex;gap:10px;margin-top:24px;}
.social-row a{width:42px;height:42px;border-radius:50%;background:var(--paper-alt);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);border:1px solid var(--line);transition:all .25s;}
.social-row a:hover{background:var(--grad-brand);color:#fff;border-color:transparent;}
.social-row svg{width:17px;height:17px;}
.map-embed{border-radius:var(--radius-l);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);aspect-ratio:4/3.4;position:relative;}
.map-embed .fallback{position:absolute;inset:0;background:var(--paper-alt);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.85rem;text-align:center;padding:20px;}

.float-actions{position:fixed;right:22px;bottom:22px;z-index:900;display:flex;flex-direction:column;gap:12px;}
.float-btn{
  width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);color:#fff;transition:transform .3s;
}
.float-btn:hover{transform:scale(1.08);}
.float-btn.whatsapp{background:#25D366;}
.float-btn.chat{background:var(--grad-brand);}
.float-btn svg{width:24px;height:24px;}

/* ---------- Divider constellation ---------- */
.constellation-divider{height:120px;position:relative;overflow:hidden;}
.constellation-divider svg{width:100%;height:100%;}

/* ---------- Footer ---------- */
.footer{background:#08122E;color:#C4CCE0;padding:88px 0 32px;}
.footer h4{color:#fff;font-size:.95rem;font-weight:600;margin-bottom:20px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1);}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-brand p{margin-top:16px;font-size:.88rem;color:#8D97B8;max-width:34ch;}
.footer-links li{margin-bottom:12px;}
.footer-links a{font-size:.88rem;color:#C4CCE0;transition:color .2s;}
.footer-links a:hover{color:#fff;}
.footer-newsletter{display:flex;gap:0;margin-top:14px;border-radius:100px;overflow:hidden;border:1px solid rgba(255,255,255,.18);}
.footer-newsletter input{flex:1;border:none;background:transparent;padding:12px 16px;color:#fff;font-family:inherit;font-size:.86rem;}
.footer-newsletter input:focus{outline:none;}
.footer-newsletter button{border:none;background:var(--grad-brand);color:#fff;padding:0 18px;font-weight:600;font-size:.82rem;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:28px;font-size:.82rem;color:#7C86A8;}
.footer-bottom-links{display:flex;gap:20px;}
.footer-bottom-links a:hover{color:#fff;}

/* ---------- Utility ---------- */
.mt-64{margin-top:64px;}
.text-center{text-align:center;}
.badge-soft{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;background:var(--paper-alt);font-size:.8rem;font-weight:600;color:var(--ink-soft);border:1px solid var(--line);}

/* mobile nav drawer */
.mobile-drawer{
  position:fixed;inset:0;z-index:1100;background:var(--white);display:flex;flex-direction:column;
  padding:26px 28px;transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.mobile-drawer.is-open{transform:translateX(0);}
.mobile-drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;}
.mobile-drawer a{display:block;padding:18px 4px;font-size:1.2rem;font-weight:500;border-bottom:1px solid var(--line);}
.mobile-drawer .btn{margin-top:30px;}
