:root{
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  /* monochrome + red accent */
  --bg:#FFFFFF; --surface:#FFFFFF; --surface2:#F5F5F6; --line:#E6E6E8; --line2:#D2D2D6;
  --ink:#0A0A0A; --text:#1A1A1A; --muted:#6B6B70; --soft:#9A9AA0;
  --accent:#E1121E; --accent-d:#B70E18; --accent-sf:#FCE9EA; --olive:#0A0A0A; --gold:#E1121E;
  --good:#1E7A3A; --warn:#B5651E; --bad:#C01622;
  --fs-hero:clamp(40px,6vw,72px); --fs-h1:clamp(30px,4vw,46px); --fs-h2:clamp(24px,3vw,34px);
  --fs-h3:clamp(18px,2vw,22px); --fs-lead:clamp(17px,1.6vw,21px);
  --radius:14px; --radius-lg:22px; --radius-pill:999px; --maxw:1180px;
  --shadow:0 1px 2px rgba(10,10,10,.05),0 8px 24px rgba(10,10,10,.06);
  --shadow-lg:0 18px 50px rgba(10,10,10,.12); --shadow-clay:0 10px 26px rgba(225,18,30,.24);
  --motion-fast:180ms; --motion-base:480ms; --ease-soft:cubic-bezier(.2,.7,.2,1); --ease-snap:cubic-bezier(.32,.72,0,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-optical-sizing:auto;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:var(--accent-d);text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em;line-height:1.1;color:var(--ink);margin:0}
h2{line-height:1.15}h3{line-height:1.22}
p{line-height:1.7;margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.kicker{font:600 12px/1.2 var(--font-body);text-transform:uppercase;letter-spacing:.14em;color:var(--accent-d)}
.lead{font-size:var(--fs-lead);line-height:1.5;color:var(--ink)}
.muted{color:var(--muted)}
.loading{padding:90px;text-align:center;color:var(--muted)}
.price-from,.price{font-variant-numeric:tabular-nums;font-weight:600;color:var(--accent-d)}
/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--motion-base) var(--ease-soft),transform var(--motion-base) var(--ease-soft)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
/* header */
.site-head{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);transition:box-shadow .2s,border-color .2s;border-bottom:1px solid transparent}
.site-head.scrolled{border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
.head-inner{display:flex;align-items:center;gap:26px;padding:14px 22px;max-width:var(--maxw);margin:0 auto}
.logo{display:inline-flex;align-items:center;gap:9px;color:var(--ink)}
.logomark{height:30px;width:auto;display:block}
.logoword{font-family:var(--font-body);font-weight:800;letter-spacing:.015em;font-size:21px;line-height:1;color:var(--ink);text-transform:uppercase;transform:scaleX(.92);transform-origin:left center}
.logo svg{height:30px;width:auto;display:block}
.mainnav{display:flex;gap:22px;color:var(--text);font-weight:500;font-size:15px}
.mainnav a{position:relative;padding:4px 0}
.mainnav a:hover{color:var(--accent-d)}
.mainnav a.on{color:var(--ink)}.mainnav a.on:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);border-radius:2px}
.head-actions{margin-left:auto;display:flex;align-items:center;gap:9px}
.search{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--text);padding:9px 14px;width:180px;outline:none;font:inherit;font-size:14px}
.search:focus{border-color:var(--accent)}
.cartbtn,.acctbtn{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:9px 14px;font-size:14px;font-weight:500;color:var(--ink)}
.cartbtn:hover,.acctbtn:hover{border-color:var(--accent);background:var(--accent-sf)}
.cartbtn span{background:var(--accent);color:#FFFDF8;border-radius:999px;padding:0 7px;font-weight:700;font-size:12px}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:8px 11px;cursor:pointer;font-size:18px;color:var(--ink)}
.mobnav{position:fixed;inset:0;background:var(--bg);z-index:50;display:none;flex-direction:column;padding:80px 28px;gap:6px}
.mobnav.open{display:flex}
.mobnav a{font-family:var(--font-display);font-size:30px;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line)}
.mobnav .x{position:absolute;top:22px;right:24px;font-size:26px;cursor:pointer;color:var(--muted)}
@media(max-width:880px){.mainnav,.search{display:none}.burger{display:block}}
/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:16px;padding:.85em 1.6em;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;background:var(--accent);color:#FFFDF8;transition:transform var(--motion-fast) var(--ease-snap),box-shadow var(--motion-fast),background-color var(--motion-fast)}
.btn:hover{background:var(--accent-d);transform:translateY(-2px);box-shadow:var(--shadow-clay)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line2);border-radius:var(--radius-pill)}
.btn.ghost:hover{background:var(--accent-sf);border-color:var(--accent);box-shadow:none;transform:translateY(-2px)}
.btn.ghost.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.ghost.on:hover{background:var(--accent-d);border-color:var(--accent-d);color:#fff}
.btn.sm{padding:.6em 1.1em;font-size:14px}.btn.block{width:100%}
.btn:focus-visible{outline:3px solid var(--accent-d);outline-offset:2px}
/* hero */
.hero{padding:64px 0 30px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:28px}}
.hero h1{font-size:var(--fs-hero);margin:14px 0 16px}
.hero .uline{position:relative;color:var(--ink);white-space:nowrap}
.hero .uline:after{content:"";position:absolute;left:0;right:-2px;bottom:.04em;height:.14em;background:var(--accent);border-radius:6px;transform:rotate(-.6deg)}
.hero p{font-size:var(--fs-lead);color:var(--ink);max-width:34ch}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 18px}
.hero .trust{color:var(--muted);font-size:14px;display:flex;gap:8px;flex-wrap:wrap}
.hero .trust b{color:var(--olive)}
.hero-photo{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface2);box-shadow:var(--shadow-lg)}
.hero-photo img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease-soft)}
.hero-photo:hover img{transform:scale(1.04)}
/* sections */
section{padding:56px 0}
.alt{background:var(--surface2)}
.section-h{display:flex;align-items:end;justify-content:space-between;gap:16px;margin:0 0 26px}
.section-h h2{font-size:var(--fs-h2)}
.section-h .sub{color:var(--muted);max-width:48ch;margin-top:8px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:900px){.cards4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cards4{grid-template-columns:1fr}}
.vcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}
.vcard .ic{width:40px;height:40px;color:var(--accent);margin-bottom:12px}
.vcard h3{font-size:var(--fs-h3);margin-bottom:6px}.vcard p{color:var(--muted);font-size:15px;margin:0}
/* product cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .15s var(--ease-soft),box-shadow .15s;box-shadow:var(--shadow)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.thumb{aspect-ratio:1/1;background:#fff;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line)}
.thumb img{width:100%;height:100%;object-fit:contain;transition:transform .5s var(--ease-soft)}
.card:hover .thumb img{transform:scale(1.03)}
.cardbody{padding:14px 16px}
.cardname{font-family:var(--font-display);font-size:16px;font-weight:600;min-height:40px;line-height:1.25;color:var(--ink)}
.cardmeta{margin-top:8px;display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}
.swrow{display:flex;gap:4px}.sw{width:13px;height:13px;border-radius:50%;border:1px solid rgba(0,0,0,.12)}
/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}
.step .n{font-family:var(--font-display);font-size:34px;color:var(--accent);line-height:1}
.step h3{font-size:var(--fs-h3);margin:12px 0 6px}.step p{color:var(--muted);font-size:15px;margin:0}
/* compare */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.compare{grid-template-columns:1fr}}
.cmp{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}
.cmp h3{font-size:var(--fs-h3)}.cmp ul{margin:12px 0;padding-left:18px;color:var(--text)}.cmp li{margin:5px 0}
.chiplabel{display:inline-block;background:var(--accent-sf);color:var(--accent-d);border-radius:var(--radius-pill);padding:5px 12px;font-size:13px;font-weight:600}
/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:840px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}
.quote .stars{color:var(--gold);font-size:14px;letter-spacing:2px}
.quote .q{font-family:var(--font-display);font-size:19px;color:var(--ink);line-height:1.4;margin:10px 0}
.quote .who{color:var(--muted);font-size:14px}
/* split / over */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:24px}}
.split.rev .ph{order:-1}
.ph{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface2);box-shadow:var(--shadow)}
.ph img{width:100%;height:100%;object-fit:cover}
.pull{font-family:var(--font-display);font-style:italic;font-size:clamp(20px,2.4vw,28px);color:var(--ink);line-height:1.4;border-left:3px solid var(--accent);padding-left:18px;margin:18px 0}
.sign{font-family:var(--font-display);font-style:italic;font-size:22px;color:var(--ink)}
.photostrip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
.photostrip .ph{scroll-snap-align:start;aspect-ratio:3/4}
/* cta band */
.ctaband{background:var(--accent-sf);text-align:center;border-radius:var(--radius-lg);padding:48px 24px;margin:0 auto}
.ctaband h2{font-size:var(--fs-h2);margin-bottom:18px}
.ctaband .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* footer */
.site-foot{background:var(--ink);color:#C9C9CE;margin-top:60px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:28px;padding:48px 22px 26px;max-width:var(--maxw);margin:0 auto}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
.site-foot .logo,.site-foot .logoword{color:#FFFFFF}
.site-foot .logomark{filter:invert(1) brightness(2)}
.site-foot h4{color:#FFFFFF;font-size:14px;margin:0 0 10px;font-family:var(--font-body);font-weight:700;letter-spacing:.04em}
.site-foot a{display:block;color:#9A9AA0;padding:3px 0;font-size:15px}.site-foot a:hover{color:var(--accent)}
.site-foot p{color:#9A9AA0;font-size:15px}
.foot-bottom{border-top:1px solid #262629;padding:16px 22px;max-width:var(--maxw);margin:0 auto;color:#6B6B70;font-size:13px}
/* page heads / prose */
.pagehead{padding:30px 0 8px}.pagehead h1{font-size:var(--fs-h1)}
.prose{color:var(--text);line-height:1.8;max-width:64ch}.prose p{margin:0 0 1.1em}
.toolbar{display:flex;gap:9px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:8px 15px;font-size:14px;color:var(--muted);cursor:pointer;font-weight:500}
.chip:hover{border-color:var(--accent)}.chip.on{border-color:var(--accent);color:#FFFDF8;background:var(--accent)}
/* portfolio */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.pcase{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}
.pcase:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.pcase .cov{aspect-ratio:16/10;overflow:hidden;background:var(--surface2);position:relative}
.pcase .cov img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-soft)}
.pcase:hover .cov img{transform:scale(1.04)}
.pcase .cat{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;border-radius:var(--radius-pill);padding:4px 11px;font-size:12px;font-weight:600}
.pcase .pb{padding:16px 18px}.pcase h3{font-size:var(--fs-h3)}.pcase .meta{color:var(--muted);font-size:14px;margin-top:4px}
.projhead{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.projcover{aspect-ratio:16/8;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface2);margin:18px 0}
.projcover img{width:100%;height:100%;object-fit:cover}
.galgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin:24px 0}
.galgrid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius);cursor:pointer;background:var(--surface2)}
.lightbox{position:fixed;inset:0;background:rgba(20,16,12,.92);display:none;place-items:center;z-index:60;padding:24px}
.lightbox.open{display:grid}.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px}
.lightbox .x{position:fixed;top:20px;right:26px;color:#fff;font-size:30px;cursor:pointer}
/* designer (warm) */
.designer{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start}
.designer>div:last-child{position:sticky;top:74px;align-self:start;max-height:calc(100vh - 88px);overflow-y:auto;overscroll-behavior:contain;padding-right:3px;scrollbar-width:thin}
.designer>div:last-child::-webkit-scrollbar{width:7px}.designer>div:last-child::-webkit-scrollbar-thumb{background:var(--line2);border-radius:9px}
@media(max-width:880px){.designer{grid-template-columns:1fr}.designer>div:last-child{position:static;max-height:none;overflow:visible}}
.stage-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow)}
#fabricWrap{width:100%;max-width:460px;aspect-ratio:1/1;position:relative;margin:0 auto}
.viewtabs{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;justify-content:center}
.tab{background:var(--surface2);border:1px solid var(--line);border-radius:var(--radius-pill);padding:6px 12px;font-size:13px;cursor:pointer;color:var(--muted);font-weight:500}
.tab.on{border-color:var(--accent);color:var(--accent-d);background:var(--accent-sf)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}
.panel h3{font-size:var(--fs-h3);margin-bottom:10px}
.label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px;font-weight:600}
.swatches{display:flex;flex-wrap:wrap;gap:7px}
.swatch{width:26px;height:26px;border-radius:50%;border:2px solid var(--line);cursor:pointer}
.swatch.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-sf)}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.field input,.field select,.field textarea{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);padding:10px 12px;outline:none;font:inherit;font-size:15px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.row{display:flex;gap:10px}.row>*{flex:1}
.toolrow{display:flex;gap:7px;flex-wrap:wrap;margin:9px 0;justify-content:center}
.toolrow .btn.ghost{padding:7px 12px;font-size:13px}
.pricebox{background:var(--surface2);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-top:6px}
.pricebox .big{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--accent-d)}
.pricebox .ln{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;margin:3px 0}
.warn{color:var(--warn);font-size:13px;margin-top:8px}
.slider{width:100%;accent-color:var(--accent)}
/* conversion-optimised price panel */
.hero-price{background:var(--surface2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.hero-price .pp{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.hero-price .vanaf{font-family:var(--font-body);font-weight:600;font-size:14px;color:var(--muted)}
.hero-price .amt{font-family:var(--font-display);font-weight:700;font-size:34px;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.hero-price .unit{font-weight:600;color:var(--muted);font-size:16px}
.hero-price .ppsub{color:var(--muted);font-size:12.5px;margin-top:4px}
.hero-price .ppsub s{opacity:.75}
.hero-price.flash{animation:ppflash .55s var(--ease-soft)}
@keyframes ppflash{0%{background:var(--accent-sf)}100%{background:var(--surface2)}}
.totalline{font-size:13px;color:var(--muted);margin:10px 2px 0}
.invite{font-size:13.5px;color:var(--text);line-height:1.55;margin:11px 0 2px}
.savings{background:#ECF7EE;border:1px solid #CDE8D3;color:#1E7A3A;border-radius:var(--radius);padding:8px 11px;font-size:13px;font-weight:600;margin:11px 0 2px}
.stafflabel{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;margin:14px 0 6px}
.staffel{display:flex;flex-direction:column;gap:5px;margin:0 0 2px}
.srow{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:13px;background:var(--surface);transition:border-color .12s,background-color .12s}
.srow:hover{border-color:var(--accent)}
.srow.on{border-color:var(--accent);background:var(--accent-sf)}
.srow .sq{flex:1;color:var(--text)}
.srow .sp{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.srow .sb{font-size:11px;font-weight:700;color:var(--accent-d);background:#fff;border:1px solid var(--accent);border-radius:999px;padding:1px 7px}
.srow .sb.base{color:var(--muted);border-color:var(--line);background:transparent}
.breakdown{margin-top:12px;border-top:1px solid var(--line);padding-top:8px}
.breakdown summary{cursor:pointer;font-size:13px;color:var(--muted);font-weight:600;list-style:revert}
.breakdown .ln{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;margin:5px 0}
.trust{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
.trust li{font-size:12.5px;color:var(--muted);padding-left:19px;position:relative;line-height:1.4}
.trust li:before{content:"✓";position:absolute;left:0;top:0;color:var(--good);font-weight:800}
.trustline{margin-top:12px;font-size:12px;color:var(--muted);line-height:1.5}
.colorwarn{background:#FFF6E6;border:1px solid #F2D08A;border-radius:var(--radius);padding:11px 12px;margin-top:10px}
.colorwarn .cw-t{font-weight:700;font-size:13px;color:#9A6B12;margin-bottom:4px}
.colorwarn .cw-m{font-size:12.5px;color:#5C4A28;line-height:1.5}
.colorwarn .cw-m b{color:#3a2f18}
.colorwarn .cw-btns{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}
.colorwarn .cw-btns .btn{padding:.5em .9em;font-size:13px}
.methodhint{font-size:12px;line-height:1.5;margin-top:10px}
.zeefbox{background:var(--surface2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.zeefbox p{font-size:13.5px;line-height:1.55;margin:0 0 10px}
.zeefbadge{display:inline-block;background:var(--ink);color:#fff;border-radius:var(--radius-pill);padding:5px 12px;font-size:11.5px;font-weight:700;margin-bottom:10px}
/* sizes — compact 6-up grid, scales to 3-up on narrow */
.size-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:4px}
@media(max-width:430px){.size-grid{grid-template-columns:repeat(3,1fr)}}
.size-cell{border:1px solid var(--line);border-radius:10px;padding:5px 3px;text-align:center;min-width:0}
.size-cell.on{border-color:var(--accent);background:var(--accent-sf)}
.size-cell.off{opacity:.55}
.soldout{font-size:10px;color:var(--muted);text-align:center;padding:6px 0;line-height:1.4}
.size-cell .size-lbl{display:block;font-weight:700;font-size:12px;color:var(--ink);line-height:1.1}
.size-cell .up{display:block;font-weight:600;font-size:8.5px;color:var(--accent-d);line-height:1}
.size-step{display:flex;align-items:stretch;margin-top:4px}
.size-step button{width:20px;flex:none;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;font-size:13px;line-height:1;padding:0}
.size-step button:first-child{border-radius:7px 0 0 7px}.size-step button:last-child{border-radius:0 7px 7px 0}
.size-step button:hover{border-color:var(--accent);background:var(--accent-sf);color:var(--accent-d)}
.size-step input{width:100%;min-width:0;text-align:center;border:1px solid var(--line);border-left:0;border-right:0;padding:5px 0;font:inherit;font-size:13px;outline:none;background:var(--surface);color:var(--text)}
.size-step input:focus{border-color:var(--accent)}
.size-total{margin-top:9px;font-size:13.5px;color:var(--text)}
/* mobile sticky price+cta bar */
.dmobile{display:none}
@media(max-width:880px){
  .dmobile{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:46;align-items:center;gap:12px;
    background:var(--surface);border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(10,10,10,.10);padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom))}
  .dmobile .dm-info{display:flex;flex-direction:column;line-height:1.15}
  .dmobile .dm-info b{font-family:var(--font-display);font-size:20px;color:var(--ink)}
  .dmobile .dm-info span{font-size:11.5px;color:var(--muted)}
  .dmobile .btn{margin-left:auto;flex:none;padding:.7em 1.2em}
  main#view{padding-bottom:78px}
  .fab{bottom:84px}
}
.sizes-panel h3{display:flex;align-items:center;justify-content:space-between;gap:8px}
.link-mini{background:none;border:0;color:var(--accent-d);font:inherit;font-size:12px;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}
.size-chart{margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.sctable{width:100%;border-collapse:collapse;font-size:13px}
.sctable th{text-align:left;color:var(--muted);font-weight:600;padding:4px 6px;border-bottom:1px solid var(--line);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.sctable td{padding:5px 6px;border-bottom:1px solid var(--line);color:var(--text)}
.sctable td:first-child{font-weight:700;color:var(--ink)}
/* cart accordion */
.cart-line{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-bottom:12px}
.cl-head{display:flex;gap:14px;align-items:center;padding:13px;cursor:pointer}
.cl-head .lt{width:64px;height:64px;border-radius:var(--radius);background:#fff;overflow:hidden;flex:none;display:grid;place-items:center;border:1px solid var(--line)}
.cl-head .lt img{width:100%;height:100%;object-fit:contain}
.cl-mid{flex:1;min-width:0}
.sidechips{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.sidechip{font-size:11px;background:var(--surface2);border:1px solid var(--line);border-radius:999px;padding:2px 9px;color:var(--muted)}
.cl-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.quote-pill{color:var(--accent-d)}
.chev{color:var(--muted);transition:transform .25s var(--ease-soft);font-size:18px}
.cart-line.open .chev{transform:rotate(180deg)}
.cl-detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s var(--ease-soft)}
.cart-line.open .cl-detail{grid-template-rows:1fr}
.cl-detail-in{overflow:hidden;min-height:0}
.cart-line.open .cl-detail-in{border-top:1px solid var(--line)}
.side-strip{display:flex;gap:10px;flex-wrap:wrap;padding:14px}
.side-strip figure{margin:0}
.side-strip img{width:120px;height:120px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.side-strip figcaption{font-size:12px;color:var(--muted);text-align:center;margin-top:4px}
.cl-sizes{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 4px}
.szchip{font-size:12px;font-weight:600;background:var(--accent-sf);color:var(--accent-d);border:1px solid var(--accent);border-radius:999px;padding:3px 10px}
.cl-actions{display:flex;gap:8px;padding:12px 14px}
/* button busy / success */
.btn.is-busy{position:relative;color:transparent!important;pointer-events:none}
.btn.is-busy::after{content:"";position:absolute;width:1.1em;height:1.1em;top:calc(50% - .55em);left:calc(50% - .55em);border:2px solid rgba(255,255,255,.65);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}
.btn.ghost.is-busy::after{border-color:rgba(0,0,0,.4);border-top-color:transparent}
.btn.is-success{background:var(--good)!important;border-color:var(--good)!important;color:#fff!important}
.btn[aria-disabled="true"]{opacity:.55;cursor:not-allowed}
@keyframes spin{to{transform:rotate(360deg)}}
.cartbtn span.bump{animation:bump .35s var(--ease-soft);display:inline-block}
@keyframes bump{0%{transform:scale(1)}30%{transform:scale(1.4)}60%{transform:scale(.92)}100%{transform:scale(1)}}
/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,16px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:var(--radius);box-shadow:var(--shadow-lg);border-left:3px solid var(--accent);font-size:14px;z-index:70;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;max-width:90vw}
.toast.show{opacity:1;transform:translate(-50%,0)}
@media(prefers-reduced-motion:reduce){.btn.is-busy::after,.cartbtn span.bump{animation:none}.chev,.cl-detail,.toast{transition:none}}
.stepper{display:flex;align-items:stretch;max-width:170px}
.stepper button{width:42px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:18px;cursor:pointer;line-height:1}
.stepper button:first-child{border-radius:var(--radius) 0 0 var(--radius)}
.stepper button:last-child{border-radius:0 var(--radius) var(--radius) 0}
.stepper button:hover{border-color:var(--accent);background:var(--accent-sf);color:var(--accent-d)}
.stepper input{flex:1;width:60px;text-align:center;border:1px solid var(--line);border-left:0;border-right:0;border-radius:0;background:var(--surface);color:var(--text);padding:10px 4px;outline:none;font:inherit;font-size:15px}
.stepper input:focus{border-color:var(--accent)}
.cta{font-size:16px}
.btn.block:disabled{opacity:.55;cursor:not-allowed;background:var(--soft);box-shadow:none;transform:none}
/* cart/account */
.list{display:flex;flex-direction:column;gap:12px}
.litem{display:flex;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:13px;align-items:center;box-shadow:var(--shadow)}
.litem .lt{width:72px;height:72px;border-radius:var(--radius);background:#fff;overflow:hidden;flex:none;display:grid;place-items:center;border:1px solid var(--line)}
.litem .lt img{width:100%;height:100%;object-fit:contain}.litem .li{flex:1}
.summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;position:sticky;top:88px;box-shadow:var(--shadow)}
.summary .ln{display:flex;justify-content:space-between;margin:7px 0}
.summary .tot{font-family:var(--font-display);font-size:22px;font-weight:600;border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
.tag{display:inline-block;font-size:11px;padding:2px 9px;border-radius:var(--radius-pill);border:1px solid var(--line);color:var(--muted)}
.tag.dtf,.tag.zeefdruk{color:var(--accent-d);border-color:var(--accent);background:var(--accent-sf)}
.split2{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media(max-width:740px){.split2{grid-template-columns:1fr}}
.sheet{background:#fff;border-radius:var(--radius);position:relative;overflow:hidden;border:1px solid var(--line);max-width:300px;margin:0 auto}
.gpiece{position:absolute;border:1px dashed var(--accent)}.gpiece img{width:100%;height:100%;object-fit:contain}
.empty{padding:46px;text-align:center;color:var(--muted)}
.notice{background:#EEF6EE;border:1px solid #C9E3CC;color:#2C5733;border-radius:var(--radius);padding:12px 14px;margin:12px 0}
.faq{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:10px;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:600;font-family:var(--font-display)}
.authbox{max-width:420px;margin:48px auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow)}
.authtabs{display:flex;gap:8px;margin-bottom:18px}.authtabs .tab{flex:1;text-align:center}
.map{width:100%;height:340px;border:0;border-radius:var(--radius-lg);filter:saturate(.92)}
/* assistant */
.fab{position:fixed;right:22px;bottom:22px;z-index:45;width:54px;height:54px;border-radius:50%;background:var(--accent);color:#FFFDF8;border:none;cursor:pointer;font-size:22px;box-shadow:var(--shadow-clay)}
.fab:hover{background:var(--accent-d)}
.assist{position:fixed;right:22px;bottom:86px;z-index:45;width:340px;max-width:calc(100vw - 44px);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;display:none;flex-direction:column}
.assist.open{display:flex}
.assist .ah{background:var(--ink);color:#fff;padding:13px 16px;font-weight:600;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display)}
.assist .am{padding:14px;display:flex;flex-direction:column;gap:10px;max-height:340px;overflow:auto}
.bub{padding:9px 12px;border-radius:14px;font-size:14px;line-height:1.45;max-width:85%}
.bub.a{background:var(--surface2);border:1px solid var(--line);align-self:flex-start}
.bub.u{background:var(--accent);color:#FFFDF8;align-self:flex-end}
.assist .ab{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.assist .ab input{flex:1;border:1px solid var(--line);border-radius:var(--radius);padding:9px 11px;outline:none;font:inherit}

/* --- Shop hub --- */
.shop-intro{ text-align:center; padding:48px 0 6px; }
.shop-intro h1{ font-size:var(--fs-h1); margin:12px 0 14px; }
.shop-intro .lead{ max-width:62ch; margin:0 auto; color:var(--muted); }
.shop-paths-sec{ padding-top:22px; }
.cards3{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:820px){ .cards3{ grid-template-columns:1fr; } }
.pathcard{ display:flex; flex-direction:column; align-items:flex-start; gap:13px; padding:28px 26px;
  text-decoration:none; color:var(--ink); background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius-lg); box-shadow:var(--shadow); transition:border-color .15s, box-shadow .15s, transform .15s; }
.pathcard:hover{ border-color:var(--accent); box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.pathcard .pic{ width:62px; height:62px; border-radius:var(--radius-pill); background:var(--accent-sf);
  display:flex; align-items:center; justify-content:center; font-size:30px; line-height:1; }
.pathcard h3{ font-size:var(--fs-h3); }
.pathcard p{ flex:1; margin:0; color:var(--muted); font-size:15px; line-height:1.55; }
.pathcard .btn.block{ margin-top:6px; }
.step-n{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px;
  border-radius:var(--radius-pill); background:var(--accent-sf); color:var(--accent-d);
  font-family:var(--font-body); font-weight:700; margin-bottom:8px; }
/* --- DTF transfer product cards --- */
.dtf-prev{ display:flex; align-items:center; justify-content:center; height:170px; width:100%; margin-bottom:4px; }
.dtf-sheet-mini{ background:#fff; border:1px solid var(--line2); border-radius:4px; box-shadow:var(--shadow); display:flex; align-items:center; justify-content:center; }
.dtf-sheet-mini span{ font:700 12px/1.2 var(--font-body); color:var(--accent-d); text-align:center }
.dtf-bul{ list-style:none; padding:0; margin:2px 0 0; color:var(--muted); font-size:14px; flex:1 }
.dtf-bul li{ position:relative; padding-left:15px; margin:4px 0 }
.dtf-bul li:before{ content:"•"; color:var(--accent); position:absolute; left:2px }
.dtf-price{ font-family:var(--font-display); font-weight:600; font-size:26px; color:var(--accent-d); margin:10px 0 2px }
.sheet-over{ position:absolute; left:0; right:0; bottom:0; background:var(--accent); color:#fff; font-size:12px; padding:5px 8px; text-align:center }
.dtf-stage{ display:flex; justify-content:center; align-items:flex-start; background:var(--surface2); border:1px solid var(--line); border-radius:var(--radius); padding:14px; min-height:280px }
.dtf-stage .canvas-container{ box-shadow:var(--shadow); border:1px solid var(--line2); border-radius:3px }
/* --- saved-design cards (account) --- */
.dcard{display:flex;flex-direction:column}
.dcard-act{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
/* --- save / busy overlay --- */
.fvbusy{position:fixed;inset:0;z-index:200;background:rgba(10,10,10,.45);display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.fvbusy-card{background:#fff;border-radius:var(--radius-lg);padding:28px 36px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;max-width:80vw}
.fvbusy-msg{font-weight:600;color:var(--ink);font-size:16px}
.fvbusy-sub{color:var(--muted);font-size:13px}
.fvspin{width:40px;height:40px;border:4px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:fvspin .8s linear infinite}
@keyframes fvspin{to{transform:rotate(360deg)}}
