/* ============================================================
   JUST T-SHIRTS — page + component styles
   ============================================================ */

/* ---------- HERO (home) ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1.4px,transparent 1.5px);background-size:16px 16px;opacity:.7}
.hero__glow{position:absolute;width:780px;height:780px;border-radius:50%;
  background:radial-gradient(circle,rgba(26,155,215,.5),transparent 62%);
  top:-280px;right:-200px;filter:blur(10px);pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding-block:clamp(48px,7vw,92px)}
.hero__kicker{display:inline-flex;margin-bottom:1.4rem}
.hero h1{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;
  font-size:clamp(2.9rem,7.2vw,5.6rem);line-height:.9;letter-spacing:.005em;color:#fff}
.hero h1 .ink{color:var(--brand-bright);position:relative;white-space:nowrap}
.hero h1 .ink::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.5em;background:var(--brand);opacity:.22;z-index:-1;transform:skewX(-8deg)}
.hero p.lead{color:var(--on-dark);margin-top:1.4rem;max-width:46ch}
.hero__cta{display:flex;gap:.9rem;margin-top:2rem;flex-wrap:wrap}
.hero__meta{display:flex;gap:1.8rem;margin-top:2.4rem;flex-wrap:wrap}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:'Anton';font-size:1.9rem;color:var(--brand-bright);line-height:1}
.hero__meta span{font-size:.82rem;color:var(--on-dark-soft);letter-spacing:.04em;text-transform:uppercase;font-weight:600;margin-top:.3rem}

/* hero tile mosaic = the consolidation thesis */
.hero__range{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.range-tile{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;
  background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  text-align:center;padding:1rem .5rem;transition:transform var(--t),box-shadow var(--t);
  box-shadow:0 10px 24px rgba(0,0,0,.25);border:3px solid transparent}
.range-tile:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 18px 36px rgba(0,0,0,.4)}
.range-tile img{height:54px;width:auto;object-fit:contain}
.range-tile .tname{font-family:'Archivo';font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink)}
.range-tile .sash-mini{position:absolute;top:10px;left:-26px;transform:rotate(-38deg);background:var(--accent,var(--brand));color:#fff;font-family:'Archivo';font-weight:800;font-size:.56rem;letter-spacing:.1em;padding:3px 30px}
.range-tile--cta{background:var(--brand);color:#fff;cursor:pointer;justify-content:center}
.range-tile--cta .tname{color:#fff}
.range-tile--cta b{font-family:'Anton';font-size:1.5rem;line-height:.95;text-transform:uppercase}
.range-tile--cta span{font-size:.74rem;color:rgba(255,255,255,.85)}

/* ---------- Marquee notice ---------- */
.ticker{background:var(--amber);color:var(--ink);font-family:'Archivo';font-weight:800;
  font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;overflow:hidden;white-space:nowrap}
.ticker__track{display:inline-flex;gap:3rem;padding-block:.6rem;animation:tick 60s linear infinite}
.ticker:hover .ticker__track{animation-play-state:paused}
.ticker__track span{display:inline-flex;align-items:center;gap:.6rem}
.ticker__track span::before{content:"";width:7px;height:7px;background:var(--ink);border-radius:50%}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- Category hero (inner pages) ---------- */
.cat-hero{position:relative;color:#fff;overflow:hidden;background:var(--accent,var(--brand))}
.cat-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(6,40,58,.55),rgba(6,40,58,.05));}
.cat-hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.10) 1.4px,transparent 1.5px);background-size:15px 15px;opacity:.6}
.cat-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center;padding-block:clamp(40px,6vw,72px)}
.cat-hero h1{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4.4rem);line-height:.92}
.cat-hero p{color:rgba(255,255,255,.92);max-width:52ch;margin-top:1rem;font-size:1.08rem}
.cat-hero__logo{justify-self:end}
.cat-hero__logo img{height:clamp(110px,16vw,180px);width:auto;filter:drop-shadow(0 14px 30px rgba(0,0,0,.35))}
.breadcrumbs{display:flex;gap:.5rem;align-items:center;font-size:.82rem;color:rgba(255,255,255,.85);margin-bottom:1rem;font-weight:600}
.breadcrumbs a:hover{color:#fff;text-decoration:underline}
.breadcrumbs span{opacity:.6}

/* ---------- Filter bar ---------- */
.filterbar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:2rem}
.chip{font-family:'Archivo';font-weight:700;font-size:.86rem;padding:.55em 1.05em;border-radius:999px;
  background:#fff;color:var(--ink);border:1.5px solid var(--line);transition:var(--t)}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.filterbar__count{margin-left:auto;font-size:.86rem;color:var(--text-faint);font-weight:600}

/* ---------- Product card ---------- */
.product-card{background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform var(--t),box-shadow var(--t),border-color var(--t);position:relative}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.product-card__media{aspect-ratio:1;position:relative;background:linear-gradient(160deg,#f2f7fa,#e7eef3);display:grid;place-items:center;overflow:hidden}
.product-card__media svg{width:74%;height:74%}
.product-card__badge{position:absolute;top:12px;left:0;z-index:2}
.product-card__fav{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;color:var(--text-faint);transition:var(--t)}
.product-card__fav:hover{color:var(--c-mugs);background:#fff}
.product-card__body{padding:1.05rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.product-card__cat{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--brand));font-family:'Archivo'}
.product-card__name{font-family:'Archivo';font-weight:800;font-size:1.06rem;color:var(--ink);line-height:1.15}
.product-card__swatches{display:flex;gap:5px;margin-top:.1rem}
.product-card__swatches i{width:16px;height:16px;border-radius:50%;border:1.5px solid rgba(0,0,0,.12);display:block}
.product-card__swatches .more{font-size:.72rem;color:var(--text-faint);font-weight:700;align-self:center;margin-left:2px}
.product-card__foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:auto;padding-top:.5rem}
.product-card__price{font-family:'Archivo';font-weight:800;color:var(--ink);font-size:1.05rem}
.product-card__price small{display:block;font-size:.68rem;color:var(--text-faint);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.product-card__cta{font-family:'Archivo';font-weight:800;font-size:.82rem;color:#fff;background:var(--accent,var(--brand));padding:.5em .9em;border-radius:999px;transition:var(--t)}
.product-card:hover .product-card__cta{filter:brightness(1.08)}

/* ---------- Garment silhouette colours via CSS var ---------- */
.gmt{--g:#fff}
.gmt .body{fill:var(--g)}
.gmt .shade{fill:rgba(0,0,0,.08)}
.gmt .outline{fill:none;stroke:rgba(6,40,58,.55);stroke-width:6}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split--rev .split__media{order:2}
.split__media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);position:relative;background:#fff}
.feature-list{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.feature-list li{display:flex;gap:.85rem;align-items:flex-start}
.feature-list svg{width:24px;height:24px;color:var(--brand);flex-shrink:0;margin-top:3px}
.feature-list b{font-family:'Archivo';font-weight:800;color:var(--ink)}
.feature-list span{display:block;color:var(--text-soft);font-size:.95rem}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.3rem;counter-increment:s}
.step::before{content:counter(s,decimal-leading-zero);font-family:'Anton';font-size:2.4rem;color:var(--brand);opacity:.22;position:absolute;top:.6rem;right:1rem;line-height:1}
.step h3{font-size:1.12rem;margin-bottom:.5rem}
.step p{font-size:.92rem;color:var(--text-soft);margin:0}
.step__ico{width:46px;height:46px;border-radius:12px;background:#eef6fb;color:var(--brand);display:grid;place-items:center;margin-bottom:1rem}
.step__ico svg{width:25px;height:25px}

/* ---------- Bulk pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem}
.tier{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.3rem 1rem;text-align:center;transition:var(--t);position:relative}
.tier:hover{border-color:var(--brand);transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.tier__qty{font-family:'Archivo';font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint)}
.tier__save{font-family:'Anton';font-size:2.1rem;color:var(--brand);line-height:1;margin:.4rem 0}
.tier__lbl{font-size:.8rem;color:var(--text-soft)}
.tier--best{background:var(--ink);border-color:var(--ink)}
.tier--best .tier__qty,.tier--best .tier__lbl{color:var(--on-dark-soft)}
.tier--best .tier__save{color:var(--amber)}
.tier--best::after{content:"Best value";position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--amber);color:var(--ink);font-family:'Archivo';font-weight:800;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;padding:.25em .8em;border-radius:999px;white-space:nowrap}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testi{background:#fff;border-radius:var(--r);padding:1.6rem;border:1px solid var(--line);display:flex;flex-direction:column;gap:1rem}
.testi__stars{color:var(--amber);font-size:1.05rem;letter-spacing:2px}
.testi__txt{font-size:.98rem;color:var(--text);font-style:italic;margin:0;flex:1}
.testi__who{display:flex;align-items:center;gap:.7rem}
.testi__av{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:'Archivo';font-weight:800}
.testi__who b{font-family:'Archivo';color:var(--ink);display:block;font-size:.95rem}
.testi__who span{font-size:.82rem;color:var(--text-faint)}

/* ---------- Google reviews band ---------- */
.greviews{display:flex;align-items:center;gap:1.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem 1.8rem;flex-wrap:wrap;justify-content:center;box-shadow:var(--shadow-sm)}
.greviews__g{font-family:'Archivo';font-weight:800;font-size:1.3rem}
.greviews__g .b{color:#4285F4}.greviews__g .r{color:#EA4335}.greviews__g .y{color:#FBBC05}.greviews__g .g{color:#34A853}
.greviews__stars{color:var(--amber);font-size:1.3rem;letter-spacing:2px}
.greviews b.score{font-family:'Anton';font-size:1.8rem;color:var(--ink)}

/* ---------- Video ---------- */
.video-wrap{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/9;background:#000}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-cover{position:absolute;inset:0;cursor:pointer;display:grid;place-items:center;background-size:cover;background-position:center}
.video-cover::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,40,58,.25),rgba(6,40,58,.6))}
.video-play{position:relative;z-index:2;width:84px;height:84px;border-radius:50%;background:var(--c-mugs);display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:var(--t)}
.video-cover:hover .video-play{transform:scale(1.08)}
.video-play svg{width:34px;height:34px;color:#fff;margin-left:4px}

/* ---------- CTA band ---------- */
.cta-band{background:var(--brand);color:#fff;border-radius:var(--r-lg);padding:clamp(2rem,5vw,3.4rem);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1.4px,transparent 1.5px);background-size:15px 15px;opacity:.5}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:clamp(1.8rem,4.5vw,3rem);line-height:.95}
.cta-band p{color:rgba(255,255,255,.92);max-width:54ch;margin:1rem auto 1.8rem}
.cta-band .btn-row{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ---------- Facebook feed ---------- */
.fb-embed{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#fff;min-height:130px}
.fb-embed iframe{border:none;width:100%;display:block}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.pd__gallery{position:sticky;top:90px}
.pd__stage{aspect-ratio:1;background:linear-gradient(160deg,#f2f7fa,#e7eef3);border-radius:var(--r-lg);display:grid;place-items:center;border:1px solid var(--line);position:relative;overflow:hidden}
.pd__stage svg{width:72%;height:72%}
.pd__thumbs{display:flex;gap:.6rem;margin-top:.8rem}
.pd__thumb{width:70px;height:70px;border-radius:var(--r-sm);background:#fff;border:2px solid var(--line);display:grid;place-items:center;cursor:pointer;transition:var(--t)}
.pd__thumb.is-active{border-color:var(--brand)}
.pd__thumb svg{width:64%;height:64%}
.pd h1{font-family:'Archivo';font-weight:900;font-size:clamp(1.8rem,4vw,2.6rem);margin:.6rem 0 .4rem}
.pd__price{display:flex;align-items:baseline;gap:.6rem;margin:1rem 0}
.pd__price b{font-family:'Anton';font-size:2.4rem;color:var(--ink)}
.pd__price small{color:var(--text-faint);font-weight:600}
.pd__opt{margin:1.4rem 0}
.pd__opt h4{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft);margin-bottom:.7rem;font-family:'Archivo'}
.swatch-row{display:flex;gap:.55rem;flex-wrap:wrap}
.swatch{width:34px;height:34px;border-radius:50%;border:2px solid rgba(0,0,0,.12);cursor:pointer;position:relative;transition:transform var(--t)}
.swatch:hover{transform:scale(1.12)}
.swatch.is-active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--brand)}
.size-row{display:flex;gap:.5rem;flex-wrap:wrap}
.size-btn{min-width:48px;padding:.6em .4em;border-radius:var(--r-sm);border:1.5px solid var(--line);background:#fff;font-family:'Archivo';font-weight:700;color:var(--ink);transition:var(--t)}
.size-btn:hover{border-color:var(--brand)}
.size-btn.is-active{background:var(--brand);color:#fff;border-color:var(--brand)}
.qty-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.7rem;margin-top:.4rem}
.qty-cell{border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.5rem;text-align:center}
.qty-cell label{display:block;font-size:.74rem;font-weight:800;color:var(--text-soft);font-family:'Archivo'}
.qty-cell input{width:100%;border:none;text-align:center;font-family:'Archivo';font-weight:800;font-size:1.1rem;color:var(--ink);background:transparent;margin-top:.2rem}
.pd__actions{display:flex;gap:.8rem;margin-top:1.6rem;flex-wrap:wrap}
.pd__note{display:flex;gap:.6rem;align-items:center;font-size:.86rem;color:var(--text-soft);margin-top:1rem}
.pd__note svg{width:18px;height:18px;color:var(--brand)}
.pd__accordion{margin-top:2rem;border-top:1px solid var(--line)}

/* ============================================================
   DESIGNER (T-Shirt Hub)
   ============================================================ */
.designer{display:grid;grid-template-columns:280px 1fr 320px;gap:1.2rem;align-items:start}
.dz-panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.2rem;position:sticky;top:90px}
.dz-panel h3{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft);margin-bottom:.9rem;font-family:'Archivo'}
.dz-panel + .dz-panel{margin-top:1.2rem}
.dz-stage-wrap{background:repeating-conic-gradient(#eef3f6 0% 25%,#fff 0% 50%) 50%/26px 26px;border:1px solid var(--line);border-radius:var(--r-lg);position:relative;min-height:520px;display:grid;place-items:center;overflow:hidden}
#dzStage{position:relative;width:min(440px,86%);aspect-ratio:1}
#dzStage .gmt-svg{width:100%;height:100%}
.dz-canvas{position:absolute;left:24%;top:26%;width:52%;height:46%;}
.dz-art{position:absolute;cursor:move;user-select:none;touch-action:none;border:1.5px dashed transparent;display:grid;place-items:center}
.dz-art.sel{border-color:var(--brand)}
.dz-art img{width:100%;height:100%;object-fit:contain;pointer-events:none}
.dz-art .dz-text{font-weight:800;line-height:1.05;text-align:center;white-space:pre-wrap}
.dz-handle{position:absolute;right:-9px;bottom:-9px;width:18px;height:18px;background:var(--brand);border:2px solid #fff;border-radius:50%;cursor:nwse-resize}
.dz-del{position:absolute;right:-9px;top:-9px;width:18px;height:18px;background:var(--c-mugs);border:2px solid #fff;border-radius:50%;color:#fff;display:grid;place-items:center;font-size:11px;cursor:pointer}
.dz-garments{display:flex;gap:.5rem;flex-wrap:wrap}
.dz-garment{flex:1;min-width:72px;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.6rem .3rem;background:#fff;display:flex;flex-direction:column;align-items:center;gap:.3rem;transition:var(--t)}
.dz-garment svg{width:42px;height:42px}
.dz-garment span{font-size:.74rem;font-weight:700;font-family:'Archivo'}
.dz-garment.is-active{border-color:var(--brand);background:#f0f7fb}
.dz-field{margin-bottom:.9rem}
.dz-field label{display:block;font-size:.78rem;font-weight:700;color:var(--text-soft);margin-bottom:.35rem;font-family:'Archivo'}
.dz-input,.dz-select{width:100%;padding:.6em .7em;border:1.5px solid var(--line);border-radius:var(--r-sm);background:#fff}
.dz-input:focus,.dz-select:focus{outline:none;border-color:var(--brand)}
.dz-row{display:flex;gap:.5rem}
.dz-mini-btn{flex:1;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.55em;font-family:'Archivo';font-weight:700;font-size:.84rem;background:#fff;transition:var(--t);display:flex;align-items:center;justify-content:center;gap:.4em}
.dz-mini-btn:hover{border-color:var(--brand);color:var(--brand)}
.dz-upload{border:1.6px dashed var(--brand);border-radius:var(--r-sm);padding:1rem;text-align:center;color:var(--brand);font-weight:700;font-family:'Archivo';font-size:.86rem;cursor:pointer;transition:var(--t);background:#f7fbfe}
.dz-upload:hover{background:#eef6fb}
.dz-positions{display:flex;gap:.5rem}
.dz-pos{flex:1;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.5em;font-family:'Archivo';font-weight:700;font-size:.82rem;background:#fff;transition:var(--t)}
.dz-pos.is-active{background:var(--brand);color:#fff;border-color:var(--brand)}
.dz-summary{display:flex;flex-direction:column;gap:.55rem;font-size:.9rem}
.dz-summary .row{display:flex;justify-content:space-between;color:var(--text-soft)}
.dz-summary .row b{color:var(--ink)}
.dz-total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);margin-top:.6rem;padding-top:.8rem}
.dz-total b{font-family:'Anton';font-size:1.8rem;color:var(--ink)}
.dz-swatches{display:flex;gap:6px;flex-wrap:wrap}
.dz-sw{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.12);cursor:pointer;transition:transform var(--t)}
.dz-sw:hover{transform:scale(1.12)}
.dz-sw.is-active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--brand)}
.dz-toolbar{display:flex;gap:.5rem;justify-content:center;margin-top:.8rem;flex-wrap:wrap}

/* ============================================================
   QUOTE WIZARD
   ============================================================ */
.quote-hero{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.quote-hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1.4px,transparent 1.5px);background-size:15px 15px;opacity:.7}
.quote-hero .wrap{position:relative;z-index:2;padding-block:clamp(40px,6vw,68px)}
.quote-hero h1{font-family:'Anton';font-weight:400;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4rem);line-height:.92}
.quote-hero p{color:var(--on-dark);max-width:54ch;margin-top:1rem;font-size:1.1rem}
.quote-shell{max-width:920px;margin:-60px auto 0;position:relative;z-index:5;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.quote-progress{display:flex;background:var(--paper);border-bottom:1px solid var(--line)}
.qp-step{flex:1;padding:1rem .6rem;text-align:center;position:relative;font-family:'Archivo';font-weight:700;font-size:.82rem;color:var(--text-faint)}
.qp-step .n{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#e4ecf1;color:var(--text-faint);font-size:.84rem;margin-bottom:.35rem;transition:var(--t)}
.qp-step.is-active{color:var(--brand)}
.qp-step.is-active .n{background:var(--brand);color:#fff}
.qp-step.is-done .n{background:var(--c-polos);color:#fff}
.qp-step.is-done{color:var(--ink)}
.qp-bar{position:absolute;left:0;bottom:0;height:3px;background:var(--brand);transition:width .4s ease}
.quote-body{padding:clamp(1.6rem,4vw,2.6rem)}
.qstep{display:none;animation:fade .35s ease}
.qstep.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.qstep h2{font-size:1.5rem;margin-bottom:.4rem}
.qstep > p.sub{color:var(--text-soft);margin-bottom:1.6rem}
.opt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem}
.opt-card{border:1.8px solid var(--line);border-radius:var(--r);padding:1.3rem 1rem;text-align:center;cursor:pointer;transition:var(--t);background:#fff;position:relative}
.opt-card:hover{border-color:var(--brand);transform:translateY(-3px)}
.opt-card.is-sel{border-color:var(--brand);background:#f3f9fd}
.opt-card.is-sel::after{content:"✓";position:absolute;top:8px;right:10px;color:var(--brand);font-weight:800}
.opt-card svg{width:46px;height:46px;margin-bottom:.5rem;color:var(--brand)}
.opt-card b{font-family:'Archivo';font-weight:800;display:block;color:var(--ink);font-size:.98rem}
.opt-card span{font-size:.8rem;color:var(--text-faint)}
.qfield{margin-bottom:1.2rem}
.qfield label{display:block;font-family:'Archivo';font-weight:700;font-size:.9rem;margin-bottom:.4rem;color:var(--ink)}
.qfield label .req{color:var(--c-mugs)}
.qinput{width:100%;padding:.85em 1em;border:1.6px solid var(--line);border-radius:var(--r-sm);background:#fff;transition:var(--t)}
.qinput:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,123,182,.12)}
.qgrid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.qty-stepper{display:flex;align-items:stretch;border:1.6px solid var(--line);border-radius:var(--r-sm);overflow:hidden;width:fit-content}
.qty-stepper button{width:48px;background:var(--paper);font-size:1.3rem;font-weight:700;color:var(--brand)}
.qty-stepper input{width:90px;border:none;text-align:center;font-family:'Archivo';font-weight:800;font-size:1.2rem;color:var(--ink)}
.qty-presets{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.qty-preset{padding:.45em .9em;border:1.5px solid var(--line);border-radius:999px;font-family:'Archivo';font-weight:700;font-size:.84rem;background:#fff;transition:var(--t)}
.qty-preset:hover,.qty-preset.is-active{background:var(--brand);color:#fff;border-color:var(--brand)}
.print-pick{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.7rem}
.dropzone{border:1.8px dashed var(--brand);border-radius:var(--r);padding:1.8rem;text-align:center;color:var(--brand);background:#f7fbfe;cursor:pointer;transition:var(--t)}
.dropzone:hover,.dropzone.drag{background:#eef6fb}
.dropzone svg{width:38px;height:38px;margin-bottom:.5rem}
.dropzone small{display:block;color:var(--text-faint);font-weight:500;margin-top:.3rem}
.file-list{margin-top:.8rem;display:flex;flex-direction:column;gap:.5rem}
.file-row{display:flex;align-items:center;gap:.6rem;background:var(--paper);border-radius:var(--r-sm);padding:.5rem .8rem;font-size:.86rem}
.file-row .x{margin-left:auto;color:var(--c-mugs);cursor:pointer;font-weight:800}
.quote-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.review-list{display:flex;flex-direction:column;gap:.7rem;background:var(--paper);border-radius:var(--r);padding:1.4rem;margin-bottom:1.4rem}
.review-list .row{display:flex;justify-content:space-between;font-size:.94rem;gap:1rem}
.review-list .row b{color:var(--ink);font-family:'Archivo'}
.review-list .row span{color:var(--text-soft);text-align:right}
.quote-done{text-align:center;padding:2rem 1rem}
.quote-done__ico{width:80px;height:80px;border-radius:50%;background:var(--c-polos);display:grid;place-items:center;margin:0 auto 1.4rem;color:#fff}
.quote-done__ico svg{width:42px;height:42px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.contact-card{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:clamp(1.8rem,3vw,2.6rem);position:relative;overflow:hidden}
.contact-card::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1.4px,transparent 1.5px);background-size:14px 14px;opacity:.6}
.contact-card > *{position:relative;z-index:2}
.contact-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}
.contact-item svg{width:24px;height:24px;color:var(--brand-bright);flex-shrink:0;margin-top:3px}
.contact-item b{font-family:'Archivo';color:#fff;display:block}
.contact-item a,.contact-item span{color:var(--on-dark-soft)}
.contact-item a:hover{color:#fff}
.map-embed{border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.15);margin-top:1.5rem;height:200px}
.map-embed iframe{width:100%;height:100%;border:0;filter:grayscale(.3)}

/* ---------- About stats ---------- */
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.about-stat{text-align:center;padding:1.4rem 1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r)}
.about-stat b{font-family:'Anton';font-size:2.6rem;color:var(--brand);line-height:1;display:block}
.about-stat span{font-size:.86rem;color:var(--text-soft);font-weight:600}

/* ---------- Cart drawer ---------- */
.drawer-back{position:fixed;inset:0;background:rgba(6,40,58,.5);z-index:95;opacity:0;visibility:hidden;transition:var(--t)}
.drawer-back.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,90vw);background:#fff;z-index:96;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:1.3rem;border-bottom:1px solid var(--line)}
.drawer__head h3{font-family:'Archivo';font-weight:800}
.drawer__body{flex:1;overflow-y:auto;padding:1.3rem;display:flex;flex-direction:column;gap:1rem}
.drawer__empty{text-align:center;color:var(--text-faint);margin-top:3rem}
.drawer__empty svg{width:56px;height:56px;margin-bottom:1rem;color:var(--line)}
.cart-item{display:flex;gap:.9rem;align-items:center;border-bottom:1px solid var(--line);padding-bottom:1rem}
.cart-item__media{width:60px;height:60px;border-radius:var(--r-sm);background:linear-gradient(160deg,#f2f7fa,#e7eef3);display:grid;place-items:center;flex-shrink:0}
.cart-item__media svg{width:74%;height:74%}
.cart-item b{font-family:'Archivo';font-size:.92rem;color:var(--ink)}
.cart-item span{font-size:.8rem;color:var(--text-faint)}
.cart-item .x{margin-left:auto;color:var(--text-faint);font-weight:800;cursor:pointer}
.drawer__foot{padding:1.3rem;border-top:1px solid var(--line)}
.drawer__total{display:flex;justify-content:space-between;font-family:'Archivo';font-weight:800;font-size:1.1rem;margin-bottom:1rem}
.stripe-note{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.8rem;color:var(--text-faint);margin-top:.8rem}
.stripe-note svg{width:16px;height:16px;color:var(--c-polos)}

/* responsive for components */
@media (max-width:1080px){
  .designer{grid-template-columns:1fr}
  .dz-panel{position:static}
  .pd{grid-template-columns:1fr}
  .pd__gallery{position:static}
  .steps{grid-template-columns:repeat(2,1fr)}
  .tiers{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .hero .wrap{grid-template-columns:1fr}
  .hero__range{max-width:480px}
  .cat-hero .wrap{grid-template-columns:1fr}
  .cat-hero__logo{justify-self:start}
  .split{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .testi-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .about-stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .steps,.tiers{grid-template-columns:1fr 1fr}
  .quote-progress .qp-step .lbl{display:none}
  .hero__range{grid-template-columns:repeat(3,1fr)}
  .qgrid2{grid-template-columns:1fr}
}
