/* ════════════════════════════════════════════════════════════
   EXTREME CNC TOOLS — Shared site stylesheet
   One file. Brand tokens, type system, responsive layout.
═══════════════════════════════════════════════════════════════ */

:root {
  --bone:#f5f1ea; --paper:#faf7f0; --ink:#1a1a1a; --graphite:#4a4a4a;
  --steel:#8a8580; --rule:#d4cec2; --rule-soft:#e8e3d6;
  --signal:#c63623; --signal-deep:#a32815; --moss:#3d5a3c;
  --copper:#b8762d; --sky:#5a7a8a;
  --display:'Saira','Helvetica Neue',system-ui,sans-serif;
  --sans:'Saira',system-ui,sans-serif;
  --mono:'IBM Plex Mono','Courier New',monospace;
}

*,*::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(--bone);color:var(--ink);
     line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;color:inherit}

/* ── HEADER ─────────────────────────────────────────────── */
.hdr{background:var(--bone);border-bottom:1px solid var(--rule);
     position:sticky;top:0;z-index:200}
.hdr-inner{max-width:1320px;margin:0 auto;padding:12px 40px;
           display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav{display:flex;gap:clamp(18px,2.4vw,44px);align-items:center}
.nav a{font-weight:600;font-size:clamp(13px,1.15vw,19px);letter-spacing:.06em;
       text-transform:uppercase;color:var(--graphite);transition:color .2s;
       white-space:nowrap;padding:8px 0}
.nav a:hover,.nav a[aria-current="page"]{color:var(--signal)}
.logo-wrap{display:flex;align-items:center;justify-content:center}
.logo-img{height:76px;width:auto;max-width:100%;mix-blend-mode:multiply;object-fit:contain}
.cart-btn{background:var(--ink);color:var(--bone);font-family:var(--sans);
          font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
          padding:10px 18px;border:none;display:inline-flex;align-items:center;gap:6px;
          transition:background .2s}
.cart-btn:hover{background:var(--signal)}
.cart-count{background:var(--signal);color:#fff;padding:2px 7px;font-size:11px;
            border-radius:10px;min-width:20px;text-align:center}

/* Hamburger + Drawer */
.hamburger{display:none;flex-direction:column;gap:5px;background:transparent;
           border:none;padding:10px;cursor:pointer}
.hamburger span{display:block;width:24px;height:2.5px;background:var(--ink);
                transition:all .25s}
.drawer{position:fixed;inset:0;z-index:600;pointer-events:none}
.drawer-open{pointer-events:auto}
.drawer-bg{position:absolute;inset:0;background:rgba(26,26,26,0);transition:background .3s}
.drawer-open .drawer-bg{background:rgba(26,26,26,.6)}
.drawer-panel{position:absolute;top:0;left:0;bottom:0;width:min(86vw,360px);
              background:var(--bone);display:flex;flex-direction:column;
              transform:translateX(-100%);transition:transform .3s ease-out;
              box-shadow:4px 0 24px rgba(0,0,0,.1)}
.drawer-open .drawer-panel{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;
             padding:18px 22px;border-bottom:1px solid var(--rule);
             background:var(--ink);color:var(--bone)}
.drawer-title{font-weight:900;font-style:italic;font-size:16px;
              letter-spacing:-.01em;text-transform:uppercase}
.drawer-close{background:transparent;color:var(--bone);border:none;
              font-size:20px;cursor:pointer;padding:4px 10px;line-height:1}
.drawer-nav{display:flex;flex-direction:column;padding:14px 0;flex:1}
.drawer-nav a{display:block;padding:18px 22px;font-weight:700;font-size:17px;
              letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
              border-bottom:1px solid var(--rule);transition:background .15s,color .15s}
.drawer-nav a:hover,.drawer-nav a[aria-current="page"]{background:var(--paper);color:var(--signal)}
.drawer-foot{padding:18px 22px;border-top:1px solid var(--rule)}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;
         text-transform:uppercase;color:var(--signal);display:block;margin-bottom:20px}
.h1{font-weight:900;font-style:italic;font-size:clamp(44px,6vw,88px);
    line-height:.93;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:28px}
.h2{font-weight:900;font-style:italic;font-size:clamp(34px,4.4vw,56px);
    line-height:.95;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:24px}
.h3{font-weight:800;font-style:italic;font-size:clamp(22px,2.4vw,28px);
    line-height:1.05;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:14px}
.lead{font-size:17px;line-height:1.65;color:var(--graphite);max-width:640px}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-block;font-family:var(--sans);font-weight:700;font-size:13px;
     letter-spacing:.08em;text-transform:uppercase;padding:16px 28px;border:none;
     cursor:pointer;text-align:center;transition:all .2s}
.btn-primary{background:var(--ink);color:var(--bone)}
.btn-primary:hover{background:var(--signal)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink);padding:14.5px 26.5px}
.btn-outline:hover{border-color:var(--signal);color:var(--signal)}
.btn-signal{background:var(--signal);color:#fff}
.btn-signal:hover{background:var(--signal-deep)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{max-width:1320px;margin:0 auto;padding:0 40px}
.section{padding:96px 0}
.section-tight{padding:64px 0}
.bg-paper{background:var(--paper)}
.bg-ink{background:var(--ink);color:var(--bone)}
.bg-ink .h1,.bg-ink .h2,.bg-ink .h3{color:var(--bone)}
.bg-ink .lead{color:rgba(245,241,234,.78)}

/* ── HERO ───────────────────────────────────────────────── */
.hero{max-width:1320px;margin:0 auto;padding:80px 40px;
      display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
      min-height:78vh}
.hero-stats{display:flex;gap:36px;padding-top:32px;margin-top:24px;
            border-top:1px solid var(--rule);flex-wrap:wrap}
.stat-num{font-weight:800;font-style:italic;font-size:34px;line-height:1;
          letter-spacing:-.02em}
.stat-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;
            text-transform:uppercase;color:var(--steel);margin-top:5px}
.hero-cards{position:relative;min-height:480px}
.hero-card{position:absolute;background:var(--paper);border:1px solid var(--rule);
           box-shadow:0 10px 36px rgba(0,0,0,.07);overflow:hidden;width:48%}
.hero-card-1{top:0;left:0;transform:rotate(-3deg)}
.hero-card-2{top:30%;right:0;transform:rotate(4deg)}
.hero-card-3{bottom:0;left:18%;transform:rotate(-1deg)}
.hero-card img{width:100%;height:170px;object-fit:cover;background:var(--bone)}
.hero-card-body{padding:18px 16px}
.hero-card-name{font-weight:800;font-style:italic;font-size:18px;letter-spacing:-.01em;
                text-transform:uppercase;line-height:1.05;margin-bottom:6px}
.hero-card-sku{font-family:var(--mono);font-size:10px;color:var(--steel);
               letter-spacing:.1em;margin-bottom:4px}
.hero-card-desc{font-size:13px;color:var(--graphite)}

/* ── PRODUCT GRID ───────────────────────────────────────── */
.section-head{display:flex;justify-content:space-between;align-items:flex-end;
              gap:32px;margin-bottom:48px;flex-wrap:wrap}
.filters{display:flex;flex-wrap:wrap;gap:6px}
.filter-btn{background:transparent;color:var(--graphite);font-family:var(--sans);
            font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
            padding:9px 14px;border:1px solid var(--rule);transition:all .15s}
.filter-btn:hover{border-color:var(--ink);color:var(--ink)}
.filter-btn.active{background:var(--ink);color:var(--bone);border-color:var(--ink)}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.product-card{background:#fff;border:1px solid var(--rule);
              display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;
              text-decoration:none;color:inherit}
.product-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(0,0,0,.08)}
.product-img-wrap{aspect-ratio:1/1;background:var(--bone);overflow:hidden;
                  display:flex;align-items:center;justify-content:center}
.product-img{width:100%;height:100%;object-fit:cover}
.product-meta{padding:18px 18px 12px;flex:1;display:flex;flex-direction:column;gap:6px}
.product-cat{font-family:var(--mono);font-size:9px;letter-spacing:.16em;
             text-transform:uppercase;color:var(--moss)}
.product-name{font-weight:800;font-style:italic;font-size:19px;line-height:1.05;
              letter-spacing:-.01em;text-transform:uppercase;margin:2px 0 4px}
.product-sku{font-family:var(--mono);font-size:10px;letter-spacing:.1em;
             color:var(--steel)}
.product-price{font-family:var(--mono);font-size:17px;font-weight:600;
               color:var(--ink);margin-top:auto;padding-top:8px}
.badge{display:inline-block;font-family:var(--mono);font-size:9px;letter-spacing:.14em;
       text-transform:uppercase;padding:3px 8px;color:#fff;background:var(--signal);
       align-self:flex-start;margin-bottom:4px}
.badge-moss{background:var(--moss)}
.badge-copper{background:var(--copper)}
.add-btn{background:var(--ink);color:var(--bone);font-family:var(--sans);
         font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
         padding:13px 16px;border:none;width:100%;transition:background .15s}
.add-btn:hover{background:var(--signal)}

/* ── PRODUCT DETAIL ─────────────────────────────────────── */
.pd-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;
         padding:48px 40px 80px;max-width:1320px;margin:0 auto;align-items:start}
.pd-img{background:var(--paper);border:1px solid var(--rule);
        aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
        overflow:hidden;position:sticky;top:120px}
.pd-img img{width:100%;height:100%;object-fit:contain;padding:24px}
.pd-info .product-cat{font-size:11px;margin-bottom:6px}
.pd-info .h1{font-size:clamp(34px,4.6vw,52px);margin-bottom:8px}
.pd-info .product-sku{font-size:12px;margin:0 0 24px}
.pd-price{font-family:var(--mono);font-size:30px;font-weight:600;margin:24px 0;
          padding:24px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.pd-actions{display:flex;gap:12px;margin:24px 0;flex-wrap:wrap}
.pd-qty{display:inline-flex;border:1.5px solid var(--ink);align-items:center}
.pd-qty button{background:transparent;border:none;padding:14px 14px;font-size:18px;
               font-weight:700;cursor:pointer}
.pd-qty input{border:none;width:48px;text-align:center;font-family:var(--mono);
              font-size:14px;font-weight:600;background:transparent;padding:14px 0}
.pd-qty input::-webkit-outer-spin-button,
.pd-qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pd-qty input{-moz-appearance:textfield}
.pd-add{flex:1;min-width:200px}
.pd-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.pd-section h3{font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
               color:var(--ink);margin-bottom:14px}
.pd-section p{font-size:15px;line-height:1.65;color:var(--graphite);margin-bottom:12px}
.pd-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);
          border:1px solid var(--rule);margin-top:8px}
.spec{background:var(--paper);padding:12px 14px}
.spec-label{font-family:var(--mono);font-size:9px;letter-spacing:.14em;
            text-transform:uppercase;color:var(--steel);margin-bottom:2px}
.spec-value{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:600}
.pd-breadcrumb{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
               color:var(--steel);padding:16px 40px;max-width:1320px;margin:0 auto;
               text-transform:uppercase}
.pd-breadcrumb a{color:var(--steel);transition:color .15s}
.pd-breadcrumb a:hover{color:var(--signal)}

/* ── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--ink);color:var(--bone);padding:72px 0 28px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
             padding:0 40px;max-width:1320px;margin:0 auto}
.footer-brand{font-weight:900;font-style:italic;font-size:24px;letter-spacing:-.01em;
              text-transform:uppercase;margin-bottom:14px}
.footer-tag{font-size:13px;line-height:1.6;color:rgba(245,241,234,.6);max-width:280px}
.footer-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
               text-transform:uppercase;color:rgba(245,241,234,.5);margin-bottom:18px}
.footer-col a,.footer-col li{display:block;font-size:13px;color:rgba(245,241,234,.85);
                              padding:5px 0;transition:color .15s;list-style:none}
.footer-col a:hover{color:var(--signal)}
.footer-bot{max-width:1320px;margin:48px auto 0;padding:24px 40px 0;
            border-top:1px solid rgba(245,241,234,.1);
            display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
            font-family:var(--mono);font-size:10px;letter-spacing:.1em;
            text-transform:uppercase;color:rgba(245,241,234,.4)}

/* ── ABOUT / FEATURES ───────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-photo{aspect-ratio:4/5;background:var(--paper);overflow:hidden}
.about-photo img{width:100%;height:100%;object-fit:cover}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.feat{padding:24px 20px;background:var(--paper);border:1px solid var(--rule)}
.feat-num{font-family:var(--mono);font-size:11px;font-weight:600;
          color:var(--signal);letter-spacing:.16em;margin-bottom:12px}
.feat h4{font-weight:800;font-style:italic;font-size:17px;letter-spacing:-.01em;
         text-transform:uppercase;margin-bottom:8px;line-height:1.1}
.feat p{font-size:13px;line-height:1.6;color:var(--graphite)}

/* ── CTA ─────────────────────────────────────────────────── */
.cta{padding:96px 40px;text-align:center;background:var(--ink);color:var(--bone)}
.cta .h2{color:var(--bone);max-width:780px;margin:0 auto 20px}
.cta-body{font-size:17px;line-height:1.6;color:rgba(245,241,234,.78);
          max-width:560px;margin:0 auto 32px}
.cta .btn-row{justify-content:center}

/* ── MARQUEE ─────────────────────────────────────────────── */
.marquee{padding:18px 0;background:var(--signal);color:#fff;overflow:hidden;
         white-space:nowrap;border-top:1px solid var(--signal-deep);
         border-bottom:1px solid var(--signal-deep)}
.marquee-track{display:inline-block;animation:marquee 28s linear infinite;
               font-family:var(--mono);font-size:14px;letter-spacing:.1em;
               text-transform:uppercase;font-weight:600}
.marquee-track span{margin:0 32px}
.marquee-track span::before{content:"◆ ";color:rgba(255,255,255,.5)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── FAQ / SIMPLE CONTENT ──────────────────────────────── */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:clamp(28px,3.6vw,42px);margin:48px 0 16px}
.prose h3{font-size:20px;margin:32px 0 12px;font-style:normal;text-transform:none;
          letter-spacing:0;font-weight:700}
.prose p{font-size:16px;line-height:1.7;color:var(--graphite);margin-bottom:16px}
.prose ul,.prose ol{margin:8px 0 24px 24px}
.prose li{font-size:16px;line-height:1.7;color:var(--graphite);margin-bottom:6px}
.faq-item{border-bottom:1px solid var(--rule);padding:24px 0}
.faq-q{font-weight:800;font-size:18px;margin-bottom:10px;cursor:pointer;
       display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:"+";font-family:var(--mono);font-weight:300;color:var(--signal);
              transition:transform .2s;font-size:22px}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{font-size:15px;line-height:1.7;color:var(--graphite);max-height:0;
       overflow:hidden;transition:max-height .3s,padding .3s}
.faq-item.open .faq-a{max-height:600px;padding-top:8px}

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info{padding:24px 0}
.contact-info-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--rule)}
.contact-info-row strong{font-family:var(--mono);font-size:10px;letter-spacing:.14em;
                         text-transform:uppercase;color:var(--steel);display:block;margin-bottom:4px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;
                  text-transform:uppercase;color:var(--steel);margin-bottom:6px}
.form-control{width:100%;padding:13px 14px;border:1.5px solid var(--rule);
              font-family:var(--mono);font-size:14px;background:#fff;outline:none}
.form-control:focus{border-color:var(--signal)}
textarea.form-control{min-height:140px;resize:vertical;font-family:var(--sans)}

/* ── BREAKPOINTS ───────────────────────────────────────── */
@media (max-width:1100px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:860px){
  .hdr-inner{padding:10px 16px;gap:12px;display:grid;grid-template-columns:auto 1fr auto}
  .logo-img{height:80px}
  .cart-btn{padding:9px 12px;font-size:11px;letter-spacing:.06em}
  .nav{display:none}
  .hamburger{display:flex}
  .logo-wrap{justify-self:center}
  .container{padding:0 20px}
  .section{padding:64px 0}
  .hero{grid-template-columns:1fr;padding:40px 20px 60px;min-height:auto;gap:40px}
  .hero-cards{min-height:340px}
  .hero-card{transform:none!important;width:100%;position:relative;margin-bottom:16px}
  .hero-card-1,.hero-card-2,.hero-card-3{top:auto;bottom:auto;left:auto;right:auto}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr;gap:32px;padding:0 20px}
  .footer-bot{padding:20px 20px 0}
  .pd-grid{grid-template-columns:1fr;gap:36px;padding:24px 20px 60px}
  .pd-img{position:relative;top:0}
  .pd-breadcrumb{padding:14px 20px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .cta{padding:64px 20px}
  .marquee-track{font-size:12px}
}
@media (max-width:540px){
  .hdr-inner{padding:8px 12px;gap:8px}
  .logo-img{height:68px}
  .cart-btn{padding:7px 10px;font-size:10px}
  .h1{font-size:42px}
  .h2{font-size:32px}
  .section{padding:48px 0}
  .pd-specs{grid-template-columns:1fr}
  .product-grid{gap:8px}
  .product-meta{padding:14px 12px 8px}
  .product-name{font-size:16px}
  .product-price{font-size:15px}
}

/* ── Snipcart overrides (match brand) ─────────────────── */
.snipcart-modal__container{font-family:var(--sans)!important}
.snipcart-button-primary{background:var(--signal)!important;
                          color:#fff!important;font-weight:700!important;
                          letter-spacing:.06em!important;text-transform:uppercase!important}
.snipcart-button-primary:hover{background:var(--signal-deep)!important}
