/*
Theme Name: DATAPOT
Theme URI: https://datapot.com/
Author: datapot llc.
Description: DATAPOT WEB — An engineer's editorial. 静謐なホワイトペーパー／コンソール調の和歌山発テーマ。
Version: 1.1.5
Requires at least: 6.0
Requires PHP: 8.0
License: GPL v2 or later
Text Domain: datapot
*/

:root{
  --bg:#FAFAF5; --panel:#F4F2EB; --fg:#15140F; --dim:#7a7368; --line:#D8D4C8; --line-s:#E8E5DB;
  --accent:#15140F;
  --ok:#4a7a4e; --hl:#8a7a45;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
  --f-m:"Shippori Mincho B1","Noto Serif JP",serif;
  --f-s:"Noto Serif JP",serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg);font-family:var(--f-mono);font-size:14px;line-height:1.75;-webkit-font-smoothing:antialiased;font-feature-settings:"palt"}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px;position:relative}

/* faint graph paper */
body::before{content:"";position:fixed;inset:0;background-image:linear-gradient(to right,rgba(21,20,15,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(21,20,15,.035) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}

.mute{color:var(--dim)}
.hair{border-top:1px solid var(--line)}
.hair-s{border-top:1px solid var(--line-s)}

/* ───── Topbar ───── */
.topbar{position:sticky;top:0;z-index:30;background:rgba(250,250,245,.88);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.tin{display:flex;align-items:center;height:64px;max-width:1280px;margin:0 auto;padding:0 32px;gap:16px}
.path{font-family:var(--f-mono);font-size:13px;color:var(--fg);letter-spacing:.08em;line-height:1;display:inline-flex;align-items:center;gap:8px;padding-bottom:3px;position:relative}
.path::before{content:"";width:16px;height:1px;background:var(--fg);display:block;opacity:.55}
.path::after{content:"";position:absolute;left:24px;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,var(--fg) 0%,var(--fg) 40%,transparent 100%);opacity:.25}
.path b{color:var(--fg);font-weight:500;font-family:"JetBrains Mono",ui-monospace,monospace;font-variant-numeric:tabular-nums}
a.path{cursor:pointer;transition:opacity .15s ease}
a.path:hover{opacity:.75}
.path .dot{width:4px;height:4px;border-radius:50%;background:var(--ok);display:inline-block;margin-left:4px;animation:pulse 2.2s ease-out infinite;position:relative;cursor:help}
.path .dot[data-state="closed"]{background:#b5ad9e;animation:none}
.path .dot[data-state="closed"]::after{content:"";position:absolute;inset:-3px;border:1px dashed #b5ad9e;border-radius:50%;opacity:.6}
.path .hrs{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.1em;margin-left:8px;text-transform:uppercase;padding-left:8px;border-left:1px solid var(--line-s);line-height:1}
.path .hrs b{font-weight:500;font-variant-numeric:tabular-nums;color:var(--fg)}
.path .hrs[data-state="closed"] b{color:var(--dim)}
@media(max-width:640px){.path .hrs{display:none}}
.tspace{flex:1}
.tnav{display:flex;gap:20px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim)}
.tnav a:hover,.tnav a.cur{color:var(--fg)}
.tnav a::before{content:"[";opacity:.4;margin-right:4px}
.tnav a::after{content:"]";opacity:.4;margin-left:4px}
.tcta{font-size:11px;color:var(--bg);background:var(--accent);padding:6px 12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.tcta:hover{background:var(--fg)}

/* ───── Logo ───── */
.logo{display:inline-flex;align-items:center;gap:12px}
.logo .mk{width:40px;height:40px;display:block;flex-shrink:0;transform-origin:60% 60%;animation:lg-hover 5.5s ease-in-out infinite}
.logo .wm{display:flex;flex-direction:column;line-height:1}
.logo-footer{display:inline-block;line-height:0}
.logo-footer img{display:block;width:220px;max-width:100%;height:auto}
@keyframes lg-hover{
  0%,100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-1.5px) rotate(-2deg)}
  50%{transform:translateY(1px) rotate(0deg)}
  75%{transform:translateY(-1px) rotate(1.5deg)}
}

/* ───── Hero (front) ───── */
.hero{padding:80px 0 120px;position:relative;border-bottom:1px solid var(--line);z-index:2}
.hero .wrap{display:grid;grid-template-columns:1fr 420px;gap:60px;align-items:start}
.hero .prompt{font-size:13px;color:var(--dim);margin-bottom:32px}
.hero .prompt .pfx{color:var(--ok);margin-right:8px}
.hero .prompt .cmd{color:var(--fg)}
.hero h1{font-family:var(--f-m);font-weight:500;font-size:clamp(44px,6vw,80px);line-height:1.28;letter-spacing:.04em;color:var(--fg);max-width:900px}
.hero h1 .mono{font-family:var(--f-mono);font-weight:400;font-size:.85em;color:var(--dim);letter-spacing:.02em}
.hero h1 .cursor{display:inline-block;width:.55em;height:.9em;background:var(--fg);vertical-align:-6px;margin-left:6px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.hero .sub{margin-top:40px;font-family:var(--f-m);font-size:17px;line-height:2;letter-spacing:.05em;color:var(--fg);max-width:640px}

.hero .meta-rows{margin-top:56px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero .meta-rows .mr{display:grid;grid-template-columns:160px 1fr auto;gap:24px;padding:14px 0;border-bottom:1px dashed var(--line-s);font-size:12px;align-items:baseline}
.hero .meta-rows .mr:last-child{border-bottom:0}
.hero .meta-rows .k{color:var(--dim);text-transform:uppercase;letter-spacing:.1em;font-size:10px}
.hero .meta-rows .v{color:var(--fg)}
.hero .meta-rows .t{color:var(--dim);font-size:10px}

.term{background:var(--panel);border:1px solid var(--line);border-radius:4px;font-size:12px;line-height:1.8;overflow:hidden;box-shadow:0 20px 40px -20px rgba(21,20,15,.18)}
.term .tt-head{padding:10px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;background:#EDEAE0}
.term .tt-head .lh{display:flex;gap:6px;align-items:center}
.term .body{padding:18px 16px;background:var(--panel)}
.term .ln{display:grid;grid-template-columns:28px 1fr;gap:12px;color:var(--fg)}
.term .lno{color:#b5ad9e;text-align:right;user-select:none;font-variant-numeric:tabular-nums}
.term .kw{color:#8a5a2a}
.term .st{color:#4a7a4e}
.term .nm{color:#2a2a20}
.term .cm{color:var(--dim);font-style:italic}
.term .pn{color:#8a7a45}
.term .foot{padding:10px 14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:.08em;background:#EDEAE0}
.term .foot .ok{color:var(--ok)}

.statusbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);background:var(--panel)}
.statusbar .cell{padding:18px 24px;border-right:1px solid var(--line)}
.statusbar .cell:last-child{border-right:0}
.statusbar .k{color:var(--dim);font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.statusbar .v{font-size:13px;color:var(--fg)}

/* Sections */
section.sec{padding:120px 0;border-bottom:1px solid var(--line);position:relative;z-index:2}
.sh{display:grid;grid-template-columns:160px 1fr auto;gap:32px;align-items:baseline;padding-bottom:24px;margin-bottom:56px;position:relative}
.sh::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--line);transform:scaleX(0);transform-origin:left center;transition:transform 1s cubic-bezier(.2,.9,.2,1)}
.sh.in::after,.sh:not(.reveal)::after{transform:scaleX(1)}
.sh .idx{font-size:11px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase}
.sh h2{font-family:var(--f-m);font-weight:500;font-size:40px;line-height:1.25;letter-spacing:.03em}
.sh h2 .en{display:block;font-family:var(--f-mono);font-size:13px;font-weight:400;color:var(--dim);letter-spacing:.1em;margin-top:6px;text-transform:uppercase}
.sh .stamp{font-size:10px;color:var(--dim);border:1px solid var(--line);padding:4px 10px;letter-spacing:.1em;text-transform:uppercase;align-self:start;justify-self:end}

.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc .card{border:1px solid var(--line);background:var(--bg);padding:0;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s}
.svc .card:hover{border-color:var(--fg)}
.svc .card .h{padding:12px 18px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:.08em;text-transform:uppercase}
.svc .card .b{padding:28px 24px 24px}
.svc .card .num{font-size:11px;color:var(--dim);letter-spacing:.1em;margin-bottom:16px}
.svc .card h3{font-family:var(--f-m);font-weight:500;font-size:30px;line-height:1.3;letter-spacing:.04em}
.svc .card .en{font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.1em;margin-top:4px;text-transform:uppercase}
.svc .card p{font-family:var(--f-s);font-size:13px;line-height:2;margin-top:24px;color:#3a362c;letter-spacing:.04em}
.svc .card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:24px;padding-top:20px;border-top:1px dashed var(--line-s)}
.svc .card .tag{font-size:10px;color:var(--dim);letter-spacing:.06em}
.svc .card .tag::before{content:"#"}

.yb{display:grid;grid-template-columns:1.1fr 1fr;border:1px solid var(--line);background:var(--bg)}
.yb .l{padding:48px 40px;border-right:1px solid var(--line)}
.yb .kicker{font-size:10px;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:24px}
.yb h3{font-family:var(--f-m);font-weight:500;font-size:64px;line-height:1.1;letter-spacing:.06em}
.yb .en{font-family:var(--f-mono);font-size:13px;color:var(--dim);letter-spacing:.1em;margin-top:8px;text-transform:uppercase}
.yb .l p{font-family:var(--f-s);font-size:14px;line-height:2.1;margin-top:28px;color:#3a362c;letter-spacing:.04em}
.yb .facts{margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.yb .facts>div{padding:20px 0}
.yb .facts .n{font-family:var(--f-m);font-size:42px;line-height:1}
.yb .facts .k{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);margin-top:8px}
.yb .btn{margin-top:32px;display:inline-flex;align-items:center;gap:14px;padding:14px 22px;border:1px solid var(--fg);color:var(--fg);font-size:11px;letter-spacing:.15em;text-transform:uppercase;transition:background .2s,color .2s}
.yb .btn:hover{background:var(--fg);color:var(--bg)}
.yb .r{padding:40px 32px;background:var(--panel);position:relative;display:flex;align-items:center;justify-content:center;min-height:560px;background-image:linear-gradient(to right,rgba(21,20,15,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(21,20,15,.04) 1px,transparent 1px);background-size:24px 24px}
.yb-mock{display:block;max-width:100%;transition:transform .3s ease}
.yb-mock img{display:block;width:100%;max-width:460px;height:auto}
.yb-mock:hover{transform:translateY(-2px)}

.co{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.co .intro{font-family:var(--f-m);font-size:17px;line-height:2.15;letter-spacing:.05em;color:var(--fg)}
.co .intro p{margin-bottom:1em}
.co dl{border-top:1px solid var(--line)}
.co .row{display:grid;grid-template-columns:140px 1fr;gap:20px;padding:14px 0;border-bottom:1px dashed var(--line-s);align-items:baseline}
.co dt{font-size:10px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase}
.co dd{font-family:var(--f-m);font-size:15px;letter-spacing:.04em;margin:0}
.co dd .en{display:block;font-family:var(--f-mono);font-size:11px;color:var(--dim);margin-top:4px;letter-spacing:.08em;text-transform:uppercase}

/* CTA */
.cta{padding:120px 0;border-bottom:1px solid var(--line);position:relative;z-index:2}
.cta .box{border:1px solid var(--line);background:var(--panel);display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch;position:relative;overflow:hidden}
.cta .bL{padding:56px 48px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2}
.cta .bL .prompt{font-size:12px;color:var(--ok);margin-bottom:14px;font-family:var(--f-mono)}
.cta .bL h3{font-family:var(--f-m);font-weight:500;font-size:40px;line-height:1.35;letter-spacing:.04em}
.cta .bL .sub{font-family:var(--f-m);font-size:13px;line-height:2;color:#3a362c;margin-top:20px;letter-spacing:.04em;max-width:420px}
.cta .bL .meta{margin-top:28px;display:flex;gap:24px;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim)}
.cta .bL .meta .dot{width:5px;height:5px;background:var(--ok);border-radius:50%;display:inline-block;margin-right:6px;vertical-align:2px}
.cta .bD{width:1px;background:var(--line);position:relative}
.cta .bD::before,.cta .bD::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:7px;height:7px;border:1px solid var(--line);background:var(--bg)}
.cta .bD::before{top:40px}
.cta .bD::after{bottom:40px}
.cta .bR{padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);border-left:1px solid var(--line);position:relative;min-height:320px}
.cta .illo{width:180px;height:180px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--line);color:var(--dim);font-family:var(--f-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;text-align:center;padding:16px;background:repeating-linear-gradient(135deg,transparent 0 10px,rgba(21,20,15,.02) 10px 11px)}
.cta .illo .tag{display:block;color:var(--fg);font-size:11px;margin-bottom:6px;letter-spacing:.12em}
.cta .illo.illo-mail{border:0;background:none;padding:0;width:auto;height:auto;max-width:140px}
.cta .illo.illo-mail img{display:block;width:100%;height:auto}
.cta .btn-wrap{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:10px}
.cta .btn{display:inline-flex;align-items:center;gap:14px;padding:18px 28px;background:var(--accent);color:var(--bg);font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:500;border:1px solid var(--accent);transition:all .2s;position:relative}
.cta .btn:hover{background:transparent;color:var(--accent)}
.cta .btn-note{font-family:var(--f-mono);font-size:9px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase}

/* Footer */
footer.ft{padding:80px 0 40px;border-top:1px solid var(--line);position:relative;z-index:2}
.fg{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.fg .big{font-family:var(--f-m);font-size:40px;letter-spacing:.15em;line-height:1}
.fg .addr{margin-top:20px;font-size:11px;line-height:2;color:var(--dim);letter-spacing:.05em}
.fg h5{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);margin-bottom:16px}
.fg ul{list-style:none}
.fg li{font-family:var(--f-m);font-size:14px;line-height:2.3;letter-spacing:.04em}
.fb{margin-top:24px;display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:.1em}

/* News (front list) */
.news-list{border-top:1px solid var(--line)}
.news-list .i{display:grid;grid-template-columns:140px 120px 1fr auto;gap:24px;padding:22px 0;border-bottom:1px solid var(--line-s);align-items:baseline;transition:padding-left .2s ease;cursor:pointer}
.news-list .i:hover{padding-left:14px}
.news-list .i:hover .a{transform:translateX(4px);color:var(--fg)}
.news-list .date{font-size:12px;color:var(--dim);letter-spacing:.05em}
.news-list .cat{font-size:10px;color:var(--fg);border:1px solid var(--line);padding:3px 9px;letter-spacing:.1em;text-transform:uppercase;justify-self:start}
.news-list .t{font-family:var(--f-m);font-size:15px;letter-spacing:.04em;color:var(--fg)}
.news-list .a{color:var(--dim);font-size:14px;transition:transform .2s,color .2s}

@media(max-width:900px){
  .tnav{display:none}
  .hero .wrap{grid-template-columns:1fr}
  .statusbar{grid-template-columns:1fr 1fr}
  .statusbar .cell{border-bottom:1px solid var(--line)}
  .svc{grid-template-columns:1fr}
  .yb{grid-template-columns:1fr}
  .yb .l{border-right:0;border-bottom:1px solid var(--line)}
  .co{grid-template-columns:1fr;gap:40px}
  .news-list .i{grid-template-columns:1fr;gap:6px}
  .cta .box{grid-template-columns:1fr}
  .cta .bD{display:none}
  .cta .bR{border-left:0;border-top:1px solid var(--line);min-height:260px}
  .fg{grid-template-columns:1fr}
  .sh{grid-template-columns:1fr;gap:12px}
  .sh .stamp{display:none}
  .yb-mock img{max-width:320px}
}

/* reveal */
.reveal{opacity:0;transform:translateY(22px) scale(.985);filter:blur(6px);transition:opacity .55s cubic-bezier(.2,.9,.2,1),transform .55s cubic-bezier(.2,.9,.2,1),filter .55s cubic-bezier(.2,.9,.2,1)}
.reveal.in{opacity:1;transform:none;filter:blur(0)}
.reveal.d1{transition-delay:.05s}
.reveal.d2{transition-delay:.10s}
.reveal.d3{transition-delay:.15s}
.reveal.d4{transition-delay:.20s}
.reveal.d5{transition-delay:.25s}
.reveal.d6{transition-delay:.30s}

/* Hero title: snap char-by-char "shun-shun" — applied via JS-wrapped .w spans */
.heroh1 .w{display:inline-block;opacity:0;transform:translateY(14px) scale(.95);filter:blur(6px);animation:shun .45s cubic-bezier(.15,.9,.2,1) forwards}
.heroh1 .mono{display:inline-block;opacity:0;animation:papa .3s ease .25s forwards}
@keyframes shun{to{opacity:1;transform:none;filter:blur(0)}}

/* Hero prompt typewriter */
.hero .prompt{overflow:hidden}
.hero .prompt .cmd{display:inline-block;white-space:nowrap;vertical-align:bottom;max-width:0;overflow:hidden;animation:type 1.4s steps(42,end) 1.6s forwards}
@keyframes type{to{max-width:520px}}

/* Meta rows: papapa rapid-fire reveal */
.hero .meta-rows .mr{opacity:0;transform:translateY(8px);animation:papa .35s cubic-bezier(.2,.9,.2,1) forwards}
.hero .meta-rows .mr:nth-child(1){animation-delay:2.3s}
.hero .meta-rows .mr:nth-child(2){animation-delay:2.4s}
.hero .meta-rows .mr:nth-child(3){animation-delay:2.5s}
@keyframes papa{to{opacity:1;transform:none}}

/* Terminal card: overall "shun" in, then papapa lines */
.term{opacity:0;transform:translateX(28px) scale(.98);filter:blur(8px);animation:shunR .6s cubic-bezier(.15,.9,.2,1) .5s forwards}
@keyframes shunR{to{opacity:1;transform:none;filter:blur(0)}}
.term .ln{opacity:0;transform:translateX(-6px);animation:ln-in .28s cubic-bezier(.2,.9,.2,1) forwards}
.term .ln:nth-child(1){animation-delay:1.2s}
.term .ln:nth-child(2){animation-delay:1.26s}
.term .ln:nth-child(3){animation-delay:1.32s}
.term .ln:nth-child(4){animation-delay:1.38s}
.term .ln:nth-child(5){animation-delay:1.44s}
.term .ln:nth-child(6){animation-delay:1.50s}
.term .ln:nth-child(7){animation-delay:1.56s}
.term .ln:nth-child(8){animation-delay:1.62s}
.term .ln:nth-child(9){animation-delay:1.68s}
.term .ln:nth-child(10){animation-delay:1.74s}
.term .ln:nth-child(11){animation-delay:1.80s}
.term .ln:nth-child(12){animation-delay:1.86s}
.term .ln:nth-child(13){animation-delay:1.92s}
.term .ln:nth-child(14){animation-delay:1.98s}
@keyframes ln-in{to{opacity:1;transform:none}}

/* Topbar: pa! in */
.topbar{animation:barIn .5s cubic-bezier(.2,.9,.2,1) both}
@keyframes barIn{from{opacity:0;transform:translateY(-10px);filter:blur(4px)}to{opacity:1;transform:none;filter:none}}

/* Scanline flash across hero on load */
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(21,20,15,.06) 50%,transparent 100%);transform:translateX(-100%);animation:scan 1.1s cubic-bezier(.2,.9,.2,1) .1s 1}
@keyframes scan{to{transform:translateX(100%)}}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  .logo .mk{animation:none}
  .hero h1 .cursor{animation:none}
  .heroh1 .w,.heroh1 .mono,.hero .meta-rows .mr,.term,.term .ln,.topbar,.hero::after{animation:none;opacity:1;transform:none;filter:none}
  .hero .prompt .cmd{max-width:none;animation:none}
}

/* pulse */
.pulse{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ok);margin-right:6px;vertical-align:1px;box-shadow:0 0 0 0 rgba(74,122,78,.55);animation:pulse 2.2s ease-out infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(74,122,78,.5)}
  70%{box-shadow:0 0 0 10px rgba(74,122,78,0)}
  100%{box-shadow:0 0 0 0 rgba(74,122,78,0)}
}

/* Back to top */
.to-top{position:fixed;right:24px;bottom:24px;z-index:40;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--fg);color:var(--bg);border:1px solid var(--fg);cursor:pointer;font-size:0;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .3s,transform .3s,background .2s,color .2s}
.to-top.on{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{background:var(--bg);color:var(--fg)}
.to-top svg{width:14px;height:14px;display:block}

/* ───── Generic page (wp content area) ───── */
.pg-wrap{padding:72px 0 120px;position:relative;z-index:2}
.pg-body{max-width:760px;margin:0 auto;padding:0 32px;font-family:var(--f-m);font-size:16px;line-height:2.1;letter-spacing:.05em;color:var(--fg)}
.pg-body h2{font-family:var(--f-m);font-weight:500;font-size:26px;margin:3em 0 1em;padding-bottom:.6em;border-bottom:1px solid var(--line)}
.pg-body h2::before{content:"§ ";color:var(--dim);font-family:var(--f-mono);font-size:14px}
.pg-body h3{font-family:var(--f-m);font-weight:500;font-size:18px;margin:2.4em 0 .8em}
.pg-body p{margin-bottom:1.7em}
.pg-body a{text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--line)}
.pg-body a:hover{text-decoration-color:var(--fg)}

/* alignments for WP default blocks */
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.alignwide{max-width:1100px}
.alignfull{max-width:100%}
.wp-caption-text{font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.05em;margin-top:8px}
blockquote{margin:2em 0;padding:18px 24px;border-left:2px solid var(--fg);background:var(--panel)}

/* WP comment / password / search form minimal reset */
.screen-reader-text{position:absolute !important;clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden}

/* Pagination (news list) */
.nw-pg{margin-top:56px;display:flex;align-items:center;justify-content:space-between;padding-top:28px;border-top:1px solid var(--line);font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--dim)}
.nw-pg .nav{display:flex;gap:6px}
.nw-pg .nav a,.nw-pg .nav span.current,.nw-pg .nav .dots{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--line);background:var(--bg);color:var(--fg);font-size:11px;font-variant-numeric:tabular-nums;letter-spacing:.08em;transition:background .15s ease,color .15s ease,border-color .15s ease}
.nw-pg .nav a:hover{border-color:var(--fg)}
.nw-pg .nav .current{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* ───── Article (single post) ───── */
.art-wrap{padding:72px 0 96px;position:relative;z-index:2}
.art{max-width:760px;margin:0 auto;padding:0 32px}

.art .head{padding-bottom:40px;border-bottom:1px solid var(--line);margin-bottom:48px}
.art .head .meta{display:flex;align-items:center;gap:16px;font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.08em;margin-bottom:24px;flex-wrap:wrap}
.art .head .cat{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);padding:3px 9px}
.art .head .cat.product{background:var(--panel);color:var(--fg)}
.art .head .cat.notice{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.art .head .dt{font-variant-numeric:tabular-nums;color:var(--fg)}
.art .head .dt::before{content:"◯ ";color:var(--dim)}
.art .head .slug{color:var(--dim);font-size:10px;letter-spacing:.1em;margin-left:auto}
.art .head h1{font-family:var(--f-m);font-weight:500;font-size:clamp(30px,3.4vw,42px);line-height:1.45;letter-spacing:.05em;color:var(--fg);text-wrap:pretty}
.art .head .sub{font-family:var(--f-m);font-size:15px;line-height:2;color:#3a362c;letter-spacing:.04em;margin-top:20px;text-wrap:pretty}

.art .body{font-family:var(--f-m);font-size:16px;line-height:2.1;letter-spacing:.05em;color:var(--fg)}
.art .body p{margin-bottom:1.7em;text-wrap:pretty}
.art .body h2{font-family:var(--f-m);font-weight:500;font-size:24px;line-height:1.5;letter-spacing:.04em;margin:3em 0 1em;padding-bottom:.6em;border-bottom:1px solid var(--line);position:relative}
.art .body h2::before{content:"§ ";color:var(--dim);font-family:var(--f-mono);font-size:14px;margin-right:6px;letter-spacing:.1em}
.art .body h3{font-family:var(--f-m);font-weight:500;font-size:18px;letter-spacing:.04em;margin:2.4em 0 .8em}
.art .body h3::before{content:"▸ ";color:var(--dim);font-family:var(--f-mono);font-size:12px;margin-right:2px}
.art .body ul,.art .body ol{margin:0 0 1.7em 0;padding-left:0;list-style:none}
.art .body li{padding-left:1.6em;position:relative;margin-bottom:.5em;line-height:2}
.art .body ul li::before{content:"—";position:absolute;left:0;color:var(--dim);font-family:var(--f-mono)}
.art .body ol{counter-reset:li}
.art .body ol li{counter-increment:li}
.art .body ol li::before{content:counter(li,decimal-leading-zero);position:absolute;left:0;color:var(--dim);font-family:var(--f-mono);font-size:12px;font-variant-numeric:tabular-nums;top:.2em}
.art .body blockquote{margin:2em 0;padding:18px 24px;border-left:2px solid var(--fg);background:var(--panel);font-family:var(--f-m);font-size:15px;line-height:1.95;color:#3a362c;letter-spacing:.04em}
.art .body blockquote::before{content:"// ";color:var(--dim);font-family:var(--f-mono);font-size:12px}
.art .body code{font-family:var(--f-mono);font-size:.88em;background:var(--panel);padding:2px 6px;border:1px solid var(--line-s);border-radius:2px;color:#8a5a2a;letter-spacing:0}
.art .body pre{font-family:var(--f-mono);font-size:12px;line-height:1.8;background:var(--panel);border:1px solid var(--line);padding:18px 20px;margin:1.6em 0;overflow-x:auto;letter-spacing:0;color:var(--fg)}
.art .body a{color:var(--fg);text-decoration:underline;text-decoration-color:var(--line);text-decoration-thickness:1px;text-underline-offset:4px;transition:text-decoration-color .2s}
.art .body a:hover{text-decoration-color:var(--fg)}
.art .body hr{border:0;border-top:1px dashed var(--line);margin:3em 0}
.art .body figure{margin:2.2em 0;padding:0}
.art .body figcaption{font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.05em;margin-top:10px;padding-left:10px;border-left:2px solid var(--line)}
.art .body img{max-width:100%;height:auto;display:block}

/* Share row */
.art .share{margin-top:64px;padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:20px;font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase;flex-wrap:wrap}
.art .share .lb{margin-right:auto}
.art .share .lb::before{content:"// "}
.art .share a{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid var(--line);color:var(--fg);font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;transition:border-color .2s,background .2s,color .2s}
.art .share a:hover{border-color:var(--fg);background:var(--fg);color:var(--bg)}

/* Tags */
.art .tags{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap;font-family:var(--f-mono);font-size:11px}
.art .tags .t{color:var(--dim);letter-spacing:.04em}
.art .tags .t::before{content:"#"}
.art .tags .t:hover{color:var(--fg)}

/* Prev / Next / Back */
nav.pn{max-width:960px;margin:80px auto 0;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
nav.pn a,nav.pn span.pv,nav.pn span.nx{display:block;padding:24px;border:1px solid var(--line);background:var(--bg);transition:border-color .2s ease,transform .2s ease}
nav.pn a:hover{border-color:var(--fg)}
nav.pn a.nx,nav.pn span.nx{text-align:right}
nav.pn .k{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px}
nav.pn .d{font-family:var(--f-mono);font-size:10px;color:var(--dim);margin-bottom:6px;letter-spacing:.06em;font-variant-numeric:tabular-nums}
nav.pn .t{font-family:var(--f-m);font-size:15px;line-height:1.6;letter-spacing:.04em;color:var(--fg);text-wrap:pretty}
nav.pn .dis{opacity:.4;pointer-events:none}

.bk-list{max-width:960px;margin:40px auto 120px;padding:0 32px;text-align:center}
.bk-list a{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border:1px solid var(--line);font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);transition:background .2s,color .2s,border-color .2s}
.bk-list a:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

@media(max-width:900px){
  nav.pn{grid-template-columns:1fr}
  .art .body{font-size:15px;line-height:2}
  .art .share{flex-wrap:wrap;gap:10px}
}

/* ───── News timeline (archive) ───── */
.nw-wrap{padding:72px 0 120px;position:relative;z-index:2}
.nw-grid{display:grid;grid-template-columns:220px 1fr;gap:56px;align-items:start}

.nw-side{position:sticky;top:96px;font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.08em}
.nw-side .k{font-size:10px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.nw-side .v{font-family:var(--f-m);font-size:22px;color:var(--fg);letter-spacing:.04em;line-height:1.2}
.nw-side .blk{border-top:1px solid var(--line);padding:20px 0}
.nw-side .blk:first-child{border-top:0;padding-top:0}
.nw-side .legend{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.nw-side .lg{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:11px;color:var(--fg);letter-spacing:.04em;text-transform:none}
.nw-side .lg .pip{width:10px;height:10px;border:1px solid var(--line);display:inline-block;background:var(--bg);font-size:0}
.nw-side .lg b{font-family:var(--f-mono);font-weight:500;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-left:auto;font-variant-numeric:tabular-nums}

.nw-year{display:grid;grid-template-columns:120px 1fr;gap:40px;padding:28px 0;border-top:1px solid var(--line);position:relative}
.nw-year:first-child{border-top:0;padding-top:0}
.nw-year .yh{position:sticky;top:96px;align-self:start}
.nw-year .yh .y{font-family:var(--f-m);font-weight:500;font-size:48px;line-height:1;letter-spacing:.06em;color:var(--fg)}
.nw-year .yh .ct{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.1em;margin-top:10px;text-transform:uppercase}
.nw-year .yh .bar{width:40px;height:1px;background:var(--fg);margin-top:14px;opacity:.4}

.nw-months{display:flex;flex-direction:column;gap:20px}
.nw-month{border-top:1px dashed var(--line-s);padding-top:18px}
.nw-month:first-child{border-top:0;padding-top:0}
.nw-month .mh{display:flex;align-items:baseline;gap:12px;margin-bottom:8px;font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.15em;text-transform:uppercase}
.nw-month .mh .m{font-family:var(--f-m);font-weight:500;font-size:18px;color:var(--fg);letter-spacing:.04em;text-transform:none}
.nw-month .mh .en{font-family:var(--f-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim)}

.nw-item{display:grid;grid-template-columns:86px 110px 1fr auto;gap:20px;padding:16px 0;border-bottom:1px solid var(--line-s);align-items:baseline;transition:padding-left .18s ease,border-color .2s ease}
.nw-item:hover{padding-left:10px;border-bottom-color:var(--fg)}
.nw-item:hover .arr{transform:translateX(4px);color:var(--fg)}
.nw-item .dt{font-family:var(--f-mono);font-size:11px;color:var(--dim);letter-spacing:.06em;font-variant-numeric:tabular-nums}
.nw-item .cat{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);padding:3px 9px;justify-self:start;color:var(--fg)}
.nw-item .cat.notice{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.nw-item .cat.product{background:var(--panel);color:var(--fg)}
.nw-item .tt{font-family:var(--f-m);font-size:15px;letter-spacing:.04em;color:var(--fg);line-height:1.6}
.nw-item .arr{font-family:var(--f-mono);color:var(--dim);font-size:14px;transition:transform .18s ease,color .18s ease}

@media(max-width:900px){
  .nw-grid{grid-template-columns:1fr;gap:32px}
  .nw-side{position:static}
  .nw-year{grid-template-columns:1fr;gap:16px}
  .nw-year .yh{position:static}
  .nw-year .yh .y{font-size:36px}
  .nw-item{grid-template-columns:80px 1fr;gap:10px}
  .nw-item .cat{grid-column:2;justify-self:start}
  .nw-item .tt{grid-column:1/-1}
  .nw-item .arr{display:none}
}

/* ───── Contact form ───── */
.ct-wrap{padding:72px 0 120px;position:relative;z-index:2}
.ct-grid{display:grid;grid-template-columns:320px 1fr;gap:72px;align-items:start}

.ct-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:28px}
.ct-side .blk{padding:22px 0;border-top:1px solid var(--line)}
.ct-side .blk:first-child{border-top:0;padding-top:0}
.ct-side .k{font-family:var(--f-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}
.ct-side .k::before{content:"// "}
.ct-side .phone{font-family:var(--f-m);font-weight:500;font-size:30px;letter-spacing:.08em;color:var(--fg);line-height:1.1}
.ct-side .hrs{font-family:var(--f-mono);font-size:11px;color:var(--dim);margin-top:10px;letter-spacing:.05em;line-height:1.8}
.ct-side .hrs .dot{width:6px;height:6px;background:var(--ok);border-radius:50%;display:inline-block;margin-right:6px;vertical-align:1px;box-shadow:0 0 0 0 rgba(74,122,78,.55);animation:pulse 2.2s ease-out infinite}
.ct-side .mail{font-family:var(--f-mono);font-size:14px;letter-spacing:.05em;color:var(--fg);word-break:break-all}
.ct-side .mail:hover{text-decoration:underline;text-underline-offset:4px}
.ct-side .reply{font-family:var(--f-m);font-size:14px;line-height:1.8;color:var(--fg);letter-spacing:.04em}
.ct-side .reply em{font-family:var(--f-mono);font-style:normal;color:var(--ok);letter-spacing:.05em}
.ct-side .addr{font-family:var(--f-m);font-size:13px;line-height:2;color:var(--fg);letter-spacing:.04em}
.ct-side .addr .mono{display:block;font-family:var(--f-mono);font-size:11px;color:var(--dim);margin-top:4px;letter-spacing:.06em}

.ct-form{position:relative}
.ct-form .head{display:flex;align-items:baseline;gap:14px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:40px}
.ct-form .head .idx{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.15em;text-transform:uppercase}
.ct-form .head .tl{font-family:var(--f-m);font-size:22px;letter-spacing:.04em;color:var(--fg)}
.ct-form .head .fill{flex:1;height:1px;background:var(--line-s);margin:0 4px;align-self:center}
.ct-form .head .stamp{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase}

.fld{display:grid;grid-template-columns:180px 1fr;gap:28px;padding:22px 0;border-bottom:1px dashed var(--line-s);align-items:start}
.fld.full{grid-template-columns:180px 1fr}
.fld label{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--dim);text-transform:uppercase;padding-top:11px;display:flex;align-items:center;gap:10px}
.fld label .jp{font-family:"Noto Sans JP",sans-serif;font-size:13px;color:var(--fg);font-weight:500;letter-spacing:.1em;text-transform:none}
.fld label .req{font-family:var(--f-mono);font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--fg);color:var(--bg);background:var(--fg);margin-left:auto}
.fld label .opt{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-left:auto}

.inp{width:100%;font-family:var(--f-m);font-size:15px;color:var(--fg);background:var(--bg);border:0;border-bottom:1px solid var(--line);padding:16px 10px;line-height:1.8;letter-spacing:.04em;transition:border-color .2s}
.inp::placeholder{color:#c6bfae;font-family:var(--f-m);letter-spacing:.04em}
.inp:focus{outline:0;border-bottom-color:var(--fg)}

textarea.inp{min-height:220px;resize:vertical;line-height:2;padding:22px 24px;border:1px solid var(--line);background:var(--bg)}
textarea.inp:focus{border-color:var(--fg)}
textarea.inp::placeholder{line-height:2}

.hint{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.05em;margin-top:8px;display:flex;justify-content:space-between}

.cats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.cat{position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);background:var(--bg);cursor:pointer;transition:background .15s,border-color .15s}
.cat input{position:absolute;opacity:0;pointer-events:none}
.cat .box{width:14px;height:14px;border:1px solid var(--line);border-radius:50%;flex-shrink:0;position:relative;transition:border-color .15s}
.cat .box::after{content:"";position:absolute;inset:3px;background:var(--fg);border-radius:50%;transform:scale(0);transition:transform .18s ease}
.cat .lb{font-family:"Noto Sans JP",sans-serif;font-size:13px;color:var(--fg);letter-spacing:.06em;font-weight:500}
.cat .lb .en{display:block;font-family:var(--f-mono);font-size:9px;color:var(--dim);margin-top:3px;letter-spacing:.1em;text-transform:uppercase;font-weight:400}
.cat:hover{border-color:var(--fg)}
.cat input:checked ~ .box{border-color:var(--fg)}
.cat input:checked ~ .box::after{transform:scale(1)}
.cat:has(input:checked){background:var(--panel);border-color:var(--fg)}

.pv{margin-top:32px;padding:20px;border:1px solid var(--line);background:var(--panel);font-family:var(--f-m);font-size:13px;line-height:2;letter-spacing:.04em;color:var(--fg)}
.pv h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);margin-bottom:8px}
.pv h4::before{content:"// "}

.agree{margin-top:20px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:4px 0;user-select:none;position:relative}
.agree input{position:absolute;opacity:0;pointer-events:none}
.agree .box{width:18px;height:18px;border:1px solid var(--fg);background:var(--bg);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;transition:background .15s}
.agree .box svg{width:11px;height:11px;stroke:var(--bg);stroke-width:3;fill:none;opacity:0;transition:opacity .15s}
.agree input:checked ~ .box{background:var(--fg)}
.agree input:checked ~ .box svg{opacity:1}
.agree .lb{font-family:"Noto Sans JP",sans-serif;font-size:13px;line-height:1.8;color:var(--fg);letter-spacing:.04em;font-weight:500}

.actions{margin-top:40px;padding-top:28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.actions .note{font-family:var(--f-mono);font-size:10px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;max-width:320px}
.actions .note::before{content:"// "}
.submit{display:inline-flex;align-items:center;gap:14px;padding:18px 32px;background:var(--accent);color:var(--bg);font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;border:1px solid var(--accent);cursor:pointer;transition:background .2s,color .2s;position:relative}
.submit:hover{background:transparent;color:var(--accent)}
.submit::after{content:"→";font-family:var(--f-mono);font-size:14px;line-height:1}

.done{display:block;padding:48px;border:1px solid var(--fg);background:var(--panel);font-family:var(--f-mono);font-size:13px;line-height:2;letter-spacing:.04em;color:var(--fg);margin-top:32px}
.done .pfx{color:var(--ok)}
.done b{font-family:var(--f-m);font-size:22px;font-weight:500;letter-spacing:.06em;display:block;margin:10px 0 16px}

@media(max-width:1000px){
  .ct-grid{grid-template-columns:1fr;gap:48px}
  .ct-side{position:static;flex-direction:row;flex-wrap:wrap;gap:24px 40px}
  .ct-side .blk{flex:1;min-width:240px;border-top:1px solid var(--line);padding-top:22px}
  .ct-side .blk:first-child{border-top:1px solid var(--line);padding-top:22px}
}
@media(max-width:820px){
  .fld{grid-template-columns:1fr !important;gap:10px;padding:16px 0}
  .fld.full{grid-template-columns:1fr !important}
  .fld label{padding-top:0;justify-content:space-between}
  .fld > div{width:100%}
  .cats{grid-template-columns:1fr}
  .actions{flex-direction:column;align-items:stretch}
  .actions .note{order:2;max-width:none}
  .submit{justify-content:center}
}

/* scan anim for pg-hero */
@keyframes scan{to{transform:translateX(100%)}}

/* ───── Contact Form 7 integration ───── */
/* CF7 wraps inputs in spans — make them inherit full width */
.ct-form .wpcf7-form-control-wrap{display:block;width:100%}
.ct-form .wpcf7-form-control.wpcf7-text,
.ct-form .wpcf7-form-control.wpcf7-email,
.ct-form .wpcf7-form-control.wpcf7-tel,
.ct-form .wpcf7-form-control.wpcf7-textarea{width:100%}

/* Radio group — flatten CF7 wrappers via display:contents so list items become direct grid children of .cats */
.cats .wpcf7-form-control-wrap,
.cats .wpcf7-form-control.wpcf7-radio{display:contents}
.cats .wpcf7-list-item{margin:0;display:block}
.cats .wpcf7-list-item > label{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);background:var(--bg);cursor:pointer;transition:background .15s,border-color .15s;font-family:"Noto Sans JP",sans-serif;font-size:13px;color:var(--fg);letter-spacing:.06em;font-weight:500;min-height:52px;width:100%}
.cats .wpcf7-list-item > label:hover{border-color:var(--fg)}
.cats .wpcf7-list-item input[type=radio]{accent-color:var(--fg);margin:0;width:14px;height:14px;flex-shrink:0}
.cats .wpcf7-list-item:has(input:checked) > label{background:var(--panel);border-color:var(--fg)}

/* Agree checkbox (CF7 acceptance) — reset my custom hidden-input hack since CF7 renders its own visible checkbox */
.agree{display:block;margin-top:20px;padding:4px 0;user-select:none;position:static}
.agree .wpcf7-form-control-wrap,
.agree .wpcf7-form-control.wpcf7-acceptance{display:block;width:100%}
.agree .wpcf7-list-item{margin:0;display:block}
.agree .wpcf7-list-item > label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-family:"Noto Sans JP",sans-serif;font-size:13px;line-height:1.8;color:var(--fg);letter-spacing:.04em;font-weight:500}
.agree .wpcf7-list-item input[type=checkbox]{position:static !important;opacity:1 !important;pointer-events:auto !important;margin:4px 0 0;width:18px;height:18px;accent-color:var(--fg);cursor:pointer;flex-shrink:0}
.agree .wpcf7-list-item-label{font-family:"Noto Sans JP",sans-serif;font-size:13px;line-height:1.8;color:var(--fg);letter-spacing:.04em;font-weight:500}

/* Validation messages */
.wpcf7-not-valid-tip{font-family:var(--f-mono);font-size:11px;color:#a04040;margin-top:6px;letter-spacing:.04em}
.wpcf7-response-output{margin:24px 0 0;padding:16px 20px;border:1px solid var(--line);font-family:var(--f-m);font-size:13px;line-height:1.8;letter-spacing:.04em}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output{border-color:#a04040;background:#fbf3f3;color:#7a2a2a}
.wpcf7 form.sent .wpcf7-response-output{border-color:var(--ok);background:#f0f5ef;color:var(--ok)}
.wpcf7 form.submitting .wpcf7-response-output{border-color:var(--dim);background:var(--panel);color:var(--dim)}

/* Loading spinner */
.wpcf7-spinner{background-color:var(--fg)}

@media (max-width:700px){
	.cats{grid-template-columns:1fr}
}

/* reCAPTCHA badge — show only on the contact page, push up so FAB doesn't overlap */
.grecaptcha-badge{bottom:90px !important;z-index:20}
body:not(.is-contact) .grecaptcha-badge{visibility:hidden !important;opacity:0 !important;pointer-events:none !important}

/* Statusbar online/offline indicator */
#bizStatus{color:var(--ok);transition:color .2s ease}
#bizStatus[data-state="closed"]{color:var(--dim)}
#bizStatus[data-state="closed"] .pulse{background:#b5ad9e;box-shadow:none;animation:none}

/* ───── Scroll progress bar (A) — 最上端の hairline ───── */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;background:transparent;z-index:60;pointer-events:none}
.scroll-progress > i{display:block;height:100%;width:0;background:var(--fg);transition:width 80ms linear}

/* ───── Noise / film grain overlay (C) ───── */
html::after{
	content:"";
	position:fixed;inset:0;
	pointer-events:none;
	z-index:1;
	opacity:.07;
	mix-blend-mode:multiply;
	background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
@media (prefers-reduced-motion:reduce){
	html::after{opacity:.04}
}

/* ───── Section header underline draw-in animation (I) — extra hairlines ───── */
/* meta-rows の上下線も描画アニメに */
.hero .meta-rows{position:relative;border:0}
.hero .meta-rows::before,
.hero .meta-rows::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--line);transform:scaleX(0);transform-origin:left center;transition:transform 1s cubic-bezier(.2,.9,.2,1)}
.hero .meta-rows::before{top:0}
.hero .meta-rows::after{bottom:0}
.hero .meta-rows.reveal.in::before,
.hero .meta-rows.reveal.in::after,
.hero .meta-rows:not(.reveal)::before,
.hero .meta-rows:not(.reveal)::after{transform:scaleX(1)}
.hero .meta-rows.reveal.in::after{transition-delay:.15s}

@media (prefers-reduced-motion:reduce){
	.sh::after,
	.hero .meta-rows::before,
	.hero .meta-rows::after{transform:scaleX(1) !important;transition:none !important}
}

/* ───── Boot sequence overlay (front page, first visit only) ───── */
.boot-seq{position:fixed;inset:0;z-index:100;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:13px;color:var(--fg);padding:0 32px}
.boot-seq .boot-inner{width:100%;max-width:640px}

/* Header: title + spinner */
.boot-seq .boot-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;margin-bottom:26px;border-bottom:1px solid var(--line)}
.boot-seq .boot-title{font-family:var(--f-mono);font-size:14px;font-weight:600;letter-spacing:.25em;color:var(--fg);text-transform:uppercase}
.boot-seq .boot-title::after{content:"...";display:inline-block;width:1.2em;text-align:left;margin-left:.15em;color:var(--dim);animation:bootDots 1.2s steps(4) infinite}
.boot-seq .boot-spin{display:inline-block;width:22px;height:22px;border:2px solid var(--line);border-top-color:var(--fg);border-radius:50%;animation:bootSpin .8s linear infinite;flex-shrink:0}
@keyframes bootSpin{to{transform:rotate(360deg)}}
@keyframes bootDots{
	0%{content:""}
	25%{content:"."}
	50%{content:".."}
	75%{content:"..."}
	100%{content:""}
}

/* Progress bar + hint */
.boot-seq .boot-bar{height:2px;background:var(--line-s);position:relative;overflow:hidden;margin-top:28px;border-radius:1px}
.boot-seq .boot-bar-fill{position:absolute;top:0;left:0;bottom:0;width:0;background:var(--fg);animation:bootBarFill 2.8s cubic-bezier(.25,.9,.3,1) .1s forwards}
@keyframes bootBarFill{to{width:100%}}
.boot-seq .boot-hint{margin-top:10px;font-size:10px;color:var(--dim);letter-spacing:.15em;text-transform:uppercase}
.boot-seq .boot-line{opacity:0;transform:translateX(-8px);filter:blur(3px);animation:bootLineIn .38s cubic-bezier(.2,.9,.2,1) forwards;line-height:2.1;letter-spacing:.04em;white-space:nowrap}
.boot-seq .boot-line:nth-child(1){animation-delay:.20s}
.boot-seq .boot-line:nth-child(2){animation-delay:.55s}
.boot-seq .boot-line:nth-child(3){animation-delay:.90s}
.boot-seq .boot-line:nth-child(4){animation-delay:1.25s}
.boot-seq .boot-line:nth-child(5){animation-delay:1.60s}
.boot-seq .boot-line:nth-child(6){animation-delay:2.00s}
.boot-seq .pfx{color:var(--ok);margin-right:6px}
.boot-seq .ok{color:var(--ok);font-weight:500}
.boot-seq .ready{color:var(--ok);font-weight:600;letter-spacing:.06em}
.boot-seq .dim{color:var(--dim)}
.boot-seq .cursor{display:inline-block;margin-left:8px;animation:bootBlink 1s steps(1) infinite;color:var(--fg)}
@keyframes bootLineIn{to{opacity:1;transform:none;filter:blur(0)}}
@keyframes bootBlink{50%{opacity:0}}
.boot-seq.fade-out{animation:bootFadeOut .6s cubic-bezier(.4,.0,.2,1) forwards}
@keyframes bootFadeOut{to{opacity:0;visibility:hidden;pointer-events:none}}
html.booted .boot-seq{display:none !important}

@media (max-width:640px){
	.boot-seq{font-size:11px}
	.boot-seq .boot-line{white-space:normal}
}

/* Pause hero-area animations while boot overlay is shown */
html:not(.booted) .topbar,
html:not(.booted) .hero::after,
html:not(.booted) .heroh1 .w,
html:not(.booted) .heroh1 .mono,
html:not(.booted) .hero .prompt .cmd,
html:not(.booted) .hero .meta-rows .mr,
html:not(.booted) .term,
html:not(.booted) .term .ln{animation-play-state:paused !important}

@media (prefers-reduced-motion:reduce){
	.boot-seq{display:none !important}
}
