/* Ambassador join funnel — all selectors scoped under #amb-join so nothing here
   can affect the rest of the site. Reuses the theme's brand tokens + fonts. */

#amb-join{ --g:var(--gold,#C9A24B); --bn:var(--bone,#F2EEE3); --ob:var(--obsidian,#14110A);
  --el:var(--bg-elev,#1C1810); --mut:var(--fg-muted,#A89E89); --em:var(--ember,#BB3B2B);
  color:var(--bn); }
#amb-join .wrap{max-width:1120px;margin:0 auto;padding:0 22px}
#amb-join .gold{color:var(--g)}
#amb-join .eyebrow{font-family:var(--font-ui,sans-serif);font-weight:700;letter-spacing:.28em;text-transform:uppercase;font-size:11px;color:var(--g)}

/* hero */
#amb-join .amb-hero{position:relative;text-align:center;padding:74px 0 54px;
  background:radial-gradient(120% 90% at 50% 0%,#241d10 0%,var(--ob) 62%)}
#amb-join .step-count{display:inline-flex;gap:8px;align-items:center;font-size:12px;color:var(--mut);
  border:1px solid #3a3118;border-radius:999px;padding:6px 14px;margin-bottom:22px;font-weight:600}
#amb-join .step-count b{color:var(--g)}
#amb-join .amb-hero h1{font-family:var(--font-display,serif);font-weight:800;font-size:clamp(34px,6vw,60px);line-height:1.02;letter-spacing:.01em;margin:0}
#amb-join .amb-hero .tag{margin:18px auto 0;max-width:560px;color:var(--mut);font-size:17px}
#amb-join .reframe{margin:26px auto 0;max-width:620px;font-size:15px;color:var(--bn);
  background:rgba(201,162,75,.08);border:1px solid rgba(201,162,75,.28);border-radius:14px;padding:16px 20px}
#amb-join .reframe b{color:var(--g)}
#amb-join .flow{display:flex;justify-content:center;gap:0;margin:30px auto 0;flex-wrap:wrap;max-width:760px}
#amb-join .flow .f{flex:1;min-width:140px;padding:0 12px;position:relative}
#amb-join .flow .f .n{font-family:var(--font-display,serif);font-size:22px;color:var(--g);font-weight:700}
#amb-join .flow .f .t{font-weight:700;font-size:14px;margin-top:4px}
#amb-join .flow .f .d{font-size:12.5px;color:var(--mut);margin-top:3px}
#amb-join .flow .f:not(:last-child):after{content:"\2192";position:absolute;right:-8px;top:2px;color:#4a3d1d}

/* trust stats */
#amb-join .stats{border-top:1px solid #2a2414;border-bottom:1px solid #2a2414;margin-top:34px;background:#100d07}
#amb-join .stats .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:18px;padding:22px}
#amb-join .stat{text-align:center;min-width:120px}
#amb-join .stat .num{font-family:var(--font-display,serif);font-weight:800;font-size:clamp(24px,4vw,34px);color:var(--g);line-height:1}
#amb-join .stat .lbl{font-size:12px;color:var(--mut);margin-top:6px;letter-spacing:.04em}

/* picker */
#amb-join .section{padding:48px 0 10px}
#amb-join .section-head{text-align:center;margin-bottom:30px}
#amb-join .section-head h2{font-family:var(--font-display,serif);font-weight:700;font-size:clamp(26px,4vw,38px);margin:8px 0 0}
#amb-join .section-head .lead{color:var(--mut);margin-top:10px;font-size:15px}
#amb-join .urgency{display:flex;width:max-content;max-width:100%;margin:16px auto 0;align-items:center;gap:8px;
  font-size:12.5px;color:#e8c87a;font-weight:600;
  background:rgba(187,59,43,.12);border:1px solid rgba(187,59,43,.35);padding:8px 16px;border-radius:999px;text-align:left}
#amb-join .pulse{width:8px;height:8px;border-radius:50%;background:var(--em);animation:ambpulse 1.4s infinite}
@keyframes ambpulse{0%{box-shadow:0 0 0 0 rgba(187,59,43,.6)}70%{box-shadow:0 0 0 8px rgba(187,59,43,0)}100%{box-shadow:0 0 0 0 rgba(187,59,43,0)}}

#amb-join .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:760px){#amb-join .grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media(max-width:480px){#amb-join .grid{grid-template-columns:1fr}}

/* Reset the theme's GLOBAL .card rule that otherwise leaks in here: its
   aspect-ratio:4/5 forced these cards to a fixed-tall box (content spilled out
   and overlapped the footer), and grid tracks sized to the product image's
   intrinsic width pushed cards off-screen. Restore content-sized, shrinkable cards. */
#amb-join .card{aspect-ratio:auto;min-width:0;place-items:stretch;padding:0}
#amb-join .card::after{content:none;display:none}

#amb-join .card{background:var(--el);border:1px solid #2a2414;border-radius:16px;overflow:visible;
  display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
#amb-join .card:hover{transform:translateY(-3px);border-color:#3f3419}
#amb-join .card.in-kit{border-color:var(--g);box-shadow:0 0 0 1px var(--g)}
#amb-join .card .art{flex:none;aspect-ratio:1;width:100%;display:flex;align-items:center;justify-content:center;padding:10px;background:#0e0c07;position:relative;border:0;border-radius:15px 15px 0 0;overflow:hidden;cursor:zoom-in;font:inherit}
#amb-join .card .art img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .25s var(--ease,ease)}
#amb-join .card .art:hover img{transform:scale(1.04)}
/* zoom affordance so it's obvious the image opens a bigger preview */
#amb-join .card .art .zoom{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--bn);background:rgba(12,10,6,.62);
  border:1px solid rgba(242,238,227,.25);opacity:0;transform:translateY(4px);transition:.18s;backdrop-filter:blur(4px)}
#amb-join .card .art:hover .zoom,#amb-join .card .art:focus-visible .zoom{opacity:1;transform:translateY(0)}

/* product-type filter bar */
#amb-join .amb-filter{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0 0 26px}
#amb-join .fbtn{font-family:var(--font-ui,sans-serif);font-size:13px;font-weight:600;letter-spacing:.01em;
  color:var(--bn);background:var(--el);border:1px solid #2a2414;border-radius:999px;padding:8px 16px;cursor:pointer;transition:.15s}
#amb-join .fbtn:hover{border-color:var(--g)}
#amb-join .fbtn.sel{background:var(--g);color:#191307;border-color:var(--g)}

/* pager */
#amb-join .amb-pager{display:flex;align-items:center;justify-content:center;gap:16px;margin:30px 0 4px}
#amb-join .amb-pager[hidden]{display:none}
#amb-join .amb-pager .pg{font-family:var(--font-ui,sans-serif);font-size:13px;font-weight:700;color:var(--bn);
  background:var(--el);border:1px solid #2a2414;border-radius:999px;padding:9px 18px;cursor:pointer;transition:.15s}
#amb-join .amb-pager .pg:hover:not([disabled]){border-color:var(--g);color:var(--g)}
#amb-join .amb-pager .pg[disabled]{opacity:.4;cursor:default}
#amb-join .amb-pager .pg-info{font-size:12.5px;color:var(--mut);letter-spacing:.04em}

/* quick-add modal (image + colour + size + add) */
#amb-join .lightbox{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;
  padding:24px;background:rgba(8,6,3,.9);backdrop-filter:blur(6px)}
#amb-join .lightbox.show{display:flex}
#amb-join .qa-box{position:relative;display:flex;gap:0;max-width:840px;width:100%;max-height:88vh;overflow:hidden;
  background:var(--el);border:1px solid #2a2414;border-radius:20px;box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
#amb-join .qa-media{flex:1 1 52%;background:#fff;display:flex;align-items:center;justify-content:center;min-width:0}
#amb-join .qa-media img{width:100%;height:100%;max-height:88vh;object-fit:contain}
#amb-join .qa-info{flex:1 1 48%;padding:28px 26px;display:flex;flex-direction:column;overflow:auto}
#amb-join .qa-name{font-family:var(--font-display,serif);font-weight:700;font-size:22px;line-height:1.1;color:var(--bn)}
#amb-join .qa-info .cRow,#amb-join .qa-info .sRow{margin-top:0}
#amb-join .qa-price{font-weight:800;font-size:20px;margin-top:16px}
#amb-join .qa-add{margin-top:16px;width:100%;border:0;border-radius:10px;background:var(--g);color:#191307;
  font-weight:800;font-size:15px;padding:13px;cursor:pointer;font-family:var(--font-ui,sans-serif);transition:.12s}
#amb-join .qa-add:hover{filter:brightness(1.06)}
#amb-join .qa-add.added{background:#2a3a22;color:#9fe08a}
#amb-join .qa-add.err{background:#3a2420;color:#f0b9ad}
#amb-join .lb-close{position:absolute;top:12px;right:12px;z-index:2;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(20,17,10,.18);background:rgba(255,255,255,.85);color:#191307;font-size:24px;line-height:1;cursor:pointer;transition:.15s}
#amb-join .lb-close:hover{border-color:var(--g);color:var(--g);background:#fff}
@media(max-width:640px){#amb-join .qa-box{flex-direction:column;max-height:92vh;overflow:auto}
  #amb-join .qa-media{flex:none;aspect-ratio:1}}
#amb-join .card .body{padding:13px 13px 15px;flex:1 1 auto;display:flex;flex-direction:column}
#amb-join .card .name{font-family:var(--font-display,serif);font-weight:600;font-size:15px;line-height:1.2}
#amb-join .row{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
#amb-join .pill{font-size:11.5px;font-weight:600;border:1px solid #3a3118;background:transparent;color:var(--bn);
  border-radius:8px;padding:5px 9px;cursor:pointer;transition:.12s}
#amb-join .pill:hover{border-color:var(--g)}
#amb-join .pill.sel{background:var(--g);color:#1a1408;border-color:var(--g)}
/* colour pills — swatch dot + name; quick-pick from the card, swaps the image.
   Every swatch carries a light ring so even Black/Navy/Maroon read clearly on
   the dark card (otherwise a dark fill on a dark bg looks invisible). */
#amb-join .rlbl{font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mut);margin-top:12px;margin-bottom:6px}
#amb-join .cRow{margin-top:0}
#amb-join .sRow{margin-top:0}
#amb-join .cpill{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;
  border:1px solid #4a3f20;background:rgba(255,255,255,.04);color:var(--bn);border-radius:9px;
  padding:5px 10px 5px 6px;cursor:pointer;transition:.12s;line-height:1}
#amb-join .cpill:hover{border-color:var(--g);background:rgba(201,162,75,.10)}
#amb-join .cpill.sel{border-color:var(--g);background:rgba(201,162,75,.14);box-shadow:0 0 0 1px var(--g)}
#amb-join .cpill .sw{width:16px;height:16px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,#9a9a9a,#3a3a3a);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5),0 0 0 1px rgba(0,0,0,.45)}
#amb-join .add.err{background:#3a2420;color:#f0b9ad}
#amb-join .price{font-weight:800;font-size:17px;margin-top:11px}
#amb-join .add{margin-top:auto;width:100%;border:0;border-radius:10px;background:var(--g);color:#191307;
  font-weight:800;font-size:14px;padding:11px;cursor:pointer;font-family:var(--font-ui,sans-serif);transition:.12s}
#amb-join .add:hover{filter:brightness(1.06)}
#amb-join .add.added{background:#2a3a22;color:#9fe08a}

/* UGC wall */
#amb-join .ugc{padding:54px 0 20px}
#amb-join .ugc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:26px}
@media(max-width:880px){#amb-join .ugc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){#amb-join .ugc-grid{grid-template-columns:repeat(2,1fr)}}
#amb-join .post{background:var(--el);border:1px solid #2a2414;border-radius:14px;overflow:hidden;transition:transform .15s}
#amb-join .post:hover{transform:translateY(-3px)}
#amb-join .post .ph{aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:14px;background:#0e0c07}
#amb-join .post .ph img{max-width:100%;max-height:100%;object-fit:contain}
#amb-join .post .meta{display:flex;align-items:center;gap:8px;padding:9px 11px}
#amb-join .post .av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--em));flex:none}
#amb-join .post .h{font-size:12px;font-weight:700}
#amb-join .post .lk{margin-left:auto;font-size:11.5px;color:var(--mut)}
#amb-join .handles{text-align:center;margin-top:24px;color:var(--mut);font-size:13.5px}
#amb-join .handles a{color:var(--g);font-weight:700;text-decoration:none}

/* sticky tray */
#amb-join .tray{position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(12,10,6,.96);
  border-top:1px solid #3a3118;backdrop-filter:blur(10px);transform:translateY(100%);transition:transform .28s}
#amb-join .tray.show{transform:translateY(0)}
#amb-join .tray .inner{max-width:1120px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
#amb-join .tray .sum{flex:1;min-width:200px}
#amb-join .tray .sum .ic{font-size:13px;color:var(--mut)}
#amb-join .tray .sum .ic b{color:var(--bn)}
#amb-join .tray .sum .tot{font-family:var(--font-display,serif);font-weight:700;font-size:22px}
#amb-join .tray .earn{font-size:12.5px;color:#9fe08a;font-weight:600;margin-top:2px}
#amb-join .tray .cta{border:0;border-radius:12px;background:var(--g);color:#191307;font-weight:800;
  font-size:15px;padding:14px 26px;cursor:pointer;font-family:var(--font-ui,sans-serif);white-space:nowrap}
#amb-join .tray .cta:hover{filter:brightness(1.06)}

/* reveal modal */
#amb-join .modal{position:fixed;inset:0;z-index:80;background:rgba(8,6,3,.82);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:22px}
#amb-join .modal.show{display:flex}
#amb-join .modal .box{max-width:520px;width:100%;background:var(--el);border:1px solid var(--g);
  border-radius:20px;padding:34px 30px;text-align:center;animation:ambpop .3s ease}
@keyframes ambpop{from{transform:scale(.93);opacity:0}to{transform:scale(1);opacity:1}}
#amb-join .modal .eyebrow{display:block;margin-bottom:10px}
#amb-join .modal h3{font-family:var(--font-display,serif);font-weight:700;font-size:27px;line-height:1.1;margin:0}
#amb-join .modal p{color:var(--mut);margin-top:12px;font-size:14.5px}
#amb-join .modal .math{margin:20px 0;background:#0e0c07;border:1px solid #2a2414;border-radius:14px;padding:18px;text-align:left}
#amb-join .modal .math .ln{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}
#amb-join .modal .math .ln b{color:var(--bn)}
#amb-join .modal .math .ln.hl b{color:#9fe08a;font-size:16px}
#amb-join .modal .go{margin-top:8px;width:100%;border:0;border-radius:12px;background:var(--g);color:#191307;
  font-weight:800;font-size:15px;padding:15px;cursor:pointer;font-family:var(--font-ui,sans-serif)}
#amb-join .modal .close{margin-top:12px;background:none;border:0;color:var(--mut);font-size:13px;cursor:pointer;text-decoration:underline}
#amb-join .surprise{background:linear-gradient(100deg,rgba(187,59,43,.22),rgba(201,162,75,.22));
  border:1px solid var(--g);border-radius:12px;padding:12px 14px;font-size:14px;margin-bottom:18px;
  transform:scale(.85);opacity:0;animation:ambreveal .5s .15s forwards cubic-bezier(.2,1.2,.4,1)}
#amb-join .surprise b{color:#f0d488}
@keyframes ambreveal{to{transform:scale(1);opacity:1}}
#amb-join .emailcap{margin-top:16px;padding-top:16px;border-top:1px solid #2a2414}
#amb-join .emailcap p{font-size:13px;margin-top:0}
#amb-join .emailcap .field{display:flex;gap:8px;margin-top:10px}
#amb-join .emailcap input{flex:1;background:#0e0c07;border:1px solid #3a3118;border-radius:10px;color:var(--bn);
  padding:11px 12px;font-family:var(--font-ui,sans-serif);font-size:14px}
#amb-join .emailcap button{border:1px solid var(--g);border-radius:10px;background:transparent;color:var(--g);
  font-weight:700;font-size:13px;padding:0 14px;cursor:pointer;font-family:var(--font-ui,sans-serif);white-space:nowrap}

/* ===== type filter ===== */
#amb-join .amb-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 24px}
#amb-join .fbtn{font:inherit;font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid #3a3118;background:transparent;color:var(--bn);padding:8px 17px;border-radius:999px;cursor:pointer;transition:.15s}
#amb-join .fbtn:hover{border-color:var(--g)}
#amb-join .fbtn.sel{background:var(--g);color:#1a1408;border-color:var(--g)}

/* ===== pagination ===== */
#amb-join .amb-pager{display:flex;align-items:center;justify-content:center;gap:18px;margin:34px auto 0}
#amb-join .amb-pager[hidden]{display:none}
#amb-join .pg{font:inherit;font-weight:700;font-size:13px;border:1px solid #3a3118;background:transparent;color:var(--bn);
  padding:9px 18px;border-radius:10px;cursor:pointer;transition:.15s}
#amb-join .pg:hover:not([disabled]){border-color:var(--g);color:var(--g)}
#amb-join .pg[disabled]{opacity:.38;cursor:default}
#amb-join .pg-info{font-size:13px;color:#a89e89;letter-spacing:.04em}

/* ===== quick-add modal (reuses .lightbox overlay) ===== */
#amb-join .lightbox .qa-box{display:flex;gap:26px;max-width:880px;width:100%;background:var(--el,#1c1810);
  border:1px solid #2a2414;border-radius:18px;padding:22px;align-items:stretch;position:relative}
#amb-join .qa-media{flex:1 1 50%;background:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;
  padding:16px;min-height:360px}
#amb-join .qa-media img{max-width:100%;max-height:62vh;object-fit:contain}
#amb-join .qa-info{flex:1 1 46%;display:flex;flex-direction:column;text-align:left;padding-right:6px}
#amb-join .qa-name{font-family:var(--font-display,serif);font-weight:600;font-size:23px;line-height:1.2;margin-bottom:12px}
#amb-join .qa-info .cRow,#amb-join .qa-info .sRow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
#amb-join .qa-price{font-weight:800;font-size:21px;margin:14px 0 0}
#amb-join .qa-add{margin-top:16px;width:100%;border:0;border-radius:11px;background:var(--g);color:#191307;
  font:inherit;font-weight:800;font-size:15px;padding:15px;cursor:pointer;transition:.15s}
#amb-join .qa-add:hover{filter:brightness(1.06)}
#amb-join .qa-add.added{background:#2a3a22;color:#9fe08a}
#amb-join .qa-add.err{background:#3a2420;color:#f0b9ad}
@media(max-width:680px){
  #amb-join .lightbox .qa-box{flex-direction:column;gap:16px;max-width:94vw;max-height:90vh;overflow:auto}
  #amb-join .qa-media{min-height:240px}
}

/* Mobile a11y: 16px inputs (no iOS zoom) + 44px tap targets (2026-06-24 audit). */
@media (max-width: 768px) {
  #amb-join .emailcap input { font-size: 16px; }
  #amb-join .fbtn, #amb-join .pill, #amb-join .cpill,
  #amb-join .qa-add, #amb-join .add { min-height: 44px; }
}
