/* ============================================================
   DoMan Identity System v2.0 — strict monochrome
   Black #000 · White #fff · Charcoal #333 · K-scale grays
   Playfair Display (headlines) · Inter (body/UI)
   ============================================================ */
:root{
  --black:#000000; --white:#ffffff; --charcoal:#333333;
  --k60:#666666; --k40:#999999; --k20:#cccccc; --k10:#e6e6e6;
  --serif:'Playfair Display', Georgia, serif;
  --sans:'Inter', -apple-system, sans-serif;
  --max:1240px;
  --header-h:76px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:400;line-height:1.6;color:var(--black);background:var(--white);-webkit-font-smoothing:antialiased}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:var(--sans);cursor:pointer;border:none;background:none}
input,select,textarea{font-family:var(--sans);font-size:15px;color:var(--black)}

/* ---------- type roles ---------- */
.label{font:600 11px/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--k60)}
.label.on-dark{color:var(--k40)}
h1,h2,h3,.serif{font-family:var(--serif);font-weight:700;line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(38px,5.6vw,72px);font-weight:800}
h2{font-size:clamp(28px,3.6vw,46px)}
h3{font-size:22px}
.lead{font-size:17px;color:var(--charcoal);max-width:62ch}
.on-dark .lead, .lead.on-dark{color:var(--k20)}

/* ---------- refined ampersand (Playfair italic) ---------- */
.amp{font-family:var(--serif);font-style:italic;font-weight:500;font-size:1.18em;line-height:0;padding:0 .04em;letter-spacing:0}

/* ---------- Klarna payment badge (official brand asset) ---------- */
.klarna-logo{height:20px;width:auto;display:inline-block;vertical-align:middle}
.klarna-band{display:flex;align-items:center;gap:12px;background:var(--k10);padding:12px 16px;margin:16px 0;font:500 12.5px var(--sans);color:var(--charcoal)}
.klarna-band.on-dark{background:#111;color:var(--k20)}
.klarna-trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.klarna-trust .pay-pill{height:34px;width:auto}
.klarna-trust .sep-dot{width:4px;height:4px;border-radius:50%;background:var(--k20)}

/* ---------- wood-grain quote banner ---------- */
.wood-banner{position:relative;padding:104px 0;text-align:center;background:var(--black);overflow:hidden}
.wood-banner .wood-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;filter:invert(1)}
.wood-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.74),rgba(0,0,0,.5),rgba(0,0,0,.8))}
.wood-banner .wrap{position:relative;z-index:2;color:var(--white)}
.wood-banner .jp{font-family:var(--serif);font-size:15px;letter-spacing:.5em;color:var(--k40);margin-bottom:18px}
.wood-banner h2{font-size:clamp(30px,4.4vw,56px);max-width:24ch;margin:0 auto 16px;color:var(--white)}
.wood-banner p{color:var(--k20);max-width:56ch;margin:0 auto}

/* ---------- page-hero: stronger heading legibility ---------- */
.page-hero .hero-content h1{text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero-meta{display:flex;gap:22px;flex-wrap:wrap;margin:0 0 30px;font:500 13px var(--sans);color:var(--k10)}
.hero-meta span{display:flex;align-items:center;gap:8px}
.hero-meta .b{font-family:var(--serif);font-weight:800;font-size:17px;color:var(--white)}

/* ---------- social icons ---------- */
.social{display:flex;gap:12px;margin-top:18px}
.social a{width:40px;height:40px;border:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;color:var(--k20);transition:.22s}
.social a:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.social svg{width:18px;height:18px}

/* ---------- legal / terms page ---------- */
.legal{max-width:820px}
.legal h2{font-size:30px;margin:40px 0 14px}
.legal h2:first-child{margin-top:0}
.legal p{font-size:15px;color:var(--charcoal);margin-bottom:14px;line-height:1.75}
.legal ul.bul{margin:0 0 16px;padding:0}
.legal ul.bul li{font-size:15px;color:var(--charcoal);padding:6px 0 6px 18px;position:relative;line-height:1.7}
.legal ul.bul li::before{content:'';position:absolute;left:0;top:13px;width:6px;height:6px;background:var(--black)}
.legal .toc{border:1px solid var(--k10);padding:22px 26px;margin-bottom:30px}
.legal .toc a{display:block;padding:5px 0;font-size:14px;color:var(--k60);border-bottom:1px solid var(--k10)}
.legal .toc a:last-child{border:none}
.legal .toc a:hover{color:var(--black)}
.legal .meta-box{background:var(--k10);padding:20px 24px;margin:24px 0;font-size:14px;line-height:1.8}

/* ---------- textures (brand patterns) ---------- */
.tex-charred{background-color:var(--black);background-image:repeating-linear-gradient(90deg,#000 0 14px,#0c0c0c 14px 22px,#050505 22px 40px,#111 40px 46px,#000 46px 78px)}
.tex-seigaiha{background-color:var(--black);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='60' viewBox='0 0 120 60'%3E%3Cg fill='none' stroke='%23222222' stroke-width='3'%3E%3Ccircle cx='0' cy='60' r='54'/%3E%3Ccircle cx='0' cy='60' r='40'/%3E%3Ccircle cx='0' cy='60' r='26'/%3E%3Ccircle cx='0' cy='60' r='12'/%3E%3Ccircle cx='120' cy='60' r='54'/%3E%3Ccircle cx='120' cy='60' r='40'/%3E%3Ccircle cx='120' cy='60' r='26'/%3E%3Ccircle cx='120' cy='60' r='12'/%3E%3Ccircle cx='60' cy='30' r='54'/%3E%3Ccircle cx='60' cy='30' r='40'/%3E%3Ccircle cx='60' cy='30' r='26'/%3E%3Ccircle cx='60' cy='30' r='12'/%3E%3C/g%3E%3C/svg%3E")}
.divider-seigaiha{height:42px;background-color:var(--white);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='84' height='42' viewBox='0 0 84 42'%3E%3Cg fill='none' stroke='%23000000' stroke-width='2.4'%3E%3Ccircle cx='0' cy='42' r='38'/%3E%3Ccircle cx='0' cy='42' r='28'/%3E%3Ccircle cx='0' cy='42' r='18'/%3E%3Ccircle cx='0' cy='42' r='8'/%3E%3Ccircle cx='84' cy='42' r='38'/%3E%3Ccircle cx='84' cy='42' r='28'/%3E%3Ccircle cx='84' cy='42' r='18'/%3E%3Ccircle cx='84' cy='42' r='8'/%3E%3Ccircle cx='42' cy='21' r='38'/%3E%3Ccircle cx='42' cy='21' r='28'/%3E%3Ccircle cx='42' cy='21' r='18'/%3E%3Ccircle cx='42' cy='21' r='8'/%3E%3C/g%3E%3C/svg%3E");border-top:1px solid var(--black);border-bottom:1px solid var(--black)}

/* ---------- layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section.dark{background:var(--black);color:var(--white)}
.section-head{margin-bottom:48px}
.section-head .label{display:block;margin-bottom:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font:600 12px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;padding:18px 32px;border:1px solid var(--black);transition:all .25s ease}
.btn-solid{background:var(--black);color:var(--white)}
.btn-solid:hover{background:var(--charcoal);border-color:var(--charcoal)}
.btn-ghost{background:transparent;color:var(--black)}
.btn-ghost:hover{background:var(--black);color:var(--white)}
.btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-white:hover{background:transparent;color:var(--white)}
.btn-ghost-white{background:transparent;color:var(--white);border-color:var(--white)}
.btn-ghost-white:hover{background:var(--white);color:var(--black)}
.btn .arr{transition:transform .25s}.btn:hover .arr{transform:translateX(5px)}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--header-h);background:rgba(0,0,0,.92);backdrop-filter:blur(10px);border-bottom:1px solid #1a1a1a;transition:background .3s}
.header-in{max-width:var(--max);margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:46px;width:auto}
.brand-name{font-family:var(--serif);font-weight:700;font-size:21px;color:var(--white)}
nav.main ul{display:flex;gap:4px}
nav.main a{display:block;padding:10px 13px;font:500 13px/1 var(--sans);color:var(--k20);letter-spacing:.04em;transition:color .2s;position:relative}
nav.main a:hover{color:var(--white)}
nav.main a.active{color:var(--white)}
nav.main a.active::after{content:'';position:absolute;left:13px;right:13px;bottom:4px;height:2px;background:var(--white)}
.nav-cta{white-space:nowrap;padding:13px 22px!important}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:var(--white);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- breadcrumbs ---------- */
.crumbs{padding:14px 0;border-bottom:1px solid var(--k10);font:500 12px var(--sans);color:var(--k60)}
.crumbs a:hover{color:var(--black);text-decoration:underline}
.crumbs .sep{margin:0 8px;color:var(--k20)}
.crumbs .cur{color:var(--black);font-weight:600}

/* ---------- hero (video) ---------- */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:flex-end;background:var(--black);overflow:hidden}
.hero video,.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.1) 40%,rgba(0,0,0,.78) 100%)}
.hero-content{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto;padding:0 24px 92px;color:var(--white)}
.hero-content .label{color:var(--k20);margin-bottom:18px;display:block}
.hero-content h1{margin-bottom:22px;max-width:14ch}
.hero-content .lead{color:var(--k10);margin-bottom:38px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-kanji{position:absolute;top:50%;right:5%;transform:translateY(-50%);z-index:2;font-family:var(--serif);font-size:clamp(70px,9vw,140px);color:rgba(255,255,255,.13);writing-mode:vertical-rl;letter-spacing:.3em;user-select:none}
.page-hero{position:relative;min-height:72vh;display:flex;align-items:flex-end;background:var(--black);overflow:hidden;padding-top:calc(var(--header-h) + 24px)}
.page-hero>video,.page-hero>img.hero-bg,.page-hero>.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.page-hero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.35) 45%,rgba(0,0,0,.72) 100%)}
.page-hero .hero-content{position:relative;z-index:2}
.page-hero .hero-content{padding-bottom:64px}

/* ---------- cards ---------- */
.svc-card{position:relative;display:block;background:var(--black);overflow:hidden;aspect-ratio:4/5;color:var(--white)}
.svc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.78;transition:transform .6s ease,opacity .4s}
.svc-card:hover img{transform:scale(1.05);opacity:.55}
.svc-card .in{position:absolute;inset:auto 0 0 0;padding:28px;background:linear-gradient(transparent,rgba(0,0,0,.88))}
.svc-card .label{color:var(--k20);display:block;margin-bottom:8px}
.svc-card h3{font-size:26px;margin-bottom:8px}
.svc-card p{font-size:14px;color:var(--k20);max-width:34ch}
.svc-card .go{margin-top:14px;font:600 11px var(--sans);letter-spacing:.2em;text-transform:uppercase;display:inline-flex;gap:8px;align-items:center;border-bottom:1px solid var(--white);padding-bottom:4px}

.prod-card{border:1px solid var(--k10);background:var(--white);display:flex;flex-direction:column;transition:border-color .25s,box-shadow .25s;cursor:pointer}
.prod-card:hover{border-color:var(--black);box-shadow:0 18px 44px rgba(0,0,0,.10)}
.prod-card .ph{aspect-ratio:4/3;background:var(--k10);overflow:hidden;position:relative}
.prod-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.prod-card:hover .ph img{transform:scale(1.045)}
.prod-card .ph .tag{position:absolute;top:14px;left:14px;background:var(--black);color:var(--white);font:600 10px var(--sans);letter-spacing:.18em;text-transform:uppercase;padding:7px 11px}
.prod-card .body{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.prod-card h3{font-size:20px}
.prod-card .meta{font:500 12px var(--sans);color:var(--k60);letter-spacing:.04em}
.prod-card .price-row{margin-top:auto;padding-top:14px;border-top:1px solid var(--k10);display:flex;justify-content:space-between;align-items:flex-end;gap:8px}
.prod-card .price{font:700 19px var(--sans)}
.prod-card .price small{font:500 11px var(--sans);color:var(--k60);display:block;letter-spacing:.04em}
.prod-card .klarna{font:600 10.5px var(--sans);color:var(--k60);letter-spacing:.03em;text-align:right}
.prod-card .klarna b{color:var(--black)}

/* ---------- wood finish cards ---------- */
.wood-card{position:relative;overflow:hidden;aspect-ratio:3/4;background:var(--black);color:var(--white)}
.wood-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85;transition:transform .6s}
.wood-card:hover img{transform:scale(1.06)}
.wood-card .in{position:absolute;inset:auto 0 0 0;padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.9))}
.wood-card .nr{font-family:var(--serif);font-weight:800;font-size:15px;color:var(--k40)}
.wood-card h3{font-size:21px;margin:4px 0 6px}
.wood-card p{font-size:13px;color:var(--k20)}

/* ---------- stats / steps ---------- */
.steps{counter-reset:step}
.step{display:grid;grid-template-columns:88px 1fr;gap:24px;padding:34px 0;border-top:1px solid #222}
.step:last-child{border-bottom:1px solid #222}
.step .nr{font-family:var(--serif);font-weight:800;font-size:46px;color:var(--charcoal);line-height:1}
.step h3{margin-bottom:8px}
.step p{color:var(--k40);font-size:15px;max-width:60ch}

/* ---------- gallery ---------- */
.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:34px}
.filter-tabs button{font:600 11px var(--sans);letter-spacing:.16em;text-transform:uppercase;padding:12px 20px;border:1px solid var(--k20);color:var(--k60);transition:.2s}
.filter-tabs button:hover{border-color:var(--black);color:var(--black)}
.filter-tabs button.active{background:var(--black);color:var(--white);border-color:var(--black)}
.mosaic{columns:3;column-gap:16px}
.mosaic .tile{break-inside:avoid;margin-bottom:16px;position:relative;overflow:hidden;cursor:zoom-in;background:var(--k10)}
.mosaic .tile img{width:100%;transition:transform .5s}
.mosaic .tile:hover img{transform:scale(1.04)}
.mosaic .tile .cap{position:absolute;inset:auto 0 0 0;padding:24px 16px 12px;background:linear-gradient(transparent,rgba(0,0,0,.75));color:var(--white);font:600 10.5px var(--sans);letter-spacing:.16em;text-transform:uppercase;opacity:0;transition:.3s}
.mosaic .tile:hover .cap{opacity:1}
.tile.hidden{display:none}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;object-fit:contain}
.lightbox .x,.lightbox .nav-b{position:absolute;color:var(--white);font-size:34px;padding:14px;line-height:1;opacity:.7;transition:.2s}
.lightbox .x:hover,.lightbox .nav-b:hover{opacity:1}
.lightbox .x{top:18px;right:24px}
.lightbox .prev{left:14px;top:50%;transform:translateY(-50%)}
.lightbox .next{right:14px;top:50%;transform:translateY(-50%)}

/* ---------- modal base ---------- */
.modal-back{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.66);display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:5vh 16px 6vh}
.modal-back.open{display:flex}
.modal{background:var(--white);width:100%;max-width:680px;position:relative;animation:pop .28s ease}
@keyframes pop{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.modal .m-head{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--k10)}
.modal .m-head h3{font-size:24px}
.modal .m-x{font-size:13px;font-weight:600;letter-spacing:.14em;color:var(--k60);padding:8px}
.modal .m-x:hover{color:var(--black)}
.modal .m-body{padding:28px}
.modal.wide{max-width:880px}

/* ---------- wizard ---------- */
.wiz-prog{display:flex;align-items:center;justify-content:center;gap:0;padding:22px 28px;border-bottom:1px solid var(--k10)}
.wiz-dot{display:flex;flex-direction:column;align-items:center;gap:6px;width:84px}
.wiz-dot .c{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--k20);display:flex;align-items:center;justify-content:center;font:600 12px var(--sans);color:var(--k60);transition:.25s;background:var(--white)}
.wiz-dot span{font:600 10px var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--k60)}
.wiz-dot.done .c,.wiz-dot.cur .c{background:var(--black);border-color:var(--black);color:var(--white)}
.wiz-dot.cur span{color:var(--black)}
.wiz-line{width:54px;height:1.5px;background:var(--k20);margin-bottom:20px}
.wiz-line.done{background:var(--black)}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:14px 0 26px}
.tile-opt{border:1.5px solid var(--k20);padding:20px 12px;text-align:center;cursor:pointer;transition:.2s;position:relative;background:var(--white)}
.tile-opt:hover{border-color:var(--black)}
.tile-opt.sel{border-color:var(--black);background:#f4f4f4}
.tile-opt.sel::after{content:'✓';position:absolute;top:8px;left:10px;width:20px;height:20px;border-radius:50%;background:var(--black);color:var(--white);font-size:11px;display:flex;align-items:center;justify-content:center}
.tile-opt.off{opacity:.38;pointer-events:none}
.tile-opt.off::after{content:'!';position:absolute;top:8px;right:10px;width:20px;height:20px;border-radius:50%;background:var(--charcoal);color:var(--white);font-size:11px;display:flex;align-items:center;justify-content:center}
.tile-opt svg{display:block;margin:0 auto 10px}
.tile-opt .t{font:600 12.5px var(--sans);letter-spacing:.03em}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.f-field{display:flex;flex-direction:column;gap:7px}
.f-field.full{grid-column:1/-1}
.f-field label{font:600 10.5px var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--k60)}
.f-field input,.f-field select,.f-field textarea{border:1px solid var(--k20);padding:14px;background:var(--white);transition:border-color .2s}
.f-field input:focus,.f-field select:focus,.f-field textarea:focus{outline:none;border-color:var(--black)}
.f-field input:disabled{background:var(--k10);color:var(--k60)}
.f-field .err{font:500 11.5px var(--sans);color:var(--black);background:var(--k10);padding:7px 10px;display:none}
.f-field.invalid input{border-color:var(--black);border-width:2px}
.f-field.invalid .err{display:block}
.calc-out{background:var(--black);color:var(--white);padding:22px 24px;margin:8px 0 22px;display:none}
.calc-out.show{display:block}
.calc-out .row{display:flex;justify-content:space-between;gap:14px;padding:7px 0;border-bottom:1px solid #222;font-size:14px}
.calc-out .row:last-child{border:none}
.calc-out .row b{font-size:16px}
.calc-out .note{font-size:11.5px;color:var(--k40);margin-top:10px}
.wiz-foot{display:flex;justify-content:space-between;gap:12px;padding-top:8px}
.check-row{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--charcoal);margin:18px 0}
.check-row input{margin-top:3px;width:17px;height:17px;accent-color:var(--black)}
.fineprint{font-size:12px;color:var(--k60)}
.success{text-align:center;padding:36px 12px}
.success .big{width:74px;height:74px;border-radius:50%;background:var(--black);color:var(--white);font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.success h3{font-size:28px;margin-bottom:10px}
.success p{color:var(--k60);max-width:46ch;margin:0 auto 24px}

/* ---------- product detail modal ---------- */
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.pd-img{aspect-ratio:1/1;background:var(--k10);overflow:hidden}
.pd-img img{width:100%;height:100%;object-fit:cover}
.pd h4{font:600 11px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--k60);margin:18px 0 8px}
.pd ul.specs li{font-size:13.5px;padding:6px 0;border-bottom:1px solid var(--k10);display:flex;justify-content:space-between;gap:14px}
.pd ul.dots li{font-size:13.5px;padding:4px 0 4px 16px;position:relative}
.pd ul.dots li::before{content:'';position:absolute;left:0;top:12px;width:6px;height:6px;background:var(--black)}
.pd .price-big{font:700 26px var(--sans);margin-top:4px}
.pd .price-big small{display:block;font:500 12px var(--sans);color:var(--k60)}
.prod-page-head{margin-bottom:30px}
.prod-page-head h1{font-size:clamp(32px,4.4vw,52px);margin:8px 0 0}
#page-product .pd h4{margin:22px 0 10px;font:700 13px var(--sans);letter-spacing:.04em;text-transform:uppercase}
/* product image gallery */
.pd-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.pd-thumb{width:74px;height:74px;padding:0;border:1px solid var(--k20);background:var(--k10);cursor:pointer;overflow:hidden;border-radius:2px;transition:border-color .15s}
.pd-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pd-thumb.active{border-color:var(--black);border-width:2px}
/* facade configurator */
.fcfg{margin:6px 0 0}
.fc-units{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.fc-u{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:13px 15px;border:1.5px solid var(--k20);background:var(--white);cursor:pointer;text-align:left;border-radius:3px;transition:.15s}
.fc-u b{font:700 15px var(--serif)}
.fc-u i{font-style:normal;font:500 11.5px var(--sans);color:var(--k60)}
.fc-u.active{border-color:var(--black);background:var(--black)}
.fc-u.active b,.fc-u.active i{color:var(--white)}
.fc-block{margin-bottom:18px}
.fc-lbl{display:block;font:600 11px var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--k60);margin-bottom:10px}
.fc-lbl em{font-style:normal;text-transform:none;letter-spacing:0;font-weight:500;color:var(--k40);margin-left:6px}
.fc-forms{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.fc-form{display:flex;flex-direction:column;align-items:center;gap:7px;padding:12px 6px;border:1.5px solid var(--k20);background:var(--white);cursor:pointer;border-radius:3px;transition:.15s}
.fc-form img{width:100%;height:34px;object-fit:contain;opacity:.85}
.fc-form span{font:600 11px var(--sans);color:var(--charcoal)}
.fc-form:hover{border-color:var(--k40)}
.fc-form.active{border-color:var(--black);border-width:2px;background:var(--k10)}
.fc-qrow{display:flex;align-items:center;gap:0;max-width:240px}
.fc-step{width:44px;height:46px;border:1.5px solid var(--k20);background:var(--white);font-size:20px;cursor:pointer;line-height:1;color:var(--black)}
.fc-step:hover{background:var(--k10)}
.fc-qrow input{flex:1;height:46px;border:1.5px solid var(--k20);border-left:0;text-align:center;font:600 16px var(--sans);width:50px;-moz-appearance:textfield}
.fc-qrow input::-webkit-outer-spin-button,.fc-qrow input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.fc-suffix{height:46px;display:flex;align-items:center;padding:0 10px;border:1.5px solid var(--k20);border-left:0;border-right:0;font:600 13px var(--sans);color:var(--k40);background:var(--white)}
.fc-cta{width:100%;justify-content:center;margin-top:4px}
.fc-note{font:500 12px var(--sans);color:var(--k60);margin:12px 0 0;line-height:1.5}
@media(max-width:560px){.fc-forms{grid-template-columns:repeat(2,1fr)}}
.klarna-band{display:flex;align-items:center;gap:12px;background:var(--k10);padding:13px 16px;margin:16px 0;font:500 12.5px var(--sans)}
.klarna-badge{background:var(--black);color:var(--white);font:700 12px var(--sans);padding:6px 12px;letter-spacing:.02em}

/* ---------- contact options ---------- */
.contact-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.c-opt{border:1px solid var(--k10);padding:40px 30px;display:flex;flex-direction:column;gap:14px;transition:.25s;background:var(--white)}
.c-opt:hover{border-color:var(--black);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.c-opt .ico{width:54px;height:54px;border:1px solid var(--black);display:flex;align-items:center;justify-content:center}
.c-opt h3{font-size:21px}
.c-opt p{font-size:14px;color:var(--k60);flex:1}

/* ---------- footer ---------- */
footer{background:var(--black);color:var(--k40);padding:72px 0 36px;border-top:1px solid #1a1a1a}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:48px;border-bottom:1px solid #1c1c1c}
.foot-grid h4{font:600 11px var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--white);margin-bottom:18px}
.foot-grid a{display:block;padding:5px 0;font-size:14px;transition:color .2s}
.foot-grid a:hover{color:var(--white)}
.foot-grid p{font-size:14px}
.foot-brand img{height:60px;margin-bottom:16px}
.foot-tag{font-family:var(--serif);font-size:17px;color:var(--k20);margin-bottom:8px}
.foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:28px;font-size:12.5px;color:var(--k60)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.vis{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- pages ---------- */
section.page{display:block}
.notice{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--black);padding:18px 20px;font-size:13.5px;margin:22px 0;background:var(--white)}
.notice .i{font-family:var(--serif);font-weight:800;font-size:18px;line-height:1}
.img-block{overflow:hidden;background:var(--k10)}
.img-block img{width:100%;height:100%;object-fit:cover}
.quote-banner{padding:96px 0;text-align:center}
.quote-banner .jp{font-family:var(--serif);font-size:15px;letter-spacing:.5em;color:var(--k40);margin-bottom:18px}
.quote-banner h2{font-size:clamp(30px,4.4vw,56px);max-width:24ch;margin:0 auto 16px}
.quote-banner p{color:var(--k40);max-width:54ch;margin:0 auto}

/* ---------- responsive ---------- */
@media(max-width:1020px){
  nav.main{position:fixed;top:var(--header-h);left:0;right:0;background:var(--black);border-bottom:1px solid #1c1c1c;transform:translateY(-130%);transition:transform .3s ease;z-index:190}
  nav.main.open{transform:none}
  nav.main ul{flex-direction:column;padding:14px 24px 24px}
  nav.main a{padding:13px 4px;font-size:15px}
  nav.main a.active::after{display:none}
  .burger{display:flex}
  .grid-3,.grid-4,.contact-opts{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .mosaic{columns:2}
}
@media(max-width:640px){
  .grid-2,.grid-3,.grid-4,.contact-opts,.f-row,.pd-grid{grid-template-columns:1fr}
  .mosaic{columns:1}
  .section{padding:60px 0}
  .hero-kanji{display:none}
  .foot-grid{grid-template-columns:1fr}
  .step{grid-template-columns:56px 1fr}
  .wiz-line{width:26px}
}

/* ==========================================================================
   WooCommerce — DoMan brand overrides
   ========================================================================== */

/* ---- Product grid ---- */
.woocommerce ul.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:28px;padding:0;margin:0}
.woocommerce ul.products li.product{margin:0!important;padding:0;width:100%!important;float:none;border:1px solid var(--k10);background:var(--white);transition:border-color .25s,box-shadow .25s}
.woocommerce ul.products li.product:hover{border-color:var(--black);box-shadow:0 18px 44px rgba(0,0,0,.10)}

/* product images */
.woocommerce ul.products li.product a img{margin:0;border-radius:0;aspect-ratio:4/3;object-fit:cover;transition:transform .55s}
.woocommerce ul.products li.product:hover a img{transform:scale(1.045)}
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail{width:100%;height:auto}

/* product titles */
.woocommerce ul.products li.product .woocommerce-loop-product__title{font:700 18px var(--serif)!important;color:var(--black);padding:18px 20px 6px!important;margin:0;letter-spacing:-.01em}
.woocommerce ul.products li.product a{text-decoration:none}

/* product prices */
.woocommerce ul.products li.product .price{font:700 17px var(--sans)!important;color:var(--black);padding:0 20px 14px;display:block}
.woocommerce ul.products li.product .price del{color:var(--k40);font-weight:400}
.woocommerce ul.products li.product .price ins{text-decoration:none;font-weight:700}

/* add to cart button */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.added_to_cart{display:block;text-align:center;font:600 11px/1 var(--sans)!important;letter-spacing:.18em;text-transform:uppercase;padding:16px 20px!important;margin:0 20px 20px;border:1px solid var(--black)!important;background:var(--black)!important;color:var(--white)!important;border-radius:0!important;transition:all .25s}
.woocommerce ul.products li.product .button:hover{background:var(--charcoal)!important;border-color:var(--charcoal)!important}

/* ---- WooCommerce results / ordering bar ---- */
.woocommerce .woocommerce-result-count{font:500 13px var(--sans);color:var(--k60);letter-spacing:.04em}
.woocommerce .woocommerce-ordering select{font:500 13px var(--sans);border:1px solid var(--k20);padding:10px 14px;background:var(--white);color:var(--black)}

/* ---- Pagination ---- */
.woocommerce nav.woocommerce-pagination{margin-top:48px;text-align:center}
.woocommerce nav.woocommerce-pagination ul{border:none!important;display:inline-flex;gap:6px}
.woocommerce nav.woocommerce-pagination ul li{border:none!important}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{font:600 13px var(--sans)!important;padding:12px 18px!important;border:1px solid var(--k20)!important;background:var(--white)!important;color:var(--black)!important;min-width:auto!important;transition:.2s}
.woocommerce nav.woocommerce-pagination ul li a:hover{border-color:var(--black)!important;background:var(--black)!important;color:var(--white)!important}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--black)!important;border-color:var(--black)!important;color:var(--white)!important}

/* ---- Single product ---- */
.woocommerce div.product{padding:0}
.woocommerce div.product div.images{margin-bottom:0}
.woocommerce div.product div.images img{border-radius:0}
.woocommerce div.product .product_title{font:800 clamp(28px,3.4vw,42px)/1.12 var(--serif)!important;color:var(--black);margin-bottom:14px}
.woocommerce div.product p.price{font:700 26px var(--sans)!important;color:var(--black);margin-bottom:20px}
.woocommerce div.product p.price del{color:var(--k40);font-weight:400}
.woocommerce div.product p.price ins{text-decoration:none}
.woocommerce div.product .woocommerce-product-details__short-description{font:400 15px/1.7 var(--sans);color:var(--charcoal);margin-bottom:22px;max-width:62ch}
.woocommerce div.product form.cart{margin-bottom:28px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.woocommerce div.product form.cart .quantity input.qty{font:600 16px var(--sans);border:1px solid var(--k20);padding:14px 12px;width:72px;text-align:center;border-radius:0}
.woocommerce div.product form.cart button.single_add_to_cart_button{font:600 12px/1 var(--sans)!important;letter-spacing:.18em;text-transform:uppercase;padding:18px 36px!important;background:var(--black)!important;color:var(--white)!important;border:1px solid var(--black)!important;border-radius:0!important;transition:.25s;flex:1;min-width:200px;text-align:center}
.woocommerce div.product form.cart button.single_add_to_cart_button:hover{background:var(--charcoal)!important;border-color:var(--charcoal)!important}

/* single product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0!important;margin:40px 0 0!important;display:flex;gap:0;border-bottom:1px solid var(--k10)!important}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:none!important;border:none!important;padding:0!important;margin:0!important;border-radius:0!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{font:600 12px var(--sans)!important;letter-spacing:.16em;text-transform:uppercase;padding:16px 24px!important;color:var(--k60)!important;border-bottom:2px solid transparent;transition:.2s;display:block}
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover{color:var(--black)!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{background:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--black)!important;border-bottom-color:var(--black)}
.woocommerce div.product .woocommerce-tabs .panel{padding:28px 0;font:400 15px/1.7 var(--sans);color:var(--charcoal)}
.woocommerce div.product .woocommerce-tabs .panel h2{font:700 22px var(--serif);margin-bottom:16px}

/* related products */
.woocommerce div.product .related h2,
.woocommerce div.product .upsells h2{font:700 28px var(--serif)!important;margin-bottom:28px}

/* ---- Breadcrumb (WooCommerce built-in) ---- */
.woocommerce .woocommerce-breadcrumb{display:none}

/* ---- Notices / messages ---- */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error{border-top:none!important;background:var(--white);border:1px solid var(--black);font:500 14px var(--sans);padding:16px 20px;margin-bottom:24px}
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before{color:var(--black)!important}
.woocommerce .woocommerce-message .button{font:600 11px var(--sans)!important;letter-spacing:.14em;text-transform:uppercase;background:var(--black)!important;color:var(--white)!important;padding:10px 18px!important;border-radius:0!important}

/* ---- Cart ---- */
.woocommerce table.shop_table{border:1px solid var(--k10)!important;border-radius:0!important;font-family:var(--sans)}
.woocommerce table.shop_table th{font:600 11px var(--sans)!important;letter-spacing:.16em;text-transform:uppercase;color:var(--k60);padding:16px 14px!important;border-bottom:1px solid var(--k10)!important}
.woocommerce table.shop_table td{padding:16px 14px!important;border-bottom:1px solid var(--k10)!important;font-size:14px;vertical-align:middle}
.woocommerce .cart-collaterals .cart_totals h2{font:700 22px var(--serif)!important}
.woocommerce a.checkout-button,
.woocommerce .wc-proceed-to-checkout a.checkout-button{font:600 12px/1 var(--sans)!important;letter-spacing:.18em;text-transform:uppercase;padding:18px 28px!important;background:var(--black)!important;color:var(--white)!important;border-radius:0!important;display:block;text-align:center}

/* ---- On sale badge ---- */
.woocommerce span.onsale{background:var(--black)!important;color:var(--white)!important;font:600 10px var(--sans)!important;letter-spacing:.18em;text-transform:uppercase;padding:8px 12px!important;min-width:auto!important;min-height:auto!important;line-height:1!important;border-radius:0!important}

/* ---- Star ratings ---- */
.woocommerce .star-rating{color:var(--black)!important}
.woocommerce .star-rating::before{color:var(--k20)!important}

/* ---- Variation swatches & select ---- */
.woocommerce div.product .variations{margin-bottom:18px}
.woocommerce div.product .variations td{padding:8px 0!important}
.woocommerce div.product .variations td.label label{font:600 11px var(--sans)!important;letter-spacing:.14em;text-transform:uppercase;color:var(--k60)}
.woocommerce div.product .variations td.value select{font:500 14px var(--sans);border:1px solid var(--k20);padding:12px 14px;border-radius:0}