  /* ---------- 1. DESIGN TOKENS (change these to re-skin the whole shop) ---------- */
  :root{
    --baize:        #14241d;   /* the dealer's table — deep green */
    --baize-deep:   #0e1a14;
    --surface:      #1c2c24;   /* cards sit on this */
    --surface-2:    #243730;
    --line:         #34473d;   /* hairline borders */
    --paper:        #f1ead9;   /* main text — warm parchment */
    --muted:        #93a298;   /* secondary text — sage */
    --gold:         #d4af5a;   /* prices & key accent (real product!) */
    --gold-soft:    #e7cd8a;
    --silver:       #c2cbcd;
    --radius:       14px;
    --maxw:         1140px;
  }

  *{ box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  body{
    margin:0;
    font-family:"Inter",system-ui,sans-serif;
    color:var(--paper);
    background:
      radial-gradient(120% 80% at 50% -10%, #1d3328 0%, var(--baize) 45%, var(--baize-deep) 100%);
    background-attachment:fixed;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  a{ color:inherit; }
  img{ max-width:100%; }
  .wrap{ max-width:var(--maxw); margin:0 auto; padding:0 22px; }

  /* visible focus for keyboard users */
  a:focus-visible, button:focus-visible{
    outline:2px solid var(--gold-soft);
    outline-offset:3px;
    border-radius:8px;
  }

  /* ---------- TOP CHROME: browser-style tabs + toolbar ---------- */
  .chrome{ position:sticky; top:0; z-index:50; }
  .tabbar{ display:flex; gap:4px; align-items:stretch; padding:8px 12px 0;
           background:var(--baize-deep); border-bottom:1px solid var(--line); }
  .tab{ flex:1 1 0; min-width:0; display:inline-flex; align-items:center; justify-content:center; gap:7px;
        text-align:center; font-family:"Aptos","Segoe UI",Inter,system-ui,sans-serif;
        font-size:.84rem; font-weight:600; letter-spacing:.01em;
        color:var(--paper); background:var(--surface); border:1px solid var(--line);
        border-bottom:none; border-radius:11px 11px 0 0; padding:11px 12px; cursor:pointer;
        line-height:1.2; position:relative; top:1px; transition:color .15s, background .15s; }
  .tab:hover{ color:var(--gold-soft); background:var(--surface-2); }
  .tab[aria-selected="true"]{ color:var(--gold); background:var(--baize); border-bottom-color:var(--baize); }
  .tab .n{ opacity:.7; }
  .tab .home-ic{ width:15px; height:15px; display:block; }
  .toolbar{ display:flex; align-items:center; justify-content:space-between;
            padding:11px 22px; background:var(--baize); border-bottom:1px solid var(--line); }
  .brand{ display:flex; flex-direction:row; align-items:center; gap:11px; background:none;
          border:none; cursor:pointer; padding:0; text-decoration:none; text-align:left; }
  .brand-text{ display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
  .logo-mark{ width:46px; height:46px; flex:none; display:block; }
  .hero-logo{ width:min(352px,81vw); height:auto; aspect-ratio:1; display:block;
              filter:drop-shadow(0 18px 34px rgba(0,0,0,.55)); }
  .brand b{ font-family:"Fraunces",serif; font-weight:600; font-size:1.4rem;
            letter-spacing:.01em; line-height:1; color:var(--paper); }
  .brand small{ font-family:"Space Mono",monospace; font-size:.62rem; letter-spacing:.22em;
                text-transform:uppercase; color:var(--muted); }
  .cart-btn{ display:inline-flex; align-items:center; gap:9px; font-family:"Space Mono",monospace;
             font-size:.78rem; letter-spacing:.04em; color:var(--paper); background:var(--surface-2);
             border:1px solid var(--line); padding:9px 15px; border-radius:999px; cursor:pointer;
             transition:border-color .2s, background .2s; }
  .cart-btn:hover{ border-color:var(--gold); background:var(--surface); }
  .cart-count{ min-width:20px; height:20px; padding:0 5px; border-radius:999px; background:var(--gold);
               color:#26200d; font-weight:700; font-size:.72rem; display:inline-grid; place-items:center; }
  .cart-icon{ color:var(--paper); display:inline-block; transform-origin:center; transition:color .2s; }
  .cart-btn:hover .cart-icon{ color:var(--gold); }
  .cart-icon.bump{ animation:cartBump .5s ease; }
  @keyframes cartBump{ 0%{transform:scale(1)} 25%{transform:scale(1.4)} 55%{transform:scale(.85)} 100%{transform:scale(1)} }
  .fly-coin{ position:fixed; z-index:9999; pointer-events:none; border-radius:50%; overflow:hidden;
             box-shadow:0 10px 22px rgba(0,0,0,.45); will-change:transform,opacity; }
  .fly-coin .coin{ width:100% !important; height:100% !important; margin:0 !important; }
  .fly-coin img{ width:100%; height:100%; object-fit:cover; border-radius:50%; }
  .qty-pick{ display:flex; align-items:center; gap:14px; margin:6px 0 16px; }
  .qty-label{ font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:#b7ad97; }
  .qty-stepper{ display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:999px; overflow:hidden; background:var(--surface-2); }
  .qty-stepper .qstep{ width:40px; height:40px; border:0; background:transparent; color:var(--paper); font-size:1.25rem; line-height:1; cursor:pointer; transition:background .15s, color .15s; }
  .qty-stepper .qstep:hover{ background:var(--surface); color:var(--gold); }
  .qty-stepper > span{ min-width:36px; text-align:center; font-family:"Space Mono",monospace; font-weight:700; font-size:.98rem; color:var(--paper); }
  .card-buy{ display:flex; align-items:center; gap:10px; margin-top:12px; }
  .card-buy .add{ flex:1; }
  .qty-stepper.sm{ flex:0 0 auto; }
  .qty-stepper.sm .qstep{ width:34px; height:34px; font-size:1.05rem; }
  .qty-stepper.sm > span{ min-width:26px; font-size:.9rem; }
  .qty-num{ cursor:text; -webkit-user-select:text; user-select:text; padding:0 2px; border-radius:4px; }
  .qty-num:focus{ outline:none; background:var(--surface); box-shadow:inset 0 0 0 1px var(--gold); }
  .about{ max-width:680px; margin:18px auto 0; padding:36px 22px 8px; text-align:center; }
  .about h2{ font-family:"Fraunces",Georgia,serif; font-weight:600; font-size:1.8rem; color:var(--paper); margin:0; }
  .about .about-rule{ width:54px; height:2px; background:var(--gold); border:0; margin:12px auto 22px; opacity:.75; }
  .about p{ color:#cdbfa3; line-height:1.75; margin:0 0 16px; font-size:1.03rem; }
  .about .sign{ font-family:"Fraunces",Georgia,serif; font-style:italic; color:var(--gold); font-size:1.06rem; margin-top:6px; }
  .tb-left{ display:flex; align-items:center; gap:16px; }
  .nav-back{ display:inline-flex; align-items:center; gap:6px; font-family:"Space Mono",monospace;
             font-size:.74rem; letter-spacing:.04em; color:var(--paper); background:var(--surface-2);
             border:1px solid var(--line); padding:8px 14px; border-radius:999px; cursor:pointer;
             transition:border-color .18s, color .18s; }
  .nav-back:hover{ border-color:var(--gold); color:var(--gold); }
  .nav-back.hidden{ display:none; }

  /* ---------- HERO ---------- */
  .hero{ display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
         padding:72px 0 60px; }
  .eyebrow{
    font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.28em;
    text-transform:uppercase; color:var(--gold); margin:0 0 18px;
  }
  .hero h1{
    font-family:"Fraunces",serif; font-weight:600; font-size:clamp(2.4rem,5vw,3.7rem);
    line-height:1.02; margin:0 0 18px; letter-spacing:-.01em;
  }
  .hero h1 em{ font-style:italic; color:var(--gold-soft); }
  .hero p{ color:var(--muted); font-size:1.06rem; max-width:46ch; margin:0 0 28px; }
  .cta{
    display:inline-block; border:none; cursor:pointer;
    font-family:"Space Mono",monospace; font-size:.82rem;
    letter-spacing:.06em; text-decoration:none; color:#22190a; background:var(--gold);
    padding:14px 26px; border-radius:999px; font-weight:700; transition:transform .15s, box-shadow .2s;
    box-shadow:0 8px 24px -10px rgba(212,175,90,.7);
  }
  .cta:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(212,175,90,.8); }
  .hero-stage{ display:grid; place-items:center; }

  /* ---------- THE CSS COINS (the signature element) ---------- */
  /* A coin is a disc: reeded edge + metal face + embossed centre. */
  .coin{
    position:relative; border-radius:50%; display:grid; place-items:center;
    /* the reeded (ridged) edge, drawn with a repeating cone of light/dark */
    background:repeating-conic-gradient(var(--edge-d) 0 3deg, var(--edge-l) 3deg 6deg);
    box-shadow:0 18px 34px -14px rgba(0,0,0,.7);
  }
  .coin::before{ /* the metal face, slightly inset from the edge */
    content:""; position:absolute; inset:7%;
    border-radius:50%;
    background:radial-gradient(circle at 34% 28%, var(--face-hi) 0%, var(--face-mid) 46%, var(--face-lo) 100%);
    box-shadow:inset 0 2px 4px rgba(255,255,255,.35), inset 0 -8px 16px rgba(0,0,0,.35);
  }
  .coin .face{ /* embossed text/motif in the centre */
    position:relative; z-index:2; text-align:center; color:var(--emboss);
    font-family:"Fraunces",serif; font-weight:600; line-height:1.05;
    text-shadow:0 1px 0 var(--face-hi), 0 -1px 1px rgba(0,0,0,.45);
    padding:0 6px;
  }
  .coin .face .big{ display:block; font-size:1.5em; }
  .coin .face .sm{ font-family:"Space Mono",monospace; font-weight:700;
                   font-size:.5em; letter-spacing:.12em; opacity:.8; }
  /* coloured commemoratives: a "printed" colour spot in the middle */
  .coin .spot{ position:absolute; z-index:1; width:46%; aspect-ratio:1; border-radius:50%;
               box-shadow:inset 0 1px 3px rgba(0,0,0,.4), 0 0 0 1px rgba(0,0,0,.18); }
  .coin .face.on-color{ color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.55); }
  .coin.photo{ background:#0e1812; overflow:hidden; border-radius:16px; aspect-ratio:1;
               box-shadow:0 16px 32px -14px rgba(0,0,0,.75); }
  .coin.photo::before{ content:none; }
  .coin.photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
  /* slow shine sweep across the hero coin */
  .coin .shine{
    position:absolute; inset:7%; border-radius:50%; z-index:3; overflow:hidden; pointer-events:none;
  }
  .coin .shine::after{
    content:""; position:absolute; top:-60%; left:-30%; width:60%; height:220%;
    background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
    transform:rotate(18deg); animation:sweep 5.5s ease-in-out infinite;
  }
  @keyframes sweep{ 0%,70%{ left:-40%; } 100%{ left:130%; } }

  /* metal recipes — swap a coin's metal by changing its class */
  .gold  { --edge-d:#8a6d2b; --edge-l:#caa14d;
           --face-hi:#f8e9a8; --face-mid:#cda04c; --face-lo:#8a6a24; --emboss:#7c5e1e; }
  .silver{ --edge-d:#7e8a8c; --edge-l:#c9d1d2;
           --face-hi:#f4f6f6; --face-mid:#bcc6c7; --face-lo:#828d8e; --emboss:#6f7a7b; }
  .copper{ --edge-d:#7a4a24; --edge-l:#b5723c;
           --face-hi:#f0c79a; --face-mid:#c07e44; --face-lo:#7e4d26; --emboss:#6e4222; }

  .hero-coin{ width:min(330px,72vw); aspect-ratio:1; }
  .hero-coin .face .big{ font-size:2.1em; }
  .felt{ /* the velvet pad the hero coin rests on */
    width:min(420px,86vw); aspect-ratio:1; border-radius:50%; display:grid; place-items:center;
    background:radial-gradient(circle at 50% 40%, #21362b 0%, #16241d 70%, transparent 72%);
  }

  /* ---------- TRUST STRIP ---------- */
  .trust{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
          background:var(--line); border:1px solid var(--line); border-radius:var(--radius);
          overflow:hidden; margin:8px 0 64px; }
  .trust div{ background:var(--surface); padding:20px 22px; }
  .trust h4{ font-family:"Space Mono",monospace; font-size:.7rem; letter-spacing:.14em;
             text-transform:uppercase; color:var(--gold); margin:0 0 6px; }
  .trust p{ margin:0; font-size:.9rem; color:var(--muted); }

  /* ---------- PRODUCT GRID ---------- */
  .section-head{ display:flex; align-items:flex-end; justify-content:space-between; margin:0 0 26px; }
  .section-head h2{ font-family:"Fraunces",serif; font-weight:600; font-size:2rem; margin:0; }
  .section-head span{ font-family:"Space Mono",monospace; font-size:.74rem; color:var(--muted); letter-spacing:.08em; }

  /* a labelled group of coins (Gold / Silver / Australian $2) */
  .cat{ margin-bottom:52px; }
  .cat-head{ font-family:"Fraunces",serif; font-weight:600; font-size:1.3rem; margin:0 0 22px;
             padding-bottom:12px; border-bottom:1px solid var(--line);
             display:flex; align-items:baseline; gap:11px; }
  .cat-head span{ font-family:"Space Mono",monospace; font-size:.7rem; color:var(--muted); letter-spacing:.1em; }

  /* page views: Home vs a category */
  .view{ display:none; }
  .view.active{ display:block; }
  .empty-cat{ color:var(--muted); font-family:"Space Mono",monospace; font-size:.85rem; line-height:1.6;
        text-align:center; padding:64px 20px; border:1px dashed var(--line); border-radius:14px; }

  /* small disclaimer at the foot of the Circulated Coins section + pages */
  .cat-note{ margin:30px 0 8px; padding-top:14px; border-top:1px solid var(--line);
             color:var(--muted); font-size:.74rem; line-height:1.5; max-width:75ch; }
  .cat-note strong{ color:var(--muted); font-weight:600; }

  /* ---------- COIN DETAIL PAGE ---------- */
  .card{ cursor:pointer; }
  .card:focus-visible{ outline:2px solid var(--gold-soft); outline-offset:3px; }
  .back{ font-family:"Space Mono",monospace; font-size:.78rem; letter-spacing:.03em; color:var(--muted);
         background:none; border:none; cursor:pointer; padding:0; margin:0 0 26px; }
  .back:hover{ color:var(--gold); }
  .detail{ display:grid; grid-template-columns:minmax(0,38%) minmax(0,1fr); gap:32px; align-items:start; }

  /* left — product gallery (sticky, compact) */
  .detail-gallery{ position:sticky; top:20px; }
  .gallery-main{ background:var(--surface); border:1px solid var(--line); border-radius:14px;
                 padding:12px; display:grid; place-items:center; }
  .gallery-main img{ width:100%; height:auto; border-radius:10px; display:block; }
  .gallery-main.drawn{ padding:30px; }
  .gallery-main.drawn .coin{ width:200px; aspect-ratio:1; }
  .gallery-main.drawn .coin .face .big{ font-size:1.8em; }
  .thumbs{ display:flex; gap:8px; margin-top:10px; flex-wrap:wrap; }
  .thumb{ width:56px; height:56px; padding:0; border:1px solid var(--line); border-radius:9px;
          background:var(--surface); cursor:pointer; overflow:hidden; }
  .thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
  .thumb.active{ border-color:var(--gold); }

  /* right — product info (compact, above-the-fold) */
  .detail-info .eyebrow{ margin:0 0 6px; }
  .detail-info h2{ font-family:"Fraunces",serif; font-weight:600; font-size:1.9rem; line-height:1.05; margin:0 0 12px; color:#f3efe6; }
  .price-stock{ display:flex; align-items:baseline; gap:16px; flex-wrap:wrap; margin:0 0 14px; }
  .detail-price{ font-family:"Space Mono",monospace; font-weight:700; font-size:1.7rem; color:var(--gold); margin:0; }
  .detail-price .cur{ font-size:.78rem; color:var(--muted); letter-spacing:.05em; }
  .detail-stock{ font-family:"Space Mono",monospace; font-size:.78rem; margin:0; }
  .detail-stock.in{ color:#8fd6a3; }
  .detail-stock.out{ color:var(--muted); }
  .detail-stock .dot{ display:inline-block; width:8px; height:8px; border-radius:50%; background:#3fbf6a;
                      margin-right:6px; box-shadow:0 0 0 3px rgba(63,191,106,.18); }

  /* attribute chips */
  .chips{ list-style:none; padding:0; margin:0 0 18px; display:flex; flex-wrap:wrap; gap:8px; }
  .chips li{ font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.02em; color:#d3dcd3;
             border:1px solid var(--line); border-radius:999px; padding:6px 12px; background:rgba(255,255,255,.02); }
  .chips li::before{ content:"✓ "; color:var(--gold); font-weight:700; }

  /* purchase controls */
  .buy-row{ display:flex; align-items:stretch; gap:10px; margin:0 0 10px; }
  .buy-row .qty-stepper{ flex:none; }
  .buy-row .detail-add{ flex:1; }
  .detail-add{ font-family:"Space Mono",monospace; font-size:.86rem; letter-spacing:.04em; font-weight:700;
               color:#22190a; background:var(--gold); border:none; border-radius:12px; padding:15px 22px;
               cursor:pointer; transition:background .18s; box-shadow:0 12px 26px -12px rgba(212,175,90,.8); }
  .detail-add:hover{ background:var(--gold-soft); }
  .detail-add:disabled{ background:var(--line); color:var(--muted); box-shadow:none; cursor:default; }
  .buy-now{ width:100%; font-family:"Space Mono",monospace; font-size:.82rem; letter-spacing:.04em; font-weight:700;
            color:var(--gold); background:transparent; border:1px solid var(--gold); border-radius:12px;
            padding:12px 22px; cursor:pointer; transition:background .18s,color .18s; margin:0; }
  .buy-now:hover{ background:var(--gold); color:#22190a; }
  .buy-now:disabled{ opacity:.6; cursor:default; }

  /* inline trust icons under purchase */
  .trust-row{ list-style:none; padding:0; display:flex; flex-wrap:wrap; gap:6px 16px; margin:16px 0 0;
              font-family:"Space Mono",monospace; font-size:.7rem; letter-spacing:.02em; color:var(--muted); }
  .trust-row a{ color:var(--muted); text-decoration:none; }
  .trust-row a:hover{ color:var(--gold); }

  /* tabs: Overview / Specifications / Shipping / Returns */
  .detail-tabs{ margin-top:34px; }
  .tablist{ display:flex; gap:2px; border-bottom:1px solid var(--line); flex-wrap:wrap; }
  .tabbtn{ font-family:"Space Mono",monospace; font-size:.76rem; letter-spacing:.03em; font-weight:700;
           color:var(--muted); background:none; border:none; cursor:pointer; padding:12px 16px;
           border-bottom:2px solid transparent; margin-bottom:-1px; }
  .tabbtn:hover{ color:#cdd7cd; }
  .tabbtn.active{ color:var(--gold); border-bottom-color:var(--gold); }
  .tabpanel{ display:none; padding:20px 2px; }
  .tabpanel.active{ display:block; }
  .detail-desc{ color:#c2ccc2; font-size:1rem; line-height:1.65; margin:0; max-width:64ch; }
  .tabpanel .highlights{ list-style:none; padding:0; margin:14px 0 0; display:grid; gap:7px; }
  .tabpanel .highlights li{ position:relative; padding-left:24px; color:#cdd7cd; font-size:.92rem; }
  .tabpanel .highlights li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--gold); font-weight:700; }
  .tabpanel p{ color:#c2ccc2; line-height:1.6; margin:0; max-width:70ch; }
  .tabpanel a{ color:var(--gold); }

  /* compact 2-column specs grid */
  .spec-grid{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0 32px; max-width:580px; }
  .spec-row{ display:flex; justify-content:space-between; gap:12px; padding:8px 0; border-bottom:1px solid var(--line); }
  .spec-k{ color:var(--muted); font-size:.86rem; }
  .spec-v{ color:#dbe3db; font-size:.86rem; text-align:right; }

  @media (max-width:780px){
    .detail{ grid-template-columns:1fr; gap:20px; }
    .detail-gallery{ position:static; max-width:320px; margin:0 auto; }
    .detail-info h2{ font-size:1.7rem; }
    .gallery-main.drawn .coin{ width:190px; }
    .spec-grid{ grid-template-columns:1fr; }
  }

  /* ---------- STOCK + OWNER PANEL ---------- */
  .stock-line{ font-family:"Space Mono",monospace; font-size:.7rem; color:var(--muted);
               margin:10px 0 0; text-align:center; }
  .soldout{ font-family:"Space Mono",monospace; font-size:.72rem; color:var(--muted);
            border:1px solid var(--line); border-radius:999px; padding:9px 14px; }
  .detail-stock{ font-family:"Space Mono",monospace; font-size:.8rem; color:var(--silver); margin:0 0 18px; }
  .detail-stock.out{ color:var(--muted); }
  .detail-add:disabled{ background:var(--surface-2); color:var(--muted); cursor:not-allowed; box-shadow:none; }

  .foot-link{ font-family:"Space Mono",monospace; font-size:.74rem; letter-spacing:.04em; color:var(--muted);
              background:none; border:none; cursor:pointer; text-decoration:underline; }
  .foot-link:hover{ color:var(--gold); }
  .admin h2{ font-family:"Fraunces",serif; font-weight:600; font-size:2rem; margin:0 0 8px; }
  .admin-note{ font-family:"Space Mono",monospace; font-size:.8rem; color:var(--muted); margin:0 0 24px; line-height:1.5; }
  .admin-note.ok{ color:var(--gold-soft); }
  .admin-note.warn{ color:#e0b15a; }
  .admin-tbl{ width:100%; border-collapse:collapse; margin-bottom:26px; }
  .admin-tbl th{ text-align:left; font-family:"Space Mono",monospace; font-size:.66rem; letter-spacing:.1em;
                 text-transform:uppercase; color:var(--muted); padding:0 12px 12px; border-bottom:1px solid var(--line); }
  .admin-tbl th:nth-child(2), .admin-tbl th:nth-child(3){ width:150px; }
  .admin-tbl td{ padding:12px; border-bottom:1px solid var(--line); vertical-align:middle; }
  .ac-name{ font-family:"Fraunces",serif; font-size:1rem; color:var(--paper); }
  .ac-cur{ color:var(--muted); margin-right:4px; font-family:"Space Mono",monospace; }
  .ac-in{ width:96px; background:var(--baize-deep); border:1px solid var(--line); color:var(--paper);
          font-family:"Space Mono",monospace; font-size:.9rem; padding:8px 10px; border-radius:8px; }
  .ac-in:focus{ outline:none; border-color:var(--gold); }

  .grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(248px,1fr)); gap:22px;
         padding-bottom:80px; }
  .card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
         padding:26px 22px 20px; display:flex; flex-direction:column; align-items:center;
         transition:transform .18s, border-color .18s; }
  .card:hover{ transform:translateY(-4px); border-color:#4a5f53; }
  .card .coin{ width:128px; aspect-ratio:1; margin-bottom:20px; }
  /* photo products: show the whole image at full card width (no bars, no crop) */
  .card .coin.photo{ width:100%; aspect-ratio:auto; background:transparent;
                     box-shadow:none; border-radius:0; margin-bottom:18px; }
  .card .coin.photo img{ position:static; width:100%; height:auto; border-radius:12px;
                         filter:drop-shadow(0 12px 20px rgba(0,0,0,.5)); }
  .card .coin .face .big{ font-size:1.15em; }
  .card h3{ font-family:"Fraunces",serif; font-weight:600; font-size:1.12rem;
            text-align:center; margin:0 0 12px; line-height:1.15; }
  .card .desc{ font-size:.82rem; color:var(--muted); text-align:center;
               margin:0 0 16px; line-height:1.45;
               display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
               overflow:hidden; }
  /* the specimen "data plate" — coin facts as a little label */
  .plate{ width:100%; background:var(--baize-deep); border:1px solid var(--line);
          border-radius:9px; padding:9px 11px; margin-bottom:16px; }
  .plate dl{ display:grid; grid-template-columns:auto 1fr; gap:3px 10px; margin:0;
             font-family:"Space Mono",monospace; font-size:.68rem; }
  .plate dt{ color:var(--muted); letter-spacing:.06em; }
  .plate dd{ margin:0; text-align:right; color:var(--paper); }
  .card .row{ width:100%; display:flex; align-items:center; justify-content:space-between;
              gap:10px; margin-top:auto; }
  .price{ font-family:"Space Mono",monospace; font-weight:700; font-size:1.16rem; color:var(--gold); }
  .add{ font-family:"Space Mono",monospace; font-size:.74rem; letter-spacing:.04em;
        border:1px solid var(--gold); color:var(--gold); background:transparent;
        padding:9px 14px; border-radius:999px; cursor:pointer; transition:.18s; white-space:nowrap; }
  .add:hover{ background:var(--gold); color:#22190a; }

  /* ---------- CART DRAWER ---------- */
  .overlay{ position:fixed; inset:0; background:rgba(6,12,9,.6); opacity:0; visibility:hidden;
            transition:.25s; z-index:50; }
  .overlay.open{ opacity:1; visibility:visible; }
  .drawer{ position:fixed; top:0; right:0; height:100%; width:min(400px,100%);
           background:var(--baize); border-left:1px solid var(--line);
           transform:translateX(100%); transition:transform .28s cubic-bezier(.4,0,.2,1);
           z-index:60; display:flex; flex-direction:column; }
  .drawer.open{ transform:translateX(0); }
  .drawer header{ position:static; backdrop-filter:none; background:transparent; }
  .drawer-top{ display:flex; align-items:center; justify-content:space-between;
               padding:22px 22px 16px; border-bottom:1px solid var(--line); }
  .drawer-top h3{ font-family:"Fraunces",serif; font-weight:600; font-size:1.3rem; margin:0; }
  .x{ background:none; border:none; color:var(--muted); font-size:1.5rem; cursor:pointer; line-height:1; }
  .x:hover{ color:var(--paper); }
  .items{ flex:1; overflow-y:auto; padding:8px 22px; }
  .empty{ color:var(--muted); text-align:center; padding:60px 10px; font-size:.95rem; }
  .line{ display:flex; gap:14px; align-items:center; padding:16px 0; border-bottom:1px solid var(--line); }
  .line .coin{ width:48px; aspect-ratio:1; flex:none; }
  .line .coin .face{ display:none; } /* tiny — skip the text */
  .line .info{ flex:1; min-width:0; }
  .line .info b{ font-family:"Fraunces",serif; font-weight:600; font-size:.95rem; display:block; }
  .line .info .p{ font-family:"Space Mono",monospace; font-size:.8rem; color:var(--gold); }
  .qty{ display:flex; align-items:center; gap:9px; font-family:"Space Mono",monospace; font-size:.85rem; }
  .qty button{ width:24px; height:24px; border-radius:6px; border:1px solid var(--line);
               background:var(--surface-2); color:var(--paper); cursor:pointer; font-size:1rem; line-height:1; }
  .qty button:hover{ border-color:var(--gold); }
  .drawer-foot{ border-top:1px solid var(--line); padding:20px 22px 26px; }
  .subtotal{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:16px; }
  .subtotal span{ color:var(--muted); font-size:.85rem; font-family:"Space Mono",monospace; letter-spacing:.04em; }
  .subtotal b{ font-family:"Space Mono",monospace; font-size:1.4rem; color:var(--gold); }
  .checkout{ width:100%; font-family:"Space Mono",monospace; font-size:.85rem; letter-spacing:.05em;
             background:var(--gold); color:#22190a; border:none; padding:15px; border-radius:10px;
             font-weight:700; cursor:pointer; transition:.18s; }
  .checkout:hover:not(:disabled){ background:var(--gold-soft); }
  .checkout:disabled{ opacity:.4; cursor:not-allowed; }
  .note{ margin:14px 0 0; font-size:.76rem; color:var(--muted); text-align:center; line-height:1.5; }

  /* ---------- FOOTER ---------- */
  footer{ border-top:1px solid var(--line); padding:34px 0; }
  .foot{ display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center;
         font-family:"Space Mono",monospace; font-size:.74rem; color:var(--muted); letter-spacing:.04em; }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width:780px){
    .hero{ grid-template-columns:1fr; padding:48px 0 40px; text-align:center; }
    .hero p{ margin-inline:auto; }
    .hero-stage{ order:-1; }
    .trust{ grid-template-columns:1fr; }
    .tabbar{ padding:8px 8px 0; }
    .toolbar{ padding:10px 14px; }
    .tab{ font-size:.66rem; padding:9px 5px; gap:4px; }
    .brand small{ display:none; }
  }

  /* respect people who prefer no motion */
  @media (prefers-reduced-motion:reduce){
    *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  }
