/* ============================================================
   DELEGATA — editorial-luxury design system (mobile-first)
   Warm ivory · deep teal · gold · serif display · star motif
   One cached file, zero image dependencies.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* palette */
  --teal-900:#0c2a34;
  --teal-800:#0f3340;
  --teal-700:#15414f;
  --ink:#15333d;          /* headings / dark text (alias kept) */
  --gold:#c2894e;
  --gold-bright:#d9ab63;
  --gold-deep:#a8703a;
  --champagne:#ead7b4;
  --cream:#fbf8f2;        /* page background — warm ivory */
  --cream-2:#f4ecdd;      /* soft warm section */
  --paper:#fffdf8;        /* cards */
  --text:#43514f;
  --text-soft:#76817e;
  --line:#e8ddca;
  --green:#4f9a6a;
  --white:#fff;

  /* aliases used by inline styles in the HTML */
  --brass:var(--gold);
  --brass-dark:var(--gold-deep);
  --brass-soft:var(--champagne);
  --brass-tint:#f4e8d3;
  --bg:var(--cream);
  --bg-soft:var(--cream-2);
  --bg-warm:#f6efe1;
  --line-2:#ddd0b8;

  /* type */
  --serif:"Fraunces","Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
  --font:var(--sans);

  /* shape & depth */
  --radius:18px;
  --radius-sm:11px;
  --radius-lg:26px;
  --shadow-sm:0 1px 2px rgba(20,51,61,.04),0 6px 18px -10px rgba(20,51,61,.14);
  --shadow:0 10px 30px -16px rgba(20,51,61,.28),0 30px 60px -40px rgba(20,51,61,.32);
  --shadow-gold:0 12px 26px -12px rgba(168,112,58,.55);
  --maxw:1180px;

  /* textures */
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-deep);text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.12;font-weight:600;letter-spacing:-.015em;font-optical-sizing:auto}
.accent{font-family:var(--serif);font-style:italic;color:var(--gold-deep);font-weight:500}
.hero .accent{color:var(--gold-bright)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
::selection{background:var(--champagne);color:var(--teal-900)}

/* ---------- A11y ---------- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--teal-900);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:22px}
.section{padding-block:clamp(3rem,8vw,6rem)}
.section--soft{background:var(--cream-2)}
.section--warm{background:var(--bg-warm)}
.section-head{text-align:center;max-width:60ch;margin-inline:auto;margin-bottom:clamp(2rem,4vw,3rem)}
.section-head h2{font-size:clamp(1.9rem,5vw,3rem)}
.section-head p{color:var(--text-soft);margin-top:.8rem;font-size:1.05rem}

/* eyebrow with gold rule + star */
.eyebrow{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep)}
.eyebrow::before{content:"✦";font-size:.7em;color:var(--gold)}
.section-head .eyebrow{margin-bottom:.5rem}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:1rem;line-height:1;
  padding:1em 1.7em;border-radius:999px;border:1px solid transparent;overflow:hidden;
  transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s,background .25s,color .25s,border-color .25s;
  white-space:nowrap}
.btn svg{width:1.05em;height:1.05em;flex:none}
.btn--primary{background:linear-gradient(135deg,var(--gold-bright),var(--gold) 60%,var(--gold-deep));color:#241606;box-shadow:var(--shadow-gold)}
.btn--primary::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);transform:translateX(-130%);transition:transform .6s}
.btn--primary:hover{transform:translateY(-2px)}
.btn--primary:hover::after{transform:translateX(130%)}
.btn--ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(234,215,180,.55);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(234,215,180,.16);border-color:var(--champagne);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--outline:hover{border-color:var(--gold);color:var(--gold-deep);transform:translateY(-2px)}
.btn--light{background:var(--cream);color:var(--teal-900);box-shadow:var(--shadow-sm)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--block{width:100%}
.btn--sm{padding:.7em 1.15em;font-size:.9rem}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,248,242,.82);backdrop-filter:blur(14px) saturate(1.1);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px;padding-block:.5rem}
.brand{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--serif);font-weight:600;font-size:1.5rem;color:var(--ink);letter-spacing:-.01em}
.brand svg{width:30px;height:30px;flex:none}
.nav-links{display:none;align-items:center;gap:1.7rem}
.nav-links a{color:var(--ink);font-weight:500;font-size:.96rem;position:relative;padding-block:.4rem}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--gold);transition:right .3s}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{right:0}
.nav-links a[aria-current="page"]{color:var(--gold-deep)}
.nav-actions{display:flex;align-items:center;gap:.7rem}

.lang{display:inline-flex;border:1px solid var(--line-2);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.5)}
.lang button{background:transparent;border:0;padding:.45em .75em;font-size:.76rem;font-weight:700;color:var(--text-soft);letter-spacing:.06em;transition:.2s}
.lang button[aria-pressed="true"]{background:var(--teal-900);color:var(--champagne)}

.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:transparent;border:0;padding:11px}
.burger span{height:2px;width:100%;background:var(--ink);border-radius:2px;transition:.25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{display:none;position:fixed;inset:74px 0 0;background:var(--cream);z-index:99;padding:1.6rem 22px 2.5rem;overflow-y:auto;flex-direction:column;gap:.2rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:1.3rem;color:var(--ink);padding:.95rem .25rem;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:1.4rem}
.mobile-menu .lang{margin-top:1.5rem;align-self:flex-start}
body.menu-open{overflow:hidden}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;text-align:center;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(90% 70% at 18% 8%,rgba(217,171,99,.30),transparent 55%),
    radial-gradient(80% 90% at 92% 100%,rgba(13,40,50,.7),transparent 60%),
    linear-gradient(150deg,#103340 0%,#15414f 45%,#0c2a34 100%);}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.9;
  background:
    radial-gradient(2px 2px at 12% 24%,rgba(234,215,180,.85),transparent 60%),
    radial-gradient(1.6px 1.6px at 26% 64%,rgba(234,215,180,.6),transparent 60%),
    radial-gradient(2.2px 2.2px at 68% 18%,rgba(234,215,180,.7),transparent 60%),
    radial-gradient(1.4px 1.4px at 82% 52%,rgba(234,215,180,.6),transparent 60%),
    radial-gradient(1.5px 1.5px at 47% 38%,rgba(234,215,180,.5),transparent 60%),
    radial-gradient(2px 2px at 90% 78%,rgba(234,215,180,.55),transparent 60%),
    radial-gradient(1.3px 1.3px at 38% 84%,rgba(234,215,180,.45),transparent 60%),
    var(--grain);
  background-size:auto,auto,auto,auto,auto,auto,auto,180px 180px;}
.hero--img::before{background:linear-gradient(180deg,rgba(12,42,52,.72),rgba(12,42,52,.84)),var(--hero-img,linear-gradient(150deg,#103340,#15414f));background-size:cover;background-position:center}
.hero-inner{padding-block:clamp(3.6rem,12vw,7.5rem);max-width:58ch;margin-inline:auto;position:relative}
.hero .eyebrow{color:var(--champagne);justify-content:center;display:flex;margin-bottom:1.2rem}
.hero .eyebrow::before{color:var(--gold-bright)}
.hero h1{color:#fff;font-size:clamp(2.4rem,7.5vw,4.4rem);line-height:1.06;font-weight:500;letter-spacing:-.02em}
.hero p.lede{color:rgba(255,255,255,.86);font-size:clamp(1.05rem,2.4vw,1.28rem);line-height:1.6;margin-top:1.3rem;max-width:50ch;margin-inline:auto;font-weight:300}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:2.1rem}
/* scroll cue */
.hero-inner::after{content:"";display:block;width:1px;height:46px;margin:2.6rem auto -1rem;
  background:linear-gradient(var(--champagne),transparent);opacity:.6;animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.5);opacity:.25;transform-origin:top}50%{transform:scaleY(1);opacity:.7}}

/* staggered hero entrance */
.hero-inner>*{opacity:0;animation:rise .9s cubic-bezier(.2,.7,.3,1) forwards}
.hero-inner>.eyebrow{animation-delay:.05s}
.hero-inner>h1{animation-delay:.18s}
.hero-inner>.lede{animation-delay:.32s}
.hero-inner>.hero-cta{animation-delay:.46s}
.hero-inner::after{animation-delay:.8s}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* stats bar */
.stats{display:grid;grid-template-columns:1fr;gap:.2rem;background:rgba(12,42,52,.45);border:1px solid rgba(234,215,180,.22);border-radius:var(--radius);
  backdrop-filter:blur(10px);padding:1.3rem 1.4rem;max-width:920px;margin:2rem auto -3.4rem;position:relative;z-index:2;box-shadow:var(--shadow)}
.stat{display:flex;align-items:center;gap:.85rem;justify-content:center;padding:.6rem}
.stat .ic{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));display:grid;place-items:center;flex:none;box-shadow:0 6px 14px -6px rgba(168,112,58,.7)}
.stat .ic svg{width:22px;height:22px;color:#241606}
.stat .num{font-family:var(--serif);font-size:1.8rem;font-weight:600;color:var(--champagne);line-height:1}
.stat .lbl{font-size:.82rem;color:rgba(255,255,255,.78)}
.hero + .section,.hero-wrap + .section{padding-top:clamp(5rem,10vw,7rem)}

/* ---------- Grids & cards ---------- */
.grid{display:grid;gap:1.3rem}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s,border-color .3s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--champagne)}
.card h3{font-size:1.3rem;margin-bottom:.5rem}
.card p{color:var(--text-soft);font-size:.97rem}

/* icon tile (light sections) */
.ic-line{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:1rem;
  background:linear-gradient(135deg,#f7ecd6,#efddc0);border:1px solid var(--champagne)}
.ic-line svg{width:22px;height:22px;color:var(--gold-deep)}

/* checklist */
.checklist{display:grid;gap:1rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start}
.checklist .tick{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#f7ecd6,#e9d4ae);color:var(--gold-deep);display:grid;place-items:center;flex:none;margin-top:2px;border:1px solid var(--champagne)}
.checklist .tick svg{width:13px;height:13px}
.checklist.green .tick{background:#e3f0e8;color:var(--green);border-color:#c3e0cd}

/* split */
.split{display:grid;gap:clamp(1.8rem,5vw,3.4rem);align-items:center;grid-template-columns:1fr}

/* media panel (designed, image-free) */
.media-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;position:relative;
  background:radial-gradient(120% 100% at 80% 0%,rgba(217,171,99,.28),transparent 55%),linear-gradient(150deg,#15414f,#0c2a34);display:grid;place-items:end;color:#fff;isolation:isolate}
.media-card::before{content:"✦";position:absolute;inset:0;display:grid;place-items:center;font-size:8rem;color:rgba(234,215,180,.14);z-index:0}
.media-card::after{content:"";position:absolute;inset:0;background:var(--grain);background-size:170px;opacity:.5;mix-blend-mode:overlay;z-index:0}
.media-card .cap{position:relative;z-index:2;padding:1.3rem 1.4rem;font-size:.95rem;background:linear-gradient(0deg,rgba(12,42,52,.9),transparent);width:100%}
.media-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.media-card img[src^="data:"]{display:none}  /* hide placeholder data-URIs; real photos show */

/* dark band */
.band-dark{position:relative;background:radial-gradient(100% 120% at 100% 0%,rgba(217,171,99,.16),transparent 55%),linear-gradient(155deg,#103340,#0c2a34);color:#fff;isolation:isolate;overflow:hidden}
.band-dark::before{content:"";position:absolute;inset:0;background:var(--grain);background-size:180px;opacity:.4;z-index:-1}
.band-dark h2,.band-dark h3,.band-dark h4{color:#fff}
.band-dark .section-head p{color:rgba(255,255,255,.82)}
.band-dark .card{background:rgba(255,255,255,.04);border:1px solid rgba(234,215,180,.2);box-shadow:none;backdrop-filter:blur(4px)}
.band-dark .card:hover{border-color:var(--champagne);transform:translateY(-4px)}
.band-dark .card p{color:rgba(255,255,255,.78)}
.band-dark .ic-line{background:rgba(234,215,180,.1);border:1px solid rgba(234,215,180,.35)}
.band-dark .ic-line svg{color:var(--champagne)}

/* partners — editorial chips */
.partners{display:flex;flex-wrap:wrap;gap:.7rem 1rem;align-items:center;justify-content:center}
.partners span{font-size:.86rem;font-weight:600;letter-spacing:.02em;color:var(--text-soft);
  padding:.6rem 1.1rem;border:1px solid var(--line);border-radius:999px;background:var(--paper);transition:.25s;white-space:nowrap}
.partners span:hover{color:var(--gold-deep);border-color:var(--champagne);transform:translateY(-2px)}

/* ---------- Process steps ---------- */
.steps{display:grid;gap:1.4rem;position:relative}
.step{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .3s,transform .3s}
.step:hover{box-shadow:var(--shadow)}
.step-top{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:1.1rem;flex-wrap:wrap}
.step-top h3{font-size:1.25rem;display:flex;align-items:center;gap:.8rem}
.step-no{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#15414f,#0c2a34);color:var(--champagne);font-family:var(--serif);display:grid;place-items:center;font-weight:600;font-size:1.05rem;flex:none;border:1px solid rgba(234,215,180,.3)}
.step-badge{background:linear-gradient(135deg,#f7ecd6,#e9d4ae);color:var(--gold-deep);font-size:.74rem;font-weight:700;padding:.4em .9em;border-radius:999px;border:1px solid var(--champagne)}
.step-items{display:grid;gap:1rem;grid-template-columns:1fr}
.mini{display:flex;gap:.7rem;align-items:flex-start}
.mini .mi{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#f7ecd6,#efddc0);color:var(--gold-deep);display:grid;place-items:center;flex:none;border:1px solid var(--champagne)}
.mini .mi svg{width:16px;height:16px}
.mini b{display:block;font-size:.97rem;color:var(--ink);font-weight:600}
.mini span{font-size:.85rem;color:var(--text-soft)}

/* ---------- Comparison table ---------- */
.table-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm);background:var(--paper)}
.swipe-hint{text-align:center;color:var(--text-soft);font-size:.82rem;margin-top:.7rem}
table.compare{border-collapse:collapse;width:100%;min-width:680px;font-size:.93rem}
table.compare th,table.compare td{padding:1rem 1.1rem;text-align:left;border-bottom:1px solid var(--line)}
table.compare thead th{background:var(--cream-2);color:var(--ink);font-family:var(--serif);font-weight:600;font-size:1.05rem;text-align:center}
table.compare thead th:first-child{text-align:left}
table.compare thead th:nth-child(3){background:linear-gradient(180deg,#f3e6cd,#efe0c4);border-top:3px solid var(--gold)}
table.compare td:nth-child(3),table.compare tbody th:nth-child(3){background:rgba(234,215,180,.16)}
table.compare td:not(:first-child),table.compare tbody th:not(:first-child){text-align:center}
table.compare tbody th{text-align:left;font-weight:600;color:var(--ink)}
table.compare tbody tr:hover td,table.compare tbody tr:hover th{background:rgba(234,215,180,.1)}
table.compare tbody tr:hover td:nth-child(3){background:rgba(234,215,180,.24)}
table.compare .pop{display:inline-block;margin-left:.4em;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#241606;font-size:.6rem;font-weight:800;padding:.25em .65em;border-radius:999px;letter-spacing:.08em;vertical-align:middle}
table.compare .yes{color:var(--gold-deep);font-weight:700}
table.compare .no{color:var(--line-2)}
table.compare tfoot td{text-align:center;border-bottom:0;padding-top:1.3rem;background:var(--paper)}
table.compare tfoot td:nth-child(3){background:rgba(234,215,180,.16)}
table.compare .col-feat{min-width:210px}

/* ---------- Reviews ---------- */
.reviews{display:grid;gap:1.3rem;grid-template-columns:1fr}
.review{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.5rem 1.5rem;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.review:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.review::before{content:"\201C";position:absolute;top:.4rem;right:1.1rem;font-family:var(--serif);font-size:3.4rem;line-height:1;color:var(--champagne)}
.review .top{display:flex;align-items:center;gap:.7rem;margin-bottom:.6rem}
.review .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#15414f,#0c2a34);color:var(--champagne);font-family:var(--serif);display:grid;place-items:center;font-weight:600;flex:none;border:1px solid rgba(234,215,180,.35)}
.review .who b{display:block;font-size:.95rem;color:var(--ink)}
.review .who span{font-size:.78rem;color:var(--text-soft)}
.review .stars{color:#e0a52e;letter-spacing:2px;font-size:.95rem}
.review p{font-size:.93rem;color:var(--text-soft)}
.rating-badge{text-align:center;margin-bottom:1.6rem}
.rating-badge .ex{font-family:var(--serif);font-weight:600;letter-spacing:.04em;color:var(--ink);font-size:1.15rem}
.rating-badge .stars{color:#e0a52e;font-size:1.35rem;letter-spacing:3px}
.rating-badge small{color:var(--text-soft)}

/* ---------- Team ---------- */
.team{display:grid;gap:1.4rem;grid-template-columns:1fr}
.member{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.member:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.member .ph{aspect-ratio:1/1;position:relative;display:grid;place-items:center;
  background:radial-gradient(90% 90% at 50% 25%,rgba(217,171,99,.25),transparent 60%),linear-gradient(155deg,#15414f,#0c2a34)}
.member .ph::after{content:"";position:absolute;inset:14px;border:1px solid rgba(234,215,180,.35);border-radius:12px}
.member .ph svg{width:58px;height:58px;color:rgba(234,215,180,.7)}
.member .ph .mono,.bio .portrait .mono{font-family:var(--serif);font-weight:600;color:var(--champagne);letter-spacing:.06em;position:relative;z-index:1;line-height:1}
.member .ph .mono{font-size:2.7rem}
.bio .portrait .mono{font-size:3.6rem}
.member .body{padding:1.3rem 1.4rem 1.6rem}
.member b{display:block;font-family:var(--serif);color:var(--ink);font-size:1.2rem;font-weight:600}
.member .role{color:var(--gold-deep);font-weight:600;font-size:.82rem;letter-spacing:.04em;margin:.2rem 0 .6rem;text-transform:uppercase}
.member p{font-size:.89rem;color:var(--text-soft)}

/* ---------- Founder bio ---------- */
.bio{display:grid;gap:2rem;grid-template-columns:1fr}
.bio .portrait{aspect-ratio:1/1;max-width:320px;border-radius:var(--radius);position:relative;display:grid;place-items:center;box-shadow:var(--shadow);
  background:radial-gradient(90% 90% at 50% 20%,rgba(217,171,99,.3),transparent 60%),linear-gradient(155deg,#15414f,#0c2a34)}
.bio .portrait::after{content:"";position:absolute;inset:16px;border:1px solid rgba(234,215,180,.4);border-radius:13px}
.bio .portrait svg{width:70px;height:70px;color:rgba(234,215,180,.75)}
.bio h3{font-size:1.7rem}
.bio .role{color:var(--gold-deep);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:.8rem;margin:.3rem 0 1.2rem;font-family:var(--sans)}
.bio h4{color:var(--gold-deep);font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin:1.7rem 0 .8rem;display:flex;align-items:center;gap:.5em}
.bio h4::before{content:"✦";color:var(--gold)}
.timeline{display:grid;gap:1.1rem;margin-top:.5rem}
.tl{display:grid;grid-template-columns:1fr;gap:.15rem;padding-left:1.2rem;border-left:1px solid var(--champagne);position:relative}
.tl::before{content:"";position:absolute;left:-4.5px;top:6px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.tl .date{color:var(--gold-deep);font-weight:600;font-size:.84rem}
.tl b{color:var(--ink);font-size:.96rem;font-weight:600}
.tl span{color:var(--text-soft);font-size:.86rem}

/* ---------- Forms ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,4vw,2.3rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-weight:600;color:var(--ink);font-size:.92rem;margin-bottom:.45rem}
.field .req{color:#bb4d3a}
.field .hint{display:block;font-weight:400;color:var(--text-soft);font-size:.8rem;margin-top:-.15rem;margin-bottom:.4rem}
.input,.select,.textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--text);
  border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:.85em .95em;background:#fffdf8;transition:border .2s,box-shadow .2s}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,137,78,.16)}
.textarea{min-height:124px;resize:vertical}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2376817e' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center;padding-right:2.5em}
.char-count{text-align:right;font-size:.78rem;color:var(--text-soft);margin-top:.25rem}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--text-soft)}
.consent input{margin-top:.3rem;accent-color:var(--gold-deep)}
.form-success{display:none;background:#e9f2ec;border:1px solid #bcdcc8;color:#256b43;border-radius:var(--radius-sm);padding:1.05rem 1.2rem;font-weight:600}
.form-success.show{display:block}
.hpot{position:absolute;left:-9999px}

/* inclusions panel */
.panel{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,4vw,2.3rem)}
.panel h3{color:var(--gold-deep);font-size:1.5rem}
.total-pill{font-size:.86rem;color:var(--text-soft);margin-top:1.2rem;border-top:1px solid var(--line);padding-top:1rem}
.total-pill b{color:var(--gold-deep);font-family:var(--serif)}

/* case management */
.case{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,4vw,2.3rem);box-shadow:var(--shadow-sm)}
.case h3{color:var(--gold-deep);font-size:1.45rem}
.case .sub{color:var(--text-soft);font-size:.93rem;margin-bottom:1.1rem}
.case dl{display:grid;gap:.8rem;margin-top:.9rem}
.case dl div{display:flex;gap:.6rem;align-items:flex-start}
.case dl .tick{width:23px;height:23px;border-radius:50%;background:#e3f0e8;color:var(--green);display:grid;place-items:center;flex:none;margin-top:3px;border:1px solid #c3e0cd}
.case dl .tick svg{width:12px;height:12px}
.case dl b{color:var(--ink)}
.case .note{margin-top:1.3rem;background:var(--cream-2);border-radius:var(--radius-sm);padding:1rem 1.2rem;font-size:.88rem;color:var(--text-soft);border:1px solid var(--line)}
.intl{position:relative;background:linear-gradient(155deg,#103340,#0c2a34);color:#fff;border-radius:var(--radius);padding:clamp(1.5rem,4vw,2rem);margin-top:1.3rem;overflow:hidden}
.intl::before{content:"";position:absolute;inset:0;background:var(--grain);background-size:170px;opacity:.4}
.intl h4{color:var(--champagne);margin-bottom:.8rem;position:relative;font-size:1.2rem}
.intl ul{position:relative}
.intl li{display:flex;gap:.6rem;align-items:flex-start;color:rgba(255,255,255,.88);font-size:.93rem;margin-bottom:.5rem}
.intl li svg{width:16px;height:16px;color:var(--champagne);flex:none;margin-top:4px}

/* contact info cards */
.contact-cards{display:grid;gap:1rem;grid-template-columns:1fr}
.info-card{display:flex;gap:1rem;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;box-shadow:var(--shadow-sm);transition:.25s}
.info-card:hover{border-color:var(--champagne);transform:translateY(-2px);box-shadow:var(--shadow)}
.info-card .ic{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));display:grid;place-items:center;flex:none;box-shadow:0 6px 14px -8px rgba(168,112,58,.7)}
.info-card .ic svg{width:22px;height:22px;color:#241606}
.info-card b{display:block;color:var(--ink);font-family:var(--serif);font-size:1.1rem}
.info-card a,.info-card span{color:var(--text-soft);font-size:.95rem}

/* map facade */
.map-facade{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;border:1px solid var(--line);cursor:pointer;
  background:radial-gradient(90% 90% at 70% 10%,rgba(217,171,99,.2),transparent 55%),linear-gradient(155deg,#1b4b59,#0f3340)}
.map-facade .pin{width:58px;height:58px;border-radius:50%;background:var(--cream);display:grid;place-items:center;box-shadow:var(--shadow)}
.map-facade .pin svg{width:26px;height:26px;color:#bb4d3a}
.map-facade .lbl{position:absolute;bottom:14px;left:0;right:0;text-align:center;color:#fff;font-weight:600;font-size:.9rem}
.map-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:.8rem}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;transition:border-color .25s}
.faq details[open]{border-color:var(--champagne)}
.faq summary{cursor:pointer;padding:1.2rem 1.3rem;font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.12rem;
  display:flex;justify-content:space-between;gap:1rem;align-items:center;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--gold);font-weight:300;transition:transform .25s;flex:none}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 1.3rem 1.25rem;color:var(--text-soft);font-size:.97rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);color:#fff;isolation:isolate;
  background:linear-gradient(115deg,#0c2a34 0%,#15414f 42%,#a8703a 135%);padding:clamp(2.2rem,6vw,3.6rem)}
.cta-band::before{content:"";position:absolute;inset:0;background:var(--grain);background-size:180px;opacity:.35;z-index:-1}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,4.5vw,2.6rem)}
.cta-band p{color:rgba(255,255,255,.9);margin:.7rem 0 1.6rem;max-width:46ch;font-weight:300;font-size:1.05rem}
.cta-band .mark{position:absolute;right:-12px;top:50%;transform:translateY(-50%);opacity:.14;width:220px;height:220px}
.cta-band .mark svg{width:100%;height:100%;color:var(--champagne)}

/* ---------- Footer ---------- */
.site-footer{background:var(--cream-2);border-top:1px solid var(--line);padding-block:clamp(2.4rem,5vw,3.4rem) 1.6rem;margin-top:0}
.footer-top{display:grid;gap:1.6rem;grid-template-columns:1fr;align-items:start}
.footer-contact{display:grid;gap:1rem}
.footer-contact .row{display:flex;gap:.8rem;align-items:center}
.footer-contact .ic{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));display:grid;place-items:center;flex:none;box-shadow:0 5px 12px -7px rgba(168,112,58,.7)}
.footer-contact .ic svg{width:18px;height:18px;color:#241606}
.footer-contact a,.footer-contact span{color:var(--text);font-size:.95rem}
.footer-nav{display:flex;flex-wrap:wrap;gap:.9rem 1.6rem;justify-content:center;margin-block:1.8rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.footer-nav a{color:var(--ink);font-weight:500;font-size:.95rem;transition:.2s}
.footer-nav a:hover{color:var(--gold-deep)}
.footer-bottom{display:flex;flex-direction:column;align-items:center;gap:1.1rem;text-align:center}
.social{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--teal-900);color:var(--champagne);transition:.25s}
.social:hover{transform:translateY(-3px);background:var(--gold-deep);color:#241606}
.copyright{color:var(--text-soft);font-size:.85rem}

/* ---------- WhatsApp widget ---------- */
.wa-widget{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;align-items:center;gap:.6rem}
.wa-widget .wa-label{background:var(--paper);color:var(--ink);font-weight:600;font-size:.88rem;padding:.65em 1em;border-radius:999px;
  box-shadow:var(--shadow);white-space:nowrap;display:none;border:1px solid var(--line)}
.wa-btn{position:relative;width:62px;height:62px;border-radius:50%;background:#25d366;display:grid;place-items:center;
  box-shadow:0 10px 26px -8px rgba(37,211,102,.8);transition:transform .25s}
.wa-btn:hover{transform:scale(1.08)}
.wa-btn svg{width:33px;height:33px;color:#fff}
.wa-pulse{position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:wapulse 2.6s infinite}
@keyframes wapulse{70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---------- Utilities & reveal ---------- */
.center{text-align:center}
.mt-cta{margin-top:clamp(2rem,6vw,3.5rem)}
.lead-text{font-size:1.08rem;color:var(--text-soft);font-weight:300}
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal,.hero-inner>*{opacity:1!important;transform:none!important;animation:none!important;transition:none!important}
  .hero-inner::after{animation:none}
  *{scroll-behavior:auto!important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:600px){
  .stats{grid-template-columns:repeat(3,1fr);gap:0}
  .stat{border-left:1px solid rgba(234,215,180,.22)}
  .stat:first-child{border-left:0}
  .grid-2{grid-template-columns:1fr 1fr}
  .reviews{grid-template-columns:repeat(2,1fr)}
  .contact-cards{grid-template-columns:1fr 1fr}
  .step-items{grid-template-columns:1fr 1fr}
  .team{grid-template-columns:repeat(2,1fr)}
  .wa-widget .wa-label{display:block}
}
@media (min-width:850px){
  .nav-links{display:flex}
  .burger{display:none}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1.05fr .95fr}
  .split.rev>:first-child{order:2}
  .reviews{grid-template-columns:repeat(3,1fr)}
  .team{grid-template-columns:repeat(4,1fr)}
  .bio{grid-template-columns:320px 1fr}
  .timeline{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1.3fr 1fr}
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
}
@media (min-width:1050px){
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .contact-grid{grid-template-columns:1.05fr .95fr}
  .section-head h2{letter-spacing:-.02em}
}
