/* ============================================================
   RED AVENUE BOUTIQUE — brand stylesheet
   Editorial minimalism · Avenue Red signature · Cormorant + Montserrat
   ============================================================ */

:root{
  --ink:#0E0E10;
  --ink-soft:#17171B;
  --cream:#FAF7F2;
  --cream-2:#F3EEE5;
  --char:#1A1A1A;
  --muted:#6F6A62;
  --muted-light:#9A958C;
  --line:#E6DFD4;
  --line-dark:#2A2A2E;
  --red:#C1121F;
  --red-deep:#9E0E18;
  --gold:#C8A86B;
  --white:#ffffff;

  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --container:1240px;
  --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --h-eyebrow:.72rem;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--char);
  font-size:16px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--red);outline-offset:3px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.04;color:var(--ink);letter-spacing:.005em}
.display{font-size:clamp(2.8rem,8vw,6rem);font-weight:500;letter-spacing:-.01em}
.h-xl{font-size:clamp(2.1rem,5vw,3.6rem)}
.h-lg{font-size:clamp(1.7rem,3.5vw,2.6rem)}
p{color:var(--char)}
.lede{font-size:1.12rem;color:var(--muted);line-height:1.7}

.eyebrow{
  font-family:var(--sans);
  font-size:var(--h-eyebrow);
  font-weight:600;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--red);
  display:inline-block;
}
.eyebrow.muted{color:var(--muted)}

/* small red signature rule */
.rule-red{width:34px;height:2px;background:var(--red);border:0;display:inline-block}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:22px}
.section{padding-block:clamp(56px,9vw,108px)}
.section-tight{padding-block:clamp(40px,6vw,72px)}
.section--ink{background:var(--ink);color:var(--cream)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--cream)}
.section--ink p{color:#C9C4BB}
.section--cream2{background:var(--cream-2)}

.section-head{margin-bottom:clamp(32px,5vw,56px)}
.section-head .eyebrow{margin-bottom:14px}
.section-head .h-lg{max-width:18ch}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  transition:background .35s var(--ease),padding .35s var(--ease),border-color .35s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.solid{background:rgba(250,247,242,.92);backdrop-filter:blur(12px);border-bottom-color:var(--line);padding-block:13px}
.site-header.on-dark:not(.solid){color:var(--cream)}
.site-header.on-dark:not(.solid) .logo-word,
.site-header.on-dark:not(.solid) .nav-link,
.site-header.on-dark:not(.solid) .icon-btn{color:var(--cream)}

.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:38px;height:38px;flex:none;color:var(--ink)}
.site-header.on-dark:not(.solid) .brand .mark{color:var(--cream)}
.logo-word{display:flex;flex-direction:column;line-height:1}
.logo-word .lw-main{font-family:var(--serif);font-weight:600;font-size:1.42rem;letter-spacing:.02em;color:var(--ink)}
.logo-word .lw-sub{font-family:var(--sans);font-size:.52rem;font-weight:600;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-top:3px}

.nav{display:none;align-items:center;gap:34px}
.nav-link{font-size:.78rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--char);position:relative;padding-block:4px}
.nav-link::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--red);transition:width .3s var(--ease)}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{width:100%}

.header-actions{display:flex;align-items:center;gap:8px}
.icon-btn{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;color:var(--char);transition:background .25s}
.icon-btn:hover{background:rgba(0,0,0,.06)}
.site-header.on-dark:not(.solid) .icon-btn:hover{background:rgba(255,255,255,.12)}
.icon-btn svg{width:21px;height:21px;stroke:currentColor;stroke-width:1.6;fill:none}
.cart-btn{position:relative}
.cart-count{
  position:absolute;top:5px;right:4px;min-width:17px;height:17px;padding:0 4px;
  background:var(--red);color:#fff;border-radius:9px;
  font-family:var(--sans);font-size:.6rem;font-weight:700;line-height:17px;text-align:center;
  transform:scale(0);transition:transform .25s var(--ease)
}
.cart-count.show{transform:scale(1)}
.menu-btn{display:grid}
@media(min-width:960px){.nav{display:flex}.menu-btn{display:none}}

/* ---------- Mobile menu ---------- */
.mobile-menu{
  position:fixed;inset:0;z-index:300;background:var(--ink);color:var(--cream);
  transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;padding:24px 26px;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}
.mobile-menu-top .lw-main{color:var(--cream);font-family:var(--serif);font-size:1.4rem}
.mobile-menu .icon-btn{color:var(--cream)}
.mobile-nav{display:flex;flex-direction:column;gap:6px}
.mobile-nav a{font-family:var(--serif);font-size:2rem;color:var(--cream);padding-block:8px;display:flex;align-items:baseline;gap:14px}
.mobile-nav a .idx{font-family:var(--sans);font-size:.7rem;color:var(--gold);letter-spacing:.1em}
.mobile-menu-foot{margin-top:auto;border-top:1px solid var(--line-dark);padding-top:22px;font-size:.82rem;color:#C9C4BB}
.mobile-menu-foot a{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-size:.76rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  padding:16px 32px;border-radius:var(--radius);transition:.3s var(--ease);cursor:pointer;
  border:1.5px solid transparent;
}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-deep)}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{background:#000}
.btn-outline{border-color:var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-outline-light{border-color:rgba(250,247,242,.5);color:var(--cream)}
.btn-outline-light:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-block{display:flex;width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn .spin{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.loading .spin{display:inline-block}
.btn.loading .btn-label{opacity:.7}
@keyframes spin{to{transform:rotate(360deg)}}

.link-arrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:.76rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);padding-bottom:4px;border-bottom:1.5px solid var(--ink);transition:.3s}
.link-arrow:hover{color:var(--red);border-color:var(--red);gap:14px}
.section--ink .link-arrow{color:var(--cream);border-color:var(--cream)}
.section--ink .link-arrow:hover{color:var(--gold);border-color:var(--gold)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,14,16,.32) 0%,rgba(14,14,16,.18) 38%,rgba(14,14,16,.86) 100%)}
.hero-inner{position:relative;z-index:1;width:100%;padding-bottom:clamp(54px,9vw,96px);padding-top:140px}
.hero .eyebrow{color:var(--gold);margin-bottom:20px}
.hero .display{color:var(--cream);max-width:14ch}
.hero .display em{font-style:italic;color:var(--gold)}
.hero-sub{margin:22px 0 34px;max-width:46ch;color:#E7E2D9;font-size:1.08rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-scroll{position:absolute;left:22px;bottom:26px;z-index:1;display:none;align-items:center;gap:12px;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:#E7E2D9}
.hero-scroll .ln{width:46px;height:1px;background:var(--gold)}
@media(min-width:960px){.hero-scroll{display:flex}}

/* address-plate motif tag */
.plate{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--gold);padding:9px 16px;border-radius:var(--radius)}
.plate .bar{width:3px;height:15px;background:var(--red)}
.plate span{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}

/* ---------- Marquee strip ---------- */
.strip{background:var(--ink);color:var(--cream);overflow:hidden;border-block:1px solid var(--line-dark)}
.strip-track{display:flex;gap:48px;padding-block:15px;white-space:nowrap;animation:slide 32s linear infinite;width:max-content}
.strip-track span{font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#C9C4BB;display:inline-flex;align-items:center;gap:48px}
.strip-track span::after{content:"◆";color:var(--red);font-size:.55rem}
@keyframes slide{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.strip-track{animation:none}}

/* ---------- Product grid / cards ---------- */
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 14px}
@media(min-width:680px){.product-grid{gap:30px 26px}}
@media(min-width:960px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1180px){.product-grid.cols-4{grid-template-columns:repeat(4,1fr)}}

.card{position:relative;display:flex;flex-direction:column}
.card-media{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--cream-2);border-radius:var(--radius)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.card:hover .card-media img{transform:scale(1.05)}
.card-badge{position:absolute;top:12px;left:12px;z-index:2;background:var(--ink);color:var(--cream);font-family:var(--sans);font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:6px 11px;border-radius:var(--radius)}
.card-badge.red{background:var(--red)}
.card-quick{
  position:absolute;left:12px;right:12px;bottom:12px;z-index:2;
  background:var(--cream);color:var(--ink);
  font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  text-align:center;padding:13px;border-radius:var(--radius);
  opacity:0;transform:translateY(8px);transition:.35s var(--ease)
}
.card-quick:hover{background:var(--red);color:#fff}
@media(hover:hover){.card:hover .card-quick{opacity:1;transform:translateY(0)}}
.card-body{padding-top:15px}
.card-cat{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-light);margin-bottom:6px}
.card-name{font-family:var(--serif);font-size:1.32rem;font-weight:600;color:var(--ink);line-height:1.12}
.card-price{margin-top:7px;font-family:var(--sans);font-size:.92rem;font-weight:500;color:var(--char);display:flex;align-items:baseline;gap:9px}
.card-price .was{color:var(--muted-light);text-decoration:line-through;font-size:.84rem}
.card-price .now-sale{color:var(--red)}

/* ---------- Split feature ---------- */
.split{display:grid;gap:0;align-items:stretch}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}}
.split-media{aspect-ratio:4/5;min-height:340px;overflow:hidden}
.split-media img{width:100%;height:100%;object-fit:cover}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(36px,6vw,76px)}
.split--ink{background:var(--ink);color:var(--cream)}
.split--ink h2{color:var(--cream)}
.split--ink p{color:#C9C4BB}

/* ---------- Editorial trio ---------- */
.trio{display:grid;gap:26px;grid-template-columns:1fr}
@media(min-width:780px){.trio{grid-template-columns:repeat(3,1fr)}}
.trio-item .num{font-family:var(--serif);font-size:1.5rem;color:var(--red);font-style:italic}
.trio-item h3{font-size:1.4rem;margin:10px 0 8px}
.trio-item p{color:var(--muted);font-size:.96rem}
.trio-item .ln{width:100%;height:1px;background:var(--line);margin-bottom:18px}
.section--ink .trio-item .ln{background:var(--line-dark)}
.section--ink .trio-item p{color:#C9C4BB}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#C9C4BB;padding-top:clamp(56px,8vw,88px)}
.footer-grid{display:grid;gap:42px;grid-template-columns:1fr}
@media(min-width:760px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.4fr}}
.footer-brand .lw-main{font-family:var(--serif);color:var(--cream);font-size:1.7rem}
.footer-brand .lw-sub{font-size:.56rem;letter-spacing:.42em;color:var(--gold);text-transform:uppercase;display:block;margin-top:4px}
.footer-brand p{margin-top:18px;max-width:34ch;font-size:.92rem;line-height:1.7}
.footer-col h4{font-family:var(--sans);color:var(--cream);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer-col a,.footer-col li{font-size:.92rem;padding-block:6px;display:block;transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;color:#C9C4BB}
.footer-contact svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:1.6;flex:none;margin-top:4px}
.newsletter{margin-top:18px;display:flex;border:1px solid var(--line-dark);border-radius:var(--radius);overflow:hidden}
.newsletter input{flex:1;background:transparent;border:none;color:var(--cream);padding:13px 14px;font-family:var(--sans);font-size:.85rem}
.newsletter input::placeholder{color:#8B867E}
.newsletter input:focus{outline:none}
.newsletter button{background:var(--red);color:#fff;padding-inline:18px;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.newsletter button:hover{background:var(--red-deep)}
.footer-bottom{margin-top:clamp(44px,6vw,68px);border-top:1px solid var(--line-dark);padding-block:24px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:.78rem}
.footer-bottom .pays{display:flex;gap:8px;align-items:center;color:#8B867E;letter-spacing:.12em;text-transform:uppercase;font-size:.66rem}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--ink);color:var(--cream);padding-top:130px;padding-bottom:clamp(40px,6vw,64px)}
.page-hero .eyebrow{color:var(--gold)}
.page-hero h1{color:var(--cream);margin-top:14px}
.page-hero p{color:#C9C4BB;max-width:54ch;margin-top:14px}
.crumbs{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#8B867E;margin-bottom:20px}
.crumbs a:hover{color:var(--gold)}
.crumbs span{color:var(--gold)}

/* ---------- Shop toolbar ---------- */
.shop-bar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:34px}
.filters{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:9px 17px;border:1px solid var(--line);border-radius:40px;color:var(--char);transition:.25s;background:var(--cream)}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.shop-count{font-size:.78rem;color:var(--muted);letter-spacing:.06em}
.sort-sel{font-family:var(--sans);font-size:.78rem;border:1px solid var(--line);background:var(--cream);padding:10px 14px;border-radius:var(--radius);color:var(--char)}

/* ---------- Product detail ---------- */
.pdp{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:900px){.pdp{grid-template-columns:1.05fr 1fr;gap:56px;align-items:start}}
.pdp-gallery{display:flex;flex-direction:column;gap:12px}
.pdp-main{aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius);background:var(--cream-2)}
.pdp-main img{width:100%;height:100%;object-fit:cover}
.pdp-thumbs{display:flex;gap:10px}
.pdp-thumbs button{width:74px;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1.5px solid transparent;opacity:.7;transition:.2s}
.pdp-thumbs button.active{border-color:var(--ink);opacity:1}
.pdp-thumbs img{width:100%;height:100%;object-fit:cover}
.pdp-info{position:sticky;top:96px}
@media(max-width:899px){.pdp-info{position:static}}
.pdp-cat{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-light)}
.pdp-title{font-size:clamp(2rem,5vw,3rem);margin:10px 0 14px;line-height:1.02}
.pdp-price{display:flex;align-items:baseline;gap:12px;font-family:var(--sans);font-size:1.4rem;font-weight:500;color:var(--ink)}
.pdp-price .was{color:var(--muted-light);text-decoration:line-through;font-size:1.05rem}
.pdp-price .now-sale{color:var(--red)}
.pdp-desc{margin:22px 0;color:var(--muted);line-height:1.8}
.pdp-divider{height:1px;background:var(--line);margin:26px 0}
.opt-label{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:12px;display:flex;justify-content:space-between}
.size-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.size-btn{min-width:50px;height:46px;padding:0 14px;border:1.5px solid var(--line);border-radius:var(--radius);font-family:var(--sans);font-size:.82rem;font-weight:500;background:var(--cream);transition:.2s}
.size-btn:hover{border-color:var(--ink)}
.size-btn.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.qty-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.qty{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:var(--radius)}
.qty button{width:44px;height:46px;font-size:1.1rem;color:var(--ink)}
.qty input{width:44px;height:46px;text-align:center;border:none;background:transparent;font-family:var(--sans);font-size:.95rem;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pdp-meta{margin-top:26px;display:flex;flex-direction:column;gap:10px;font-size:.85rem;color:var(--muted)}
.pdp-meta div{display:flex;gap:10px;align-items:center}
.pdp-meta svg{width:17px;height:17px;stroke:var(--red);fill:none;stroke-width:1.5;flex:none}
.pdp-accordion{border-top:1px solid var(--line);margin-top:26px}
.acc-item{border-bottom:1px solid var(--line)}
.acc-head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-align:left}
.acc-head .pm{color:var(--red);font-size:1.3rem;font-family:var(--serif)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.acc-body-inner{padding-bottom:20px;color:var(--muted);font-size:.92rem;line-height:1.75}

/* ---------- Cart drawer ---------- */
.overlay{position:fixed;inset:0;z-index:400;background:rgba(14,14,16,.55);opacity:0;visibility:hidden;transition:.35s}
.overlay.open{opacity:1;visibility:visible}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:500;width:min(440px,100%);
  background:var(--cream);display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.18)
}
.cart-drawer.open{transform:translateX(0)}
.cart-top{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--line)}
.cart-top h3{font-size:1.5rem}
.cart-items{flex:1;overflow-y:auto;padding:8px 24px}
.cart-line{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--line)}
.cart-line img{width:78px;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius);flex:none}
.cart-line-info{flex:1;min-width:0}
.cart-line-info .nm{font-family:var(--serif);font-size:1.12rem;color:var(--ink);line-height:1.1}
.cart-line-info .vr{font-size:.74rem;color:var(--muted);margin-top:3px;letter-spacing:.04em}
.cart-line-info .pr{font-size:.86rem;margin-top:6px;font-weight:500}
.cart-line-actions{display:flex;justify-content:space-between;align-items:center;margin-top:9px}
.cart-line .miniqty{display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--radius)}
.cart-line .miniqty button{width:30px;height:30px;font-size:1rem}
.cart-line .miniqty span{width:30px;text-align:center;font-size:.82rem}
.cart-line .rm{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid transparent}
.cart-line .rm:hover{color:var(--red);border-color:var(--red)}
.cart-empty{padding:60px 24px;text-align:center;color:var(--muted)}
.cart-empty svg{width:46px;height:46px;stroke:var(--line);fill:none;stroke-width:1.3;margin:0 auto 18px}
.cart-foot{border-top:1px solid var(--line);padding:22px 24px}
.cart-subtotal{display:flex;justify-content:space-between;font-size:.95rem;margin-bottom:6px}
.cart-subtotal .amt{font-weight:600;font-size:1.15rem;font-family:var(--sans)}
.cart-note{font-size:.74rem;color:var(--muted);margin-bottom:16px}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--char);margin-bottom:7px}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 15px;border:1.5px solid var(--line);border-radius:var(--radius);
  font-family:var(--sans);font-size:.95rem;background:var(--white);color:var(--char);transition:border-color .2s
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field input.err,.field select.err{border-color:var(--red)}
.field input:disabled{background:var(--cream-2);color:var(--muted)}
.field-row{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:560px){.field-row.two{grid-template-columns:1fr 1fr}}
.field-msg{font-size:.74rem;color:var(--red);margin-top:6px;display:none}
.field-msg.show{display:block}

/* ---------- Checkout ---------- */
.checkout-grid{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:920px){.checkout-grid{grid-template-columns:1.3fr .9fr;gap:54px;align-items:start}}
.co-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,32px);margin-bottom:24px}
.co-card h2{font-size:1.5rem;margin-bottom:6px}
.co-card .sub{color:var(--muted);font-size:.9rem;margin-bottom:22px}
.summary{position:sticky;top:96px}
@media(max-width:919px){.summary{position:static}}
.summary-line{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.summary-line img{width:62px;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius)}
.summary-line .nm{font-family:var(--serif);font-size:1.05rem;color:var(--ink);line-height:1.1}
.summary-line .vr{font-size:.72rem;color:var(--muted);margin-top:2px}
.summary-line .pr{margin-left:auto;font-size:.86rem;font-weight:500;white-space:nowrap}
.summary-tot{display:flex;justify-content:space-between;padding-top:14px;font-size:.9rem;color:var(--muted)}
.summary-tot.grand{font-size:1.2rem;color:var(--ink);font-weight:600;font-family:var(--sans);border-top:1px solid var(--line);margin-top:8px;padding-top:16px}
.vezmo-embed{margin-top:18px;min-height:320px;border:1px solid var(--line-dark);border-radius:var(--radius);background:#0B0B0E;overflow:hidden}
.vezmo-embed iframe{display:block;width:100%;border:0}
.vezmo-edit{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.84rem;color:var(--muted);padding-top:14px}
.vezmo-edit strong{color:var(--ink)}
.vezmo-edit button{color:var(--red);font-size:.78rem;font-weight:500;text-decoration:underline}
.secure-note{display:flex;align-items:center;gap:9px;margin-top:16px;font-size:.78rem;color:var(--muted)}
.secure-note svg{width:16px;height:16px;stroke:var(--red);fill:none;stroke-width:1.6;flex:none}

/* ---------- Status page ---------- */
.status-wrap{max-width:560px;margin-inline:auto;text-align:center;padding-block:clamp(60px,10vw,110px)}
.status-icon{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 26px}
.status-icon svg{width:40px;height:40px;stroke-width:1.8;fill:none}
.status-icon.ok{background:rgba(193,18,31,.08)}
.status-icon.ok svg{stroke:var(--red)}
.status-icon.pend{background:#F3EEE5}
.status-icon.pend svg{stroke:var(--gold)}
.status-icon.fail{background:#F3EEE5}
.status-icon.fail svg{stroke:var(--char)}
.status-wrap h1{font-size:clamp(2rem,5vw,2.8rem);margin-bottom:14px}
.status-wrap p{color:var(--muted);margin-bottom:28px}
.status-box{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:left;margin-bottom:28px}
.status-box .row{display:flex;justify-content:space-between;padding:9px 0;font-size:.9rem}
.status-box .row .k{color:var(--muted)}
.status-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,140%);z-index:600;background:var(--ink);color:var(--cream);padding:15px 24px;border-radius:var(--radius);font-size:.86rem;letter-spacing:.02em;box-shadow:0 14px 40px rgba(0,0,0,.3);transition:transform .4s var(--ease);max-width:90vw;display:flex;align-items:center;gap:12px}
.toast.show{transform:translate(-50%,0)}
.toast .dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex:none}

/* ---------- Misc ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}
.center{text-align:center}
.mt-cta{margin-top:38px}
.prose p{margin-bottom:16px;color:var(--muted);line-height:1.85}
.prose h2{font-size:1.7rem;margin:34px 0 12px}
.prose h3{font-size:1.25rem;margin:24px 0 8px}
.prose ul{list-style:disc;padding-left:22px;margin-bottom:16px;color:var(--muted)}
.prose ul li{padding-block:4px}
.prose a{color:var(--red);border-bottom:1px solid var(--red)}
.legal-meta{font-size:.82rem;color:var(--muted-light);margin-bottom:30px;letter-spacing:.04em}
.noscript-note{background:var(--red);color:#fff;text-align:center;padding:10px;font-size:.85rem}
