@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&family=Space+Mono:wght@400;700&display=swap');

:root {
  --ink:#0e0e0e; --paper:#f4f2ed; --warm:#e8e4db; --accent:#c8382a;
  --gold:#b8924a; --mid:#6b6660; --light:#d4cfc6; --white:#ffffff;
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'DM Sans',sans-serif;
  --mono:'Space Mono',monospace;
  --r:3px; --shadow:0 2px 24px rgba(14,14,14,.10);
  --max:1280px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

/* ── ANNOUNCE ─────────────────────────── */
.announce{background:var(--ink);color:var(--paper);text-align:center;padding:9px 20px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;}
.announce a{color:var(--gold);text-decoration:underline;}

/* ── HEADER ───────────────────────────── */
header{position:sticky;top:0;z-index:200;background:var(--paper);border-bottom:1px solid var(--light);display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:68px;}
.logo{display:flex;align-items:center;gap:10px;white-space:nowrap;}
.logo-mark{width:32px;height:32px;background:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.logo-text{font-family:var(--serif);font-size:24px;letter-spacing:-.01em;white-space:nowrap;}
.logo-text span{color:var(--accent);}
nav{display:flex;align-items:center;}
.nav-item{position:relative;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.04em;padding:0 16px;height:68px;display:flex;align-items:center;color:var(--mid);transition:color .2s;white-space:nowrap;border-bottom:2px solid transparent;}
.nav-item:hover,.nav-item.active{color:var(--ink);border-bottom-color:var(--accent);}
.nav-item.has-drop{cursor:pointer;}
.nav-caret{font-size:11px;margin-left:3px;transition:transform .2s;}
.has-drop.open .nav-caret{transform:rotate(180deg);}
.dropdown{display:none;position:absolute;top:69px;left:50%;transform:translateX(-50%);background:var(--white);border:1px solid var(--light);border-radius:var(--r);box-shadow:0 8px 32px rgba(14,14,14,.12);min-width:260px;padding:8px 0;z-index:300;}
.has-drop.open .dropdown{display:block;}
.dropdown a{display:block;padding:11px 20px;font-size:13px;font-weight:500;color:var(--mid);transition:background .15s,color .15s;white-space:nowrap;}
.dropdown a:hover{background:var(--warm);color:var(--ink);}
.dropdown-divider{height:1px;background:var(--light);margin:6px 0;}
.dropdown-all{color:var(--accent)!important;font-weight:600!important;}
.header-right{display:flex;align-items:center;gap:12px;}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--mid);padding:6px;transition:color .2s;display:flex;align-items:center;}
.icon-btn:hover{color:var(--ink);}
.cart-btn{background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:13px;padding:9px 18px;border-radius:var(--r);border:none;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s;}
.cart-btn:hover{background:var(--accent);}
.mobile-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.mobile-btn span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;}

/* ── BUTTONS ──────────────────────────── */
.btn-primary{background:var(--accent);color:var(--white);font-family:var(--sans);font-weight:600;font-size:14px;padding:14px 30px;border-radius:var(--r);border:none;cursor:pointer;letter-spacing:.02em;transition:all .2s;display:inline-block;text-align:center;}
.btn-primary:hover{background:#a82e22;transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--paper);font-family:var(--sans);font-weight:500;font-size:14px;padding:13px 30px;border-radius:var(--r);border:1px solid rgba(244,242,237,.25);cursor:pointer;letter-spacing:.02em;transition:all .2s;display:inline-block;}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn-dark{background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:14px;padding:14px 30px;border-radius:var(--r);border:none;cursor:pointer;letter-spacing:.02em;transition:all .2s;display:inline-block;text-align:center;}
.btn-dark:hover{background:var(--accent);}
.btn-outline{background:transparent;color:var(--ink);font-family:var(--sans);font-weight:600;font-size:13px;padding:11px 24px;border-radius:var(--r);border:1px solid var(--light);cursor:pointer;transition:all .2s;display:inline-block;}
.btn-outline:hover{border-color:var(--ink);}
.link-arrow{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:6px;border-bottom:1px solid var(--ink);padding-bottom:2px;transition:color .2s,border-color .2s;}
.link-arrow:hover{color:var(--accent);border-color:var(--accent);}

/* ── SECTIONS ─────────────────────────── */
.section{max-width:var(--max);margin:0 auto;padding:96px 48px;}
.section-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.section-label::before{content:'';width:20px;height:1px;background:var(--gold);}
.section-title{font-family:var(--serif);font-size:clamp(32px,3.5vw,52px);line-height:1.05;letter-spacing:-.02em;margin-bottom:16px;}
.section-desc{color:var(--mid);max-width:520px;font-weight:300;line-height:1.75;margin-bottom:48px;}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:56px;flex-wrap:wrap;gap:20px;}

/* ── HERO ─────────────────────────────── */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 97px);overflow:hidden;}
.hero-left{background:var(--ink);display:flex;flex-direction:column;justify-content:center;padding:80px 64px;position:relative;overflow:hidden;}
.hero-left::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(184,146,74,.08) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none;}
.hero-left::after{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(200,56,42,.06) 0%,transparent 70%);bottom:60px;left:-60px;pointer-events:none;}
.hero-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--gold);text-transform:uppercase;margin-bottom:24px;display:flex;align-items:center;gap:10px;}
.hero-eyebrow::before{content:'';width:28px;height:1px;background:var(--gold);}
.hero-h1{font-family:var(--serif);font-size:clamp(44px,5.5vw,78px);line-height:1.0;color:var(--paper);margin-bottom:28px;letter-spacing:-.02em;}
.hero-h1 em{font-style:italic;color:var(--gold);}
.hero-sub{font-size:15px;color:rgba(244,242,237,.6);font-weight:300;max-width:400px;line-height:1.75;margin-bottom:44px;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;}
.hero-stats{display:flex;gap:40px;padding-top:40px;border-top:1px solid rgba(244,242,237,.12);}
.stat-val{font-family:var(--serif);font-size:32px;color:var(--paper);line-height:1;margin-bottom:4px;}
.stat-label{font-size:12px;color:rgba(244,242,237,.45);font-weight:300;letter-spacing:.04em;}
.hero-right{background:var(--warm);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:60px;}
.hero-right::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(14,14,14,.04) 39px,rgba(14,14,14,.04) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(14,14,14,.04) 39px,rgba(14,14,14,.04) 40px);}
.adapter-vis{position:relative;z-index:1;}
.adapter-vis svg{width:320px;height:320px;filter:drop-shadow(0 20px 60px rgba(14,14,14,.18));}

/* ── PRODUCT GRID ─────────────────────── */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.product-card{background:var(--white);border:1px solid var(--light);border-radius:var(--r);overflow:hidden;transition:box-shadow .25s,transform .25s;}
.product-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);}
.product-img-wrap{background:var(--warm);aspect-ratio:4/3;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.product-img-wrap img{width:200px;height:200px;object-fit:contain;}
.product-img-wrap svg{width:180px;height:180px;}
.product-badge{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;padding:4px 10px;border-radius:2px;}
.badge-new{background:var(--ink);color:var(--paper);}
.badge-sale{background:var(--accent);color:var(--white);}
.product-body{padding:20px 22px;}
.product-compat{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--gold);text-transform:uppercase;margin-bottom:8px;}
.product-name{font-family:var(--serif);font-size:20px;line-height:1.2;margin-bottom:8px;letter-spacing:-.01em;}
.product-name a{transition:color .2s;}
.product-name a:hover{color:var(--accent);}
.product-desc{font-size:12px;color:var(--mid);font-weight:300;line-height:1.6;margin-bottom:0;}
.product-footer-row{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--warm);}
.product-price{font-family:var(--serif);font-size:22px;}
.product-price-old{font-size:14px;color:var(--mid);text-decoration:line-through;margin-left:6px;}
.btn-atc{background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.04em;padding:9px 18px;border-radius:var(--r);border:none;cursor:pointer;transition:background .2s;}
.btn-atc:hover{background:var(--accent);}

/* ── FINDER ───────────────────────────── */
.finder-bg{background:var(--ink);padding:96px 0;position:relative;overflow:hidden;}
.finder-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(184,146,74,.07) 0%,transparent 70%);}
.finder-inner{max-width:var(--max);margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1;}
.finder-text .section-label{color:var(--gold);}
.finder-text .section-title{color:var(--paper);}
.finder-text .section-desc{color:rgba(244,242,237,.5);margin-bottom:0;}
.finder-form{background:rgba(244,242,237,.05);border:1px solid rgba(244,242,237,.1);border-radius:var(--r);padding:36px;}
.form-row{margin-bottom:20px;}
.form-label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(244,242,237,.4);margin-bottom:8px;}
.form-select{width:100%;background:rgba(244,242,237,.06);border:1px solid rgba(244,242,237,.12);color:var(--paper);font-family:var(--sans);font-size:14px;padding:12px 16px;border-radius:var(--r);appearance:none;cursor:pointer;transition:border-color .2s;}
.form-select:focus{outline:none;border-color:var(--gold);}
.form-select option{background:#1a1a1a;color:var(--paper);}
.finder-result{margin-top:8px;padding:16px;background:rgba(184,146,74,.08);border:1px solid rgba(184,146,74,.2);border-radius:var(--r);display:none;}
.finder-result.show{display:block;}
.finder-result-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--gold);margin-bottom:6px;}
.finder-result-text{color:var(--paper);font-size:14px;font-weight:500;margin-bottom:14px;}

/* ── COMPAT TABLE ─────────────────────── */
.compat-table-wrap{overflow-x:auto;}
.compat-table{width:100%;border-collapse:collapse;font-size:14px;}
.compat-table th{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);padding:14px 20px;text-align:left;border-bottom:2px solid var(--light);white-space:nowrap;}
.compat-table td{padding:16px 20px;border-bottom:1px solid var(--warm);color:var(--ink);vertical-align:middle;}
.compat-table tr:last-child td{border-bottom:none;}
.compat-table tr:hover td{background:var(--warm);}
.compat-table td:first-child{font-family:var(--serif);font-size:16px;}
.compat-table td a:hover{color:var(--accent);}
.check{color:#2d7a3a;font-size:16px;} .cross{color:var(--light);font-size:16px;}
.tag{display:inline-block;background:var(--warm);font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:2px;color:var(--mid);}
.tag-gold{background:rgba(184,146,74,.12);color:var(--gold);}

/* ── FEATURES ─────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);}
.feature-item{padding:48px;border-right:1px solid var(--light);border-bottom:1px solid var(--light);transition:background .2s;}
.feature-item:nth-child(even){border-right:none;}
.feature-item:nth-child(3),.feature-item:nth-child(4){border-bottom:none;}
.feature-item:hover{background:var(--warm);}
.feature-num{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--light);margin-bottom:20px;}
.feature-icon-wrap{width:48px;height:48px;border:1px solid var(--light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:20px;transition:border-color .2s;}
.feature-item:hover .feature-icon-wrap{border-color:var(--accent);}
.feature-title{font-family:var(--serif);font-size:22px;margin-bottom:12px;letter-spacing:-.01em;}
.feature-desc{font-size:14px;color:var(--mid);font-weight:300;line-height:1.75;}

/* ── TESTIMONIALS ─────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.t-card{background:var(--white);border:1px solid var(--light);border-radius:var(--r);padding:32px;}
.t-quote{font-family:var(--serif);font-size:60px;color:var(--warm);line-height:.8;margin-bottom:16px;}
.t-text{font-size:14px;color:var(--mid);line-height:1.75;font-style:italic;font-weight:300;margin-bottom:24px;font-family:var(--serif);}
.t-author{font-weight:600;font-size:13px;margin-bottom:2px;}
.t-role{font-size:12px;color:var(--mid);font-weight:300;}
.t-stars{color:var(--gold);font-size:13px;margin-bottom:16px;letter-spacing:2px;}

/* ── CART SIDEBAR ─────────────────────── */
.cart-overlay{display:none;position:fixed;inset:0;background:rgba(14,14,14,.5);z-index:400;}
.cart-overlay.open{display:block;}
.cart-sidebar{position:fixed;top:0;right:-440px;width:440px;height:100vh;background:var(--white);z-index:500;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 40px rgba(14,14,14,.12);}
.cart-sidebar.open{right:0;}
.cart-header{padding:24px 28px;border-bottom:1px solid var(--light);display:flex;align-items:center;justify-content:space-between;}
.cart-header h3{font-family:var(--serif);font-size:22px;letter-spacing:-.01em;}
.cart-close{background:none;border:none;cursor:pointer;font-size:22px;color:var(--mid);transition:color .2s;line-height:1;}
.cart-close:hover{color:var(--ink);}
.cart-items{flex:1;overflow-y:auto;padding:24px 28px;}
.cart-empty{text-align:center;padding:60px 0;color:var(--mid);font-size:14px;font-weight:300;}
.cart-item{display:flex;gap:16px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--warm);}
.cart-item:last-child{border-bottom:none;}
.cart-item-img{width:72px;height:72px;background:var(--warm);border-radius:var(--r);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.cart-item-img img{width:100%;height:100%;object-fit:contain;}
.cart-item-info{flex:1;}
.cart-item-name{font-family:var(--serif);font-size:15px;margin-bottom:4px;line-height:1.2;}
.cart-item-price{font-size:13px;color:var(--mid);margin-bottom:10px;}
.cart-item-qty{display:flex;align-items:center;gap:10px;}
.qty-btn{width:28px;height:28px;border:1px solid var(--light);background:none;border-radius:var(--r);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.qty-btn:hover{border-color:var(--ink);}
.qty-val{font-family:var(--mono);font-size:13px;min-width:20px;text-align:center;}
.cart-remove{background:none;border:none;cursor:pointer;color:var(--light);font-size:18px;transition:color .2s;margin-left:auto;align-self:flex-start;}
.cart-remove:hover{color:var(--accent);}
.cart-footer{padding:24px 28px;border-top:1px solid var(--light);}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.cart-total-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);}
.cart-total-val{font-family:var(--serif);font-size:24px;}
.cart-note{font-size:11px;color:var(--mid);text-align:center;margin-top:12px;font-weight:300;}

/* ── NEWSLETTER ───────────────────────── */
.nl-bg{background:var(--ink);padding:96px 48px;text-align:center;position:relative;overflow:hidden;}
.nl-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(184,146,74,.06) 0%,transparent 70%);}
.nl-inner{position:relative;z-index:1;max-width:520px;margin:0 auto;}
.nl-inner .section-label{justify-content:center;}
.nl-inner .section-label::before{display:none;}
.nl-title{font-family:var(--serif);font-size:clamp(32px,4vw,52px);color:var(--paper);line-height:1.05;margin-bottom:16px;letter-spacing:-.02em;}
.nl-title em{font-style:italic;color:var(--gold);}
.nl-desc{color:rgba(244,242,237,.45);font-weight:300;margin-bottom:36px;}
.nl-form{display:flex;gap:8px;}
.nl-input{flex:1;background:rgba(244,242,237,.06);border:1px solid rgba(244,242,237,.12);color:var(--paper);font-family:var(--sans);font-size:14px;padding:13px 18px;border-radius:var(--r);transition:border-color .2s;}
.nl-input:focus{outline:none;border-color:var(--gold);}
.nl-input::placeholder{color:rgba(244,242,237,.25);}

/* ── PAGE HERO ────────────────────────── */
.page-hero{background:var(--ink);padding:80px 48px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 30% 50%,rgba(184,146,74,.07) 0%,transparent 70%);}
.page-hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1;}
.page-hero .section-label{color:var(--gold);}
.page-hero h1{font-family:var(--serif);font-size:clamp(40px,5vw,72px);color:var(--paper);line-height:1.0;letter-spacing:-.02em;margin-bottom:16px;}
.page-hero p{color:rgba(244,242,237,.6);font-size:15px;font-weight:300;max-width:500px;line-height:1.75;}

/* ── COMING SOON ──────────────────────── */
.coming-soon{min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px;}
.coming-soon-inner{max-width:480px;}
.coming-soon-icon{font-size:48px;margin-bottom:24px;}
.coming-soon h2{font-family:var(--serif);font-size:40px;margin-bottom:16px;letter-spacing:-.02em;}
.coming-soon p{color:var(--mid);font-size:15px;font-weight:300;line-height:1.75;margin-bottom:32px;}
.coming-soon-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ── FOOTER ───────────────────────────── */
footer{background:var(--paper);border-top:1px solid var(--light);padding:64px 48px 32px;}
.footer-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-logo{font-family:var(--serif);font-size:22px;margin-bottom:16px;}
.footer-logo span{color:var(--accent);}
.footer-tagline{font-size:13px;color:var(--mid);font-weight:300;line-height:1.7;max-width:260px;margin-bottom:24px;}
.footer-social{display:flex;gap:10px;}
.social-btn{width:34px;height:34px;border:1px solid var(--light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--mid);transition:all .2s;}
.social-btn:hover{border-color:var(--ink);color:var(--ink);}
.footer-col h5{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:20px;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:10px;}
.footer-col a{font-size:13px;color:var(--mid);font-weight:300;transition:color .2s;}
.footer-col a:hover{color:var(--ink);}
.footer-bottom{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid var(--light);font-size:12px;color:var(--mid);flex-wrap:wrap;gap:12px;}

/* ── SCROLL REVEAL ────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease;}
.reveal.in{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}

/* ── RESPONSIVE ───────────────────────── */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;}.hero-right{display:none;}
  .product-grid{grid-template-columns:repeat(2,1fr);}
  .finder-inner{grid-template-columns:1fr;gap:40px;}
  .features-grid{grid-template-columns:1fr;}
  .feature-item{border-right:none;}.feature-item:nth-child(3){border-bottom:1px solid var(--light);}
  .testimonials-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  header{padding:0 20px;}
  nav{display:none;}
  nav.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--paper);z-index:500;padding:80px 32px 32px;overflow-y:auto;align-items:flex-start;}
  nav.open .nav-item{height:auto;border-bottom:1px solid var(--light);padding:16px 0;font-size:18px;color:var(--ink);width:100%;}
  nav.open .dropdown{position:static;transform:none;box-shadow:none;border:none;background:var(--warm);margin-top:8px;border-radius:var(--r);}
  .mobile-btn{display:flex;}
  .hero-left{padding:60px 24px;}
  .section{padding:64px 24px;}
  .product-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .nl-form{flex-direction:column;}
  .nl-bg,.page-hero{padding:64px 24px;}
  .cart-sidebar{width:100%;}
  .features-grid{grid-template-columns:1fr;}
  .section-head{flex-direction:column;align-items:flex-start;}
}

/* ── PAYMENT MODAL ────────────────────────────────────────────── */
.modal-overlay {
  display:none;position:fixed;inset:0;background:rgba(14,14,14,.6);
  z-index:600;align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.open { display:flex; }
.modal-box {
  background:var(--white);border-radius:6px;
  width:100%;max-width:480px;overflow:hidden;
  box-shadow:0 24px 80px rgba(14,14,14,.2);
}
.modal-header {
  background:var(--ink);padding:24px 28px;
  display:flex;align-items:center;justify-content:space-between;
}
.modal-header h3 { font-family:var(--serif);font-size:22px;color:var(--paper);letter-spacing:-.01em; }
.modal-header-close { background:none;border:none;cursor:pointer;color:rgba(244,242,237,.5);font-size:22px;transition:color .2s;line-height:1; }
.modal-header-close:hover { color:var(--paper); }
.modal-body { padding:28px; }
.modal-items { margin-bottom:20px; }
.modal-item {
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--warm);
  font-size:13px;color:var(--mid);
}
.modal-item:last-child { border-bottom:none; }
.modal-item span:last-child { font-family:var(--serif);font-size:16px;color:var(--ink); }
.modal-total-row {
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 0;border-top:2px solid var(--light);margin-bottom:24px;
}
.modal-total-label { font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid); }
.modal-total-amount { font-family:var(--serif);font-size:28px; }

/* Payment method buttons */
.payment-methods { display:flex;flex-direction:column;gap:12px; }
.pay-method-btn {
  width:100%;padding:14px 20px;border-radius:var(--r);
  border:1px solid var(--light);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--sans);font-weight:600;font-size:14px;
  transition:all .2s;
}
.pay-method-btn:hover { border-color:var(--ink);background:var(--warm); }
.pay-method-btn.paypal-btn {
  background:#003087;color:#fff;border-color:#003087;
}
.pay-method-btn.paypal-btn:hover { background:#001f5b; }
.pay-method-btn.card-btn {
  background:var(--ink);color:var(--paper);border-color:var(--ink);
}
.pay-method-btn.card-btn:hover { background:#333; }

/* Card icons row */
.card-icons {
  display:flex;align-items:center;gap:6px;
  flex-wrap:wrap;
}
.card-icon {
  height:24px;border-radius:3px;border:1px solid rgba(255,255,255,.2);
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 6px;font-size:10px;font-weight:700;letter-spacing:.02em;
  font-family:var(--mono);
}
.card-icon.visa    { background:#1a1f71;color:#fff; }
.card-icon.mc      { background:#eb001b;color:#fff; }
.card-icon.amex    { background:#007bc1;color:#fff; }
.card-icon.pp      { background:#009cde;color:#fff; }
.card-icon.unionpay{ background:#e21836;color:#fff; }

/* Footer payment icons */
.footer-pay-icons {
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.footer-card-icon {
  height:22px;border-radius:3px;border:1px solid var(--light);
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 7px;font-size:9px;font-weight:700;letter-spacing:.03em;
  font-family:var(--mono);color:var(--mid);background:var(--white);
}

/* Cart footer payment icons */
.cart-pay-icons {
  display:flex;align-items:center;justify-content:center;
  gap:5px;margin-top:10px;flex-wrap:wrap;
}
.cart-pay-icons .card-icon {
  height:20px;font-size:9px;
  border:1px solid rgba(14,14,14,.15);
}
.cart-pay-icons .card-icon.visa    { background:#1a1f71;color:#fff; }
.cart-pay-icons .card-icon.mc      { background:#eb001b;color:#fff; }
.cart-pay-icons .card-icon.amex    { background:#007bc1;color:#fff; }
.cart-pay-icons .card-icon.pp      { background:#003087;color:#fff; }
.cart-pay-icons .card-icon.unionpay{ background:#e21836;color:#fff; }

.modal-secure-note {
  text-align:center;margin-top:16px;
  font-size:11px;color:var(--mid);font-weight:300;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
