﻿/* ═══════════════════════════════════════════════════════════════
   DESIGN TOKENS  —  Elemental Kitchens
   Brand: Navy #0d1b3e / White #fff  (business card exact)
   Accent: Gold #c9a85c  (luxury countertop reference)
═══════════════════════════════════════════════════════════════ */
:root{
  --navy:       #0d1b3e;
  --navy-deep:  #07101f;
  --navy-mid:   #162d5c;
  --navy-light: #1e3d78;
  --navy-faint: #e6ebf5;
  --navy-ghost: #f0f3fa;
  --white:      #ffffff;
  --off-white:  #f7f8fc;
  --silver:     #dde3f0;
  --steel:      #9aaac4;
  --slate:      #5c6f8a;
  --ink:        #0a1428;
  --gold:       #c9a85c;
  --gold-deep:  #a07c34;
  --gold-light: #f0deb4;
  --green:      #166534;

  /* Inter = UI/body  |  Outfit = display/headlines */
  --f-ui:      'Inter',  -apple-system, sans-serif;
  --f-display: 'Outfit', -apple-system, sans-serif;

  --ease:  cubic-bezier(.22,1,.36,1);
  --fast:  180ms;  --mid: 320ms;  --slow: 580ms;

  --r-sm:4px; --r-md:10px; --r-lg:18px; --r-xl:28px; --r-full:9999px;

  --sh-sm: 0 1px 4px rgba(13,27,62,.10),0 2px 8px rgba(13,27,62,.07);
  --sh-md: 0 4px 16px rgba(13,27,62,.14),0 8px 32px rgba(13,27,62,.09);
  --sh-lg: 0 8px 32px rgba(13,27,62,.18),0 20px 60px rgba(13,27,62,.14);
  --sh-hero:0 24px 80px rgba(7,16,31,.65);
}

/* ── RESET ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--off-white);color:var(--ink);
  font-family:var(--f-ui);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  font-feature-settings:'cv02','cv03','cv04','cv11';
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ── ROUTER ───────────────────────────────────────────────────── */
.page{display:none}.page.active{display:block}

/* ═══════════════════════════════════════════════════════════════
   NAV  —  always solid navy, shrinks on scroll
═══════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  background:rgba(13,27,62,.97);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(255,255,255,.07);
  height:70px;overflow:hidden;
  transition:height 300ms var(--ease),
             box-shadow 300ms var(--ease),
             border-color 300ms var(--ease);
}
.nav::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, var(--gold-deep) 0%, var(--gold) 25%, var(--gold-light) 50%, var(--gold) 75%, var(--gold-deep) 100%);
  background-size:200% 100%;
  animation:goldRoll 3s linear infinite;
  z-index:2;
}
@keyframes goldRoll{
  0%{background-position:100% 0%}
  100%{background-position:-100% 0%}
}
.nav.scrolled{
  height:52px;
  box-shadow:0 4px 28px rgba(7,16,31,.5);
  border-bottom-color:rgba(255,255,255,.14);
}
.nav__bar{
  max-width:1320px;margin:0 auto;padding:0 2rem;
  height:70px;display:flex;align-items:center;
  justify-content:space-between;gap:1rem;
  transition:height 300ms var(--ease);
}
.nav.scrolled .nav__bar{height:52px}
.nav__brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.nav__icon{
  width:40px;height:40px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:width 300ms var(--ease),height 300ms var(--ease);
}
.nav.scrolled .nav__icon{width:32px;height:32px}
.nav__icon img{width:100%;height:100%;object-fit:contain;transition:width 300ms var(--ease),height 300ms var(--ease)}
.nav__wordmark{font-family:var(--f-display);font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1.2;transition:font-size 300ms var(--ease)}
.nav.scrolled .nav__wordmark{font-size:.95rem}
.nav__wordmark small{display:block;font-family:var(--f-ui);font-size:.575rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-top:1px;overflow:hidden;max-height:16px;transition:max-height 300ms var(--ease),opacity 300ms var(--ease),margin-top 300ms var(--ease)}
.nav.scrolled .nav__wordmark small{max-height:0;opacity:0;margin-top:0}
.nav__links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav__links a{font-family:var(--f-ui);font-size:.8rem;font-weight:500;color:rgba(255,255,255,.7);padding:.5rem .875rem;border-radius:var(--r-full);transition:color var(--fast),background var(--fast)}
.nav__links a:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav__links a.active{color:#fff;background:rgba(255,255,255,.12)}
.nav__cta{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--f-ui);font-size:.775rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:.6rem 1.375rem;background:#fff;color:var(--navy);
  border-radius:var(--r-full);box-shadow:var(--sh-sm);flex-shrink:0;
  transition:background var(--fast),box-shadow var(--fast),transform var(--fast);
}
.nav__cta:hover{background:var(--navy-ghost);box-shadow:var(--sh-md)}
.nav__cta:active{transform:scale(.97)}
.nav__hamburger{
  display:none;flex-direction:column;gap:5px;padding:8px;
  cursor:pointer;z-index:1001;position:relative;
}
.nav__hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.85);border-radius:2px;transition:all 0.3s var(--ease)}
.nav__hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__hamburger.active span:nth-child(2){opacity:0}
.nav__hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__drawer{
  position:fixed;top:0;right:0;width:100%;height:100dvh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  background:rgba(13,27,62,.98);backdrop-filter:blur(20px);
  padding:2rem;gap:1rem;
  z-index:1000;
  transform:translateX(100%);
  transition:transform 0.4s cubic-bezier(.22,1,.36,1);
}
.nav__drawer.open{transform:translateX(0)}
.nav__drawer a{display:block;font-size:1.5rem;font-weight:600;color:rgba(255,255,255,.7);padding:.75rem 1.5rem;border-radius:var(--r-md);transition:color var(--fast),background var(--fast)}
.nav__drawer a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav__drawer a.active{color:#fff}
@media(max-width:860px){
  .nav__links,.nav__cta{display:none}
  .nav__hamburger{display:flex}
  .nav__drawer{display:flex}
}

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-family:var(--f-ui);font-size:.775rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  padding:.7rem 1.5rem;border-radius:var(--r-full);
  border:none;cursor:pointer;
  transition:background var(--fast) var(--ease),box-shadow var(--fast) var(--ease),transform var(--fast);
}
.btn:active{transform:scale(.97)}
.btn--lg{padding:.9rem 2.25rem;font-size:.875rem}
.btn--sm{padding:.5rem 1.125rem;font-size:.72rem}
.btn--full{width:100%;justify-content:center}
.btn-white{background:#fff;color:var(--navy);box-shadow:var(--sh-sm)}.btn-white:hover{box-shadow:var(--sh-md);background:var(--navy-ghost)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.36)}.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-navy{background:var(--navy);color:#fff;box-shadow:var(--sh-sm)}.btn-navy:hover{background:var(--navy-mid);box-shadow:var(--sh-md)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy-light)}.btn-outline:hover{background:var(--navy-ghost)}
.btn-gold{background:var(--gold);color:var(--navy-deep)}.btn-gold:hover{background:var(--gold-deep);color:#fff}
.btn-soft{background:rgba(13,27,62,.06);color:var(--navy);border:1.5px solid var(--navy-faint)}.btn-soft:hover{background:var(--navy-ghost)}

/* ═══════════════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════════════ */
.section{padding:clamp(4rem,8vw,7rem) clamp(1.5rem,4vw,2rem)}
.section--sm{padding:clamp(2.5rem,5vw,4rem) clamp(1.5rem,4vw,2rem)}
.wrap{max-width:1320px;margin:0 auto}
.wrap--mid{max-width:1060px;margin:0 auto}
.wrap--narrow{max-width:760px;margin:0 auto}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.grid-2--wide{display:grid;grid-template-columns:1.25fr 1fr;gap:5rem;align-items:center}
@media(max-width:860px){.grid-2,.grid-2--wide{grid-template-columns:1fr;gap:2.5rem}}

/* ═══════════════════════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════════════════════ */
/* Outfit for all display / hero / section headings */
.t-display{
  font-family:var(--f-display);
  font-size:clamp(2.75rem,5.5vw,5.5rem);
  font-weight:700;line-height:1.05;letter-spacing:-.03em;color:var(--ink);
}
.t-display em{font-style:normal;color:var(--navy-mid)}
.t-display--white{color:#fff}.t-display--white em{color:var(--gold)}

.t-h1{
  font-family:var(--f-display);
  font-size:clamp(2.25rem,4.5vw,4.25rem);
  font-weight:700;line-height:1.08;letter-spacing:-.03em;color:var(--ink);
}
.t-h1 em{font-style:normal;color:var(--navy-mid)}
.t-h1--white{color:#fff}.t-h1--white em{color:var(--gold)}

.t-h2{
  font-family:var(--f-display);
  font-size:clamp(1.75rem,3vw,2.625rem);
  font-weight:700;line-height:1.15;letter-spacing:-.025em;color:var(--ink);
}
.t-h2 em{font-style:normal;color:var(--navy-mid)}
.t-h2--white{color:#fff}.t-h2--white em{color:var(--gold)}

.t-h3{font-family:var(--f-display);font-size:1.25rem;font-weight:700;letter-spacing:-.015em;color:var(--ink)}

/* Inter for all body / label / UI text */
.t-eyebrow{
  font-family:var(--f-ui);font-size:.68rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--steel);
  display:flex;align-items:center;gap:.5rem;margin-bottom:.875rem;
}
.t-eyebrow::before{content:'';display:block;width:24px;height:2px;background:currentColor;border-radius:2px;flex-shrink:0}
.t-eyebrow--gold{color:var(--gold)}.t-eyebrow--white{color:rgba(255,255,255,.5)}

.t-body{font-family:var(--f-ui);font-size:.9375rem;color:var(--slate);line-height:1.72}
.t-body--white{color:rgba(255,255,255,.65)}
.t-body--lg{font-size:1.0625rem;line-height:1.75}

/* ═══════════════════════════════════════════════════════════════
   PAGE HERO BANNER
═══════════════════════════════════════════════════════════════ */
.pg-hero{background:var(--navy);padding:8rem 2rem 5rem;position:relative;overflow:hidden}
.pg-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.15}
.pg-hero__inner{max-width:1320px;margin:0 auto;position:relative;z-index:1}
.pg-hero--center .pg-hero__inner{text-align:center;max-width:760px;margin:0 auto}

/* ═══════════════════════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--slow) var(--ease),transform var(--slow) var(--ease)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.stagger.in>*:nth-child(1){opacity:1;transform:none;transition-delay:0ms}
.stagger.in>*:nth-child(2){opacity:1;transform:none;transition-delay:80ms}
.stagger.in>*:nth-child(3){opacity:1;transform:none;transition-delay:160ms}
.stagger.in>*:nth-child(4){opacity:1;transform:none;transition-delay:240ms}
.stagger.in>*:nth-child(5){opacity:1;transform:none;transition-delay:320ms}
.stagger.in>*:nth-child(6){opacity:1;transform:none;transition-delay:400ms}

/* ═══════════════════════════════════════════════════════════════
   CARDS
═══════════════════════════════════════════════════════════════ */
.card{background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh-sm);overflow:hidden;transition:box-shadow var(--mid) var(--ease),transform var(--mid) var(--ease)}
.card:hover{box-shadow:var(--sh-lg);transform:translateY(-5px)}
.card__img{aspect-ratio:4/3;overflow:hidden;background:var(--navy-ghost);position:relative}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform var(--slow) var(--ease)}
.card:hover .card__img img{transform:scale(1.07)}
.card__badge{position:absolute;top:.875rem;left:.875rem;font-family:var(--f-ui);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.28rem .75rem;border-radius:var(--r-full)}
.card__badge--navy{background:var(--navy);color:#fff}
.card__badge--gold{background:var(--gold);color:var(--navy-deep)}
.card__body{padding:1.375rem 1.5rem 1.625rem}
.card__title{font-family:var(--f-display);font-size:1.175rem;font-weight:700;color:var(--ink);margin-bottom:.45rem;letter-spacing:-.015em}
.card__text{font-family:var(--f-ui);font-size:.875rem;color:var(--slate);line-height:1.65;margin-bottom:1.25rem}
.card__link{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--f-ui);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy)}
.card__link .mi{font-size:.95rem;transition:transform var(--fast)}
.card:hover .card__link .mi{transform:translateX(4px)}
.card__price{font-family:var(--f-ui);font-size:.78rem;font-weight:600;color:var(--steel)}

/* ═══════════════════════════════════════════════════════════════
   HERO SLIDER
═══════════════════════════════════════════════════════════════ */
.hero{position:relative;width:100%;height:100svh;min-height:640px;overflow:hidden}
.hero__track{display:flex;width:100%;height:100%;transition:transform 650ms cubic-bezier(.22,1,.36,1);will-change:transform}
.hero__slide{position:relative;width:100%;height:100%;flex-shrink:0;overflow:hidden}
.hero__slide::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to bottom,rgba(7,16,31,.03) 0%,rgba(7,16,31,0) 25%,rgba(7,16,31,.45) 62%,rgba(13,27,62,.95) 100%),
    linear-gradient(105deg,rgba(7,16,31,.5) 0%,transparent 52%);
}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.07);transition:transform 10s linear}
.hero__slide.on .hero__bg{transform:scale(1.0)}
.hero__content{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:clamp(2rem,5vw,4rem) clamp(1.5rem,6vw,5rem) clamp(3.5rem,6vw,6rem);max-width:860px}
.hero__eyebrow{font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:.625rem;margin-bottom:1rem;opacity:0;transform:translateY(16px);transition:opacity .5s .08s var(--ease),transform .5s .08s var(--ease)}
.hero__eyebrow::before{content:'';display:block;width:28px;height:2px;background:var(--gold);border-radius:2px}
.hero__h1{font-family:var(--f-display);font-size:clamp(2.75rem,5.5vw,5.5rem);font-weight:700;line-height:1.05;letter-spacing:-.03em;color:#fff;margin-bottom:1.25rem;opacity:0;transform:translateY(24px);transition:opacity .65s .22s var(--ease),transform .65s .22s var(--ease)}
.hero__h1 em{font-style:normal;color:var(--gold)}
.hero__sub{font-family:var(--f-ui);font-size:clamp(.9rem,1.4vw,1.05rem);color:rgba(255,255,255,.72);line-height:1.72;max-width:520px;margin-bottom:2.25rem;opacity:0;transform:translateY(20px);transition:opacity .6s .36s var(--ease),transform .6s .36s var(--ease)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.875rem;opacity:0;transform:translateY(16px);transition:opacity .5s .5s var(--ease),transform .5s .5s var(--ease)}
.hero__slide.on .hero__eyebrow,.hero__slide.on .hero__h1,.hero__slide.on .hero__sub,.hero__slide.on .hero__actions{opacity:1;transform:none}
.hero__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:52px;height:52px;background:rgba(13,27,62,.5);border:1px solid rgba(255,255,255,.22);border-radius:var(--r-full);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;color:#fff;transition:background var(--fast),transform var(--fast)}
.hero__arrow:hover{background:rgba(13,27,62,.8)}
.hero__arrow:active{transform:translateY(-50%) scale(.94)}
.hero__arrow--l{left:1.5rem}.hero__arrow--r{right:1.5rem}
.hero__dots{position:absolute;bottom:2.25rem;right:clamp(1.5rem,5vw,4.5rem);z-index:10;display:flex;align-items:center;gap:.5rem}
.hero__dot{width:8px;height:8px;border-radius:var(--r-full);background:rgba(255,255,255,.35);border:none;cursor:pointer;padding:0;transition:width var(--mid) var(--ease),background var(--fast)}
.hero__dot.on{width:28px;background:#fff}
.hero__bar{position:absolute;bottom:0;left:0;height:3px;background:var(--gold);width:0%;z-index:10}
.hero__count{position:absolute;top:90px;right:clamp(1.5rem,5vw,4.5rem);z-index:10;font-family:var(--f-ui);font-size:.7rem;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.38)}
.hero__count strong{color:#fff;font-size:1rem}
@media(max-width:768px){.hero__arrow,.hero__count{display:none}.hero__dots{right:50%;transform:translateX(50%)}}

/* ═══════════════════════════════════════════════════════════════
   TRUST BAR
═══════════════════════════════════════════════════════════════ */
.trust{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.07)}
.trust__row{max-width:1320px;margin:0 auto;padding:.95rem 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.trust__item{display:flex;align-items:center;gap:.45rem;font-family:var(--f-ui);font-size:.68rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.trust__item .mi{font-size:.95rem;color:var(--gold);font-variation-settings:'FILL' 1}

/* ═══════════════════════════════════════════════════════════════
   FEATURE GRID  (dark/navy variant)
═══════════════════════════════════════════════════════════════ */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem;margin-top:2.25rem}
.feat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:1.875rem 1.75rem;transition:background var(--mid),border-color var(--mid)}
.feat:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.feat__icon{width:50px;height:50px;background:rgba(201,168,92,.14);border:1px solid rgba(201,168,92,.28);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.feat__icon .mi{font-size:1.35rem;color:var(--gold);font-variation-settings:'FILL' 1}
.feat__title{font-family:var(--f-display);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.feat__body{font-family:var(--f-ui);font-size:.875rem;color:rgba(255,255,255,.52);line-height:1.65}
/* light variant */
.feat--light{background:#fff;border-color:var(--silver)}
.feat--light:hover{background:var(--navy-ghost);border-color:var(--navy-faint);box-shadow:var(--sh-sm)}
.feat--light .feat__icon{background:var(--navy-ghost);border-color:var(--navy-faint)}
.feat--light .feat__icon .mi{color:var(--navy)}
.feat--light .feat__title{color:var(--ink)}
.feat--light .feat__body{color:var(--slate)}

/* ═══════════════════════════════════════════════════════════════
   STATS ROW
═══════════════════════════════════════════════════════════════ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;padding:3rem 2rem;background:var(--navy);border-radius:var(--r-xl)}
@media(max-width:640px){.stats-row{grid-template-columns:1fr 1fr}}
.stat{text-align:center}
.stat__num{font-family:var(--f-display);font-size:clamp(2rem,4vw,2.75rem);font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:.25rem}
.stat__num em{font-style:normal;color:var(--gold)}
.stat__lbl{font-family:var(--f-ui);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* ═══════════════════════════════════════════════════════════════
   PROCESS STEPS
═══════════════════════════════════════════════════════════════ */
.process-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;counter-reset:step}
.step{background:#fff;border:1px solid var(--silver);border-radius:var(--r-xl);padding:2rem 1.75rem;position:relative;transition:box-shadow var(--mid),transform var(--mid)}
.step:hover{box-shadow:var(--sh-md);transform:translateY(-4px)}
.step::before{counter-increment:step;content:counter(step,'0');position:absolute;top:1.5rem;right:1.5rem;font-family:var(--f-display);font-size:2.25rem;font-weight:800;color:var(--navy-faint);line-height:1;letter-spacing:-.05em}
.step__icon{width:48px;height:48px;background:var(--navy-ghost);border:1px solid var(--navy-faint);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.step__icon .mi{font-size:1.3rem;color:var(--navy);font-variation-settings:'FILL' 1}
.step__title{font-family:var(--f-display);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.5rem}
.step__body{font-family:var(--f-ui);font-size:.875rem;color:var(--slate);line-height:1.65}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════════════════════════════ */
.tcard{background:var(--off-white);border-radius:var(--r-xl);padding:2rem;border:1px solid var(--silver);display:flex;flex-direction:column;gap:1.25rem;transition:box-shadow var(--mid),transform var(--mid)}
.tcard:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.tcard__stars{display:flex;gap:2px;color:var(--gold)}
.tcard__stars .mi{font-size:1.05rem;font-variation-settings:'FILL' 1}
.tcard__quote{font-family:var(--f-display);font-size:1.05rem;font-weight:400;color:var(--ink);line-height:1.6;flex:1;font-style:italic}
.tcard__author{display:flex;align-items:center;gap:.75rem}
.tcard__av{width:40px;height:40px;border-radius:var(--r-full);background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--f-ui);font-size:.78rem;font-weight:700;flex-shrink:0}
.tcard__name{font-family:var(--f-ui);font-weight:600;font-size:.875rem;color:var(--ink)}
.tcard__loc{font-family:var(--f-ui);font-size:.78rem;color:var(--slate)}

/* ═══════════════════════════════════════════════════════════════
   SWATCH / STONE
═══════════════════════════════════════════════════════════════ */
.swatch{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/2;position:relative;box-shadow:var(--sh-md)}
.swatch img{width:100%;height:100%;object-fit:cover}
.swatch__lbl{position:absolute;bottom:0;left:0;right:0;padding:.6rem .875rem;background:linear-gradient(to top,rgba(7,16,31,.8),transparent);font-family:var(--f-ui);font-size:.65rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#fff}
.stone-photo{border-radius:var(--r-xl);position:relative;aspect-ratio:4/3;box-shadow:var(--sh-hero)}
.stone-photo img{width:100%;height:100%;object-fit:cover;border-radius:var(--r-xl)}
.stone-badge{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--navy);color:#fff;border-radius:var(--r-lg);padding:1.25rem 1.5rem;box-shadow:var(--sh-lg);border:1px solid rgba(255,255,255,.1);font-family:var(--f-ui);font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;line-height:1.75;z-index:10;max-width:240px}
.stone-badge strong{display:block;font-family:var(--f-display);font-size:1.4rem;font-weight:800;letter-spacing:-.02em;text-transform:none;color:var(--gold)}

/* ═══════════════════════════════════════════════════════════════
   CTA STRIP
═══════════════════════════════════════════════════════════════ */
.cta-strip{background:var(--navy-deep);position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 80% at 80% 50%,rgba(22,45,92,.6),transparent 65%);pointer-events:none}
.cta-strip::after{content:'';position:absolute;top:0;right:0;width:42%;height:100%;background-image:url('https://images.unsplash.com/photo-1600566752355-35792bedcfea?w=900&q=85&auto=format&fit=crop');background-size:cover;opacity:.22;mask-image:linear-gradient(to right,transparent,rgba(0,0,0,.7) 40%);-webkit-mask-image:linear-gradient(to right,transparent,rgba(0,0,0,.7) 40%)}
@media(max-width:680px){.cta-strip::after{display:none}}
.cta-strip__inner{max-width:1320px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;align-items:center;gap:3rem}
@media(max-width:680px){.cta-strip__inner{grid-template-columns:1fr}}
.cta-strip__actions{display:flex;gap:.875rem;align-items:center}
@media(max-width:680px){
  .cta-strip__actions{flex-direction:column;align-items:stretch;gap:1rem}
  .cta-strip__actions .btn{width:100%}
}

/* ═══════════════════════════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════════════════════════ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
@media(max-width:768px){.gallery-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}
.g-item{border-radius:var(--r-lg);overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--sh-sm);background:var(--navy-faint)}
.g-item--tall{grid-row:span 2}
.g-item img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:1;display:block;
  transition:transform .8s var(--ease), filter .4s var(--ease);
  filter: contrast(1.02) brightness(1.02);
}
.g-item--tall img{aspect-ratio:unset;height:100%;min-height:400px}
.g-item:hover img{
  transform:scale(1.08);
  filter: contrast(1.05) brightness(1.05);
}
.g-item__over{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(13,27,62,.88));opacity:0;display:flex;align-items:flex-end;padding:1.25rem;transition:opacity var(--mid)}
.g-item:hover .g-item__over{opacity:1}
.g-item__lbl{font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;display:flex;align-items:center;gap:.4rem}
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(7,16,31,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--mid)}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox__img{max-width:90vw;max-height:88vh;border-radius:var(--r-lg);box-shadow:var(--sh-hero)}
.lightbox__close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:var(--r-full);background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--fast)}
.lightbox__close:hover{background:rgba(255,255,255,.2)}
.lightbox__arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:50px;height:50px;border-radius:var(--r-full);
  background:rgba(255,255,255,.1);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--fast),transform var(--fast);
  z-index:10;
}
.lightbox__arrow:hover{background:rgba(255,255,255,.2)}
.lightbox__arrow:active{transform:translateY(-50%) scale(.92)}
.lightbox__arrow--l{left:1.5rem}
.lightbox__arrow--r{right:1.5rem}
@media(max-width:640px){
  .lightbox__arrow{width:40px;height:40px}
  .lightbox__arrow--l{left:.75rem}
  .lightbox__arrow--r{right:.75rem}
}

/* ═══════════════════════════════════════════════════════════════
   TABS
═══════════════════════════════════════════════════════════════ */
.tabs{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.tab{font-family:var(--f-ui);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:.55rem 1.2rem;border-radius:var(--r-full);border:1.5px solid var(--silver);color:var(--slate);background:transparent;cursor:pointer;transition:background var(--fast),border-color var(--fast),color var(--fast)}
.tab.on,.tab:hover{background:var(--navy);border-color:var(--navy);color:#fff}

/* ═══════════════════════════════════════════════════════════════
   FORMS / CONTACT
═══════════════════════════════════════════════════════════════ */
.form-card{background:#fff;border-radius:var(--r-xl);padding:2.5rem;box-shadow:var(--sh-md);border:1px solid var(--silver)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:520px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}
.field label{font-family:var(--f-ui);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
.field input,.field select,.field textarea{font-family:var(--f-ui);font-size:.9375rem;border:1.5px solid var(--silver);border-radius:var(--r-md);padding:.75rem 1rem;background:var(--off-white);color:var(--ink);outline:none;transition:border-color var(--fast),box-shadow var(--fast)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy-light);box-shadow:0 0 0 3px rgba(30,61,120,.12)}
.field textarea{resize:vertical;min-height:120px}
.c-info{display:flex;align-items:flex-start;gap:1rem;background:#fff;border-radius:var(--r-xl);padding:1.5rem;box-shadow:var(--sh-sm);border:1px solid var(--silver)}
.c-info__icon{width:46px;height:46px;flex-shrink:0;background:var(--navy-ghost);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center}
.c-info__icon .mi{font-size:1.25rem;color:var(--navy);font-variation-settings:'FILL' 1}
.c-info__lbl{font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--steel);margin-bottom:.3rem}
.c-info__val{font-family:var(--f-ui);font-size:.9375rem;font-weight:500;color:var(--ink)}
.c-info__val a{color:var(--navy-light)}.c-info__val a:hover{text-decoration:underline}
.c-info__note{font-family:var(--f-ui);font-size:.78rem;color:var(--slate);margin-top:.2rem}

/* ═══════════════════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════════════════ */
.faq-item{border:1px solid var(--silver);border-radius:var(--r-lg);overflow:hidden;background:#fff}
.faq-item+.faq-item{margin-top:.75rem}
.faq-q{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;font-family:var(--f-ui);font-size:.9375rem;font-weight:600;color:var(--ink);gap:1rem;cursor:pointer;transition:background var(--fast)}
.faq-q:hover{background:var(--navy-ghost)}
.faq-q .mi{font-size:1.25rem;color:var(--steel);flex-shrink:0;transition:transform var(--mid) var(--ease)}
.faq-item.open .faq-q .mi{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height var(--mid) var(--ease)}
.faq-item.open .faq-a{max-height:400px}
.faq-a__inner{padding:0 1.5rem 1.5rem;font-family:var(--f-ui);font-size:.9rem;color:var(--slate);line-height:1.75}
.faq-a__inner a{color:var(--navy-light);font-weight:500;text-decoration:underline}

/* ═══════════════════════════════════════════════════════════════
   LEGAL / GDPR
═══════════════════════════════════════════════════════════════ */
.legal-wrap{max-width:800px;margin:0 auto}
.legal-wrap h2{font-family:var(--f-display);font-size:1.5rem;font-weight:700;color:var(--ink);margin:2.5rem 0 1rem;letter-spacing:-.02em}
.legal-wrap h3{font-family:var(--f-ui);font-size:1rem;font-weight:700;color:var(--ink);margin:1.75rem 0 .625rem}
.legal-wrap p{font-family:var(--f-ui);font-size:.9375rem;color:var(--slate);line-height:1.75;margin-bottom:1rem}
.legal-wrap ul{margin:.75rem 0 1rem 1.5rem;display:flex;flex-direction:column;gap:.4rem}
.legal-wrap li{font-family:var(--f-ui);font-size:.9375rem;color:var(--slate);line-height:1.7}
.legal-wrap a{color:var(--navy-light);text-decoration:underline}
.legal-wrap table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.875rem}
.legal-wrap th{background:var(--navy-ghost);padding:.75rem 1rem;font-family:var(--f-ui);font-weight:700;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);text-align:left;border:1px solid var(--silver)}
.legal-wrap td{padding:.75rem 1rem;border:1px solid var(--silver);font-family:var(--f-ui);color:var(--slate);vertical-align:top}
.legal-updated{font-family:var(--f-ui);font-size:.8rem;color:var(--steel);margin-bottom:2rem;font-style:italic}

/* ═══════════════════════════════════════════════════════════════
   COOKIE BANNER
═══════════════════════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:600;background:#fff;border-top:3px solid var(--navy);box-shadow:0 -8px 40px rgba(13,27,62,.18);padding:1.25rem 2rem;transform:translateY(100%);transition:transform .5s var(--ease)}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner__inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cookie-banner__text{flex:1;min-width:280px}
.cookie-banner__text strong{display:block;font-family:var(--f-ui);font-size:.9rem;font-weight:700;color:var(--ink);margin-bottom:.25rem}
.cookie-banner__text p{font-family:var(--f-ui);font-size:.8125rem;color:var(--slate);line-height:1.6}
.cookie-banner__text a{color:var(--navy-light);text-decoration:underline;cursor:pointer}
.cookie-banner__actions{display:flex;gap:.75rem;flex-wrap:wrap;flex-shrink:0}
/* Cookie modal */
.c-modal{position:fixed;inset:0;z-index:700;background:rgba(7,16,31,.7);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:1.5rem}
.c-modal.open{display:flex}
.c-modal__box{background:#fff;border-radius:var(--r-xl);max-width:500px;width:100%;padding:2.5rem;box-shadow:var(--sh-hero);max-height:90vh;overflow-y:auto}
.c-modal__row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem;border-radius:var(--r-lg);margin-bottom:.75rem}
.c-modal__row--always{background:var(--navy-ghost)}
.c-modal__row--opt{border:1.5px solid var(--silver)}
.c-modal__row p{font-family:var(--f-ui);font-size:.8rem;color:var(--slate);line-height:1.6;margin-top:.25rem}
.c-modal__row strong{font-family:var(--f-ui);font-size:.875rem;font-weight:700;color:var(--ink)}

/* ═══════════════════════════════════════════════════════════════
   404 PAGE
═══════════════════════════════════════════════════════════════ */
.nf{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center}
.nf__num{font-family:var(--f-display);font-size:clamp(6rem,18vw,11rem);font-weight:800;line-height:1;letter-spacing:-.06em;color:var(--navy-faint);display:block}
.nf__title{font-family:var(--f-display);font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;color:var(--ink);margin-bottom:1rem;letter-spacing:-.02em}
.nf__body{font-family:var(--f-ui);font-size:.9375rem;color:var(--slate);line-height:1.7;margin-bottom:2.5rem}
.nf__links{display:flex;gap:.875rem;flex-wrap:wrap;justify-content:center}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════ */
footer{background:#04080f;color:rgba(255,255,255,.4);padding:4rem 2rem 2rem}
.foot__grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.7fr repeat(3,1fr);gap:3rem}
@media(max-width:900px){.foot__grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:500px){.foot__grid{grid-template-columns:1fr}}
.foot__brand{font-family:var(--f-display);font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.02em}
.foot__brand small{display:block;font-family:var(--f-ui);font-size:.575rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.foot__rule{width:32px;height:2px;background:var(--navy-mid);border-radius:2px;margin:1rem 0}
.foot__tagline{font-family:var(--f-ui);font-size:.875rem;line-height:1.75;max-width:260px}
.foot__social{display:flex;gap:.5rem;margin-top:1rem}
.foot__social a{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);transition:background var(--fast),color var(--fast)}
.foot__social a:hover{background:var(--navy-mid);color:#fff}
.foot__social .mi{font-size:1rem}
.foot__hd{font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:1.25rem}
.foot__links{list-style:none;display:flex;flex-direction:column;gap:.625rem}
.foot__links a{font-family:var(--f-ui);font-size:.875rem;color:rgba(255,255,255,.4);transition:color var(--fast)}
.foot__links a:hover{color:#fff}
.foot__bottom{max-width:1320px;margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:var(--f-ui);font-size:.78rem}
.foot__bottom a{color:var(--gold)}

/* ── MI helper ─────────────────────────────────────────────── */
.mi{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;font-size:1.25rem;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;-webkit-font-smoothing:antialiased;font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24}

/* ═══════════════════════════════════════════════════════════════
   CABINET VISUALIZER COMPONENT
═══════════════════════════════════════════════════════════════ */
.cab-vis{display:grid;grid-template-columns:300px 1fr;gap:3rem;background:#fff;padding:2rem;border-radius:var(--r-xl);box-shadow:var(--sh-md);align-items:start}
@media(max-width:960px){
  .cab-vis{display:flex;flex-direction:column-reverse;gap:1.5rem;padding:1.5rem}
  .cv-preview{min-height:300px}
  .cv-lens{display:none !important} /* Disable lens on mobile */
}
.cv-preview{position:relative;background:var(--navy-ghost);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;min-height:500px;overflow:hidden;cursor:crosshair}
.cv-img{max-width:100%;max-height:600px;object-fit:contain}
.cv-lens{
  position:absolute;border:2px solid rgba(255,255,255,.8);
  width:200px;height:200px;
  border-radius:50%; /* Circle lens looks more like a magnifier */
  pointer-events:none;overflow:hidden;
  box-shadow:0 0 15px rgba(0,0,0,.25), inset 0 0 20px rgba(0,0,0,.1);
  display:none;z-index:20;background:#fff;
}
.cv-lens-img{position:absolute;width:auto;max-width:none}
.cv-selection{display:flex;flex-direction:column;gap:1.5rem}
.cv-title{font-family:var(--f-display);font-size:1.75rem;font-weight:700;color:var(--navy);line-height:1.1}
.cv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;justify-content:center}
.cv-swatch{width:100%;aspect-ratio:1;border-radius:var(--r-md);cursor:pointer;border:2px solid transparent;transition:all var(--fast);background-position:center}
.cv-swatch:hover{transform:scale(1.05);border-color:var(--gold)}
.cv-swatch.active{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,92,.3)}


/* ═══ PAGE LOADER ═════════════════════════════════════════════ */
#loader{position:fixed;inset:0;z-index:9999;background:#07101f;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;transition:opacity .65s .1s cubic-bezier(.22,1,.36,1)}
#loader.done{opacity:0;pointer-events:none}
.ldr__imgs{position:absolute;inset:0}
.ldr__img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease}
.ldr__img.on{opacity:.38}
.ldr__img:nth-child(1){background-image:url('assets/img/AdobeStock_378972930.jpeg')}
.ldr__img:nth-child(2){background-image:url('assets/img/AdobeStock_442081888.jpeg')}
.ldr__img:nth-child(3){background-image:url('assets/img/AdobeStock_479119684.jpeg')}
.ldr__img:nth-child(4){background-image:url('assets/img/AdobeStock_581716880.jpeg')}
.ldr__imgs::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(7,16,31,.55) 0%,rgba(13,27,62,.8) 100%)}
.ldr__body{position:relative;z-index:1;text-align:center;animation:ldrUp .7s cubic-bezier(.22,1,.36,1) both}
.ldr__icon{width:64px;height:64px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.ldr__icon svg{width:32px;height:32px;fill:#fff}
.ldr__name{font-family:var(--f-display);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:.375rem}
.ldr__sub{font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.ldr__track{position:relative;z-index:1;width:min(260px,68vw);height:2px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden;margin-top:2.25rem}
.ldr__fill{height:100%;width:0%;background:var(--gold);border-radius:2px;transition:width .08s linear}
.ldr__caption{position:relative;z-index:1;margin-top:1rem;font-family:var(--f-ui);font-size:.72rem;color:rgba(255,255,255,.35);letter-spacing:.06em;animation:ldrUp .8s .3s cubic-bezier(.22,1,.36,1) both}
@keyframes ldrUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ═══ MAILING LIST POPUP ══════════════════════════════════════ */
#mailPopup{position:fixed;inset:0;z-index:800;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:rgba(7,16,31,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.22,1,.36,1)}
#mailPopup.open{opacity:1;pointer-events:all}
.mpop{background:#fff;border-radius:var(--r-xl);max-width:500px;width:100%;overflow:hidden;box-shadow:var(--sh-hero);transform:translateY(24px) scale(.97);transition:transform .4s cubic-bezier(.22,1,.36,1)}
#mailPopup.open .mpop{transform:none}
.mpop__hero{height:190px;background-image:url('https://images.unsplash.com/photo-1584622650111-993a426fbf0a?w=800&q=85&auto=format&fit=crop');background-size:cover;background-position:center;position:relative}
.mpop__hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,27,62,.25),rgba(13,27,62,.78))}
.mpop__label{position:absolute;bottom:1.25rem;left:1.5rem;z-index:1;font-family:var(--f-ui);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:.5rem}
.mpop__label::before{content:'';display:block;width:18px;height:2px;background:var(--gold);border-radius:2px}
.mpop__x{position:absolute;top:.875rem;right:.875rem;z-index:10;width:34px;height:34px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background var(--fast)}
.mpop__x:hover{background:rgba(255,255,255,.28)}
.mpop__body{padding:1.875rem 2rem 2.125rem}
.mpop__title{font-family:var(--f-display);font-size:1.5rem;font-weight:700;color:var(--ink);letter-spacing:-.02em;margin-bottom:.5rem;line-height:1.2}
.mpop__title em{font-style:normal;color:var(--navy-mid)}
.mpop__text{font-family:var(--f-ui);font-size:.875rem;color:var(--slate);line-height:1.65;margin-bottom:1.375rem}
.mpop__row{display:flex;gap:.625rem;flex-wrap:wrap}
.mpop__input{flex:1;min-width:180px;font-family:var(--f-ui);font-size:.9375rem;border:1.5px solid var(--silver);border-radius:var(--r-full);padding:.7rem 1.25rem;background:var(--off-white);color:var(--ink);outline:none;transition:border-color var(--fast),box-shadow var(--fast)}
.mpop__input:focus{border-color:var(--navy-light);box-shadow:0 0 0 3px rgba(30,61,120,.12)}
.mpop__note{font-family:var(--f-ui);font-size:.7rem;color:var(--steel);margin-top:.75rem;line-height:1.5}
.mpop__note a{color:var(--navy-light);text-decoration:underline}
.mpop__ok{display:none;text-align:center;padding:2.5rem 2rem}
.mpop__ok .mi{font-size:2.75rem;color:var(--gold);font-variation-settings:'FILL' 1;display:block;margin-bottom:1rem}
.mpop__ok h3{font-family:var(--f-display);font-size:1.375rem;font-weight:700;color:var(--ink);margin-bottom:.5rem;letter-spacing:-.02em}
.mpop__ok p{font-family:var(--f-ui);font-size:.875rem;color:var(--slate);line-height:1.65}
