/*
Theme Name: GOKUDO JIKU
Theme URI: https://gokudo.kouridev.site
Author: GOKUDO Studio
Author URI: https://gokudo.studio
Description: Custom WordPress theme for GOKUDO Studio — "The Extreme Path". WooCommerce-enabled, mobile-first, with Manuka / WenDing MingTi / PPFraktionSans typography. 一品 · 不破不立.
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
License URI: https://gokudo.studio
Text Domain: gokudo-jiku
Tags: woocommerce, custom-fonts, editorial, brand
*/

/* ============ FONTS ============ */
@font-face{font-family:'Manuka';src:url('assets/fonts/Manuka-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Manuka';src:url('assets/fonts/Manuka-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Manuka';src:url('assets/fonts/Manuka-Black.otf') format('opentype');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'WenDing MingTi';src:url('assets/fonts/WenDingPLMingTi.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-RegularItalic.otf') format('opentype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Semibold.otf') format('opentype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Fraktion Sans';src:url('assets/fonts/PPFraktionSans-Black.otf') format('opentype');font-weight:900;font-style:normal;font-display:swap}

/* ============ ROOT TOKENS ============ */
:root{
  --bg:#fafafa;
  --bg2:#F2F2F2;
  --panel:#ededee;
  --ink:#181818;
  --muted:#46443f;
  --faint:#706e66;
  --line:rgba(0,0,0,.14);
  --line2:rgba(0,0,0,.07);
  --accent:oklch(0.585 0.214 25.5);
  --accent-ink:#fff;
  --accent-dim:oklch(0.585 0.214 25.5 / .12);
  --gold:#D6B598;
  --blue:oklch(0.585 0.214 25.5);
  --banner:#ffffff;
  --banner-ink:#181818;
  --han:'WenDing MingTi','Noto Sans TC',serif;
  --display:'Manuka',var(--han),Impact,sans-serif;
  --body:'Fraktion Sans','Helvetica Neue',Helvetica,var(--han),sans-serif;
  --mono:'Space Mono',ui-monospace,var(--han),monospace;
}

/* ============ RESET ============ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--accent);color:var(--accent-ink)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ============ COMMON ============ */
.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
.wrap-narrow{max-width:980px;margin:0 auto;padding:0 40px}
.col{max-width:760px;margin:0 auto;padding:0 40px}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase}
.gk{color:var(--gold)}

/* ============ BANNER (sticky dark) ============ */
header.banner{position:sticky;top:0;z-index:200;background:var(--ink);color:#fff}
.banner-inner{max-width:1320px;margin:0 auto;display:flex;align-items:stretch;height:74px}
.brand{display:flex;align-items:stretch;flex:none}
.brand .crest{background:var(--accent);color:#fff;width:74px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:38px;line-height:1}
.brand .logo{display:flex;align-items:center;padding:0 26px}
.brand .logo img{height:40px;width:auto}
nav.main{display:flex;align-items:stretch;margin-left:auto}
nav.main a{display:flex;flex-direction:column;justify-content:center;gap:3px;padding:0 22px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:#fff;position:relative;transition:background .2s,color .2s}
nav.main a .han-sub{font-family:var(--han);font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.5);font-weight:400}
nav.main a:hover{background:var(--accent);color:#fff}
nav.main a:hover .han-sub{color:rgba(255,255,255,.7)}
nav.main a.active,nav.main a.current-menu-item,nav.main li.current-menu-item > a{background:var(--accent);color:#fff}
nav.main a.active .han-sub,nav.main a.current-menu-item .han-sub,nav.main li.current-menu-item > a .han-sub{color:rgba(255,255,255,.7)}
nav.main ul{list-style:none;display:flex;align-items:stretch;margin:0;padding:0}
nav.main li{display:flex;align-items:stretch}
.cart-btn{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:0 22px;font-weight:700;transition:background .2s,color .2s;text-decoration:none}
.cart-btn:hover{background:var(--accent);color:#fff}
.cart-btn svg{width:16px;height:16px}
.cart-count{min-width:20px;height:20px;padding:0 5px;background:var(--accent);color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;line-height:1;transition:transform .3s cubic-bezier(.2,1.4,.4,1)}
.menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:0 22px;align-items:center;font-size:22px}

/* ============ MARQUEE ============ */
.marquee{background:var(--accent);color:#fff;overflow:hidden;border-bottom:1px solid rgba(0,0,0,.12)}
.marquee .track{display:flex;gap:48px;white-space:nowrap;padding:11px 0;width:max-content;animation:scroll 34s linear infinite;font-family:var(--mono);font-size:12px;letter-spacing:.26em;text-transform:uppercase}
.marquee .track span{display:flex;align-items:center;gap:48px}
.marquee .jp{font-family:var(--display);font-size:15px;letter-spacing:0}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ HERO ============ */
.hero{position:relative;min-height:92vh;display:flex;overflow:hidden;background:#fff;border-bottom:1px solid var(--line)}
.hero-stage{position:absolute;inset:0;z-index:0}
.hslide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff;opacity:0;pointer-events:none;transition:opacity 1.1s cubic-bezier(.4,0,.2,1)}
.hslide.active{opacity:1;pointer-events:auto}
.hslide img{width:100%;height:100%;object-fit:contain;object-position:center 46%;padding:74px 16px 118px;will-change:transform}
.hero-top{position:absolute;top:34px;left:0;right:0;z-index:3;pointer-events:none}
.hero-top .wrap{display:flex;justify-content:space-between;align-items:flex-start}
.hero-top .mono{color:var(--muted)}
.hero-id{display:flex;align-items:center;gap:13px}
.mark-jp{font-family:var(--display);font-size:27px;color:var(--ink);line-height:1}
.hero-badge{position:relative;display:inline-block;filter:drop-shadow(0 10px 26px rgba(0,0,0,.22))}
.badge-row{display:flex;align-items:flex-start}
.badge-crest{width:70px;height:70px;background:var(--gold);display:flex;align-items:center;justify-content:center;flex:none}
.badge-crest img{width:52px;height:52px;object-fit:contain;filter:brightness(0) invert(1)}
.badge-banner{background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:flex-start;height:90px;padding:0 26px;min-width:300px}
.badge-banner #hmCode{font-family:var(--display);font-weight:900;font-size:52px;line-height:.82;letter-spacing:.012em;text-transform:uppercase;white-space:nowrap}
#hmCode,#hIdx,.hf-name{transition:opacity .42s cubic-bezier(.4,0,.2,1)}
.txt-fade{opacity:0}
.edge{position:absolute;left:20px;top:0;bottom:118px;z-index:3;display:flex;align-items:center;pointer-events:none}
.edge .stack{writing-mode:vertical-rl;transform:rotate(180deg);display:flex;gap:26px;font-family:var(--mono);font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.edge .stack b{color:var(--accent);font-weight:400;font-family:var(--display);font-size:15px;display:inline-block;transform:rotate(90deg)}
.edge .stack .han-v{text-orientation:sideways;color:var(--accent);letter-spacing:.1em}
.edge .stack .gold{color:var(--gold)}
.hero-foot{position:absolute;left:0;right:0;bottom:0;z-index:4;border-top:1px solid var(--line);background:rgba(255,255,255,.78);backdrop-filter:blur(6px)}
.hero-foot .wrap{display:flex;justify-content:space-between;align-items:center;padding-top:18px;padding-bottom:18px;gap:24px}
.hf-left{display:flex;align-items:center;gap:18px}
.hnav{width:44px;height:44px;border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer;font-size:16px;line-height:1;transition:.2s;display:flex;align-items:center;justify-content:center}
.hnav:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.hf-cap{display:flex;flex-direction:column;gap:3px;min-width:230px}
.hf-idx{color:var(--muted);font-size:11px}
.hf-idx b{color:var(--accent);font-weight:700}
.hf-name{font-family:var(--display);font-size:26px;line-height:1;text-transform:uppercase;letter-spacing:.01em;color:var(--ink)}
.hf-dots{display:flex;align-items:center;gap:10px}
.dot{width:46px;height:3px;border:none;padding:0;cursor:pointer;background:rgba(0,0,0,.16);position:relative;overflow:hidden}
.dot::after{content:"";position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:left}
.dot.active::after{animation:dotfill 5.5s linear forwards}
@keyframes dotfill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hf-right{color:var(--muted);letter-spacing:.34em}

/* ============ SECTION SHELL ============ */
section{position:relative}
.seclabel{display:flex;align-items:center;gap:16px;color:var(--muted);margin-bottom:54px}
.seclabel .idx{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--blue)}
.seclabel .ln{flex:1;height:1px;background:var(--line)}
.seclabel .jp{font-family:var(--display);font-size:20px;color:var(--ink)}

.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============ FEATURE PRODUCT (home + single) ============ */
#products,#product{padding:120px 0 110px;background:var(--bg)}
#product{padding:54px 0 100px}
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:stretch}
.feature-media{position:relative;background:#fff;border:1px solid var(--line);overflow:hidden;min-height:560px;display:flex;flex-direction:column}
.feature-media .tag{position:absolute;top:22px;right:22px;z-index:3;background:var(--accent);color:var(--accent-ink);font-family:var(--mono);font-size:10px;letter-spacing:.2em;padding:7px 11px;text-transform:uppercase}
.feature-media .bignum{position:absolute;left:20px;top:2px;z-index:1;font-family:var(--display);font-size:170px;line-height:.8;color:rgba(0,0,0,.05);pointer-events:none}
.gal-thumbs{display:flex;flex-direction:row;gap:12px;justify-content:center;flex-wrap:wrap;padding:16px;border-top:1px solid var(--line2)}
.gal-thumb{position:relative;width:70px;height:70px;border:1px solid var(--line);background:var(--bg2);cursor:pointer;padding:5px;transition:border-color .2s,background .2s}
.gal-thumb img{width:100%;height:100%;object-fit:contain;display:block}
.gal-thumb:hover{border-color:var(--ink)}
.gal-thumb.active{border-color:var(--accent);background:#fff}
.gal-thumb.active::after{content:"";position:absolute;left:-1px;right:-1px;top:-1px;height:3px;background:var(--accent)}
.gal-stage{position:relative;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.gal-stage img{width:100%;height:100%;object-fit:contain;object-position:center;padding:26px;position:relative;z-index:2;transition:opacity .35s ease}
.gal-stage img.fade{opacity:0}
.gal-vlabel{position:absolute;left:22px;bottom:18px;z-index:3;display:flex;align-items:baseline;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.gal-vlabel b{font-family:var(--display);font-size:15px;color:var(--ink);letter-spacing:.02em}
.gal-vlabel .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em}
.feature-info{display:flex;flex-direction:column;justify-content:space-between;background:var(--bg2);border:1px solid var(--line);padding:46px 44px}
.feature-info .fi-meta{display:flex;align-items:center;gap:12px;margin-bottom:22px;color:var(--faint);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.feature-info .fi-meta .han{font-family:var(--han);color:var(--accent);font-size:14px;letter-spacing:.12em}
.feature-info .fi-meta .dot{width:5px;height:5px;background:var(--accent);border-radius:50%}
.feature-info .pname{font-family:var(--display);font-weight:900;font-size:clamp(40px,5vw,68px);line-height:.9;text-transform:uppercase;letter-spacing:-.01em}
.feature-info .pname em{font-style:normal;color:var(--accent)}
.feature-info .pdesc{color:var(--muted);font-size:17px;line-height:1.7;margin:22px 0 30px;max-width:460px}
.specs{border-top:1px solid var(--line);margin-bottom:30px}
.specrow{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line2);font-size:13px}
.specrow span:first-child{color:var(--faint);font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase}
.specrow span:last-child{color:var(--ink);font-weight:600}
.buyrow{display:flex;align-items:center;gap:18px;margin-bottom:22px}
.price{font-family:var(--display);font-size:40px;line-height:1}
.price small{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.1em;margin-left:8px}
.sizelab{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.sizelab a{color:var(--accent)}
.sizes{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.sizes button{background:transparent;border:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:12px;padding:10px 13px;cursor:pointer;transition:.18s;min-width:46px}
.sizes button:hover{border-color:var(--ink);color:var(--ink)}
.sizes button.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.addcart{width:100%;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;font-family:var(--mono);font-size:13px;letter-spacing:.22em;text-transform:uppercase;padding:20px;font-weight:700;position:relative;overflow:hidden;transition:.25s;display:block;text-align:center;text-decoration:none}
.addcart:hover{background:#181818;color:#fff}
.addcart:active{transform:scale(.99)}

/* detail grid */
.details{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:30px}
.dcard{background:var(--panel);border:1px solid var(--line);overflow:hidden;position:relative}
.dcard img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.dcard:hover img{transform:scale(1.06)}
.dcard .cap{display:flex;justify-content:space-between;align-items:center;padding:16px 18px}
.dcard .cap b{font-size:14px;letter-spacing:.02em;color:var(--ink)}
.dcard .cap span{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:.18em}
.dcard::before{content:"";position:absolute;top:0;left:0;height:2px;width:0;background:var(--accent);transition:width .5s ease;z-index:2}
.dcard:hover::before{width:100%}

/* ============ THEORY ============ */
#theory{padding:130px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.theory-jp{position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:46vh;line-height:.8;color:rgba(0,0,0,.035);pointer-events:none;user-select:none}
.theory-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;position:relative;z-index:2}
.theory-grid h2{font-family:var(--display);font-weight:900;font-size:clamp(56px,7.2vw,104px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em}
.theory-grid h2 em{font-style:normal;color:var(--accent)}
.theory-body p{color:var(--muted);font-size:18px;line-height:1.8;margin-bottom:22px}
.theory-body p strong{color:var(--ink);font-weight:600}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:48px;border:1px solid var(--line)}
.pillar{background:var(--bg2);padding:30px 26px;transition:background .3s}
.pillar:hover{background:var(--bg)}
.pillar .n{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.2em;margin-bottom:18px}
.pillar .jp{font-family:var(--display);font-size:34px;margin-bottom:10px;transition:color .3s}
.pillar:hover .jp{color:var(--accent)}
.pillar h4{font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.pillar p{color:var(--faint);font-size:14.5px;line-height:1.65}

.manifesto{margin-top:84px;padding-top:60px;border-top:1px solid var(--line);position:relative;z-index:2}
.manifesto blockquote{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(30px,4vw,58px);line-height:1.03;letter-spacing:-.01em;max-width:1040px}
.manifesto blockquote em{font-style:normal;color:var(--accent)}
.manifesto .attrib{margin-top:28px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.manifesto .attrib .han{font-family:var(--han);color:var(--muted);letter-spacing:.1em}
.manifesto .attrib .dot{width:5px;height:5px;background:var(--line);border-radius:50%}

.process{margin-top:78px;border-top:1px solid var(--line);padding-top:54px;position:relative;z-index:2}
.process-head{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:38px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.process-head .han{font-family:var(--han);color:var(--faint);letter-spacing:.1em}
.psteps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.pstep{position:relative;padding-top:24px;border-top:2px solid var(--ink)}
.pstep .pn{font-family:var(--display);font-size:42px;line-height:.8;color:var(--accent);margin-bottom:18px}
.pstep .jp{font-family:var(--han);font-size:14px;color:var(--faint);margin-bottom:10px;display:block;letter-spacing:.12em}
.pstep h4{font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:11px}
.pstep p{color:var(--muted);font-size:14px;line-height:1.65}

/* ============ ANNOUNCEMENT STRIP (home + sub) ============ */
#announcement{padding:90px 0;background:var(--bg)}
.ann{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;border:1px solid var(--line);padding:48px 52px;background:linear-gradient(120deg,var(--panel),var(--bg2))}
.ann h3{font-family:var(--display);font-weight:900;font-size:clamp(28px,3.4vw,46px);text-transform:uppercase;line-height:.95}
.ann h3 em{font-style:normal;color:var(--accent)}
.ann p{color:var(--muted);font-size:16px;margin-top:12px;max-width:440px;line-height:1.6}
.ann form{display:flex;border:1px solid var(--line);min-width:320px;background:#fff}
.ann input{flex:1;background:transparent;border:none;color:var(--ink);padding:18px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;outline:none}
.ann input::placeholder{color:var(--faint)}
.ann button{background:var(--ink);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:0 24px;font-weight:700;transition:.2s}
.ann button:hover{background:var(--accent);color:var(--accent-ink)}

/* ============ PAGE HEAD ============ */
.pagehead{border-bottom:1px solid var(--line);background:var(--bg);padding:70px 0 46px}
.ph-crumb{display:flex;align-items:center;gap:10px;color:var(--faint);margin-bottom:30px}
.ph-crumb a{color:var(--faint);transition:color .2s}
.ph-crumb a:hover{color:var(--accent)}
.ph-crumb .sep{color:var(--line)}
.ph-crumb .cur{color:var(--ink)}
.ph-row{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ph-title{display:flex;align-items:flex-end;gap:22px}
.ph-title h1{font-family:var(--display);font-weight:900;font-size:clamp(54px,7.4vw,112px);line-height:.82;text-transform:uppercase;letter-spacing:-.02em}
.ph-title .han{font-family:var(--han);font-size:clamp(30px,4vw,54px);color:var(--accent);line-height:1;margin-bottom:6px}
.ph-meta{text-align:right;color:var(--muted)}
.ph-meta .count{font-family:var(--display);font-size:46px;line-height:1;color:var(--ink)}
.ph-meta .count em{font-style:normal;color:var(--accent)}
.ph-meta .lead{font-family:var(--display);font-size:30px;line-height:1;color:var(--ink)}
.ph-sub{margin-top:34px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;color:var(--faint);font-size:15px;line-height:1.6;max-width:560px}

/* page-rule (terms) */
.ph-rule{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:30px;padding-top:22px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.ph-rule .dot{width:5px;height:5px;background:var(--line);border-radius:50%}
.ph-rule b{color:var(--ink);font-weight:700}
.ph-rule .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em;font-size:13px}

/* filter pills (catalog) */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.filters button,.filters a{background:transparent;border:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:11px 18px;cursor:pointer;transition:.18s;display:flex;align-items:center;gap:9px;text-decoration:none}
.filters button .han,.filters a .han{font-family:var(--han);letter-spacing:.08em;color:var(--faint);font-size:12px}
.filters button:hover,.filters a:hover{border-color:var(--ink);color:var(--ink)}
.filters button.sel,.filters a.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.filters button.sel .han,.filters a.sel .han{color:rgba(255,255,255,.7)}
.filters .fcount{font-size:10px;color:var(--faint)}
.filters button.sel .fcount,.filters a.sel .fcount{color:rgba(255,255,255,.55)}

/* ============ CATALOG / PRODUCT CARDS ============ */
.catalog{padding:70px 0 110px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.pcard{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);transition:border-color .35s,box-shadow .45s,transform .45s}
.pcard:hover{border-color:var(--ink);box-shadow:0 24px 60px -28px rgba(0,0,0,.4);transform:translateY(-4px)}
.pcard::before{content:"";position:absolute;top:0;left:0;height:3px;width:0;background:var(--accent);transition:width .55s cubic-bezier(.16,1,.3,1);z-index:5}
.pcard:hover::before{width:100%}
.pcard.soon{background:var(--bg2)}
.pc-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line2)}
.pc-media img.shoe{width:100%;height:100%;object-fit:contain;object-position:center 52%;padding:30px 26px 40px;position:relative;z-index:2;mix-blend-mode:multiply}
.pc-bignum{position:absolute;left:14px;bottom:-26px;z-index:1;font-family:var(--display);font-weight:900;font-size:200px;line-height:.7;color:rgba(0,0,0,.045);pointer-events:none;user-select:none}
.pc-soonimg{filter:grayscale(1) contrast(.96);opacity:.5}
.pc-badge{position:absolute;top:0;left:0;z-index:4;display:flex;align-items:stretch;filter:drop-shadow(0 8px 20px rgba(0,0,0,.16))}
.pc-badge .crest{width:52px;background:var(--gold);display:flex;align-items:center;justify-content:center;flex:none}
.pc-badge .crest img{width:34px;height:34px;object-fit:contain;filter:brightness(0) invert(1)}
.pc-badge .code{background:var(--ink);color:#fff;display:flex;align-items:center;padding:0 18px;font-family:var(--display);font-weight:900;font-size:22px;letter-spacing:.01em;text-transform:uppercase;white-space:nowrap}
.pc-tag{position:absolute;top:18px;right:18px;z-index:4;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;padding:8px 12px;font-weight:700}
.pc-tag.avail{background:var(--accent);color:#fff}
.pc-tag.soon{background:var(--ink);color:#fff}
.pc-body{display:flex;flex-direction:column;flex:1;padding:30px 32px 32px}
.pc-name{font-family:var(--display);font-weight:900;font-size:clamp(34px,3.4vw,50px);line-height:.9;text-transform:uppercase;letter-spacing:-.01em}
.pc-name em{font-style:normal;color:var(--accent)}
.pc-trans{display:flex;align-items:center;gap:12px;margin-top:14px;color:var(--faint);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.pc-trans .han{font-family:var(--han);color:var(--accent);font-size:14px;letter-spacing:.12em}
.pc-desc{color:var(--muted);font-size:15px;line-height:1.65;margin:18px 0 24px;max-width:430px}
.pc-specs{display:flex;flex-wrap:wrap;gap:0 0;border-top:1px solid var(--line2);margin-bottom:26px}
.pc-spec{flex:1 1 50%;padding:13px 0;border-bottom:1px solid var(--line2);display:flex;flex-direction:column;gap:4px}
.pc-spec:nth-child(odd){padding-right:18px}
.pc-spec .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.pc-spec .v{font-size:13.5px;font-weight:600;color:var(--ink)}
.pc-foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding-top:24px;border-top:1px solid var(--line)}
.pc-price{display:flex;flex-direction:column;gap:3px}
.pc-price .amt{font-family:var(--display);font-size:40px;line-height:.9}
.pc-price .amt small{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-left:7px}
.pc-price .note{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.pc-price .soonamt{font-family:var(--display);font-size:30px;line-height:.9;color:var(--muted)}
.pc-cta{display:inline-flex;align-items:center;gap:12px;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:17px 24px;font-weight:700;transition:.24s;white-space:nowrap;text-decoration:none}
.pc-cta:hover{background:var(--ink);color:#fff;gap:18px}
.pc-cta.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.pc-cta.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.pc-cta .arr{transition:transform .24s}
.pc-cta:hover .arr{transform:translateX(3px)}

/* catfoot strip */
.catfoot{border-top:1px solid var(--line);background:var(--bg2);padding:64px 0}
.catfoot-in{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.catfoot h3{font-family:var(--display);font-weight:900;font-size:clamp(26px,3vw,40px);text-transform:uppercase;line-height:.95}
.catfoot h3 em{font-style:normal;color:var(--accent)}
.catfoot p{color:var(--muted);font-size:15px;margin-top:10px;max-width:440px;line-height:1.6}
.catfoot a.btn{display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:18px 28px;font-weight:700;transition:.22s;text-decoration:none}
.catfoot a.btn:hover{background:var(--accent);color:#fff;gap:18px}

/* ============ ANNOUNCEMENT FEED ============ */
.feed{padding:64px 0 40px;background:var(--bg)}
.featured{display:grid;grid-template-columns:1.15fr .85fr;gap:0;border:1px solid var(--line);background:#fff;transition:border-color .35s,box-shadow .45s,transform .45s;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.featured::before{content:"";position:absolute;top:0;left:0;height:3px;width:0;background:var(--accent);transition:width .55s cubic-bezier(.16,1,.3,1);z-index:5}
.featured:hover{border-color:var(--ink);box-shadow:0 28px 70px -34px rgba(0,0,0,.45);transform:translateY(-4px)}
.featured:hover::before{width:100%}
.featured-media{position:relative;background:#fff;overflow:hidden;min-height:480px;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line2)}
.featured-media img{width:100%;height:100%;object-fit:contain;object-position:center 52%;padding:40px 30px 50px;mix-blend-mode:multiply}
.featured-media .bignum{position:absolute;left:18px;bottom:-30px;z-index:1;font-family:var(--display);font-weight:900;font-size:220px;line-height:.7;color:rgba(0,0,0,.045);pointer-events:none;user-select:none}
.featured-media .ftag{position:absolute;top:20px;left:20px;z-index:4;background:var(--accent);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;padding:9px 13px;font-weight:700}
.featured-body{padding:clamp(34px,4vw,58px);display:flex;flex-direction:column;justify-content:center}
.featured-body .dateline{display:flex;align-items:center;gap:12px;color:var(--faint);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:26px;flex-wrap:wrap}
.featured-body .dateline .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:13px}
.featured-body .dateline .dot{width:5px;height:5px;background:var(--line);border-radius:50%}
.featured-body h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,4.6vw,72px);line-height:.9;text-transform:uppercase;letter-spacing:-.015em}
.featured-body h2 em{font-style:normal;color:var(--accent)}
.featured-body .sub{color:var(--muted);font-size:17px;line-height:1.7;margin:22px 0 30px;max-width:460px}
.read-cta{display:inline-flex;align-items:center;gap:12px;align-self:flex-start;background:var(--ink);color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:17px 26px;font-weight:700;transition:.24s;text-decoration:none}
.read-cta:hover{background:var(--accent);color:#fff;gap:18px}
.read-cta .arr{transition:transform .24s}
.read-cta:hover .arr{transform:translateX(3px)}

/* dispatch list */
.dlist{padding:30px 0 90px;background:var(--bg)}
.dlist-lab{display:flex;align-items:center;gap:16px;color:var(--muted);margin:30px 0 36px}
.dlist-lab .idx{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--blue)}
.dlist-lab .ln{flex:1;height:1px;background:var(--line)}
.dlist-lab .jp{font-family:var(--display);font-size:18px;color:var(--ink)}
.drow{display:grid;grid-template-columns:140px 150px 1fr auto;gap:30px;align-items:center;padding:30px 26px;border:1px solid var(--line);border-bottom:none;background:#fff;transition:background .25s,padding .3s;text-decoration:none;color:inherit}
.drow:last-of-type{border-bottom:1px solid var(--line)}
.drow:hover{background:var(--bg2);padding-left:34px}
.drow .d-thumb{width:140px;height:88px;background:var(--bg2);border:1px solid var(--line2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.drow .d-thumb img{width:100%;height:100%;object-fit:cover;mix-blend-mode:multiply}
.drow .d-thumb.dark{background:#181818}
.drow .d-thumb.dark img{mix-blend-mode:normal}
.drow .d-when{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);line-height:1.7}
.drow .d-when .tag{display:inline-block;margin-top:8px;color:var(--accent)}
.drow .d-main h3{font-family:var(--display);font-size:clamp(24px,2.4vw,34px);text-transform:uppercase;line-height:.95;letter-spacing:-.01em;margin-bottom:10px}
.drow .d-main p{color:var(--muted);font-size:14.5px;line-height:1.6;max-width:560px}
.drow .d-go{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:10px;white-space:nowrap;transition:gap .24s,color .24s}
.drow:hover .d-go{color:var(--accent);gap:16px}

/* register strip */
.register{padding:90px 0;background:var(--bg2);border-top:1px solid var(--line)}
.reg-in{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;border:1px solid var(--line);padding:48px 52px;background:linear-gradient(120deg,var(--panel),var(--bg2))}
.reg-in h3{font-family:var(--display);font-weight:900;font-size:clamp(28px,3.4vw,46px);text-transform:uppercase;line-height:.95}
.reg-in h3 em{font-style:normal;color:var(--accent)}
.reg-in p{color:var(--muted);font-size:16px;margin-top:12px;max-width:440px;line-height:1.6}
.reg-in form{display:flex;border:1px solid var(--line);min-width:320px;background:#fff}
.reg-in input{flex:1;background:transparent;border:none;color:var(--ink);padding:18px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;outline:none}
.reg-in input::placeholder{color:var(--faint)}
.reg-in button{background:var(--ink);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:0 24px;font-weight:700;transition:.2s}
.reg-in button:hover{background:var(--accent);color:#fff}

/* ============ THEORY PAGE DEEP ============ */
.ehero{position:relative;background:var(--bg);border-bottom:1px solid var(--line);overflow:hidden;padding:50px 0 0}
.ehero .crumb{display:flex;align-items:center;gap:10px;color:var(--faint);margin-bottom:54px}
.ehero .crumb a{color:var(--faint);transition:color .2s}
.ehero .crumb a:hover{color:var(--accent)}
.ehero .crumb .sep{color:var(--line)}
.ehero .crumb .cur{color:var(--ink)}
.ehero-grid{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end}
.eh-kicker{display:flex;align-items:center;gap:14px;color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:26px}
.eh-kicker .ln{width:54px;height:1px;background:var(--accent)}
.ehero h1{font-family:var(--display);font-weight:900;font-size:clamp(74px,13vw,210px);line-height:.78;text-transform:uppercase;letter-spacing:-.025em}
.ehero h1 em{font-style:normal;color:var(--accent)}
.eh-han-col{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--han);font-size:clamp(40px,5vw,74px);line-height:1.05;color:var(--ink);letter-spacing:.08em;align-self:stretch;display:flex;align-items:flex-start;padding-bottom:8px}
.eh-han-col .red{color:var(--accent)}
.ehero-lede{border-top:1px solid var(--line);margin-top:54px;padding:46px 0 60px;display:grid;grid-template-columns:1fr 1.5fr;gap:60px}
.ehero-lede .lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);line-height:1.8}
.ehero-lede .lab .han{font-family:var(--han);color:var(--accent);font-size:15px;letter-spacing:.1em;display:block;margin-bottom:8px}
.lede-body{font-size:clamp(19px,2vw,25px);line-height:1.65;color:var(--ink);max-width:680px;text-wrap:pretty}
.lede-body .dropcap::first-letter{initial-letter:3;-webkit-initial-letter:3;font-family:var(--display);font-weight:900;color:var(--accent);margin-right:14px;text-transform:uppercase}
.lede-body p+p{margin-top:22px}

.dark{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.dark .theory-jp{position:absolute;left:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:62vh;line-height:.8;color:rgba(255,255,255,.04);pointer-events:none;user-select:none}
.split{display:grid;grid-template-columns:1fr 1fr;min-height:78vh}
.split-media{position:relative;overflow:hidden;background:#000}
.split-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.split-media .cap{position:absolute;left:24px;bottom:22px;z-index:3;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:10px}
.split-media .cap .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em;font-size:13px}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,7vw,100px);position:relative;z-index:2}
.split-text .n{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--accent);margin-bottom:30px;display:flex;align-items:center;gap:12px}
.split-text .n .ln{width:40px;height:1px;background:var(--accent)}
.split-text h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,5.2vw,82px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em}
.split-text h2 em{font-style:normal;color:var(--accent)}
.split-text .han-big{font-family:var(--han);font-size:clamp(30px,4vw,58px);color:var(--gold);margin:18px 0 26px;letter-spacing:.1em}
.split-text p{color:rgba(255,255,255,.72);font-size:17px;line-height:1.8;max-width:480px}
.split-text p+p{margin-top:18px}
.split-text p strong{color:#fff;font-weight:600}

.manifesto-deep{padding:130px 0;background:var(--bg);position:relative}
.manifesto-deep .mk{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:40px;display:flex;align-items:center;gap:14px}
.manifesto-deep .mk .ln{width:54px;height:1px;background:var(--accent)}
.manifesto-deep blockquote{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(34px,5.2vw,86px);line-height:1.0;letter-spacing:-.015em;max-width:1180px;text-wrap:balance}
.manifesto-deep blockquote em{font-style:normal;color:var(--accent)}
.manifesto-deep .attrib{margin-top:46px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.manifesto-deep .attrib .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:14px}
.manifesto-deep .attrib .dot{width:5px;height:5px;background:var(--line);border-radius:50%}

.pillars-sec{padding:0 0 130px;background:var(--bg)}
.pillars-sec .pillars{margin-top:0}
.pillar.deep{padding:46px 40px 40px}
.pillar.deep .n{margin-bottom:34px}
.pillar.deep .jp{font-size:96px;line-height:.85;margin-bottom:26px}
.pillar.deep h4{font-family:var(--display);font-size:26px;margin-bottom:14px}
.pillar.deep p{color:var(--muted);font-size:15px;line-height:1.7}

.process-sec{padding:120px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.process-jp{position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:50vh;line-height:.8;color:rgba(0,0,0,.035);pointer-events:none;user-select:none}
.process-head-deep{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:60px}
.process-head-deep h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,5vw,76px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em}
.process-head-deep h2 em{font-style:normal;color:var(--accent)}
.process-head-deep .meta{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:right}
.process-head-deep .meta .han{font-family:var(--han);color:var(--accent);font-size:14px;letter-spacing:.12em}

.vfeature{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.vfeature-in{display:grid;grid-template-columns:auto 1fr;gap:clamp(40px,8vw,120px);align-items:center;padding:120px 0}
.vstack{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--han);font-size:clamp(44px,7vw,120px);line-height:1.0;letter-spacing:.06em;color:#fff}
.vstack .red{color:var(--accent)}
.vfeature-body{max-width:560px}
.vfeature-body .mk{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:26px}
.vfeature-body h2{font-family:var(--display);font-weight:900;font-size:clamp(34px,4vw,62px);line-height:.95;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:24px}
.vfeature-body h2 em{font-style:normal;color:var(--accent)}
.vfeature-body p{color:rgba(255,255,255,.72);font-size:17px;line-height:1.8}
.vfeature-body p+p{margin-top:18px}
.vfeature-body p strong{color:#fff;font-weight:600}

.closing{padding:110px 0;background:var(--bg);text-align:center}
.closing .glyph{font-family:var(--han);font-size:clamp(60px,9vw,140px);color:var(--accent);line-height:1;margin-bottom:30px}
.closing h2{font-family:var(--display);font-weight:900;font-size:clamp(36px,5vw,72px);line-height:.95;text-transform:uppercase;letter-spacing:-.01em;max-width:900px;margin:0 auto 18px}
.closing h2 em{font-style:normal;color:var(--accent)}
.closing p{color:var(--muted);font-size:17px;line-height:1.6;max-width:480px;margin:0 auto 38px}
.closing .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.closing a.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:18px 30px;font-weight:700;transition:.22s;text-decoration:none}
.closing a.btn.solid{background:var(--accent);color:#fff}
.closing a.btn.solid:hover{background:var(--ink);gap:18px}
.closing a.btn.ghost{border:1px solid var(--line);color:var(--ink)}
.closing a.btn.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);gap:18px}

/* ============ SUPPORT ============ */
.contact{padding:64px 0 40px;background:var(--bg)}
.ccards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.ccard{background:var(--bg);padding:40px 34px 36px;display:flex;flex-direction:column;transition:background .3s;position:relative}
.ccard:hover{background:var(--bg2)}
.ccard::before{content:"";position:absolute;top:0;left:0;height:2px;width:0;background:var(--accent);transition:width .5s ease}
.ccard:hover::before{width:100%}
.ccard .jp{font-family:var(--han);font-size:16px;line-height:1;color:var(--faint);letter-spacing:.12em;margin-bottom:18px;transition:color .3s}
.ccard:hover .jp{color:var(--accent)}
.ccard h3{font-family:var(--display);font-weight:900;font-size:clamp(32px,3.2vw,44px);line-height:.9;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:16px}
.ccard p{color:var(--muted);font-size:14.5px;line-height:1.65;margin-bottom:22px;flex:1}
.ccard a.mail{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:3px;align-self:flex-start;transition:.2s}
.ccard a.mail:hover{color:var(--ink);border-color:var(--ink)}
.ccard .hours{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-top:14px}

.faq{padding:70px 0 30px;background:var(--bg)}
.faq-grid{display:grid;grid-template-columns:.42fr 1fr;gap:60px;align-items:start}
.faq-aside h2{font-family:var(--display);font-weight:900;font-size:clamp(38px,4.4vw,64px);line-height:.9;text-transform:uppercase;letter-spacing:-.015em}
.faq-aside h2 em{font-style:normal;color:var(--accent)}
.faq-aside .han{font-family:var(--han);font-size:34px;color:var(--accent);margin:18px 0;display:block;letter-spacing:.1em}
.faq-aside p{color:var(--muted);font-size:15px;line-height:1.7;max-width:300px}
.faq-list{border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;align-items:center;gap:22px;padding:26px 0;color:var(--ink);transition:color .2s}
.qa button:hover{color:var(--accent)}
.qa .qnum{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--accent);flex:none;width:30px}
.qa .qtext{font-family:var(--display);font-size:clamp(20px,2vw,27px);text-transform:uppercase;letter-spacing:.005em;line-height:1;flex:1}
.qa .qmark{flex:none;width:22px;height:22px;position:relative}
.qa .qmark::before,.qa .qmark::after{content:"";position:absolute;background:currentColor;transition:transform .3s}
.qa .qmark::before{left:0;right:0;top:10px;height:2px}
.qa .qmark::after{top:0;bottom:0;left:10px;width:2px}
.qa.open .qmark::after{transform:scaleY(0)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.qa .ans-inner{padding:0 0 28px 52px;color:var(--muted);font-size:16px;line-height:1.75;max-width:680px}
.qa .ans-inner strong{color:var(--ink);font-weight:600}
.qa .ans-inner .han{font-family:var(--han);color:var(--accent)}

.info{padding:70px 0 30px;background:var(--bg2);border-top:1px solid var(--line)}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.icol .n{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--accent);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.icol .n .han{font-family:var(--han);color:var(--faint);letter-spacing:.1em;font-size:13px}
.icol h3{font-family:var(--display);font-size:26px;text-transform:uppercase;letter-spacing:.01em;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.icol p{color:var(--muted);font-size:14.5px;line-height:1.7;margin-bottom:14px}
.icol p strong{color:var(--ink);font-weight:600}

.reach{padding:90px 0;background:var(--bg2)}
.reach-in{border:1px solid var(--line);background:var(--ink);color:#fff;display:grid;grid-template-columns:.85fr 1fr;overflow:hidden}
.reach-left{padding:clamp(36px,4vw,58px);position:relative;overflow:hidden;border-right:1px solid rgba(255,255,255,.1)}
.reach-left .glyph{position:absolute;right:-2vw;bottom:-6vh;font-family:var(--display);font-size:38vh;line-height:.8;color:rgba(255,255,255,.05);pointer-events:none}
.reach-left .mk{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;position:relative;z-index:2}
.reach-left h2{font-family:var(--display);font-weight:900;font-size:clamp(32px,3.6vw,54px);line-height:.92;text-transform:uppercase;letter-spacing:-.01em;position:relative;z-index:2}
.reach-left h2 em{font-style:normal;color:var(--accent)}
.reach-left p{color:rgba(255,255,255,.7);font-size:15px;line-height:1.7;margin-top:18px;max-width:340px;position:relative;z-index:2}
.reach-form{padding:clamp(36px,4vw,52px);display:flex;flex-direction:column;gap:16px;background:#fff;color:var(--ink)}
.reach-form .frow2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.reach-form label{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.reach-form input,.reach-form textarea,.reach-form select{background:var(--bg);border:1px solid var(--line);color:var(--ink);padding:14px;font-family:var(--body);font-size:14px;outline:none;transition:border-color .2s}
.reach-form input:focus,.reach-form textarea:focus,.reach-form select:focus{border-color:var(--accent)}
.reach-form textarea{resize:vertical;min-height:120px}
.reach-form button{margin-top:6px;background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:18px;font-weight:700;transition:.2s}
.reach-form button:hover{background:var(--ink)}

/* WPCF7 / WPForms inside .reach-form normalisation */
.reach-form .wpcf7-form-control-wrap{display:block;width:100%}
.reach-form .wpcf7-not-valid-tip{color:var(--accent);font-family:var(--mono);font-size:11px;margin-top:6px}
.reach-form .wpcf7 form.invalid .wpcf7-response-output,
.reach-form .wpcf7 form.unaccepted .wpcf7-response-output,
.reach-form .wpcf7 form.payment-required .wpcf7-response-output,
.reach-form .wpcf7 form.sent .wpcf7-response-output{margin:8px 0 0;border:0;padding:10px 12px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:var(--bg2)}

/* ============ ARTICLE (announcement detail / blog single) ============ */
.ahead{background:var(--bg);border-bottom:1px solid var(--line);padding:40px 0 0}
.ahead .crumb{display:flex;align-items:center;gap:10px;color:var(--faint);margin-bottom:48px}
.ahead .crumb a{color:var(--faint);transition:color .2s}
.ahead .crumb a:hover{color:var(--accent)}
.ahead .crumb .sep{color:var(--line)}
.ahead .crumb .cur{color:var(--ink)}
.ahead .kicker{display:flex;align-items:center;gap:14px;color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:26px;flex-wrap:wrap}
.ahead .kicker .ln{width:48px;height:1px;background:var(--accent)}
.ahead .kicker .han{font-family:var(--han);font-size:14px;letter-spacing:.12em}
.ahead h1{font-family:var(--display);font-weight:900;font-size:clamp(56px,9vw,150px);line-height:.82;text-transform:uppercase;letter-spacing:-.022em}
.ahead h1 em{font-style:normal;color:var(--accent)}
.ahead .standfirst{font-size:clamp(18px,2vw,24px);line-height:1.6;color:var(--muted);max-width:720px;margin:36px 0 50px;text-wrap:pretty}
.ahead .standfirst strong{color:var(--ink);font-weight:600}
.ahead .byline{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:22px 0 0;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:50px}
.ahead .byline .dot{width:5px;height:5px;background:var(--line);border-radius:50%}
.ahead .byline .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:13px}
.ahero-img{position:relative;background:#fff;border-top:1px solid var(--line);overflow:hidden}
.ahero-img img{width:100%;max-height:78vh;object-fit:contain;object-position:center;padding:30px 20px;mix-blend-mode:multiply}
.ahero-img .bignum{position:absolute;left:24px;bottom:-26px;z-index:1;font-family:var(--display);font-weight:900;font-size:200px;line-height:.7;color:rgba(0,0,0,.05);pointer-events:none}
.ahero-img .cap{position:absolute;right:24px;bottom:20px;z-index:3;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);display:flex;gap:10px;align-items:center}
.ahero-img .cap .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em;font-size:13px}

.article{padding:84px 0 90px;background:var(--bg)}
.article .body p,.article .body{font-size:18px;line-height:1.8;color:var(--ink)}
.article .body p{margin-bottom:26px;text-wrap:pretty}
.article .body p strong{font-weight:600}
.article .body .lead{font-size:21px;line-height:1.7}
.article .body .lead::first-letter{initial-letter:3;-webkit-initial-letter:3;font-family:var(--display);font-weight:900;color:var(--accent);margin-right:14px;text-transform:uppercase}
.article .body h2{font-family:var(--display);font-weight:900;font-size:clamp(28px,3.4vw,44px);line-height:.98;text-transform:uppercase;letter-spacing:-.01em;margin:54px 0 22px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.article .body h2 .num{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--accent);font-weight:700}
.article .body h2 .han{font-family:var(--han);font-size:.5em;color:var(--accent);letter-spacing:.06em}
.article .body h3{font-family:var(--display);font-size:clamp(22px,2.6vw,32px);line-height:1;text-transform:uppercase;letter-spacing:-.005em;margin:36px 0 16px}
.article .body ul,.article .body ol{margin:0 0 22px 22px}
.article .body li{font-size:17px;line-height:1.7;margin-bottom:8px}
.article .body img{margin:36px 0;border:1px solid var(--line)}
.article .body a{color:var(--accent);border-bottom:1px solid currentColor;transition:.2s}
.article .body a:hover{color:var(--ink)}

.pull{margin:64px 0;padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pull blockquote{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,3.6vw,52px);line-height:1.04;letter-spacing:-.01em;text-wrap:balance}
.pull blockquote em{font-style:normal;color:var(--accent)}
.pull .src{margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.pull .src .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:13px}

.figure{margin:54px 0;background:#000;border:1px solid var(--line);overflow:hidden}
.figure img{width:100%;display:block;margin:0}
.figure figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);padding:14px 20px;background:var(--bg2);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.figure figcaption .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em}

.facts{margin:64px 0 0;border:1px solid var(--line);background:var(--bg2)}
.facts .fh{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 26px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.facts .fh .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:13px}
.frow{display:flex;justify-content:space-between;gap:20px;padding:16px 26px;border-bottom:1px solid var(--line2);font-size:14px}
.frow:last-child{border-bottom:none}
.frow .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.frow .v{font-weight:600;text-align:right}

.artcta{padding:0 0 100px;background:var(--bg)}
.artcta-in{border:1px solid var(--line);padding:clamp(34px,5vw,64px);background:var(--ink);color:#fff;position:relative;overflow:hidden}
.artcta-in .glyph{position:absolute;right:-1vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:40vh;line-height:.8;color:rgba(255,255,255,.05);pointer-events:none}
.artcta-in h3{font-family:var(--display);font-weight:900;font-size:clamp(30px,4vw,58px);line-height:.95;text-transform:uppercase;letter-spacing:-.01em;position:relative;z-index:2}
.artcta-in h3 em{font-style:normal;color:var(--accent)}
.artcta-in p{color:rgba(255,255,255,.72);font-size:16px;line-height:1.7;max-width:460px;margin:16px 0 30px;position:relative;z-index:2}
.artcta-in form{display:flex;border:1px solid rgba(255,255,255,.2);max-width:440px;background:rgba(255,255,255,.04);position:relative;z-index:2}
.artcta-in input{flex:1;background:transparent;border:none;color:#fff;padding:18px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;outline:none}
.artcta-in input::placeholder{color:rgba(255,255,255,.4)}
.artcta-in button{background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:0 24px;font-weight:700;transition:.2s}
.artcta-in button:hover{background:#fff;color:var(--ink)}
.backlink{margin-top:40px;display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);transition:gap .2s,color .2s;text-decoration:none}
.backlink:hover{color:var(--ink);gap:16px}

/* ============ TERMS / DOC ============ */
.doc{padding:60px 0 100px;background:var(--bg)}
.legal{max-width:none}
.legal .preamble{font-size:18px;line-height:1.75;color:var(--muted);padding-bottom:38px;margin-bottom:10px;border-bottom:1px solid var(--line);text-wrap:pretty}
.legal .preamble strong{color:var(--ink);font-weight:600}
.clause{padding:44px 0;border-bottom:1px solid var(--line2);scroll-margin-top:104px}
.clause:last-child{border-bottom:none}
.clause h2{font-family:var(--display);font-weight:900;font-size:clamp(24px,2.6vw,34px);line-height:1;text-transform:uppercase;letter-spacing:-.005em;display:flex;align-items:baseline;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.clause h2 .cn{font-family:var(--mono);font-size:13px;letter-spacing:.08em;color:var(--accent);font-weight:700;flex:none;width:34px}
.clause p{font-size:15.5px;line-height:1.8;color:var(--ink);margin-bottom:16px;text-wrap:pretty;max-width:1040px}
.clause p:last-child{margin-bottom:0}
.clause p strong{font-weight:600}
.clause .sub{display:flex;gap:16px;margin-bottom:16px}
.clause .sub .sn{font-family:var(--mono);font-size:12px;color:var(--accent);flex:none;width:34px;padding-top:2px;letter-spacing:.04em}
.clause .sub p{margin-bottom:0}
.clause ul{list-style:none;margin:0 0 16px 34px}
.clause ul li{position:relative;padding-left:22px;font-size:15.5px;line-height:1.75;color:var(--ink);margin-bottom:10px}
.clause ul li::before{content:"—";position:absolute;left:0;color:var(--accent)}
.defs{margin:6px 0 4px 34px;border-left:1px solid var(--line);padding-left:24px}
.defs dt{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.defs dd{font-size:15px;line-height:1.7;color:var(--muted);margin:0 0 18px}
.defs dd:last-child{margin-bottom:0}
.callout{background:var(--bg2);border:1px solid var(--line);padding:24px 26px;margin:8px 0 4px;display:flex;gap:18px;align-items:flex-start}
.callout .mk{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);line-height:1.4;flex:none;padding-top:2px}
.callout p{font-size:14px;line-height:1.7;color:var(--muted);margin:0}
.callout p strong{color:var(--ink)}
.statutory{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;line-height:1.75;text-transform:uppercase;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:22px 24px;margin:8px 0 4px}
.doc-foot{margin-top:60px;padding-top:30px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.doc-foot a{color:var(--accent);transition:color .2s}
.doc-foot a:hover{color:var(--ink)}
.totop{display:inline-flex;align-items:center;gap:8px;transition:gap .2s}
.totop:hover{gap:14px}

/* next-object strip */
.nextobj{padding:80px 0;background:var(--bg)}
.nextobj-in{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;border:1px solid var(--line);padding:46px 50px;background:linear-gradient(120deg,var(--panel),var(--bg2))}
.nextobj h3{font-family:var(--display);font-weight:900;font-size:clamp(28px,3.4vw,46px);text-transform:uppercase;line-height:.95}
.nextobj h3 em{font-style:normal;color:var(--accent)}
.nextobj p{color:var(--muted);font-size:16px;margin-top:12px;max-width:440px;line-height:1.6}
.nextobj a.btn{display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:18px 28px;font-weight:700;transition:.22s;text-decoration:none}
.nextobj a.btn:hover{background:var(--accent);color:#fff;gap:18px}

/* making block (single product) */
#making{padding:120px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.making-jp{position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:46vh;line-height:.8;color:rgba(0,0,0,.035);pointer-events:none;user-select:none}
.making-head{position:relative;z-index:2}
.making-head h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,5vw,76px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em;max-width:760px}
.making-head h2 em{font-style:normal;color:var(--accent)}
.making-head p{color:var(--muted);font-size:17px;line-height:1.75;margin-top:24px;max-width:560px}

/* ============ FOOTER ============ */
footer.site-footer{background:var(--bg2);border-top:1px solid var(--line);padding:90px 0 40px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:70px;border-bottom:1px solid var(--line)}
.foot-brand img{height:60px;margin-bottom:24px}
.foot-brand p{color:var(--muted);font-size:15px;line-height:1.7;max-width:320px}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:20px}
.foot-col h5 .han{font-family:var(--han);color:var(--faint);letter-spacing:.08em;margin-left:7px;font-weight:400}
.foot-col a{display:block;color:var(--faint);font-size:14px;padding:7px 0;transition:color .2s;text-decoration:none}
.foot-col a:hover{color:var(--ink)}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:34px;flex-wrap:wrap}
.foot-bottom .copy{color:var(--faint);font-size:12.5px}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{color:var(--faint);font-size:12.5px;transition:color .2s;text-decoration:none}
.foot-links a:hover{color:var(--ink)}
.foot-links a.cur,.foot-links a.current-menu-item{color:var(--ink)}

/* ============ CART DRAWER (WC) ============ */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;visibility:hidden;transition:.35s;backdrop-filter:blur(2px)}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:440px;max-width:92vw;background:var(--bg);z-index:301;transform:translateX(100%);transition:transform .45s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;border-left:1px solid var(--line)}
.cart-drawer.open{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:26px 28px;border-bottom:1px solid var(--line)}
.cart-head h3{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:.02em}
.cart-head .x{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;line-height:1;transition:color .2s}
.cart-head .x:hover{color:var(--ink)}
.cart-items{flex:1;overflow-y:auto;padding:8px 28px}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--faint);gap:14px;text-align:center}
.cart-empty .jp{font-family:var(--display);font-size:60px;color:rgba(0,0,0,.07)}
.citem{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line2)}
.citem img{width:72px;height:72px;object-fit:cover;background:var(--panel);border:1px solid var(--line)}
.citem .ci-info{flex:1;min-width:0}
.citem .ci-info b{font-size:14px;display:block;margin-bottom:3px}
.citem .ci-info .ci-meta{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.1em;margin-bottom:12px}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line)}
.qty button{background:none;border:none;color:var(--muted);width:28px;height:28px;cursor:pointer;font-size:15px;transition:.15s}
.qty button:hover{color:var(--ink);background:rgba(0,0,0,.05)}
.qty span{min-width:30px;text-align:center;font-family:var(--mono);font-size:13px}
.citem .ci-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between}
.citem .ci-price{font-weight:700;font-size:14px}
.citem .ci-rm{background:none;border:none;color:var(--faint);font-family:var(--mono);font-size:9px;letter-spacing:.12em;cursor:pointer;text-transform:uppercase;transition:.2s;text-decoration:none}
.citem .ci-rm:hover{color:var(--accent)}
.cart-foot{padding:24px 28px;border-top:1px solid var(--line)}
.cart-sub{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;color:var(--muted)}
.cart-tot{display:flex;justify-content:space-between;align-items:baseline;margin:14px 0 20px;padding-top:16px;border-top:1px solid var(--line)}
.cart-tot .t-lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cart-tot .t-val{font-family:var(--display);font-size:30px}
.checkout{width:100%;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;font-family:var(--mono);font-size:13px;letter-spacing:.22em;text-transform:uppercase;padding:19px;font-weight:700;transition:.2s;display:block;text-align:center;text-decoration:none}
.checkout:hover{background:#181818;color:#fff}
.checkout:disabled,.checkout.disabled{opacity:.3;cursor:not-allowed;pointer-events:none}

/* toast */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(calc(100% + 40px));z-index:400;background:var(--ink);color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:15px 24px;transition:transform .45s cubic-bezier(.16,1,.3,1),opacity .3s;font-weight:700;opacity:0;visibility:hidden}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;visibility:visible}

/* ============ NEW PAGES — CATEGORY LANDING (clothing/wrestling) ============ */
.cat-hero{padding:80px 0;background:var(--bg);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.cat-hero-jp{position:absolute;right:-3vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:56vh;line-height:.8;color:rgba(0,0,0,.04);pointer-events:none;user-select:none}
.cat-hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:end;position:relative;z-index:2}
.cat-hero h1{font-family:var(--display);font-weight:900;font-size:clamp(64px,11vw,180px);line-height:.78;text-transform:uppercase;letter-spacing:-.025em;margin-bottom:24px}
.cat-hero h1 em{font-style:normal;color:var(--accent)}
.cat-hero .lede{font-size:clamp(17px,1.7vw,21px);line-height:1.65;color:var(--muted);max-width:520px}
.cat-hero .lede strong{color:var(--ink);font-weight:600}
.cat-hero .han-mark{font-family:var(--han);font-size:clamp(40px,7vw,90px);color:var(--accent);line-height:1;text-align:right}

.cat-items{padding:80px 0 110px;background:var(--bg)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

/* ============ NEW PAGES — BLOG ============ */
.blog-hero{padding:70px 0 46px;background:var(--bg);border-bottom:1px solid var(--line)}
.blog-list{padding:60px 0 100px}
.post-card{display:grid;grid-template-columns:240px 1fr;gap:30px;align-items:start;padding:34px 0;border-bottom:1px solid var(--line)}
.post-card .pc-thumb{aspect-ratio:4/3;background:var(--bg2);overflow:hidden;border:1px solid var(--line2)}
.post-card .pc-thumb img{width:100%;height:100%;object-fit:cover}
.post-card h2{font-family:var(--display);font-weight:900;font-size:clamp(26px,3vw,40px);text-transform:uppercase;line-height:.95;letter-spacing:-.01em;margin-bottom:14px}
.post-card h2 a{color:var(--ink);transition:color .2s}
.post-card h2 a:hover{color:var(--accent)}
.post-card .pc-meta{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:18px}
.post-card p{color:var(--muted);font-size:15px;line-height:1.7;max-width:680px}
.post-pag{display:flex;justify-content:space-between;align-items:center;margin-top:50px;padding-top:28px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.post-pag a{color:var(--accent);transition:color .2s;text-decoration:none}
.post-pag a:hover{color:var(--ink)}

/* ============ WOOCOMMERCE OVERRIDES (page-cart / page-checkout) ============ */
.woocommerce-page,.woocommerce-cart,.woocommerce-checkout{background:var(--bg)}
.gokudo-wc-wrap{padding:60px 0 100px}
.gokudo-wc-wrap h1.entry-title{font-family:var(--display);font-weight:900;font-size:clamp(48px,6.4vw,98px);line-height:.84;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:46px}
.woocommerce-info,.woocommerce-message,.woocommerce-error{background:var(--bg2);border-left:3px solid var(--accent);color:var(--ink);padding:18px 22px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;line-height:1.6;margin-bottom:24px;list-style:none}
.woocommerce-message a.button,.woocommerce-info a.button{background:var(--ink);color:#fff;padding:10px 16px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-left:10px;border:none;cursor:pointer;transition:.2s;text-decoration:none}
.woocommerce-message a.button:hover,.woocommerce-info a.button:hover{background:var(--accent);color:#fff}

.woocommerce table.shop_table{border:1px solid var(--line);border-collapse:collapse;width:100%;margin-bottom:24px;background:#fff}
.woocommerce table.shop_table th{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding:18px 14px;border-bottom:1px solid var(--line);text-align:left;font-weight:700}
.woocommerce table.shop_table td{padding:18px 14px;border-bottom:1px solid var(--line2);vertical-align:middle;font-size:14px}
.woocommerce table.shop_table tr:last-child td{border-bottom:none}
.woocommerce table.shop_table .product-thumbnail img{width:72px;height:72px;object-fit:cover;border:1px solid var(--line);background:var(--panel)}
.woocommerce table.shop_table .product-name a{color:var(--ink);font-weight:600;font-size:15px}
.woocommerce table.shop_table .product-price,.woocommerce table.shop_table .product-subtotal{font-family:var(--display);font-size:18px;color:var(--ink)}
.woocommerce table.shop_table .product-remove a{color:var(--faint);font-size:22px;line-height:1;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;transition:color .2s;text-decoration:none}
.woocommerce table.shop_table .product-remove a:hover{color:var(--accent)}

.woocommerce .quantity input[type="number"]{width:60px;background:#fff;border:1px solid var(--line);padding:10px;font-family:var(--mono);font-size:13px;text-align:center;color:var(--ink)}
.woocommerce input[type="text"],.woocommerce input[type="email"],.woocommerce input[type="tel"],.woocommerce input[type="password"],.woocommerce input[type="number"],.woocommerce textarea,.woocommerce select{background:#fff;border:1px solid var(--line);padding:14px;font-family:var(--body);font-size:14px;color:var(--ink);outline:none;transition:border-color .2s;width:100%}
.woocommerce input:focus,.woocommerce textarea:focus,.woocommerce select:focus{border-color:var(--accent)}

.woocommerce button.button,.woocommerce a.button,.woocommerce input.button,.woocommerce #respond input#submit{background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:15px 24px;font-weight:700;transition:.2s;text-decoration:none;display:inline-block}
.woocommerce button.button:hover,.woocommerce a.button:hover,.woocommerce input.button:hover{background:var(--ink);color:#fff}
.woocommerce button.button.alt,.woocommerce a.button.alt,.woocommerce input.button.alt,.woocommerce #place_order{background:var(--ink);color:#fff;padding:18px 28px;font-size:13px;letter-spacing:.22em;width:auto}
.woocommerce button.button.alt:hover,.woocommerce a.button.alt:hover,.woocommerce input.button.alt:hover,.woocommerce #place_order:hover{background:var(--accent);color:#fff}

.woocommerce .cart_totals h2,.woocommerce .cross-sells > h2,.woocommerce-checkout #order_review_heading,.woocommerce h2.woocommerce-column__title{font-family:var(--display);font-weight:900;font-size:clamp(24px,2.4vw,32px);text-transform:uppercase;letter-spacing:-.005em;margin-bottom:18px}
.woocommerce .cart_totals,.woocommerce-checkout #order_review{background:var(--bg2);border:1px solid var(--line);padding:28px}
.woocommerce form .form-row label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:8px;display:block}
.woocommerce form .form-row .required{color:var(--accent)}

.woocommerce ul.products{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin:0;padding:0;list-style:none}
.woocommerce ul.products li.product{margin:0;padding:0;background:#fff;border:1px solid var(--line);transition:border-color .35s,box-shadow .45s,transform .45s;text-align:left;float:none;width:auto;position:relative}
.woocommerce ul.products li.product:hover{border-color:var(--ink);box-shadow:0 24px 60px -28px rgba(0,0,0,.4);transform:translateY(-4px)}
.woocommerce ul.products li.product a img{width:100%;aspect-ratio:16/10;object-fit:contain;background:#fff;padding:30px 26px;margin:0;mix-blend-mode:multiply}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--display);font-weight:900;font-size:clamp(24px,2.4vw,34px);line-height:.95;text-transform:uppercase;letter-spacing:-.005em;padding:24px 26px 8px}
.woocommerce ul.products li.product .price{font-family:var(--display);font-size:24px;color:var(--ink);padding:0 26px;line-height:1}
.woocommerce ul.products li.product .price del{color:var(--faint);font-size:16px;opacity:.7}
.woocommerce ul.products li.product .price ins{text-decoration:none;color:var(--accent);font-weight:900}
.woocommerce ul.products li.product .button{display:inline-block;margin:18px 26px 26px}

.woocommerce-pagination{padding:40px 0;text-align:center}
.woocommerce-pagination ul.page-numbers{list-style:none;display:inline-flex;gap:8px;padding:0;margin:0;border:none}
.woocommerce-pagination ul.page-numbers li{border:1px solid var(--line);background:transparent}
.woocommerce-pagination ul.page-numbers a,.woocommerce-pagination ul.page-numbers span{padding:10px 14px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--ink);display:inline-block;text-decoration:none}
.woocommerce-pagination ul.page-numbers li:has(span.current),.woocommerce-pagination ul.page-numbers a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.woocommerce-pagination ul.page-numbers .current{background:var(--ink);color:#fff}

/* ============ RESPONSIVE ============ */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .marquee .track{animation:none}
  .dot.active::after{transform:scaleX(1);animation:none}
}
@media(max-width:980px){
  .wrap,.wrap-narrow,.col{padding:0 24px}
  nav.main{position:fixed;top:74px;left:0;right:0;background:var(--ink);flex-direction:column;align-items:stretch;padding:0;max-height:0;overflow:hidden;transition:max-height .35s ease;border-bottom:1px solid rgba(255,255,255,.1)}
  nav.main.open{max-height:560px}
  nav.main ul{flex-direction:column}
  nav.main li{display:block}
  nav.main a{padding:18px 28px;border-bottom:1px solid rgba(255,255,255,.06);flex-direction:row;justify-content:space-between;gap:14px}
  nav.main a .han-sub{font-size:11px}
  .menu-toggle{display:inline-flex;margin-left:auto}
  .hslide img{padding:64px 12px 112px}
  .feature{grid-template-columns:1fr}
  .feature-media{min-height:420px}
  .gal-thumb{width:60px;height:60px}
  .theory-grid{grid-template-columns:1fr;gap:40px}
  .details{grid-template-columns:1fr}
  .pillars,.pillars-sec .pillars{grid-template-columns:1fr}
  .psteps{grid-template-columns:1fr 1fr;gap:30px 24px}
  .ann{padding:34px 28px}
  .grid{grid-template-columns:1fr;gap:28px}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .ehero-grid{grid-template-columns:1fr}
  .eh-han-col{writing-mode:horizontal-tb;font-size:clamp(36px,8vw,60px)}
  .ehero-lede{grid-template-columns:1fr;gap:24px}
  .split{grid-template-columns:1fr}
  .split-media{min-height:50vh}
  .vfeature-in{grid-template-columns:1fr;gap:50px;padding:80px 0}
  .vstack{writing-mode:horizontal-tb;font-size:clamp(40px,10vw,72px)}
  .ccards{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .info-grid{grid-template-columns:1fr;gap:40px}
  .reach-in{grid-template-columns:1fr}
  .reach-left{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .featured{grid-template-columns:1fr}
  .featured-media{min-height:360px;border-right:none;border-bottom:1px solid var(--line2)}
  .drow{grid-template-columns:120px 1fr;gap:20px;row-gap:14px}
  .drow .d-when{grid-column:2}
  .drow .d-go{grid-column:1 / -1;justify-content:flex-start}
  .cat-hero-grid{grid-template-columns:1fr}
  .cat-hero .han-mark{text-align:left}
  .cat-grid{grid-template-columns:1fr 1fr}
  .woocommerce ul.products{grid-template-columns:1fr}
  .post-card{grid-template-columns:1fr}
  .post-card .pc-thumb{aspect-ratio:16/9}
}
@media(max-width:560px){
  .banner-inner{height:62px}
  nav.main{top:62px}
  .cart-btn span.lbl{display:none}
  .cart-btn{padding:0 14px}
  .menu-toggle{padding:0 14px}
  .foot-top{grid-template-columns:1fr}
  .psteps{grid-template-columns:1fr}
  .hf-cap{min-width:0}
  .hf-name{font-size:20px}
  .hero-badge,.hf-right{display:none}
  .ph-meta{text-align:left}
  .pc-body{padding:24px 22px 26px}
  .pc-foot{flex-direction:column;align-items:stretch}
  .pc-cta{justify-content:center}
  .article .body p{font-size:16.5px}
  .qa .ans-inner{padding-left:0}
  .reach-form .frow2{grid-template-columns:1fr}
  .drow{grid-template-columns:1fr}
  .drow .d-thumb{width:100%;height:160px}
  .drow .d-when{grid-column:1}
  .reg-in{padding:32px 26px}
  .nextobj-in{padding:32px 26px}
  .cat-grid{grid-template-columns:1fr}
}
