/* ==========================================================
   Tokens
   ========================================================== */
:root{
  --bg:#f3ede0;
  --bg-soft:#ece4d3;
  --bg-card:#fbf6ec;
  --bg-deep:#e6dcc6;
  --ink:#1a1410;
  --ink-soft:#4a3f33;
  --ink-faint:#8a7d6a;
  --ink-ghost:#c2b59c;
  --line:#d4c8b0;
  --line-soft:#e3d8bf;

  --shu:#b8351d;
  --murasaki:#6b3a6e;
  --gun:#1f4f7a;
  --moku:#3d4a55;
  --yamabuki:#b3851b;

  --shu-soft:#e8d2cb;
  --murasaki-soft:#dccfdd;
  --gun-soft:#c8d6e3;
  --moku-soft:#d2d5d9;
  --yamabuki-soft:#e8dcc1;

  --serif:'Shippori Mincho B1','Cormorant Garamond','Songti SC',serif;
  --sans:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'PingFang SC',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --dur:.32s;
  --ease:cubic-bezier(.2,.8,.2,1);
  --shadow:0 20px 48px -30px rgba(26,20,16,.28);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  font-size:15px;
  font-feature-settings:"ss01","ss02","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
}
button,input,select,textarea{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
input,select,textarea{outline:none}

body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.35;
  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='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .08 0 0 0 0 .06 0 0 0 .15 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}

.frame{position:relative;z-index:2;max-width:1440px;margin:0 auto;padding:32px 40px 120px}
@media (max-width:720px){.frame{padding:20px 18px 80px}}

.masthead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding-bottom:18px;border-bottom:1px solid var(--ink);margin-bottom:48px}
.brand{display:flex;align-items:center;gap:18px}
.brand-mark{width:64px;height:64px;display:grid;place-items:center;background:var(--ink);color:var(--bg);font-family:var(--serif);font-size:36px;font-weight:600;line-height:1;position:relative}
.brand-mark::after{content:"";position:absolute;inset:-4px;border:1px solid var(--ink);pointer-events:none}
.brand-text .brand-title{font-family:var(--serif);font-size:28px;font-weight:600;line-height:1;letter-spacing:.01em}
.brand-text .brand-sub{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.masthead-meta{display:flex;align-items:center;gap:18px}
.issue{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--ink-faint);text-transform:uppercase;text-align:right;display:none}
@media (min-width:760px){.issue{display:block}}
.config-btn{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border:1px solid var(--ink);background:var(--bg);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.config-btn:hover{background:var(--ink);color:var(--bg)}
.config-btn .dot{width:7px;height:7px;border-radius:50%;background:var(--shu);box-shadow:0 0 0 3px rgba(184,53,29,.18)}
.config-btn.is-set .dot{background:#3a8754;box-shadow:0 0 0 3px rgba(58,135,84,.18)}

.hero{display:grid;grid-template-columns:1fr;gap:28px;padding:6px 0 48px;border-bottom:1px solid var(--line);margin-bottom:42px}
@media (min-width:920px){.hero{grid-template-columns:minmax(0,1fr) 430px;align-items:end;gap:60px}}
.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(56px,9vw,128px);line-height:.92;letter-spacing:-.015em}
.hero-title em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;color:var(--shu);font-size:.62em;display:inline-block;margin-left:.06em;vertical-align:.18em}
.hero-title .stroke{display:block;color:var(--ink-ghost);font-size:.24em;letter-spacing:.06em;font-weight:400;margin-top:.42em;line-height:1.3}
.hero-aside{border-left:1px solid var(--line);padding:6px 0 6px 22px;font-size:14.5px;color:var(--ink-soft);max-width:540px}
.hero-aside .lede{font-family:var(--serif);font-size:18px;line-height:1.45;color:var(--ink);margin-bottom:14px}
.hero-aside .meta-row{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:14px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line-soft)}

.section-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink);margin-bottom:32px}
@media (max-width:680px){.section-tabs{grid-template-columns:1fr}}
.tab{position:relative;padding:24px 22px;background:var(--bg-card);text-align:left;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:18px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);overflow:hidden}
.tab::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:transparent;transform:scaleX(0);transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);transform-origin:left}
.tab:hover{background:var(--bg-deep)}
.tab[data-cat="artist"].is-active{background:var(--shu);color:#fff}
.tab[data-cat="character"].is-active{background:var(--gun);color:#fff}
.tab[data-cat="general"].is-active{background:var(--moku);color:#fff}
.tab.is-active::after{transform:scaleX(1);background:#fff}
.tab-num{font-family:var(--serif);font-size:42px;font-weight:300;line-height:1;opacity:.85}
.tab-label .tab-jp{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1;letter-spacing:.04em}
.tab-label .tab-en{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-top:8px;opacity:.75}

.panel{background:rgba(251,246,236,.68);border:1px solid var(--line);box-shadow:var(--shadow);backdrop-filter:blur(2px)}
.search-section{margin-bottom:26px;padding:20px 22px 18px}
.search-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:18px}
.search-meta .count{color:var(--shu);font-weight:500}
.mode-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.mode-pill{padding:8px 12px;border:1px solid var(--line);background:var(--bg-card);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease)}
.mode-pill.is-active{border-color:var(--ink);background:var(--ink);color:var(--bg)}
.mode-note{font-size:12.5px;color:var(--ink-soft)}
.search-bar{display:flex;align-items:stretch;border:1px solid var(--ink);background:var(--bg-card);position:relative}
.search-bar::before{content:"";position:absolute;inset:6px;border:1px solid var(--line);pointer-events:none}
.search-prefix{padding:0 22px;display:grid;place-items:center;font-family:var(--serif);font-size:22px;font-weight:500;border-right:1px solid var(--ink);background:var(--ink);color:var(--bg);min-width:120px;text-align:center}
.search-stack{position:relative;flex:1;min-width:0}
#searchInput{width:100%;padding:22px 22px;background:transparent;border:0;outline:0;font-family:var(--serif);font-size:24px;color:var(--ink);letter-spacing:.005em}
#searchInput::placeholder{color:var(--ink-ghost);font-style:italic}
.search-btn{padding:0 28px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);border-left:1px solid var(--line);transition:background var(--dur) var(--ease),color var(--dur) var(--ease);display:flex;align-items:center;gap:10px;white-space:nowrap}
.search-btn:hover{background:var(--ink);color:var(--bg)}
.search-btn .arrow{font-family:var(--serif);font-size:18px;letter-spacing:0}
.action-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.mini-btn,.text-btn,.load-more-btn{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase}
.mini-btn{padding:10px 14px;border:1px solid var(--line);background:var(--bg-card);transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease)}
.mini-btn:hover{border-color:var(--ink);background:var(--bg-soft)}
.mini-btn.primary{background:var(--ink);border-color:var(--ink);color:var(--bg)}
.mini-btn.primary:hover{background:var(--shu);border-color:var(--shu)}
.search-hint{margin-top:14px;font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:18px}
.search-hint.compact{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase}
.suggestions{position:absolute;left:0;right:0;top:100%;z-index:8;border:1px solid var(--ink);border-top:0;background:var(--bg-card);display:none;max-height:360px;overflow:auto;box-shadow:var(--shadow)}
.suggestions.show{display:block}
.suggestion-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:12px 14px;border-top:1px solid var(--line-soft);cursor:pointer;transition:background var(--dur) var(--ease)}
.suggestion-item:first-child{border-top:0}
.suggestion-item:hover{background:var(--bg-soft)}
.suggestion-main{min-width:0}
.suggestion-name{font-family:var(--serif);font-size:18px;color:var(--accent,var(--ink));word-break:break-word}
.suggestion-meta{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:10px;margin-top:3px}
.suggestion-actions{display:flex;gap:8px;align-items:start}
.icon-btn{padding:7px 10px;border:1px solid var(--line);background:transparent;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.icon-btn:hover{background:var(--bg-deep);border-color:var(--ink)}

.atelier-layout{display:grid;grid-template-columns:minmax(0,1.32fr) minmax(340px,.88fr);gap:24px;align-items:start}
@media (max-width:1080px){.atelier-layout{grid-template-columns:1fr}}
.main-pane,.side-pane{display:grid;gap:24px}
.toolbar-panel{padding:16px 18px}
.toolbar-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media (max-width:860px){.toolbar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:520px){.toolbar-grid{grid-template-columns:1fr}}
.field-inline{display:grid;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.field-inline select,.field-inline input{padding:12px 12px;border:1px solid var(--line);background:var(--bg-card);font-family:var(--mono);font-size:12px;color:var(--ink)}
.field-check{align-content:center}
.field-check input{accent-color:var(--ink)}
.subtle-inline{margin-left:auto}
@media (max-width:640px){.subtle-inline{margin-left:0}}

.results-panel{padding:22px}
.results{position:relative;min-height:280px}
.state{padding:72px 24px;display:grid;place-items:center;text-align:center;gap:18px;border:1px dashed var(--line);background:var(--bg-card)}
.state .glyph{font-family:var(--serif);font-size:96px;line-height:1;color:var(--ink-ghost)}
.state .title{font-family:var(--serif);font-size:22px;color:var(--ink)}
.state .sub{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);max-width:760px;white-space:pre-wrap;text-align:left;line-height:1.7}
.state.error .glyph,.state.error .title{color:var(--shu)}
.spinner{width:24px;height:24px;border:1.5px solid var(--line);border-top-color:var(--ink);border-radius:50%;animation:spin .9s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

.tag-list{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
.tag-row{display:grid;grid-template-columns:54px minmax(0,1fr) auto auto;align-items:center;gap:18px;padding:18px 14px;border-bottom:1px solid var(--line-soft);position:relative;transition:background var(--dur) var(--ease),padding var(--dur) var(--ease)}
@media (max-width:780px){.tag-row{grid-template-columns:48px minmax(0,1fr);grid-template-areas:"num name" "meta meta";gap:12px 16px}.tag-actions-inline{grid-area:meta;justify-content:space-between;width:100%}.tag-count{min-width:84px}}
.tag-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background var(--dur) var(--ease)}
.tag-row:hover{background:var(--bg-card);padding-left:22px}.tag-row:hover::before{background:var(--accent,var(--ink))}
.tag-row.cat-1{--accent:var(--shu)} .tag-row.cat-3{--accent:var(--murasaki)} .tag-row.cat-4{--accent:var(--gun)} .tag-row.cat-0{--accent:var(--moku)} .tag-row.cat-5{--accent:var(--yamabuki)}
.tag-num{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.1em}
.tag-name{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--accent,var(--ink));letter-spacing:.005em;word-break:break-word}
.tag-name .underscore{color:var(--ink-ghost)}
.tag-cat-chip{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--accent,var(--ink));color:var(--accent,var(--ink));background:transparent}
.tag-count{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);text-align:right}
.tag-count .label{font-size:10px;color:var(--ink-faint);letter-spacing:.18em;text-transform:uppercase;display:block;margin-top:2px}
.tag-actions-inline{display:flex;align-items:center;gap:10px}

.posts-header{display:grid;grid-template-columns:1fr auto;align-items:end;gap:24px;padding-bottom:18px;border-bottom:1px solid var(--ink);margin-bottom:28px}
@media (max-width:720px){.posts-header{grid-template-columns:1fr}}
.posts-header .crumb{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.posts-header .crumb button{font-family:inherit;font-size:inherit;letter-spacing:inherit;color:var(--shu);text-transform:inherit;border-bottom:1px solid currentColor;padding-bottom:1px}
.posts-header h2{font-family:var(--serif);font-size:clamp(34px,4vw,54px);font-weight:500;line-height:1.05;word-break:break-word}
.posts-header .count-pill{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);text-align:right;white-space:nowrap}
.posts-header .count-pill strong{display:block;font-size:32px;color:var(--ink);font-family:var(--serif);font-weight:500;letter-spacing:0;margin-bottom:2px}

.posts-grid{column-count:3;column-gap:24px}
@media (max-width:1100px){.posts-grid{column-count:2}}
@media (max-width:640px){.posts-grid{column-count:1}}
.post-card{display:block;break-inside:avoid;margin-bottom:24px;background:var(--bg-card);border:1px solid var(--line);cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);position:relative;overflow:hidden}
.post-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px -16px rgba(26,20,16,.32)}
.post-card .img-wrap{position:relative;background:var(--bg-deep);overflow:hidden}
.post-card .img-wrap::before{content:"";display:block;padding-top:var(--ar,100%)}
.post-card img,.post-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s var(--ease);background:var(--bg-deep)}
.post-card img.loaded,.post-card video.loaded{opacity:1}
.post-card .placeholder{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:14px;color:var(--ink-faint);letter-spacing:.1em}
.post-card .meta{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint)}
.post-card .meta .id{color:var(--ink)}
.post-card .meta .ext{padding:2px 8px;border:1px solid var(--line);color:var(--ink-soft)}
.post-card .badge{position:absolute;top:10px;left:10px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;padding:4px 8px;background:rgba(26,20,16,.78);color:var(--bg);z-index:2}
.load-more-wrap{margin-top:16px;display:flex;justify-content:center}
.load-more-btn{padding:14px 24px;border:1px solid var(--ink);background:var(--bg-card);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.load-more-btn:hover{background:var(--ink);color:var(--bg)}

.side-card{padding:18px}
.side-head{display:flex;align-items:start;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:16px}
.side-head h3{font-family:var(--serif);font-size:28px;font-weight:500;line-height:1.05}
.side-head .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px;line-height:1.6}
.kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--shu)}
.composer-tools{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.composer-columns{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}
.lane-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px}
.tag-chip-lane{min-height:72px;border:1px dashed var(--line);padding:10px;background:var(--bg-card);display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start}
.tag-chip-lane.empty-lane::before{content:"No tags yet";font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-ghost)}
.composer-chip{display:flex;align-items:stretch;gap:0;border:1px solid var(--accent);background:rgba(255,255,255,.44);min-width:0}
.composer-chip.cat-1{--accent:var(--shu)} .composer-chip.cat-3{--accent:var(--murasaki)} .composer-chip.cat-4{--accent:var(--gun)} .composer-chip.cat-0{--accent:var(--moku)} .composer-chip.cat-5{--accent:var(--yamabuki)} .composer-chip.cat-x{--accent:var(--ink)}
.composer-chip .chip-name{padding:8px 10px;font-family:var(--mono);font-size:11px;line-height:1.35;color:var(--accent);display:flex;align-items:center;gap:8px;min-width:0}
.composer-chip .chip-name strong{font-weight:500;word-break:break-word}
.composer-chip .chip-controls{display:flex;border-left:1px solid var(--accent)}
.composer-chip .chip-controls button{min-width:30px;padding:0 8px;color:var(--accent);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.composer-chip .chip-controls button:hover{background:var(--accent);color:var(--bg)}
.weight-pill,.pin-pill,.neg-pill{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;border:1px solid currentColor;font-size:9px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}
.prompt-block{margin-top:14px}
.prompt-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}
.prompt-output{width:100%;min-height:74px;border:1px solid var(--line);background:var(--bg-card);padding:12px 14px;resize:vertical;font-family:var(--mono);font-size:12px;line-height:1.55}
.text-btn{color:var(--shu);border-bottom:1px solid currentColor;padding-bottom:1px}

.related-wrap{display:grid;gap:14px}
.related-group{padding-top:4px}
.related-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--accent)}
.related-group.cat-1{--accent:var(--shu)} .related-group.cat-3{--accent:var(--murasaki)} .related-group.cat-4{--accent:var(--gun)} .related-group.cat-0{--accent:var(--moku)} .related-group.cat-5{--accent:var(--yamabuki)}
.related-group-head .name{font-family:var(--serif);font-size:17px;color:var(--accent)}
.related-group-head .count{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.related-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.related-chip{display:flex;align-items:center;gap:8px;padding:6px 9px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-family:var(--mono);font-size:11px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.related-chip:hover{background:var(--accent);color:var(--bg)}
.related-chip small{opacity:.7}

.wiki-search-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:14px}
.wiki-search-row input{padding:12px 14px;border:1px solid var(--line);background:var(--bg-card);font-family:var(--mono);font-size:12px}
.wiki-results,.wiki-active{display:grid;gap:10px}
.wiki-result-item{padding:12px 14px;border:1px solid var(--line);background:var(--bg-card);transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.wiki-result-item:hover{border-color:var(--ink);transform:translateY(-1px)}
.wiki-result-title{font-family:var(--serif);font-size:19px;color:var(--ink);margin-bottom:4px}
.wiki-result-meta{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.wiki-result-desc{font-size:13px;color:var(--ink-soft);margin-top:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.wiki-group-card{border:1px solid var(--line);background:var(--bg-card);padding:14px}
.wiki-group-card h4{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:4px}
.wiki-section{padding-top:12px;margin-top:12px;border-top:1px solid var(--line-soft)}
.wiki-section-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.wiki-section-head .title{font-family:var(--serif);font-size:18px}
.wiki-section-head .meta{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.wiki-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.wiki-chip{display:inline-flex;align-items:center;padding:6px 9px;border:1px solid var(--line);font-family:var(--mono);font-size:11px;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease)}
.wiki-chip:hover{border-color:var(--ink);background:var(--bg-soft)}
.bulk-actions{display:flex;flex-wrap:wrap;gap:8px}

.colophon{margin-top:52px;padding-top:24px;border-top:1px solid var(--ink);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}
.colophon .marks{display:flex;gap:18px;flex-wrap:wrap}.colophon strong{color:var(--ink);font-weight:500}

.modal{position:fixed;inset:0;z-index:50;background:rgba(20,16,12,.6);display:none;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.modal.is-open{display:flex;animation:fadeIn .25s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-card{background:var(--bg);border:1px solid var(--ink);width:100%;max-width:560px;max-height:90vh;overflow:auto;position:relative;animation:slideUp .35s var(--ease)}
.modal-card.wide{max-width:1120px}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-head{padding:24px 28px 18px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:18px}
.modal-head h3{font-family:var(--serif);font-size:28px;font-weight:500;line-height:1.1}
.modal-head .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px}
.close-btn{width:36px;height:36px;border:1px solid var(--ink);display:grid;place-items:center;font-family:var(--serif);font-size:18px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);flex-shrink:0}
.close-btn:hover{background:var(--ink);color:var(--bg)}
.modal-body{padding:24px 28px}.modal-body label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px}
.modal-body input[type=text],.modal-body input[type=password]{width:100%;padding:14px 16px;border:1px solid var(--ink);background:var(--bg-card);font-family:var(--mono);font-size:13px;outline:0;margin-bottom:18px;transition:border-color var(--dur) var(--ease)}
.modal-body input:focus{border-color:var(--shu)}
.modal-body .help{font-size:12.5px;color:var(--ink-soft);line-height:1.65;margin-bottom:18px}
.modal-body .help code{font-family:var(--mono);font-size:12px;padding:2px 6px;background:var(--bg-card);border:1px solid var(--line-soft)}
.modal-body .row{display:flex;gap:12px;align-items:center;margin-top:8px}
.modal-body .btn-primary{padding:14px 22px;background:var(--ink);color:var(--bg);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;flex:1;transition:background var(--dur) var(--ease)}
.modal-body .btn-primary:hover{background:var(--shu)}
.modal-body .btn-ghost{padding:14px 22px;background:transparent;color:var(--ink-soft);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--line)}
.modal-body .btn-ghost:hover{color:var(--shu);border-color:var(--shu)}

.post-detail{display:grid;grid-template-columns:1fr;max-height:90vh;overflow:hidden}
@media (min-width:900px){.post-detail{grid-template-columns:1.22fr 1fr}}
.post-image{background:#0a0807;display:grid;place-items:center;position:relative;min-height:300px;max-height:90vh;overflow:auto}
.post-image img,.post-image video{max-width:100%;max-height:90vh;width:auto;height:auto;object-fit:contain}
.post-image .open-original{position:absolute;top:14px;right:14px;padding:8px 14px;background:rgba(255,255,255,.92);color:var(--ink);font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;transition:background var(--dur) var(--ease)}
.post-image .open-original:hover{background:#fff}
.post-side{padding:28px;background:var(--bg);overflow-y:auto;max-height:90vh}
.post-side .post-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 20px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.post-side .post-meta .item .label{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px}
.post-side .post-meta .item .value{font-family:var(--serif);font-size:16px;color:var(--ink);word-break:break-word}
.tag-group{margin-bottom:22px}.tag-group-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--accent)}
.tag-group.g-1{--accent:var(--shu)} .tag-group.g-3{--accent:var(--murasaki)} .tag-group.g-4{--accent:var(--gun)} .tag-group.g-0{--accent:var(--moku)} .tag-group.g-5{--accent:var(--yamabuki)}
.tag-group-head .name{font-family:var(--serif);font-weight:600;font-size:14px;color:var(--accent);letter-spacing:.05em}.tag-group-head .name .jp{font-size:16px;margin-right:6px}
.tag-group-head .num{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}
.tag-chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-family:var(--mono);font-size:11.5px;padding:5px 10px;border:1px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);word-break:break-word;line-height:1.3}
.chip:hover{background:var(--accent);color:var(--bg)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--bg);padding:14px 22px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;z-index:100;opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);border-left:3px solid var(--shu);max-width:min(90vw,720px)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.hidden{display:none !important}
.muted-note{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}

@media (max-width:640px){
  .search-bar{flex-direction:column}
  .search-prefix{min-width:unset;border-right:0;border-bottom:1px solid var(--ink);padding:16px 22px}
  .search-btn{border-left:0;border-top:1px solid var(--line);justify-content:center;padding:16px 22px}
  .results-panel{padding:16px}
  .side-card{padding:16px}
  .modal-body .row{flex-direction:column}
}
