/*
Theme Name: Passaic Shatnez
Theme URI: https://passaicshatnez.com/
Author: Passaic Shatnez
Author URI: https://passaicshatnez.com/
Description: A bespoke one-page theme for Passaic Shatnez, a certified shatnez testing laboratory in Passaic, NJ offering local drop-off and worldwide mail-in. Includes an editable service & pricing catalog, a custom order cart with a mail-in/return-shipping flow, built-in local-business SEO (LocalBusiness, Service & FAQ schema), and a Customizer panel for prices, hours, phone and address. WooCommerce-ready.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: passaic-shatnez
Tags: business, one-page, custom-colors, custom-menu, e-commerce, featured-image-header, full-width-template, rtl-language-support
*/

/* ============================================================
   PASSAIC SHATNEZ — design tokens
   ============================================================ */
:root{
  --ink:#16221E;          /* deep wool green-black */
  --ink-2:#1F302A;        /* lifted ink for dark cards */
  --ink-3:#0F1916;        /* deepest */
  --parchment:#F4EFE4;    /* page background */
  --bone:#FBF8F1;         /* raised light surfaces */
  --linen:#E4DBC9;        /* soft borders / fills */
  --linen-2:#D8CDB6;      /* stronger border */
  --brass:#B5893A;        /* the one accent */
  --brass-deep:#8C682A;
  --brass-hi:#DBB66C;     /* highlight for gradients on dark */
  --ink-soft:#566159;     /* muted text on light */
  --bone-soft:#C9CFC7;    /* muted text on dark */
  --flag:#9B3B2E;         /* "flagged thread" alert color (functional, not brand) */

  --maxw:1180px;
  --radius:14px;
  --radius-lg:22px;
  --shadow:0 1px 2px rgba(22,34,30,.06), 0 18px 40px -24px rgba(22,34,30,.4);
  --shadow-soft:0 1px 2px rgba(22,34,30,.05), 0 10px 30px -22px rgba(22,34,30,.35);

  --ff-display:"Fraunces", Georgia, serif;
  --ff-body:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --ff-heb:"Frank Ruhl Libre", serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} *{animation-duration:.001ms!important;transition-duration:.001ms!important} }
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--parchment);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{font-family:var(--ff-display);font-weight:600;line-height:1.08;margin:0}
p{margin:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--brass);color:#1b1306;border:none;
  padding:.85rem 1.4rem;border-radius:999px;
  font-weight:600;font-size:.98rem;letter-spacing:.005em;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow:0 10px 24px -14px rgba(140,104,42,.9);
}
.btn:hover{background:var(--brass-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.55rem;
  background:transparent;color:var(--ink);
  border:1.5px solid var(--linen-2);
  padding:.8rem 1.3rem;border-radius:999px;font-weight:600;font-size:.98rem;
  transition:border-color .18s ease, background .18s ease, transform .18s ease;
}
.btn-ghost:hover{border-color:var(--brass);background:rgba(181,137,58,.08);transform:translateY(-2px)}
.btn-light{background:var(--brass);color:#1b1306}
.btn-outline-light{border:1.5px solid rgba(228,219,201,.4);color:var(--parchment)}
.btn-outline-light:hover{border-color:var(--brass-hi);background:rgba(219,182,108,.12)}
:focus-visible{outline:3px solid var(--brass);outline-offset:3px;border-radius:4px}

/* ---- eyebrow / section heads ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass-deep);
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--brass);display:inline-block}
.on-dark .eyebrow{color:var(--brass-hi)}
.sec-title{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-.01em;margin-top:.7rem}
.sec-intro{margin-top:1rem;max-width:56ch;color:var(--ink-soft);font-size:1.06rem}
.on-dark .sec-intro{color:var(--bone-soft)}

/* ---- section padding (single source — avoids specificity conflicts) ---- */
.sec{padding:clamp(64px,9vw,108px) 0}

/* ============================================================
   UTILITY BAR
   ============================================================ */
.utility{background:var(--ink-3);color:var(--bone-soft);font-size:.82rem}
.utility .wrap{display:flex;flex-wrap:wrap;gap:.4rem 1.6rem;align-items:center;justify-content:center;padding-top:.55rem;padding-bottom:.55rem}
.utility a{color:var(--bone-soft)}
.utility a:hover{color:var(--brass-hi)}
.u-item{display:inline-flex;align-items:center;gap:.45rem}
.u-item svg{width:14px;height:14px;flex:none;color:var(--brass-hi)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(244,239,228,.86);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--linen);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.7rem;padding-bottom:.7rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand .seal{width:46px;height:46px;flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--ff-display);font-weight:600;font-size:1.22rem;letter-spacing:-.01em}
.brand-sub{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);margin-top:.28rem;font-weight:600}
.nav-links{display:flex;gap:1.5rem;align-items:center}
.nav-links a{font-size:.95rem;font-weight:500;color:var(--ink);position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--brass);transition:width .22s ease}
.nav-links a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:.7rem}
.cart-btn{
  position:relative;display:inline-flex;align-items:center;gap:.5rem;
  background:var(--ink);color:var(--parchment);border:none;
  padding:.6rem .95rem;border-radius:999px;font-weight:600;font-size:.9rem;
  transition:transform .18s ease, background .18s ease;
}
.cart-btn:hover{background:var(--ink-2);transform:translateY(-1px)}
.cart-btn svg{width:18px;height:18px}
.cart-count{
  min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  background:var(--brass);color:#1b1306;font-size:.74rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
}
.menu-toggle{display:none;background:none;border:1.5px solid var(--linen-2);border-radius:10px;width:42px;height:42px;align-items:center;justify-content:center}
.menu-toggle svg{width:20px;height:20px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden}
.hero .wrap{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);
  align-items:center;padding-top:clamp(48px,7vw,92px);padding-bottom:clamp(56px,8vw,100px);
}
.hero-copy{max-width:36rem}
.hero h1{
  font-size:clamp(2.5rem,5.4vw,4.3rem);font-weight:600;letter-spacing:-.02em;margin-top:1.1rem;
}
.hero h1 .accent{font-style:italic;color:var(--brass-deep)}
.heb{font-family:var(--ff-heb);font-weight:700}
.hero p.lede{margin-top:1.3rem;font-size:1.18rem;color:var(--ink-soft);max-width:34ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.6rem 1.6rem;margin-top:2.1rem;padding-top:1.5rem;border-top:1px solid var(--linen)}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--ink)}
.trust-item svg{width:18px;height:18px;color:var(--brass-deep);flex:none}
.hero-art{position:relative}
.hero-art svg{width:100%;height:auto;filter:drop-shadow(0 30px 50px rgba(22,34,30,.22))}

/* ============================================================
   PROOF STRIP
   ============================================================ */
.proof{background:var(--ink);color:var(--parchment)}
.proof .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding-top:2.4rem;padding-bottom:2.4rem}
.proof .stat{padding:0 .4rem}
.proof .stat .n{font-family:var(--ff-display);font-size:clamp(1.7rem,3vw,2.3rem);font-weight:600;color:var(--brass-hi)}
.proof .stat .l{font-size:.86rem;color:var(--bone-soft);margin-top:.35rem;letter-spacing:.01em}
.proof .stat + .stat{border-left:1px solid rgba(228,219,201,.14)}
@media(max-width:780px){ .proof .stat + .stat{border-left:none} }

/* ============================================================
   HOW IT WORKS (steps)
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:3rem}
.step{
  background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);
  padding:1.6rem 1.4rem;position:relative;box-shadow:var(--shadow-soft);
}
.step .num{
  font-family:var(--ff-display);font-size:.9rem;font-weight:700;color:var(--brass-deep);
  letter-spacing:.05em;display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;
}
.step .num .dot{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--brass);display:inline-flex;align-items:center;justify-content:center;color:var(--brass-deep)}
.step h3{font-size:1.18rem;margin-bottom:.5rem}
.step p{font-size:.94rem;color:var(--ink-soft)}
.step .ico{width:26px;height:26px;color:var(--brass-deep);margin-bottom:.9rem}

/* ============================================================
   STORE / PRICING
   ============================================================ */
.store{background:linear-gradient(180deg,var(--parchment),#EFE8D8)}
.store-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.4rem}
.store-note{
  background:var(--bone);border:1px solid var(--linen);border-radius:999px;
  padding:.55rem 1rem;font-size:.85rem;color:var(--ink-soft);display:inline-flex;align-items:center;gap:.5rem;
}
.store-note svg{width:16px;height:16px;color:var(--brass-deep)}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.6rem}
.item{
  background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-soft);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--linen-2)}
.item-media{position:relative;aspect-ratio:1/1;background:#fff;display:flex;align-items:center;justify-content:center;padding:10px}
.item-media img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.item-media .placeholder{width:64%;height:64%;color:var(--linen-2)}
.item-tag{position:absolute;top:12px;left:12px;background:rgba(22,34,30,.9);color:var(--brass-hi);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .6rem;border-radius:999px}
.item-body{padding:1.15rem 1.2rem 1.3rem;display:flex;flex-direction:column;flex:1}
.item-body h3{font-size:1.16rem}
.item-body .desc{font-size:.86rem;color:var(--ink-soft);margin-top:.35rem;flex:1}
.item-foot{display:flex;align-items:center;justify-content:space-between;margin-top:1.1rem;gap:.6rem}
.price{font-family:var(--ff-display);font-size:1.45rem;font-weight:600;color:var(--ink)}
.price .cur{font-size:.9rem;color:var(--ink-soft);vertical-align:.35em;margin-right:1px}
.add-btn{
  display:inline-flex;align-items:center;gap:.4rem;background:var(--ink);color:var(--parchment);
  border:none;border-radius:999px;padding:.55rem .9rem;font-weight:600;font-size:.85rem;
  transition:background .18s ease, transform .18s ease;
}
.add-btn:hover{background:var(--brass);color:#1b1306;transform:translatey(-1px)}
.add-btn svg{width:15px;height:15px}
.add-btn.added{background:var(--brass);color:#1b1306}

/* ============================================================
   LEARN (dark, "what is shatnez")
   ============================================================ */
.learn{background:var(--ink);color:var(--parchment);position:relative;overflow:hidden}
.learn .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,68px);align-items:center}
.learn .panel{}
.learn h2{font-size:clamp(1.9rem,4vw,2.9rem)}
.learn p{margin-top:1.1rem;color:var(--bone-soft);font-size:1.05rem}
.learn .pull{
  margin-top:1.6rem;padding-left:1.3rem;border-left:3px solid var(--brass);
  font-family:var(--ff-display);font-style:italic;font-size:1.3rem;color:var(--parchment);line-height:1.4;
}
.fiber-card{
  background:var(--ink-2);border:1px solid rgba(228,219,201,.16);border-radius:var(--radius-lg);
  padding:1.8rem;
}
.fiber-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem 0}
.fiber-row + .fiber-row{border-top:1px solid rgba(228,219,201,.12)}
.fiber-row .mk{width:42px;height:42px;border-radius:10px;flex:none;display:flex;align-items:center;justify-content:center;background:rgba(181,137,58,.16);color:var(--brass-hi)}
.fiber-row .mk svg{width:22px;height:22px}
.fiber-row h4{margin:0 0 .2rem;font-family:var(--ff-body);font-weight:700;font-size:1rem;color:var(--parchment)}
.fiber-row p{margin:0;font-size:.9rem;color:var(--bone-soft)}

/* ============================================================
   WHY US
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.8rem}
.why-card{background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);padding:1.7rem;box-shadow:var(--shadow-soft)}
.why-card .ic{width:46px;height:46px;border-radius:12px;background:rgba(181,137,58,.13);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.why-card .ic svg{width:24px;height:24px;color:var(--brass-deep)}
.why-card h3{font-size:1.2rem;margin-bottom:.45rem}
.why-card p{font-size:.94rem;color:var(--ink-soft)}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{margin-top:2.4rem;max-width:820px}
details.qa{border-bottom:1px solid var(--linen-2);padding:.4rem 0}
details.qa summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.1rem 0;font-family:var(--ff-display);font-size:1.18rem;font-weight:600;color:var(--ink);
}
details.qa summary::-webkit-details-marker{display:none}
details.qa summary .pm{flex:none;width:30px;height:30px;border:1.5px solid var(--linen-2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .25s ease, border-color .2s ease, background .2s ease}
details.qa[open] summary .pm{transform:rotate(45deg);border-color:var(--brass);background:rgba(181,137,58,.1)}
details.qa summary .pm svg{width:16px;height:16px;color:var(--brass-deep)}
details.qa .ans{padding:0 0 1.3rem;color:var(--ink-soft);font-size:1rem;max-width:70ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:linear-gradient(180deg,#EFE8D8,var(--parchment))}
.contact .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(28px,5vw,56px);align-items:stretch}
.contact-info{display:flex;flex-direction:column}
.info-card{background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-soft)}
.info-card + .info-card{margin-top:1.1rem}
.info-row{display:flex;gap:.95rem;align-items:flex-start}
.info-row .ic{width:40px;height:40px;border-radius:10px;flex:none;background:rgba(181,137,58,.13);display:flex;align-items:center;justify-content:center}
.info-row .ic svg{width:20px;height:20px;color:var(--brass-deep)}
.info-row .label{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--brass-deep);font-weight:600}
.info-row .val{font-size:1.05rem;font-weight:600;margin-top:.15rem}
.info-row .val a:hover{color:var(--brass-deep)}
.hours{list-style:none;margin:.4rem 0 0;padding:0}
.hours li{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.95rem;border-bottom:1px dashed var(--linen)}
.hours li:last-child{border-bottom:none}
.hours li .d{color:var(--ink)}
.hours li .t{color:var(--ink-soft);font-weight:500}
.hours li.closed .t{color:var(--flag);font-weight:600}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--linen);min-height:380px;box-shadow:var(--shadow-soft)}
.map-wrap iframe{width:100%;height:100%;min-height:380px;border:0;display:block;filter:grayscale(.2) contrast(1.02)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink-3);color:var(--bone-soft)}
.site-footer .wrap{padding-top:clamp(48px,7vw,76px);padding-bottom:2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.foot-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.foot-brand .seal{width:44px;height:44px}
.foot-brand .brand-name{color:var(--parchment)}
.foot-about{font-size:.92rem;max-width:38ch;color:var(--bone-soft)}
.foot-heb{font-family:var(--ff-heb);color:var(--brass-hi);font-size:1.15rem;margin-top:1rem}
.foot-col h4{font-family:var(--ff-body);font-weight:700;color:var(--parchment);font-size:.95rem;letter-spacing:.02em;margin:0 0 1rem}
.foot-col a, .foot-col p{display:block;font-size:.92rem;color:var(--bone-soft);padding:.3rem 0}
.foot-col a:hover{color:var(--brass-hi)}
.foot-bottom{border-top:1px solid rgba(228,219,201,.12);margin-top:2.6rem;padding-top:1.4rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;font-size:.82rem;color:#7c857d}
.foot-bottom a:hover{color:var(--brass-hi)}

/* ============================================================
   CART DRAWER
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(15,25,22,.5);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .3s ease, visibility .3s ease;z-index:90}
.overlay.show{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);
  background:var(--parchment);z-index:100;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .34s cubic-bezier(.4,0,.2,1);
  box-shadow:-30px 0 60px -30px rgba(0,0,0,.5);
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1.3rem 1.4rem;border-bottom:1px solid var(--linen)}
.drawer-head h3{font-size:1.3rem}
.drawer-head .close{background:none;border:1.5px solid var(--linen-2);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center}
.drawer-head .close svg{width:18px;height:18px}
.drawer-body{flex:1;overflow-y:auto;padding:1.2rem 1.4rem}
.cart-empty{text-align:center;padding:3rem 1rem;color:var(--ink-soft)}
.cart-empty svg{width:54px;height:54px;color:var(--linen-2);margin:0 auto 1rem}
.cart-line{display:flex;gap:.9rem;padding:1rem 0;border-bottom:1px solid var(--linen)}
.cart-line .thumb{width:58px;height:58px;border-radius:10px;background:#fff;border:1px solid var(--linen);flex:none;display:flex;align-items:center;justify-content:center;padding:5px}
.cart-line .thumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.cart-line .thumb svg{width:60%;height:60%;color:var(--linen-2)}
.cart-line .meta{flex:1;min-width:0}
.cart-line .meta h4{margin:0;font-family:var(--ff-body);font-weight:700;font-size:.96rem}
.cart-line .meta .lp{font-size:.85rem;color:var(--ink-soft);margin-top:.1rem}
.qty{display:inline-flex;align-items:center;gap:.2rem;margin-top:.5rem;border:1px solid var(--linen-2);border-radius:999px;padding:.1rem}
.qty button{width:26px;height:26px;border:none;background:none;border-radius:50%;font-size:1.1rem;line-height:1;color:var(--ink);display:flex;align-items:center;justify-content:center}
.qty button:hover{background:var(--linen)}
.qty span{min-width:24px;text-align:center;font-weight:600;font-size:.9rem}
.line-remove{background:none;border:none;color:var(--ink-soft);font-size:.8rem;margin-top:.5rem;padding:0;text-decoration:underline;text-underline-offset:2px}
.line-remove:hover{color:var(--flag)}
.line-total{font-family:var(--ff-display);font-weight:600;font-size:1.05rem;white-space:nowrap}

.ship-toggle{margin-top:1.3rem;background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);padding:1rem 1.1rem}
.ship-toggle label.cb{display:flex;gap:.7rem;align-items:flex-start;cursor:pointer;font-size:.9rem}
.ship-toggle input{margin-top:.2rem;width:18px;height:18px;accent-color:var(--brass-deep);flex:none}
.ship-toggle .st-title{font-weight:700;color:var(--ink)}
.ship-toggle .st-sub{color:var(--ink-soft);font-size:.84rem;margin-top:.15rem}
.ship-toggle .intl{font-size:.8rem;color:var(--ink-soft);margin-top:.7rem;padding-top:.7rem;border-top:1px dashed var(--linen)}

.drawer-foot{border-top:1px solid var(--linen);padding:1.2rem 1.4rem;background:var(--bone)}
.sumline{display:flex;justify-content:space-between;font-size:.92rem;color:var(--ink-soft);padding:.2rem 0}
.sumline.total{font-size:1.25rem;font-weight:700;color:var(--ink);font-family:var(--ff-display);padding-top:.6rem;margin-top:.4rem;border-top:1px solid var(--linen)}
.drawer-foot .btn{width:100%;justify-content:center;margin-top:.9rem}
.drawer-foot .fineprint{font-size:.76rem;color:var(--ink-soft);text-align:center;margin-top:.7rem}

/* ============================================================
   CHECKOUT MODAL
   ============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(15,25,22,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:120;padding:1.2rem}
.modal-overlay.show{display:flex}
.modal{background:var(--parchment);border-radius:var(--radius-lg);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 40px 80px -30px rgba(0,0,0,.5)}
.modal-head{padding:1.6rem 1.7rem 1rem;border-bottom:1px solid var(--linen);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.modal-head h3{font-size:1.5rem}
.modal-head p{font-size:.9rem;color:var(--ink-soft);margin-top:.3rem}
.modal-head .close{background:none;border:1.5px solid var(--linen-2);border-radius:50%;width:36px;height:36px;flex:none;display:flex;align-items:center;justify-content:center}
.modal-body{padding:1.4rem 1.7rem 1.7rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.35rem}
.field input, .field select, .field textarea{
  width:100%;padding:.7rem .85rem;border:1.5px solid var(--linen-2);border-radius:10px;
  background:var(--bone);font-family:inherit;font-size:.95rem;color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-color:var(--brass)}
.modal-order{background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);padding:1rem 1.1rem;margin-bottom:1.2rem}
.modal-order .ol{display:flex;justify-content:space-between;font-size:.9rem;padding:.25rem 0;color:var(--ink-soft)}
.modal-order .ol.tt{font-weight:700;color:var(--ink);border-top:1px solid var(--linen);margin-top:.4rem;padding-top:.5rem}
.modal-note{font-size:.84rem;color:var(--ink-soft);background:rgba(181,137,58,.1);border:1px solid rgba(181,137,58,.25);border-radius:10px;padding:.8rem 1rem;margin-top:1rem;display:flex;gap:.6rem}
.modal-note svg{width:18px;height:18px;color:var(--brass-deep);flex:none;margin-top:1px}
.modal .btn{width:100%;justify-content:center;margin-top:.4rem}

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

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .nav-links{display:none}
  .menu-toggle{display:flex}
  .hero .wrap{grid-template-columns:1fr;text-align:left}
  .hero-art{order:-1;max-width:440px}
  .learn .wrap{grid-template-columns:1fr}
  .contact .wrap{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr}
  .proof .wrap{grid-template-columns:repeat(2,1fr);gap:1.6rem}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:560px){
  .menu-grid{grid-template-columns:1fr 1fr;gap:.8rem}
  .item-body{padding:.9rem .9rem 1rem}
  .item-body h3{font-size:1rem}
  .item-foot{flex-direction:column;align-items:flex-start;gap:.5rem}
  .add-btn{width:100%;justify-content:center}
  .steps{grid-template-columns:1fr}
  .brand-sub{display:none}
  .utility{font-size:.74rem}
  .hero h1{font-size:clamp(2.1rem,9vw,2.8rem)}
}

/* mobile nav panel */
.mobile-nav{position:fixed;inset:0 0 0 auto;width:min(320px,84vw);background:var(--parchment);z-index:110;transform:translateX(100%);transition:transform .3s ease;box-shadow:-20px 0 50px -25px rgba(0,0,0,.5);padding:1.4rem;display:flex;flex-direction:column;gap:.3rem}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav .mclose{align-self:flex-end;background:none;border:1.5px solid var(--linen-2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.mobile-nav a{padding:.85rem .4rem;font-size:1.1rem;font-weight:500;border-bottom:1px solid var(--linen)}
.mobile-nav .btn{margin-top:1.2rem;justify-content:center}

/* ============================================================
   SHIPPING & PAYMENT — US vs International compare
   ============================================================ */
.ship-compare{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.6rem}
.ship-col{background:var(--bone);border:1px solid var(--linen);border-radius:var(--radius);padding:1.6rem 1.7rem;box-shadow:var(--shadow-soft)}
.ship-flag{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--ff-display);font-weight:600;font-size:1.25rem;color:var(--ink);margin-bottom:.6rem}
.ship-flag svg{width:24px;height:24px;color:var(--brass-deep);flex:none}
.ship-col p{color:var(--ink-soft);font-size:.98rem;margin:0}
@media(max-width:780px){.ship-compare{grid-template-columns:1fr}}
