/* ── Design tokens ─────────────────────────────────────────────────────────── */
:root {
  --bg:   #0d1117; --bg2: #161b22; --bg3: #21262d;
  --bd:   #30363d; --bd2: #21262d;
  --t1:   #f0f6fc; --t2: #b0bec5; --t3: #8b949e;
  --accent:#58a6ff; --green:#3fb950; --orange:#f0883e;
  --red:  #f85149; --yellow:#d29922; --purple:#bc8cff;
  --r:8px; --rl:12px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Space Grotesk',sans-serif;background:var(--bg);color:var(--t1);font-size:15px;}
.mono{font-family:'DM Mono',monospace;}

/* ── Navigation ─────────────────────────────────────────────────────────────── */
#site-nav{background:var(--bg2);border-bottom:1px solid var(--bd);padding:0 24px;height:56px;
  display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;}
.nav-logo{font-size:17px;font-weight:700;letter-spacing:-0.3px;color:var(--t1);text-decoration:none;}
.nav-logo span{color:var(--accent);}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-link{font-size:13px;color:var(--t2);padding:6px 10px;border-radius:6px;
  cursor:pointer;transition:all 0.15s;font-weight:500;text-decoration:none;}
.nav-link:hover,.nav-link.active{color:var(--t1);background:var(--bg3);}
.nav-actions{display:flex;align-items:center;gap:10px;}
.cart-btn{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--bd);
  color:var(--t1);padding:7px 14px;border-radius:var(--r);cursor:pointer;font-size:13px;
  font-weight:500;transition:all 0.15s;text-decoration:none;}
.cart-btn:hover{border-color:var(--accent);color:var(--accent);}
.cart-badge{background:var(--accent);color:#0d1117;font-size:10px;font-weight:700;
  width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;}

/* ── Footer ──────────────────────────────────────────────────────────────────── */
.site-footer{background:var(--bg2);border-top:1px solid var(--bd);padding:16px 24px;margin-top:auto;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.footer-copy{font-size:12px;color:var(--t3);}
.footer-links{display:flex;gap:16px;}
.footer-links a{font-size:12px;color:var(--t3);text-decoration:none;transition:color 0.15s;}
.footer-links a:hover{color:var(--accent);}

/* ── Layout helpers ──────────────────────────────────────────────────────────── */
.page-wrap{max-width:1100px;margin:0 auto;padding:28px 24px 60px;}
.page-header{margin-bottom:24px;}
.page-title{font-size:22px;font-weight:700;letter-spacing:-0.3px;margin-bottom:4px;}
.page-subtitle{font-size:13px;color:var(--t3);}

/* ── Buttons ─────────────────────────────────────────────────────────────────── */
.add-btn{height:48px;background:#238636;border:1px solid #3fb950;color:#fff;font-size:15px;
  font-weight:700;border-radius:var(--r);cursor:pointer;transition:all 0.2s;
  font-family:inherit;width:100%;display:flex;align-items:center;justify-content:center;}
.add-btn:hover{background:#2ea043;transform:translateY(-1px);}
.add-btn.added{background:#0f6e56;border-color:#3fb950;}
.add-btn.digital-btn{background:rgba(188,140,255,0.15);border-color:var(--purple);color:var(--purple);}
.add-btn.digital-btn:hover{background:rgba(188,140,255,0.25);}
.checkout-btn{display:block;text-align:center;text-decoration:none;width:100%;height:48px;
  background:#238636;border:1px solid #3fb950;color:#fff;font-size:15px;font-weight:700;
  border-radius:var(--r);cursor:pointer;transition:all 0.2s;font-family:inherit;
  line-height:48px;margin-bottom:10px;}
.checkout-btn:hover{background:#2ea043;}
.continue-btn{display:block;text-align:center;text-decoration:none;width:100%;height:40px;
  background:none;border:1px solid var(--bd);color:var(--t2);font-size:13px;font-weight:500;
  border-radius:var(--r);cursor:pointer;transition:all 0.15s;font-family:inherit;line-height:40px;}
.continue-btn:hover{border-color:var(--accent);color:var(--accent);}
.submit-btn{width:100%;height:48px;background:#238636;border:1px solid #3fb950;color:#fff;
  font-size:15px;font-weight:700;border-radius:var(--r);cursor:pointer;transition:all 0.2s;
  font-family:inherit;margin-bottom:10px;}
.submit-btn:hover:not(:disabled){background:#2ea043;}
.submit-btn:disabled{opacity:0.6;cursor:not-allowed;}
.lookup-btn{width:100%;height:44px;background:var(--bg3);border:1px solid var(--bd);
  color:var(--t2);font-size:14px;font-weight:600;border-radius:var(--r);cursor:pointer;
  font-family:inherit;transition:all 0.15s;margin-top:16px;}
.lookup-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);}
.track-btn{display:inline-block;padding:10px 22px;background:var(--bg3);border:1px solid var(--bd);
  color:var(--t2);border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:500;
  font-family:inherit;transition:all 0.15s;text-decoration:none;}
.track-btn:hover{border-color:var(--accent);color:var(--accent);}

/* ── Forms ───────────────────────────────────────────────────────────────────── */
.field-label{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;margin-bottom:5px;display:block;}
.field-input{width:100%;background:var(--bg);border:1px solid var(--bd);color:var(--t1);
  padding:9px 12px;border-radius:var(--r);font-size:14px;font-family:'Space Grotesk',sans-serif;
  outline:none;transition:border-color 0.15s;appearance:none;}
.field-input:focus{border-color:var(--accent);}
.field-input::placeholder{color:var(--t3);}
.form-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:18px;margin-bottom:14px;}
.form-grid{display:grid;gap:12px;}
.form-grid-2{grid-template-columns:1fr 1fr;display:grid;gap:10px;}
@media(max-width:480px){.form-grid-2{grid-template-columns:1fr;}}
.section-title{font-size:13px;font-weight:600;color:var(--t2);font-family:'DM Mono',monospace;
  text-transform:uppercase;letter-spacing:0.05em;margin-bottom:14px;}

/* ── Pills & badges ──────────────────────────────────────────────────────────── */
.pill,.type-badge{font-size:10px;font-weight:700;font-family:'DM Mono',monospace;
  padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:0.03em;white-space:nowrap;}
.pg{background:rgba(63,185,80,0.12);color:var(--green);border:1px solid rgba(63,185,80,0.25);}
.pb{background:rgba(88,166,255,0.12);color:var(--accent);border:1px solid rgba(88,166,255,0.25);}
.po{background:rgba(240,136,62,0.12);color:var(--orange);border:1px solid rgba(240,136,62,0.25);}
.pr{background:rgba(248,81,73,0.12);color:var(--red);border:1px solid rgba(248,81,73,0.25);}
.pgr{background:rgba(110,118,129,0.12);color:var(--t3);border:1px solid rgba(110,118,129,0.2);}
.py{background:rgba(210,153,34,0.12);color:var(--yellow);border:1px solid rgba(210,153,34,0.25);}
.ppu{background:rgba(188,140,255,0.12);color:var(--purple);border:1px solid rgba(188,140,255,0.25);}
.badge-digital{background:rgba(188,140,255,0.15);color:var(--purple);border:1px solid rgba(188,140,255,0.3);}
.badge-physical{background:rgba(88,166,255,0.15);color:var(--accent);border:1px solid rgba(88,166,255,0.3);}
.badge-new{background:rgba(63,185,80,0.15);color:var(--green);border:1px solid rgba(63,185,80,0.3);}
.instant-badge{position:absolute;bottom:10px;right:10px;font-size:10px;font-weight:600;
  font-family:'DM Mono',monospace;padding:2px 7px;border-radius:4px;
  background:rgba(188,140,255,0.2);color:var(--purple);border:1px solid rgba(188,140,255,0.3);}
.status-pill{font-size:10px;font-weight:700;font-family:'DM Mono',monospace;
  padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:0.04em;}

/* ── Hero strip ──────────────────────────────────────────────────────────────── */
.hero-strip{background:linear-gradient(135deg,#161b22 0%,#0d1117 50%,#161b22 100%);
  border-bottom:1px solid var(--bd);padding:40px 24px 36px;text-align:center;position:relative;overflow:hidden;}
.hero-strip::before{content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:400px;height:200px;background:radial-gradient(ellipse,rgba(88,166,255,0.08) 0%,transparent 70%);pointer-events:none;}
.hero-tag{display:inline-block;font-family:'DM Mono',monospace;font-size:11px;color:var(--green);
  background:rgba(63,185,80,0.1);border:1px solid rgba(63,185,80,0.25);padding:3px 10px;
  border-radius:20px;margin-bottom:14px;letter-spacing:0.05em;}
.hero-title{font-size:clamp(24px,4vw,36px);font-weight:700;letter-spacing:-0.5px;margin-bottom:8px;}
.hero-title em{color:var(--accent);font-style:normal;}
.hero-sub{font-size:14px;color:var(--t2);max-width:420px;margin:0 auto;line-height:1.6;}

/* ── Filter bar ──────────────────────────────────────────────────────────────── */
.filter-bar{padding:14px 24px;border-bottom:1px solid var(--bd2);display:flex;
  align-items:center;gap:8px;flex-wrap:wrap;background:var(--bg);}
.filter-label{font-size:12px;color:var(--t3);font-family:'DM Mono',monospace;margin-right:4px;}
.filter-chip{font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;
  border:1px solid var(--bd);background:var(--bg2);color:var(--t2);cursor:pointer;
  transition:all 0.15s;font-family:inherit;}
.filter-chip:hover{border-color:var(--accent);color:var(--accent);}
.filter-chip.active{background:rgba(88,166,255,0.12);border-color:var(--accent);color:var(--accent);}
.filter-chip.digital-active{background:rgba(188,140,255,0.12);border-color:var(--purple);color:var(--purple);}
.filter-spacer{flex:1;}
.sort-select{background:var(--bg2);border:1px solid var(--bd);color:var(--t2);
  padding:5px 8px;border-radius:var(--r);font-size:12px;font-family:inherit;cursor:pointer;}

/* ── Product grid & cards ────────────────────────────────────────────────────── */
.shop-wrap{padding:20px 24px;max-width:1100px;margin:0 auto;}
.products-count{font-size:12px;color:var(--t3);font-family:'DM Mono',monospace;margin-bottom:14px;}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;}
.no-products{color:var(--t3);font-size:13px;padding:40px 0;grid-column:1/-1;text-align:center;}
.product-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  overflow:hidden;cursor:pointer;transition:border-color 0.2s,transform 0.2s;position:relative;}
.product-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.product-card.digital:hover{border-color:var(--purple);}
.product-img-link{display:block;text-decoration:none;}
.product-img{aspect-ratio:1;background:var(--bg3);display:flex;align-items:center;
  justify-content:center;position:relative;overflow:hidden;}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s;}
.product-card:hover .product-img img{transform:scale(1.04);}
.product-img-placeholder{font-size:38px;}
.quick-add{position:absolute;bottom:10px;left:50%;transform:translateX(-50%) translateY(8px);
  opacity:0;background:var(--accent);color:#0d1117;font-size:12px;font-weight:700;
  padding:7px 18px;border-radius:20px;border:none;cursor:pointer;white-space:nowrap;
  transition:all 0.2s;font-family:inherit;}
.product-card:hover .quick-add{opacity:1;transform:translateX(-50%) translateY(0);}
.product-info{padding:13px 13px 15px;}
.product-category{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;margin-bottom:4px;}
.product-name{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:9px;
  line-height:1.3;text-decoration:none;display:block;}
.product-name:hover{color:var(--accent);}
.product-footer{display:flex;align-items:center;justify-content:space-between;}
.product-price{font-size:16px;font-weight:700;}
.digital-price{color:var(--purple);}
.variant-dots{display:flex;gap:4px;}
.variant-dot{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.2);box-shadow:0 0 0 1px rgba(0,0,0,0.5);transition:transform 0.15s;}
.variant-dot:hover{transform:scale(1.2);}
.file-types{display:flex;gap:4px;}
.file-tag{font-size:9px;font-weight:600;font-family:'DM Mono',monospace;padding:2px 6px;
  border-radius:3px;background:var(--bg3);border:1px solid var(--bd2);color:var(--t3);}

/* ── Product detail ──────────────────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t2);
  font-family:'DM Mono',monospace;margin-bottom:24px;}
.breadcrumb a{color:var(--t2);text-decoration:none;}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb-sep{color:var(--bd);}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
@media(max-width:680px){.product-layout{grid-template-columns:1fr;gap:24px;}}
.gallery{display:flex;flex-direction:column;gap:10px;}
.gallery-main{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;}
.gallery-main img{width:100%;height:100%;object-fit:contain;}
.gallery-badge{position:absolute;top:14px;left:14px;}
.preview-watermark{font-size:80px;opacity:0.5;}
.preview-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(188,140,255,0.05),rgba(88,166,255,0.05));pointer-events:none;}
.preview-label{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  font-size:10px;font-family:'DM Mono',monospace;color:var(--t3);background:var(--bg);
  border:1px solid var(--bd2);padding:3px 10px;border-radius:4px;white-space:nowrap;}
.gallery-thumbs{display:flex;gap:8px;flex-wrap:wrap;}
.gallery-thumb{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);
  width:64px;height:64px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;overflow:hidden;transition:border-color 0.15s;flex-shrink:0;}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;}
.gallery-thumb.active{border-color:var(--accent);}
.gallery-thumb:hover{border-color:var(--t2);}
.product-info-col{display:flex;flex-direction:column;gap:18px;}
.product-type-row{display:flex;align-items:center;gap:8px;}
.digital-tag{display:flex;align-items:center;gap:5px;font-size:11px;font-family:'DM Mono',monospace;
  color:var(--purple);background:rgba(188,140,255,0.1);border:1px solid rgba(188,140,255,0.2);
  padding:4px 10px;border-radius:20px;}
.instant-tag{font-size:11px;font-family:'DM Mono',monospace;color:var(--green);
  background:rgba(63,185,80,0.1);border:1px solid rgba(63,185,80,0.2);padding:4px 10px;border-radius:20px;}
.product-title{font-size:clamp(20px,3vw,26px);font-weight:700;letter-spacing:-0.4px;line-height:1.2;}
.price-row{display:flex;align-items:baseline;gap:10px;}
.price-main{font-size:26px;font-weight:700;}
.divider{border:none;border-top:1px solid var(--bd2);}
.option-label{font-size:12px;font-family:'DM Mono',monospace;color:var(--t3);
  margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.option-label strong{color:var(--t2);font-weight:500;}
.color-swatches{display:flex;gap:8px;flex-wrap:wrap;}
.color-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;
  border:2px solid rgba(255,255,255,0.12);transition:all 0.15s;
  box-shadow:0 0 0 1px rgba(0,0,0,0.4);}
.color-swatch:hover{border-color:rgba(255,255,255,0.35);transform:scale(1.1);}
.color-swatch.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--bg),0 0 0 5px var(--accent);}
.color-swatch:hover{transform:scale(1.1);}
.size-grid{display:flex;gap:8px;flex-wrap:wrap;}
.size-btn{min-width:48px;height:40px;padding:0 12px;background:var(--bg2);border:1px solid var(--bd);
  border-radius:var(--r);color:var(--t2);font-size:13px;font-weight:600;cursor:pointer;
  transition:all 0.15s;font-family:inherit;}
.size-btn:hover:not(.unavailable){border-color:var(--t2);color:var(--t1);}
.size-btn.active{background:rgba(88,166,255,0.1);border-color:var(--accent);color:var(--accent);}
.size-btn.unavailable{opacity:0.3;cursor:not-allowed;text-decoration:line-through;}
.purchase-row{display:flex;gap:10px;align-items:stretch;}
.qty-control{display:flex;align-items:center;background:var(--bg2);border:1px solid var(--bd);
  border-radius:var(--r);overflow:hidden;}
.qty-btn{width:38px;height:48px;background:none;border:none;color:var(--t2);font-size:18px;
  cursor:pointer;transition:all 0.15s;display:flex;align-items:center;justify-content:center;}
.qty-btn:hover{color:var(--t1);background:var(--bg3);}
.qty-val{width:40px;text-align:center;font-size:15px;font-weight:600;border-left:1px solid var(--bd);
  border-right:1px solid var(--bd);line-height:48px;}
.perks{display:flex;flex-direction:column;gap:7px;}
.perk{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--t2);}
.perk-icon{width:26px;height:26px;background:var(--bg3);border:1px solid var(--bd2);
  border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;}
.included-files{display:flex;flex-direction:column;gap:8px;}
.file-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg3);
  border:1px solid var(--bd2);border-radius:var(--r);}
.file-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;
  justify-content:center;font-size:14px;flex-shrink:0;}
.file-info{flex:1;min-width:0;}
.file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.file-meta{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;}
.license-box{background:rgba(188,140,255,0.05);border:1px solid rgba(188,140,255,0.15);
  border-radius:var(--r);padding:12px 14px;}
.license-title{font-size:11px;color:var(--purple);font-family:'DM Mono',monospace;margin-bottom:6px;}
.license-text{font-size:12px;color:var(--t2);line-height:1.6;}
.product-description{font-size:13px;color:var(--t2);line-height:1.7;}

/* ── Cart page ───────────────────────────────────────────────────────────────── */
.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start;}
@media(max-width:720px){.cart-layout{grid-template-columns:1fr;}}
.cart-empty{text-align:center;padding:60px 20px;}
.cart-empty-icon{font-size:40px;margin-bottom:14px;}
.cart-empty-text{font-size:15px;color:var(--t2);margin-bottom:20px;}
.cart-loading{color:var(--t3);font-size:13px;font-family:'DM Mono',monospace;padding:40px 0;}
.cart-items{display:flex;flex-direction:column;gap:12px;}
.cart-item{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:14px;display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:center;
  transition:opacity 0.2s,transform 0.2s;}
.item-img{width:72px;height:72px;background:var(--bg3);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--bd2);
  overflow:hidden;flex-shrink:0;}
.item-img img{width:100%;height:100%;object-fit:cover;}
.item-details{min-width:0;}
.item-category{font-size:11px;color:var(--accent);font-family:'DM Mono',monospace;margin-bottom:3px;}
.item-name{font-size:14px;font-weight:600;color:var(--t1);text-decoration:none;display:block;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;}
.item-name:hover{color:var(--accent);}
.item-variant-label{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;}
.item-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;}
.item-price{font-size:16px;font-weight:700;}
.item-controls{display:flex;align-items:center;gap:6px;}
.remove-btn{width:30px;height:30px;background:none;border:1px solid var(--bd);border-radius:var(--r);
  color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:12px;transition:all 0.15s;}
.remove-btn:hover{border-color:var(--red);color:var(--red);}
.free-ship-note{font-size:12px;color:var(--green);font-family:'DM Mono',monospace;
  margin:10px 0;padding:8px 12px;background:rgba(63,185,80,0.06);
  border:1px solid rgba(63,185,80,0.15);border-radius:var(--r);}
.free-ship-note.muted{color:var(--t3);background:var(--bg2);border-color:var(--bd2);}
.promo-section{margin-top:14px;}
.promo-row{display:flex;gap:8px;}
.promo-input{flex:1;background:var(--bg2);border:1px solid var(--bd);color:var(--t1);
  padding:9px 12px;border-radius:var(--r);font-size:13px;outline:none;transition:border-color 0.15s;}
.promo-input:focus{border-color:var(--accent);}
.promo-input::placeholder{color:var(--t3);}
.promo-btn{padding:9px 14px;background:var(--bg3);border:1px solid var(--bd);color:var(--t2);
  border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;
  transition:all 0.15s;}
.promo-btn:hover{border-color:var(--accent);color:var(--accent);}
.order-summary{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:18px;position:sticky;top:72px;}
.summary-title{font-size:13px;font-weight:600;margin-bottom:14px;padding-bottom:10px;
  border-bottom:1px solid var(--bd2);}
.summary-line{display:flex;justify-content:space-between;align-items:center;
  margin-bottom:8px;font-size:13px;}
.summary-label{color:var(--t2);}
.summary-value{color:var(--t1);font-weight:500;}
.summary-value.green{color:var(--green);}
.summary-divider{border:none;border-top:1px solid var(--bd2);margin:12px 0;}
.summary-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.summary-total-label{font-size:15px;font-weight:700;}
.summary-total-value{font-size:20px;font-weight:700;}
.security-note{display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:11px;color:var(--t3);margin-top:10px;}

/* ── Checkout ─────────────────────────────────────────────────────────────────── */
.checkout-steps{display:flex;align-items:center;gap:8px;font-size:12px;
  font-family:'DM Mono',monospace;margin-bottom:24px;color:var(--t3);}
.checkout-steps .step{color:var(--t3);}
.checkout-steps .step.active{color:var(--accent);}
.checkout-steps .step.done{color:var(--green);}
.checkout-steps .step-sep{color:var(--bd);}
.checkout-layout{display:grid;grid-template-columns:1fr 320px;gap:28px;align-items:start;}
@media(max-width:700px){.checkout-layout{grid-template-columns:1fr;}}
.checkout-forms{display:flex;flex-direction:column;}
.stripe-error{color:var(--red);font-size:13px;margin-top:6px;font-family:'DM Mono',monospace;}
.checkout-error{color:var(--red);font-size:13px;padding:10px 14px;background:rgba(248,81,73,0.08);
  border:1px solid rgba(248,81,73,0.2);border-radius:var(--r);margin-bottom:12px;}
.optin-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--t2);
  margin-bottom:14px;cursor:pointer;}
.optin-row input{accent-color:var(--accent);}
.security-row{display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:11px;color:var(--t3);}
.cc-icons{display:flex;gap:4px;}
.cc-icon{font-size:8px;font-weight:700;padding:3px 6px;border-radius:3px;}
.cc-icon.visa{background:#1a1f5e;color:#fff;}
.cc-icon.mc{background:#252525;color:#eb001b;}
.cc-icon.amex{background:#2e77bc;color:#fff;}
.order-sidebar{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:18px;position:sticky;top:72px;}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 0;
  border-bottom:1px solid var(--bd2);}
.sidebar-item:last-of-type{border-bottom:none;}
.sidebar-img{width:48px;height:48px;background:var(--bg3);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  flex-shrink:0;position:relative;overflow:hidden;border:1px solid var(--bd2);}
.sidebar-qty{position:absolute;top:-5px;right:-5px;width:16px;height:16px;
  background:var(--t2);color:var(--bg);font-size:9px;font-weight:700;
  border-radius:50%;display:flex;align-items:center;justify-content:center;}
.sidebar-name{font-size:13px;font-weight:500;flex:1;min-width:0;}
.sidebar-price{font-size:13px;font-weight:600;flex-shrink:0;}
.sidebar-line{display:flex;justify-content:space-between;font-size:13px;color:var(--t2);margin-bottom:7px;}
.sidebar-line .green{color:var(--green);}
.sidebar-total{display:flex;justify-content:space-between;font-size:15px;font-weight:700;margin-top:4px;}

/* ── Confirmation ─────────────────────────────────────────────────────────────── */
.confirm-wrap{max-width:580px;margin:0 auto;}
.confirm-icon{width:64px;height:64px;background:rgba(63,185,80,0.1);
  border:1px solid rgba(63,185,80,0.25);border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-size:28px;margin:0 auto 18px;}
.confirm-title{font-size:26px;font-weight:700;letter-spacing:-0.4px;margin-bottom:8px;text-align:center;}
.confirm-sub{font-size:14px;color:var(--t2);line-height:1.6;margin-bottom:22px;text-align:center;}
.order-ref{font-family:'DM Mono',monospace;font-size:13px;color:var(--accent);
  background:rgba(88,166,255,0.08);border:1px solid rgba(88,166,255,0.2);
  padding:8px 16px;border-radius:var(--r);display:inline-block;margin-bottom:24px;
  display:block;text-align:center;}
.confirm-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:18px;margin-bottom:14px;}
.confirm-card-title{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;
  text-transform:uppercase;letter-spacing:0.05em;margin-bottom:12px;}
.confirm-steps{display:flex;flex-direction:column;gap:10px;}
.confirm-step{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--t2);}
.step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;}
.step-dot.done{background:rgba(63,185,80,0.15);color:var(--green);border:1px solid rgba(63,185,80,0.3);}
.step-dot.pending{background:var(--bg3);color:var(--t3);border:1px solid var(--bd);}
.step-dot.active-step{background:rgba(88,166,255,0.15);color:var(--accent);border:1px solid rgba(88,166,255,0.3);}
.download-item{display:flex;align-items:center;gap:12px;padding:11px 0;
  border-bottom:1px solid var(--bd2);}
.download-item:last-child{border-bottom:none;}
.dl-icon{width:40px;height:40px;background:rgba(188,140,255,0.1);
  border:1px solid rgba(188,140,255,0.2);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.dl-info{flex:1;min-width:0;}
.dl-name{font-size:13px;font-weight:500;}
.dl-meta{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;margin-top:2px;}
.dl-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;
  background:rgba(188,140,255,0.12);border:1px solid rgba(188,140,255,0.3);
  border-radius:var(--r);color:var(--purple);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all 0.15s;text-decoration:none;white-space:nowrap;flex-shrink:0;}
.dl-btn:hover{background:rgba(188,140,255,0.22);}
.expiry-note{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;
  text-align:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--bd2);}
.physical-item{display:flex;align-items:center;gap:12px;padding:10px 0;
  border-bottom:1px solid var(--bd2);}
.physical-item:last-child{border-bottom:none;}
.ph-icon{width:40px;height:40px;background:var(--bg3);border:1px solid var(--bd2);
  border-radius:var(--r);display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;}

/* ── Order lookup ─────────────────────────────────────────────────────────────── */
.lookup-wrap{max-width:480px;margin:0 auto;}
.lookup-header{text-align:center;margin-bottom:28px;}
.lookup-title{font-size:22px;font-weight:700;letter-spacing:-0.3px;margin-bottom:6px;}
.lookup-form{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);
  padding:22px;margin-bottom:18px;}
.result-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);padding:20px;}
.result-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;}
.result-order{font-family:'DM Mono',monospace;font-size:12px;color:var(--t3);}
.result-order strong{display:block;font-size:15px;color:var(--t1);margin-top:2px;}
.tracking-block{background:var(--bg);border:1px solid var(--bd2);border-radius:var(--r);
  padding:14px;margin-bottom:12px;}
.tracking-label{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;margin-bottom:4px;}
.tracking-num{font-size:15px;font-weight:600;color:var(--accent);font-family:'DM Mono',monospace;}
.tracking-carrier{font-size:12px;color:var(--t3);font-family:'DM Mono',monospace;margin-top:2px;}
.progress-bar{background:var(--bg3);border-radius:20px;height:6px;margin:12px 0 6px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--accent));
  border-radius:20px;transition:width 0.6s ease;}
.progress-steps{display:flex;justify-content:space-between;font-size:10px;
  color:var(--t3);font-family:'DM Mono',monospace;}
.progress-steps .done-step{color:var(--green);}
.progress-steps .cur{color:var(--accent);}

/* ── Responsive ───────────────────────────────────────────────────────────────── */
@media(max-width:600px){
  .nav-links{display:none;}
  .cart-item{grid-template-columns:56px 1fr;}
  .item-right{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;}
}
