/* ============================================================
   ETA JEWELS — Brand Design System
   Crafted from India. Worn with Soul.
   Palette + typography drawn from the Eta Jewels logo + brief.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root{
  /* Brand colours — built from the Eta Jewels logo: #24233B ink + #FADA16 yellow */
  --navy:        #24233B;   /* logo ink / primary dark */
  --navy-2:      #312F52;   /* lifted panel */
  --gold:        #FADA16;   /* logo yellow / primary accent */
  --gold-deep:   #9A7B05;   /* legible mustard for text on light */
  --gold-soft:   #FCE873;   /* soft yellow for text on dark */
  --saffron:     #FDF8DC;   /* pale yellow tint surface */
  --bone:        #FAF8F2;
  --bone-2:      #F2EEDF;
  --charcoal:    #1A1A1A;
  --grey:        #7A7A7A;
  --grey-2:      #9a958c;
  --line:        rgba(36,35,59,0.12);
  --line-2:      rgba(36,35,59,0.06);
  --on-navy-soft:#cdcee0;

  /* Type */
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "DM Sans", system-ui, -apple-system, sans-serif;
  --num:   "Cormorant Garamond", Georgia, serif;   /* numerals — elegant serif lining figures */

  /* Spacing scale (8px base) */
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px; --s5: 24px;
  --s6: 32px; --s7: 48px; --s8: 64px; --s9: 96px;

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 56px);
  --radius: 3px;
  --shadow-sm: 0 1px 3px rgba(36,35,59,0.07), 0 6px 18px rgba(36,35,59,0.06);
  --shadow-md: 0 4px 14px rgba(36,35,59,0.09), 0 22px 50px rgba(36,35,59,0.12);
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body{
  margin:0; background: var(--bone); color: var(--charcoal);
  font-family: var(--sans); font-size: 16px; font-weight: 400;
  line-height: 1.55; letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{ display:block; max-width:100%; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }
::selection{ background: var(--gold); color: var(--navy); }

/* ---------- numerals: elegant serif lining figures, tabular ---------- */
.num{ font-family: var(--num); font-weight: 500; font-variant-numeric: lining-nums tabular-nums; font-feature-settings: "tnum" 1, "lnum" 1; letter-spacing: 0.005em; }

/* ---------- type primitives ---------- */
.eyebrow{
  font-family: var(--sans); font-size: 11.5px; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--grey);
}
.eyebrow.gold{ color: var(--gold-deep); }
.eyebrow.on-navy{ color: var(--gold-soft); }

.display{ font-family: var(--serif); font-weight: 400; line-height: 1.02; letter-spacing: -0.01em; }
.serif-i{ font-family: var(--serif); font-style: italic; font-weight: 400; }

h1,h2,h3,h4{ font-family: var(--serif); font-weight: 400; line-height: 1.08; letter-spacing: -0.01em; margin:0; }
h1{ font-size: clamp(2.4rem, 5.2vw, 4.2rem); }
h2{ font-size: clamp(1.9rem, 3.6vw, 3rem); }
h3{ font-size: clamp(1.4rem, 2.4vw, 2rem); }
p{ margin: 0 0 1em; }
.lede{ font-size: clamp(1rem, 1.3vw, 1.18rem); color: #3a3a3a; line-height: 1.7; }
.muted{ color: var(--grey); }

/* ---------- layout ---------- */
.wrap{ max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section{ padding-block: clamp(48px, 7vw, 104px); }
.section--tight{ padding-block: clamp(36px, 4.5vw, 64px); }
.bg-navy{ background: var(--navy); color: #fff; }
.bg-saffron{ background: var(--saffron); }
.bg-bone2{ background: var(--bone-2); }
.center{ text-align:center; }

/* divider — interlocking diamond motif */
.diamond-rule{ display:flex; align-items:center; justify-content:center; gap:14px; color: var(--gold); }
.diamond-rule::before,.diamond-rule::after{ content:""; height:1px; width:min(80px,12vw); background: currentColor; opacity:.45; }
.diamond-rule i{ width:8px; height:8px; border:1.4px solid currentColor; transform: rotate(45deg); display:inline-block; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  --bg: var(--navy); --fg:#fff; --bd: var(--navy);
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  background: var(--bg); color: var(--fg); border:1.4px solid var(--bd);
  font-family: var(--sans); font-size: 13.5px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 14px 26px; border-radius: var(--radius);
  transition: transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease);
  position:relative; overflow:hidden;
}
.btn:hover{ transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn .arrow{ transition: transform .35s var(--ease); }
.btn:hover .arrow{ transform: translateX(4px); }
.btn--gold{ --bg: var(--gold); --fg: var(--navy); --bd: var(--gold); font-weight:600; }
.btn--gold:hover{ --bg: var(--gold-deep); --bd: var(--gold-deep); color:#fff; }
.btn--ghost{ --bg: transparent; --fg: var(--navy); --bd: var(--line); }
.btn--ghost:hover{ --bd: var(--navy); }
.btn--ghost-gold{ --bg: transparent; --fg: var(--gold-soft); --bd: rgba(250,218,22,.5); }
.btn--ghost-gold:hover{ --bd: var(--gold); --fg:#fff; }
.btn--sm{ padding: 9px 16px; font-size: 12px; letter-spacing:.1em; }
.btn--block{ width:100%; }
.btn--lg{ padding: 17px 34px; font-size: 14px; }

.link-arrow{ display:inline-flex; align-items:center; gap:8px; font-size:12.5px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--navy); }
.link-arrow .arrow{ transition: transform .35s var(--ease); }
.link-arrow:hover .arrow{ transform: translateX(4px); }
.link-arrow.gold{ color: var(--gold-deep); }

/* ============================================================
   PILLS / BADGES / TAGS
   ============================================================ */
.pill{
  display:inline-flex; align-items:center; gap:6px;
  border:1px solid var(--line); border-radius: 100px;
  padding: 7px 15px; font-size: 12.5px; color: #3a3a3a; background:#fff;
  letter-spacing: .02em; transition: all .25s var(--ease); white-space:nowrap;
}
.pill:hover{ border-color: var(--navy); }
.pill.is-active{ background: var(--navy); color:#fff; border-color: var(--navy); }

.tag{
  display:inline-flex; align-items:center; gap:5px;
  font-family: var(--sans); font-size: 10.5px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  padding: 5px 9px; border-radius: 2px; line-height:1;
}
.tag--gold{ background: var(--gold); color: var(--navy); }
.tag--navy{ background: var(--navy); color: var(--gold-soft); }
.tag--stock{ background:#fff; color:#8a2b1f; border:1px solid #e7c9bf; }
.tag--sale{ background:#8a2b1f; color:#fff; }

.eyebrow-tier{ font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); }

/* ============================================================
   SQUARE IMAGE FRAME — every product image is a perfect square
   ============================================================ */
.sq{ position:relative; aspect-ratio:1/1; overflow:hidden; background: var(--bone-2); border-radius: var(--radius); }
.sq > img{ width:100%; height:100%; object-fit:cover; display:block; transition: transform .9s var(--ease), opacity .5s var(--ease); }
.sq--zoom:hover > img{ transform: scale(1.06); }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.card{ position:relative; display:flex; flex-direction:column; }
.card__media{ position:relative; aspect-ratio:1/1; overflow:hidden; border-radius: var(--radius); background: var(--bone-2); }
.card__media img{ width:100%; height:100%; object-fit:cover; transition: transform 1s var(--ease), opacity .5s var(--ease); }
.card:hover .card__media img{ transform: scale(1.05); }
.card__badges{ position:absolute; top:12px; left:12px; display:flex; gap:6px; z-index:2; }
.card__wish{
  position:absolute; top:10px; right:10px; z-index:2;
  width:36px; height:36px; border-radius:50%; border:none;
  background: rgba(255,255,255,.9); color: var(--navy);
  display:grid; place-items:center; font-size:15px;
  transition: all .25s var(--ease); backdrop-filter: blur(4px);
}
.card__wish:hover{ background: var(--navy); color:#fff; transform: scale(1.08); }
.card__wish.is-on{ background: var(--gold); color: var(--navy); }
.card__quickadd{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  background: var(--navy); color:#fff; border:none;
  font-family:var(--sans); font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  padding: 14px; transform: translateY(101%); transition: transform .4s var(--ease);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.card__media:hover .card__quickadd{ transform: translateY(0); }
.card__info{ padding-top:14px; }
.card__tier{ display:block; margin-bottom:3px; }
.card__name{ font-family:var(--serif); font-style:italic; font-size:1.28rem; line-height:1.1; color:var(--navy); }
.card__price{ margin-top:6px; font-size:17.5px; font-weight:700; color:var(--charcoal); display:flex; align-items:baseline; gap:8px; }
.card__price .was{ color:var(--grey); text-decoration:line-through; font-size:13.5px; font-weight:400; }
.card__fomo{ margin-top:4px; font-size:11px; letter-spacing:.04em; color:#8a2b1f; }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announce{ background: var(--navy); color: var(--gold-soft); overflow:hidden; }
.announce__track{ display:flex; align-items:center; justify-content:center; height:38px; position:relative; }
.announce__item{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:10px;
  font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; font-weight:400;
  opacity:0; transition: opacity .6s var(--ease); padding-inline:16px; text-align:center;
}
.announce__item.is-on{ opacity:1; }
.announce__item b{ color:#fff; font-weight:500; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-head{ position:sticky; top:0; z-index:60; background: var(--bone); border-bottom:1px solid var(--line-2); transition: background .4s var(--ease), box-shadow .4s var(--ease); }
.site-head.is-scrolled{ box-shadow: 0 1px 0 var(--line), var(--shadow-sm); }
.nav{ display:flex; align-items:center; gap: clamp(20px,3vw,54px); height: 74px; }
.nav__logo{ display:flex; align-items:center; gap:10px; flex-shrink:0; margin-right:auto; }
.nav__logo img{ height: 38px; width:auto; }
.nav__links{ display:flex; align-items:center; gap: clamp(13px,1.5vw,26px); margin-inline:auto; }
.nav__link{
  position:relative; font-size: 12.5px; font-weight: 500; letter-spacing:.13em; text-transform:uppercase; color: var(--navy);
  padding: 6px 0; white-space:nowrap;
}
.nav__link::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background: var(--gold); transition: right .35s var(--ease); }
.nav__link:hover::after, .nav__link.is-current::after{ right:0; }
.nav__link .new-dot{ position:absolute; top:-2px; right:-9px; width:5px; height:5px; border-radius:50%; background: var(--gold); animation: pulse 1.8s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(250,218,22,.5);} 50%{ box-shadow:0 0 0 5px rgba(250,218,22,0);} }
.nav__icons{ display:flex; align-items:center; gap: 20px; flex-shrink:0; margin-left:auto; }
.nav__ic{ position:relative; background:none; border:none; color: var(--navy); line-height:1; display:grid; place-items:center; width:30px; height:30px; padding:0; transition: color .25s; }
.nav__ic svg{ width:23px; height:23px; display:block; }
.nav__ic:hover{ color: var(--gold-deep); }
.nav__ic .count{ position:absolute; top:-7px; right:-9px; min-width:16px; height:16px; padding:0 4px; border-radius:9px; background: var(--gold); color:var(--navy); font-size:10px; font-weight:600; display:grid; place-items:center; font-family:var(--sans); }
.nav__burger{ display:none; background:none; border:none; font-size:22px; color:var(--navy); }
.nav__signin{ font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; white-space:nowrap; }

/* mobile drawer */
.mnav{ position:fixed; inset:0; z-index:90; visibility:hidden; }
.mnav__scrim{ position:absolute; inset:0; background:rgba(36,35,59,.4); opacity:0; transition:opacity .4s; }
.mnav__panel{ position:absolute; top:0; right:0; bottom:0; width:min(86vw,360px); background:var(--bone); transform:translateX(100%); transition:transform .45s var(--ease); padding:24px; display:flex; flex-direction:column; gap:6px; overflow-y:auto; }
.mnav.is-open{ visibility:visible; }
.mnav.is-open .mnav__scrim{ opacity:1; }
.mnav.is-open .mnav__panel{ transform:translateX(0); }
.mnav__link{ font-family:var(--serif); font-style:italic; font-size:1.7rem; color:var(--navy); padding:10px 0; border-bottom:1px solid var(--line-2); }
.mnav__close{ align-self:flex-end; background:none; border:none; font-size:26px; color:var(--navy); margin-bottom:8px; }

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{ background: var(--gold); color: var(--navy); }
.trust__row{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding-block:14px; flex-wrap:wrap; }
.trust__item{ display:flex; align-items:center; gap:9px; font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; }
.trust__item svg{ width:17px; height:17px; flex-shrink:0; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background: var(--navy); color: var(--on-navy-soft); }
.foot__top{ display:grid; grid-template-columns: 1.6fr repeat(3, 1fr) 1.3fr; gap: clamp(24px,4vw,56px); padding-block: 64px; }
.foot__brand img{ height:64px; margin-bottom:16px; }
.foot__tagline{ font-family:var(--serif); font-style:italic; font-size:1.35rem; color:#fff; line-height:1.3; }
.foot__col h4{ font-family:var(--sans); font-size:11.5px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:16px; }
.foot__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.foot__col a{ font-size:13.5px; color:var(--on-navy-soft); transition:color .2s; }
.foot__col a:hover{ color:#fff; }
.foot__news input{ width:100%; background:transparent; border:1px solid rgba(255,255,255,.2); color:#fff; padding:12px 14px; border-radius:var(--radius); font-family:var(--sans); font-size:13.5px; margin-bottom:10px; }
.foot__news input::placeholder{ color:#8089a8; }
.foot__bottom{ border-top:1px solid rgba(255,255,255,.1); padding-block:20px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:12px; color:#8089a8; }
.foot__social{ display:flex; gap:10px; }
.foot__social a{ width:34px; height:34px; border:1px solid rgba(255,255,255,.2); border-radius:50%; display:grid; place-items:center; font-size:11px; letter-spacing:.05em; color:var(--on-navy-soft); transition: all .25s; }
.foot__social a:hover{ background:var(--gold); color:var(--navy); border-color:var(--gold); }

/* ============================================================
   WHATSAPP FLOAT + CUSTOM CURSOR
   ============================================================ */
.wa-float{ position:fixed; right:20px; bottom:22px; z-index:70; width:54px; height:54px; border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center; box-shadow: 0 8px 24px rgba(0,0,0,.18); transition: transform .3s var(--ease); }
.wa-float:hover{ transform: scale(1.08) translateY(-2px); }
.wa-float svg{ width:28px; height:28px; }

.cursor-dot, .cursor-ring{ position:fixed; top:0; left:0; pointer-events:none; z-index:9999; border-radius:50%; mix-blend-mode: normal; }
.cursor-dot{ width:7px; height:7px; background: var(--gold); transform: translate(-50%,-50%); }
.cursor-ring{ width:34px; height:34px; border:1.4px solid rgba(250,218,22,.55); transform: translate(-50%,-50%); transition: width .25s, height .25s, background .25s, border-color .25s; }
.cursor-ring.is-hot{ width:48px; height:48px; background: rgba(250,218,22,.1); border-color: var(--gold); }
@media (hover: none){ .cursor-dot,.cursor-ring{ display:none; } }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
  .reveal.is-in{ opacity:1; transform:none; }
  .reveal[data-d="1"]{ transition-delay:.08s; }
  .reveal[data-d="2"]{ transition-delay:.16s; }
  .reveal[data-d="3"]{ transition-delay:.24s; }
  .reveal[data-d="4"]{ transition-delay:.32s; }
}

/* ============================================================
   CART DRAWER  (shared)
   ============================================================ */
.drawer{ position:fixed; inset:0; z-index:95; visibility:hidden; }
.drawer__scrim{ position:absolute; inset:0; background:rgba(36,35,59,.42); opacity:0; transition:opacity .4s; }
.drawer__panel{ position:absolute; top:0; right:0; bottom:0; width:min(92vw,420px); background:var(--bone); transform:translateX(100%); transition:transform .45s var(--ease); display:flex; flex-direction:column; }
.drawer.is-open{ visibility:visible; }
.drawer.is-open .drawer__scrim{ opacity:1; }
.drawer.is-open .drawer__panel{ transform:translateX(0); }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; padding:20px 24px; border-bottom:1px solid var(--line); }
.drawer__head h3{ font-size:1.4rem; }
.drawer__head button{ background:none; border:none; font-size:22px; color:var(--navy); }
.drawer__body{ flex:1; overflow-y:auto; padding:20px 24px; }
.drawer__ship{ background:var(--saffron); padding:12px 14px; border-radius:var(--radius); font-size:12px; letter-spacing:.04em; margin-bottom:18px; }
.drawer__ship .bar{ height:4px; background:#e7ddc0; border-radius:3px; margin-top:8px; overflow:hidden; }
.drawer__ship .bar i{ display:block; height:100%; background:var(--gold); border-radius:3px; transition:width .6s var(--ease); }
.cart-line{ display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--line-2); }
.cart-line .sq{ width:74px; flex-shrink:0; }
.cart-line__t{ font-family:var(--serif); font-style:italic; font-size:1.15rem; color:var(--navy); line-height:1.15; }
.cart-line__m{ font-size:11px; color:var(--grey); letter-spacing:.05em; text-transform:uppercase; margin-top:2px; }
.cart-line__p{ font-size:14px; font-weight:500; margin-top:6px; }
.cart-empty{ text-align:center; color:var(--grey); padding:48px 0; }
.cart-empty .mk{ font-family:var(--serif); font-style:italic; font-size:3rem; color:var(--line); }
.drawer__foot{ border-top:1px solid var(--line); padding:20px 24px; }
.drawer__total{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:14px; }
.drawer__total .lbl{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--grey); }
.drawer__total .val{ font-family:var(--serif); font-size:1.8rem; }

/* toast */
.toast{ position:fixed; left:50%; bottom:30px; transform:translate(-50%,20px); background:var(--navy); color:#fff; padding:13px 22px; border-radius:var(--radius); font-size:13px; letter-spacing:.04em; z-index:120; opacity:0; pointer-events:none; transition:all .4s var(--ease); box-shadow:var(--shadow-md); }
.toast.is-on{ opacity:1; transform:translate(-50%,0); }

/* ============================================================
   FORMS / INPUTS
   ============================================================ */
.field{ width:100%; background:#fff; border:1.4px solid var(--line); color:var(--charcoal); padding:13px 16px; border-radius:var(--radius); font-family:var(--sans); font-size:14px; transition:border-color .25s; }
.field:focus{ outline:none; border-color:var(--navy); }

/* qty */
.qty{ display:inline-flex; border:1.4px solid var(--navy); border-radius:var(--radius); }
.qty button{ width:42px; height:48px; background:none; border:none; font-size:18px; color:var(--navy); }
.qty span{ width:46px; display:grid; place-items:center; border-inline:1px solid var(--line); font-weight:500; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px){
  .foot__top{ grid-template-columns:1fr 1fr; }
  .foot__brand{ grid-column:1 / -1; }
}
@media (max-width: 880px){
  .nav__links{ display:none; }
  .nav__signin{ display:none; }
  .nav__burger{ display:block; }
  .nav{ height:62px; gap:14px; }
  .nav__logo{ margin-right:auto; }
}
@media (max-width: 620px){
  .foot__top{ grid-template-columns:1fr; gap:30px; }
  .trust__row{ justify-content:flex-start; gap:14px 22px; }
  .trust__item{ font-size:11px; }
}

/* image placeholder — for founder/workshop shots not yet supplied */
.ph{ position:relative; aspect-ratio:1/1; overflow:hidden; border-radius:var(--radius);
  background:
    repeating-linear-gradient(135deg, transparent 0, transparent 13px, rgba(36,35,59,.05) 13px, rgba(36,35,59,.05) 14px),
    var(--bone-2);
  display:grid; place-items:center; }
.ph--navy{ background:
    repeating-linear-gradient(135deg, transparent 0, transparent 13px, rgba(252,232,115,.10) 13px, rgba(252,232,115,.10) 14px),
    var(--navy); }
.ph__t{ font-family:var(--sans); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--grey); background:rgba(250,248,242,.82); padding:5px 9px; border-radius:2px; text-align:center; max-width:80%; }
.ph--navy .ph__t{ color:var(--gold-soft); background:rgba(36,35,59,.6); }

/* utilities */
.stack{ display:flex; flex-direction:column; }
.row{ display:flex; }
.hide-m{ } 
@media(max-width:880px){ .hide-m{ display:none !important; } }
.only-m{ display:none; }
@media(max-width:880px){ .only-m{ display:block; } }

/* ============================================================
   MODAL (shared — auth, quote, edit-profile)
   ============================================================ */
.modal{ position:fixed; inset:0; z-index:140; visibility:hidden; }
.modal__scrim{ position:absolute; inset:0; background:rgba(36,35,59,.55); backdrop-filter:blur(3px); opacity:0; transition:opacity .35s; }
.modal__card{ position:absolute; left:50%; top:50%; transform:translate(-50%,-46%); width:min(94vw,440px); max-height:92vh; overflow-y:auto; background:var(--bone); border-radius:var(--radius); box-shadow:var(--shadow-md); opacity:0; transition:opacity .35s var(--ease), transform .35s var(--ease); }
.modal.is-open{ visibility:visible; }
.modal.is-open .modal__scrim{ opacity:1; }
.modal.is-open .modal__card{ opacity:1; transform:translate(-50%,-50%); }
.modal__x{ position:absolute; top:14px; right:16px; background:none; border:none; font-size:24px; line-height:1; color:var(--grey); z-index:2; }
.modal__x:hover{ color:var(--navy); }
.modal--wide .modal__card{ width:min(94vw,560px); }

.auth__head{ background:var(--navy); color:#fff; padding:30px 32px 26px; text-align:center; }
.auth__head .mk{ font-family:var(--serif); font-style:italic; font-size:2rem; color:var(--gold); line-height:1; }
.auth__head h3{ color:#fff; margin-top:8px; font-size:1.7rem; }
.auth__head p{ color:var(--on-navy-soft); font-size:13px; margin:6px 0 0; }
.auth__tabs{ display:flex; border-bottom:1px solid var(--line); }
.auth__tab{ flex:1; background:none; border:none; padding:15px 0; font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--grey); position:relative; }
.auth__tab.is-on{ color:var(--navy); }
.auth__tab.is-on::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background:var(--gold); }
.auth__body{ padding:26px 32px 30px; }
.auth__field{ margin-bottom:14px; }
.auth__field label{ display:block; font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--grey); margin-bottom:6px; }
.auth__hint{ font-size:12px; color:var(--grey); text-align:center; margin:16px 0 0; }
.auth__hint a{ color:var(--gold-deep); font-weight:600; }
.auth__or{ display:flex; align-items:center; gap:12px; color:var(--grey); font-size:11px; letter-spacing:.14em; text-transform:uppercase; margin:18px 0; }
.auth__or::before,.auth__or::after{ content:""; flex:1; height:1px; background:var(--line); }
.auth__social{ display:flex; gap:10px; }
.auth__social button{ flex:1; background:#fff; border:1.4px solid var(--line); border-radius:var(--radius); padding:11px 0; font-size:12.5px; font-weight:500; color:var(--charcoal); transition:border-color .2s; }
.auth__social button:hover{ border-color:var(--navy); }
.modal-form-head{ padding:26px 32px 0; }
.modal-form-head h3{ font-size:1.6rem; }
.modal-form-head p{ color:var(--grey); font-size:13.5px; margin:6px 0 0; }
.modal-form-body{ padding:20px 32px 30px; }
.frow{ display:flex; gap:12px; }
.frow > *{ flex:1; }
