: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.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:48px 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 330px;gap:22px;align-items:start}
@media(max-width:880px){.designer{grid-template-columns:1fr}}
.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:18px;margin-bottom:14px;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)}
/* 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}
