/* ============ VEDAONE LINEN — palette ============ */
:root{
  --white:#FFFFFF;
  --offwhite:#F5F2EA;       /* warm off-white / linen */
  --offwhite-2:#EFEBE0;
  --royal:#0B1F4D;          /* dark royal blue */
  --royal-2:#13295E;
  --black:#0B0B0C;
  --ink:#1A1C20;
  --line:rgba(11,31,77,.12);
  --muted:#5A6175;
  --radius:16px;
  --max:1200px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter Tight',system-ui,sans-serif;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em}
em{font-style:italic}
section{padding:96px 32px}
.eyebrow{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--royal);font-weight:600;display:inline-block;margin-bottom:18px;
}
.eyebrow.light{color:rgba(255,255,255,.7)}

/* ============ BRAND — morphs from hero-center to nav-left ============ */
.brand{
  position:fixed;top:42px;left:50%;transform:translateX(-50%);
  z-index:80;display:flex;align-items:center;text-decoration:none;color:#fff;
  transition:top .55s cubic-bezier(.6,.05,.1,1),left .55s cubic-bezier(.6,.05,.1,1),
             transform .55s cubic-bezier(.6,.05,.1,1),color .45s ease;
}
.brand .brand-name{
  font-family:'Playfair Display',serif;font-weight:500;
  font-size:clamp(34px,4.8vw,52px);letter-spacing:.04em;
  /* nudge so the letter-spacing on the last char stays visually centred */
  padding-left:.04em;
  transition:font-size .55s cubic-bezier(.6,.05,.1,1),letter-spacing .55s cubic-bezier(.6,.05,.1,1);
}
/* docked state (after scroll) — glides to the left */
.brand.dock{top:22px;left:32px;transform:translateX(0);color:var(--ink);}
.brand.dock .brand-name{font-size:23px;letter-spacing:.02em;padding-left:.02em;}

/* ============ NAV BAR ============ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:70;
  display:flex;align-items:center;justify-content:center;padding:16px 32px;
  background:transparent;border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s,box-shadow .4s;
}
.header.show{
  background:rgba(245,242,234,.86);backdrop-filter:saturate(1.2) blur(14px);
  border-bottom:1px solid var(--line);box-shadow:0 8px 30px rgba(11,31,77,.06);
}
.nav-links{
  display:flex;gap:4px;margin-left:0;
  opacity:0;transform:translateY(-8px);pointer-events:none;
  transition:opacity .45s .08s ease,transform .45s .08s ease;
}
.header.show .nav-links{opacity:1;transform:none;pointer-events:auto;}
/* tubelight nav (ported from tubelight-navbar component) */
.tube-nav{
  position:relative;display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:5px;
  border:1px solid var(--line);border-radius:999px;
  background:rgba(255,255,255,.55);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  box-shadow:0 12px 34px rgba(11,31,77,.10);
}
.tube-tab{
  position:relative;z-index:2;cursor:pointer;white-space:nowrap;
  padding:8px 22px;border-radius:999px;font-family:inherit;font-size:13.5px;font-weight:600;
  color:var(--ink);opacity:.78;transition:color .25s,opacity .25s;
}
.tube-tab:hover,.tube-tab.active{color:var(--royal);opacity:1;}
/* the sliding "lamp": muted pill behind active tab + glowing tube bar on top */
.tube-lamp{
  position:absolute;z-index:1;top:5px;left:0;width:0;height:calc(100% - 10px);
  border-radius:999px;background:rgba(11,31,77,.06);pointer-events:none;opacity:0;
  transition:left .35s cubic-bezier(.3,1.2,.4,1),width .35s cubic-bezier(.3,1.2,.4,1),opacity .25s;
}
.tube-bar{position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:34px;height:4px;border-radius:0 0 7px 7px;background:var(--royal);}
.tube-bar::before{content:"";position:absolute;left:-9px;top:-9px;width:52px;height:24px;border-radius:999px;background:rgba(11,31,77,.28);filter:blur(11px);}
.tube-bar::after{content:"";position:absolute;left:5px;top:-4px;width:24px;height:14px;border-radius:999px;background:rgba(11,31,77,.30);filter:blur(7px);}
.cta-pill{
  margin-left:auto;display:flex;align-items:center;gap:8px;text-decoration:none;
  padding:12px 22px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.01em;
  background:rgba(255,255,255,.55);color:var(--royal);
  box-shadow:0 2px 12px rgba(11,31,77,.10);
  opacity:0;transform:translateY(-8px);pointer-events:none;
  transition:opacity .45s .08s ease,transform .45s .08s ease,box-shadow .25s,background .25s;
}
.cta-pill svg,.cta-pill span{position:relative;z-index:1;}
.header.show .cta-pill{opacity:1;transform:none;pointer-events:auto;}
.cta-pill:hover{transform:translateY(-1px) scale(1.03);background:rgba(255,255,255,.7);box-shadow:0 6px 18px rgba(11,31,77,.16);}

/* ============ LIQUID GLASS (ported from liquid-glass-button) ============ */
.glass{position:relative;isolation:isolate;overflow:hidden;}
.glass::before{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;
  -webkit-backdrop-filter:blur(3px) brightness(1.06);
  backdrop-filter:url(#container-glass) blur(3px) brightness(1.06);
}
.glass::after{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;pointer-events:none;
  box-shadow:
    inset 2px 2px 1px -2px rgba(255,255,255,.95),
    inset -2px -2px 1px -2px rgba(255,255,255,.8),
    inset 1px 1px 1px -.5px rgba(11,31,77,.12),
    inset -1px -1px 1px -.5px rgba(11,31,77,.10),
    inset 0 0 6px 6px rgba(255,255,255,.10),
    0 0 12px rgba(255,255,255,.25);
}

/* footer wordmark keeps its own small style */
.foot-brand .brand-name{font-family:'Fraunces',serif;font-weight:600;letter-spacing:.14em;font-size:15px;display:inline-flex;align-items:center;gap:8px;color:var(--ink)}
.brand-mark.sm{width:24px;height:24px;font-size:14px;border-radius:7px;background:var(--royal);color:#fff;display:inline-grid;place-items:center;font-family:'Fraunces',serif;font-weight:600}

/* ============ MEGA MENU ============ */
.mega{
  position:fixed;top:62px;left:0;right:0;z-index:55;
  display:flex;justify-content:center;pointer-events:none;
}
.mega-panel{
  display:none;pointer-events:auto;
  background:var(--white);border:1px solid var(--line);
  border-radius:18px;box-shadow:0 24px 60px rgba(11,31,77,.16);
  padding:26px;gap:40px;margin-top:6px;
  min-width:520px;
  animation:drop .22s ease;
}
.mega-panel.show{display:flex}
@keyframes drop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mega-col{display:flex;flex-direction:column;gap:4px;min-width:230px}
.mega-col.feature{background:var(--offwhite);border-radius:12px;padding:18px;min-width:220px;justify-content:flex-start}
.mega-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:600}
.mega-link{display:flex;flex-direction:column;padding:9px 10px;border-radius:9px;cursor:pointer;text-decoration:none;transition:background .18s}
.mega-link:hover{background:var(--offwhite)}
.mega-link strong{font-size:14.5px;color:var(--ink);display:flex;align-items:center;gap:8px}
.mega-link span{font-size:12.5px;color:var(--muted)}
.mega-note{font-size:13px;color:var(--royal);line-height:1.45;margin-top:8px}
.tag{font-style:normal;font-size:9.5px;letter-spacing:.1em;background:var(--royal);color:#fff;padding:2px 6px;border-radius:5px;font-weight:600}

/* ============ HERO — full-screen video + overlaid text ============ */
.hero{
  position:relative;min-height:100vh;overflow:hidden;color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:150px 32px 96px;
  background:linear-gradient(160deg,var(--royal),var(--black)); /* fallback before video loads */
}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;
  transform:scale(1.08);transform-origin:center;}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(11,31,77,.40) 0%,rgba(11,11,12,.72) 100%);}
.hero-inner{position:relative;z-index:2;max-width:800px;}
.hero h1{font-size:clamp(44px,6.6vw,82px);color:#fff;margin:10px 0 22px}
.hero h1 em{color:#cdd8ff}
.hero .lede{font-size:18px;color:rgba(255,255,255,.86);max-width:560px;margin:0 auto}
.hero-cta{display:flex;gap:14px;margin-top:36px;justify-content:center;flex-wrap:wrap}
.btn{cursor:pointer;text-decoration:none;padding:14px 28px;border-radius:999px;font-size:15px;font-weight:500;transition:transform .2s,background .2s,color .2s;display:inline-block}
.btn-primary{background:#fff;color:var(--royal)}
.btn-primary:hover{background:var(--offwhite);transform:translateY(-2px)}
.btn-ghost-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12)}
.scroll-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;
  background:none;border:none;color:rgba(255,255,255,.82);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:7px;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-family:inherit;
}
.scroll-hint svg{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ============ TRUST STRIP ============ */
.trust{background:var(--offwhite);text-align:center;padding:48px 32px}
.trust>span{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:48px;margin-top:22px}
.logos span{font-family:'Fraunces',serif;font-size:18px;letter-spacing:.08em;color:var(--royal);opacity:.55}

/* ============ BANDS ============ */
.band{max-width:var(--max);margin:0 auto}
.band.alt{background:transparent}
.band-head{max-width:640px;margin-bottom:54px}
.band-head.center{margin-left:auto;margin-right:auto;text-align:center}
.band-head h2{font-size:clamp(30px,4vw,46px);color:var(--black);margin-bottom:18px}
.band-head p{font-size:17px;color:var(--muted)}

/* cards — uniform, classy, turn royal-blue on hover */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{
  position:relative;background:var(--white);border:1px solid var(--line);border-radius:18px;
  padding:34px 30px 30px;display:flex;flex-direction:column;gap:16px;
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,background .4s,border-color .4s;
}
.card:hover{
  transform:translateY(-8px);background:var(--royal);border-color:transparent;
  box-shadow:0 30px 60px -22px rgba(11,31,77,.5);
}
.card-ico{
  width:48px;height:48px;border-radius:13px;background:var(--offwhite);color:var(--royal);
  display:grid;place-items:center;transition:background .4s,color .4s;
}
.card h3{font-family:'Fraunces',serif;font-weight:500;font-size:20px;color:var(--ink);transition:color .4s;}
.card p{font-size:14px;line-height:1.6;color:var(--muted);flex:1;transition:color .4s;}
.card-link{font-size:13.5px;color:var(--royal);font-weight:600;cursor:pointer;text-decoration:none;transition:color .4s;}
/* hover (blue) state */
.card:hover h3{color:#fff;}
.card:hover p{color:rgba(255,255,255,.75);}
.card:hover .card-ico{background:rgba(255,255,255,.14);color:#fff;}
.card:hover .card-link{color:#cdd8ff;}

/* products — expand-on-hover gallery */
.expand-cards{
  display:flex;gap:8px;justify-content:center;align-items:stretch;
  height:26rem;max-width:var(--max);margin:0 auto;
}
.ec-card{
  position:relative;flex:1 1 0;min-width:0;height:100%;
  border-radius:22px;overflow:hidden;cursor:pointer;background:var(--offwhite-2);
  transition:flex .6s cubic-bezier(.4,0,.2,1);
}
.ec-card.active{flex:4.4 1 0;}
.ec-card img{width:100%;height:100%;object-fit:cover;display:block;}
.ec-card::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 45%,rgba(11,11,12,.66));
  opacity:0;transition:opacity .4s;}
.ec-card.active::after{opacity:1;}
.ec-cap{
  position:absolute;left:0;bottom:0;padding:24px 28px;color:#fff;z-index:2;max-width:30rem;
  opacity:0;transform:translateY(10px);transition:opacity .45s .12s ease,transform .45s .12s ease;
}
.ec-card{text-decoration:none;}
.ec-card.active .ec-cap{opacity:1;transform:none;}
.ec-cap strong{font-family:'Fraunces',serif;font-weight:600;font-size:28px;color:#fff;display:flex;align-items:center;gap:8px;white-space:nowrap;margin-bottom:4px;}
.ec-cap span{display:block;font-size:12.5px;letter-spacing:.04em;color:rgba(255,255,255,.85);line-height:1.5;}
.ec-cap .ec-go{margin-top:14px;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#cdd8ff;transition:gap .2s;}
.ec-card:hover .ec-cap .ec-go{color:#fff;}

/* shoppable hotspot dots (only on the expanded card) */
.ec-dot{
  position:absolute;z-index:5;width:18px;height:18px;border-radius:50%;
  background:#fff;border:2px solid var(--royal);cursor:pointer;
  opacity:0;transform:scale(.6);pointer-events:none;
  transition:opacity .35s .15s,transform .35s .15s;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.ec-card.active .ec-dot{opacity:1;transform:scale(1);pointer-events:auto;}
.ec-dot::after{ /* pulsing ring */
  content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(255,255,255,.85);
  animation:dotPulse 2s ease-out infinite;
}
@keyframes dotPulse{0%{transform:scale(.7);opacity:.9}100%{transform:scale(2.1);opacity:0}}

/* pop-out material card */
.ec-pop{
  position:absolute;bottom:170%;left:50%;width:220px;
  transform:translateX(-50%) translateY(8px);
  background:#fff;color:var(--ink);border-radius:14px;padding:16px 16px 14px;
  box-shadow:0 24px 50px -16px rgba(11,31,77,.5);
  opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:6;text-align:left;
}
.ec-pop::after{ /* little pointer */
  content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:7px solid transparent;border-top-color:#fff;
}
.ec-dot:hover .ec-pop,.ec-dot.open .ec-pop{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.ec-pop strong{display:flex;align-items:center;gap:7px;font-family:'Fraunces',serif;font-weight:600;font-size:16px;color:var(--royal);margin-bottom:4px;}
.ec-pop em{display:block;font-style:normal;font-size:12.5px;line-height:1.45;color:var(--muted);margin-bottom:12px;}
.ec-add{
  width:100%;border:none;cursor:pointer;border-radius:999px;padding:9px 14px;
  background:var(--royal);color:#fff;font-family:inherit;font-size:12.5px;font-weight:600;letter-spacing:.02em;
  transition:background .2s,transform .15s;
}
.ec-add:hover{background:var(--royal-2);}
.ec-add.added{background:#1a8a4a;}

/* floating quote bar */
.quote-bar{
  position:fixed;bottom:24px;right:24px;z-index:85;display:none;align-items:center;gap:10px;
  background:var(--royal);color:#fff;text-decoration:none;padding:13px 20px;border-radius:999px;
  font-size:14px;box-shadow:0 16px 40px rgba(11,31,77,.4);
  animation:qbIn .4s cubic-bezier(.3,1.2,.4,1);
}
.quote-bar.show{display:flex;}
.quote-bar .qb-count{display:grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#fff;color:var(--royal);font-weight:700;font-size:12.5px;}
.quote-bar strong{font-weight:600;}
@keyframes qbIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ============ SUSTAINABILITY — editorial ============ */
.susta{background:var(--offwhite);color:var(--ink);padding:128px 32px;}
.susta-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:84px;align-items:center;
}
.susta-eyebrow{
  display:flex;align-items:center;gap:14px;margin-bottom:30px;
  font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--royal);font-weight:600;
}
.susta-eyebrow .hair{display:block;width:42px;height:1px;background:var(--royal);opacity:.45;}
.susta h2{
  font-family:'Fraunces',serif;font-weight:400;letter-spacing:-.015em;
  font-size:clamp(38px,4.8vw,62px);line-height:1.04;color:var(--royal);margin-bottom:26px;
}
.susta h2 em{font-style:italic;}
.susta-text>p{font-size:17px;line-height:1.75;color:var(--muted);max-width:440px;margin-bottom:44px;}
.susta-index{list-style:none;margin:0;padding:0;border-top:1px solid var(--line);max-width:480px;}
.susta-index li{
  display:flex;align-items:baseline;gap:24px;
  padding:19px 2px;border-bottom:1px solid var(--line);
}
.susta-index .num{font-family:'Fraunces',serif;font-size:14px;color:var(--royal);opacity:.5;min-width:22px;letter-spacing:.05em;}
.susta-index .lbl{font-size:15.5px;color:var(--ink);line-height:1.4;}

/* passport — luxury swing-tag / certificate */
.passport{
  position:relative;margin:0;background:var(--royal);color:#fff;border-radius:3px;
  padding:48px 46px;max-width:430px;justify-self:center;
  box-shadow:0 50px 90px -36px rgba(11,31,77,.6);
  border:1px solid rgba(255,255,255,.16);
}
.passport::before{content:"";position:absolute;inset:13px;border:1px solid rgba(255,255,255,.18);border-radius:1px;pointer-events:none;}
.passport-seal{
  position:absolute;top:32px;right:36px;width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(255,255,255,.42);display:grid;place-items:center;
  font-family:'Fraunces',serif;font-weight:500;font-size:22px;color:#fff;letter-spacing:.04em;
}
.passport-kicker{display:block;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:30px;}
.passport-rows{display:flex;flex-direction:column;}
.prow{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:17px 0;border-bottom:1px solid rgba(255,255,255,.13);}
.prow:first-child{border-top:1px solid rgba(255,255,255,.13);}
.prow span{font-size:12.5px;letter-spacing:.05em;color:rgba(255,255,255,.55);text-transform:uppercase;}
.prow strong{font-family:'Fraunces',serif;font-weight:400;font-size:18px;color:#fff;text-align:right;}
.passport-foot{margin-top:28px;display:flex;align-items:center;gap:10px;font-size:12.5px;letter-spacing:.03em;color:rgba(255,255,255,.74);font-style:italic;}
.passport-foot .dot{width:6px;height:6px;border-radius:50%;background:#cdd8ff;box-shadow:0 0 0 4px rgba(205,216,255,.16);}

/* ============ REGIONS ============ */
.regions{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:var(--max);margin:0 auto}
.region{background:var(--offwhite);border-radius:var(--radius);padding:26px;transition:background .25s,transform .25s}
.region:hover{background:var(--offwhite-2);transform:translateY(-4px)}
.region strong{font-family:'Fraunces',serif;font-size:20px;color:var(--royal);display:block;margin-bottom:6px}
.region span{font-size:13.5px;color:var(--muted)}

/* ============ CONVERT ============ */
.convert{background:var(--black);color:#fff;text-align:center}
.convert-inner{max-width:var(--max);margin:0 auto}
.convert h2{font-size:clamp(30px,4vw,46px);color:#fff;margin-bottom:44px}
.convert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cv-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:30px;text-align:left;cursor:pointer;text-decoration:none;
  display:flex;flex-direction:column;gap:12px;transition:background .25s,transform .25s,border-color .25s;
}
.cv-card:hover{background:rgba(255,255,255,.08);transform:translateY(-5px);border-color:rgba(159,180,255,.5)}
.cv-card:first-child{background:var(--royal);border-color:transparent}
.cv-card:first-child:hover{background:var(--royal-2)}
.cv-ico{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center}
.cv-card h3{font-size:21px;color:#fff}
.cv-card p{font-size:14px;color:rgba(255,255,255,.65);flex:1}
.cv-go{font-size:14px;color:#9fb4ff;font-weight:500}

/* ---- contact modal ---- */
.modal-backdrop{
  position:fixed;inset:0;z-index:120;display:none;align-items:flex-start;justify-content:center;
  padding:40px 20px;overflow-y:auto;
  background:rgba(7,12,28,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.modal-backdrop.open{display:flex;animation:mbIn .25s ease;}
@keyframes mbIn{from{opacity:0}to{opacity:1}}
.modal{
  position:relative;width:100%;max-width:660px;margin:auto;text-align:left;
  background:linear-gradient(180deg,#141a30,#0d1224);color:#fff;
  border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:38px 38px 34px;
  box-shadow:0 50px 100px -30px rgba(0,0,0,.7);
  animation:modalIn .32s cubic-bezier(.2,.8,.2,1);
}
@keyframes modalIn{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:20px;right:20px;width:38px;height:38px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.8);
  display:grid;place-items:center;transition:background .2s,color .2s;
}
.modal-close:hover{background:rgba(255,255,255,.14);color:#fff;}
.modal-eyebrow{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:#9fb4ff;font-weight:600;}
.modal-title{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(26px,3vw,34px);color:#fff;margin:10px 0 8px;}
.modal-sub{font-size:14.5px;color:rgba(255,255,255,.6);margin-bottom:26px;max-width:460px;}
body.modal-open{overflow:hidden;}

/* ---- contact form ---- */
.cform{text-align:left;}
.cform-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;}
.cform-field{display:flex;flex-direction:column;gap:8px;}
.cform-field.cform-full{grid-column:1 / -1;}
.cform-field>span{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.cform-field input,.cform-field select,.cform-field textarea{
  width:100%;font-family:inherit;font-size:15px;color:#fff;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);border-radius:11px;
  padding:13px 15px;transition:border-color .2s,background .2s;outline:none;resize:vertical;
}
.cform-field input::placeholder,.cform-field textarea::placeholder{color:rgba(255,255,255,.35);}
.cform-field input:focus,.cform-field select:focus,.cform-field textarea:focus{
  border-color:rgba(159,180,255,.7);background:rgba(255,255,255,.08);
}
.cform-field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' width='12'%3E%3Cpath fill='%23ffffff' d='M233.4 406.6c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L256 338.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l192 192z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center;background-size:11px;padding-right:36px;}
.cform-field select option{color:#0b1f4d;}
.cform-foot{display:flex;align-items:center;gap:18px;margin-top:24px;flex-wrap:wrap;}
.cform-btn{
  background:#fff;color:var(--royal);border:none;cursor:pointer;
  padding:14px 30px;border-radius:999px;font-family:inherit;font-size:15px;font-weight:600;
  transition:transform .2s,background .2s,opacity .2s;
}
.cform-btn:hover{transform:translateY(-2px);background:var(--offwhite);}
.cform-btn:disabled{opacity:.55;cursor:default;transform:none;}
.cform-status{font-size:14px;color:#9fb4ff;margin:0;}
.cform-status.ok{color:#7fe0a8;}
.cform-status.err{color:#ff9a9a;}

/* ============ FOOTER ============ */
.footer{background:var(--offwhite);padding:64px 32px 28px}
.foot-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:36px}
.foot-brand p{font-size:14px;color:var(--muted);margin-top:12px;max-width:240px}
.foot-col h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--royal);margin-bottom:14px}
.foot-col a{display:block;font-size:14px;color:var(--muted);text-decoration:none;padding:5px 0;cursor:pointer;transition:color .18s}
.foot-col a:hover{color:var(--royal)}
.foot-bottom{max-width:var(--max);margin:40px auto 0;padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted)}

/* ============ STICKY MOBILE CTA ============ */
.sticky-cta{
  display:none;position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  background:var(--royal);color:#fff;text-decoration:none;z-index:70;
  padding:14px 28px;border-radius:999px;font-size:15px;font-weight:500;
  box-shadow:0 12px 34px rgba(11,31,77,.4);
}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media(max-width:920px){
  .nav-links{display:none}
  .cta-pill{display:none}
  .sticky-cta{display:block}
  .brand.dock .brand-name{font-size:16px}
  .cards,.regions,.convert-grid{grid-template-columns:1fr 1fr}
  .cform-grid{grid-template-columns:1fr}
  /* expand-cards: no hover on touch → horizontal scroll, all captions visible */
  .expand-cards{height:20rem;overflow-x:auto;justify-content:flex-start;padding-bottom:10px;scroll-snap-type:x mandatory;}
  .ec-card{flex:0 0 16rem!important;scroll-snap-align:start;}
  .ec-card::after{opacity:1;}
  .ec-card .ec-cap{opacity:1;transform:none;}
  .susta{padding:72px 22px}
  .susta-inner{grid-template-columns:1fr;gap:48px}
  .passport{justify-self:stretch;max-width:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:64px 22px}
}
@media(max-width:560px){
  .cards,.prod-grid,.regions,.convert-grid,.foot-grid{grid-template-columns:1fr}
  .logos{gap:24px}
  .foot-bottom{flex-direction:column;gap:8px}
}
