/* Tsumugu Dictionary — Paper & Ink (direction B, accepted 2026-06-12) */
:root{
  --paper:#f7f3ea; --card:#fbf8f1; --ink:#211d18; --mut:#6e675c; --faint:#a59d8e;
  --rule:#d8d1c2; --rule2:#c9c1af; --seal:#b25a44; --seal-soft:rgba(178,90,68,.08);
  --shadow:rgba(33,29,24,.35);
  --radius: 8px;
  --ming:"Songti TC","Noto Serif TC","Source Han Serif TC",Georgia,serif;
  --kai:"Kaiti TC","Kaiti SC",STKaiti,BiauKai,serif;
  --sans:Inter,-apple-system,"Helvetica Neue",sans-serif;
  --mono:"SF Mono",ui-monospace,Menlo,monospace;
}
[data-theme="dark"]{
  --paper:#17150f; --card:#1d1a13; --ink:#eae3d4; --mut:#9d957f; --faint:#6b6451;
  --rule:#373226; --rule2:#46402f; --seal:#cd7a62; --seal-soft:rgba(205,122,98,.1);
  --shadow:rgba(0,0,0,.6);
}
*{margin:0;padding:0;box-sizing:border-box}
html{background:var(--paper)}
body{background:var(--paper);color:var(--ink);font-family:var(--ming);-webkit-font-smoothing:antialiased;transition:background .25s,color .25s;display:flex;flex-direction:column;min-height:100vh}
a{color:inherit}
.wrap{max-width:880px;margin:0 auto;padding:0 28px}

nav{display:flex;align-items:baseline;gap:26px;padding:34px 0 26px;border-bottom:1px solid var(--ink);flex-wrap:wrap}
.wordmark{font-family:var(--sans);font-weight:700;font-size:19px;text-decoration:none}
.wordmark span{color:var(--seal)}
.navlinks{display:flex;gap:24px;font-family:var(--sans);font-size:14px;color:var(--mut)}
.navlinks a{text-decoration:none}
.navlinks a:hover{color:var(--seal)}
.spacer{flex:1}
.theme{font-family:var(--sans);font-size:13.5px;color:var(--mut);background:none;border:1px solid var(--rule2);border-radius:999px;padding:5px 14px;cursor:pointer}
.theme:hover{color:var(--seal);border-color:var(--seal)}
.free{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}

/* search */
.bigsearch{position:relative;margin:0 auto;max-width:640px}
.sbox{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--rule2);border-radius:18px;padding:8px 8px 8px 22px;box-shadow:0 14px 36px -24px var(--shadow);transition:border-color .2s}
.sbox:focus-within{border-color:var(--seal);box-shadow:0 14px 36px -22px var(--shadow),0 0 0 4px var(--seal-soft)}
.sbox input{flex:1;background:none;border:none;outline:none;font-family:var(--ming);font-size:19px;color:var(--ink);min-width:0}
.sbox input::placeholder{color:var(--faint)}
.sbox button{font-family:var(--kai);font-size:17px;color:var(--paper);background:var(--seal);border:none;border-radius:12px;padding:11px 22px;cursor:pointer;letter-spacing:.1em;opacity:.95}
.sresults{position:absolute;left:0;right:0;top:calc(100% + 8px);background:var(--card);border:1px solid var(--rule2);border-radius:12px;box-shadow:0 20px 50px -20px var(--shadow);max-height:340px;overflow-y:auto;z-index:50;display:none}
.sresults.on{display:block}
.srow{display:flex;gap:14px;align-items:baseline;padding:10px 18px;border-bottom:1px dotted var(--rule);text-decoration:none}
.srow:last-child{border-bottom:none}
.srow:hover,.srow.sel{background:var(--seal-soft)}
.srow .h{font-family:var(--kai);font-size:20px}
.srow .r{font-family:var(--sans);font-size:11.5px;color:var(--seal)}
.srow .g{font-family:var(--sans);font-size:11.5px;color:var(--mut);margin-left:auto;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:50%}
.snone{padding:12px 18px;font-family:var(--sans);font-size:12.5px;color:var(--faint)}

/* entry page — layout per dict-demo, reskinned Paper & Ink */
:root{--r-meaning:#b25a44;--r-sound:#46698c;--r-form:#6e675c;--r-empty:#a59d8e}
[data-theme="dark"]{--r-meaning:#cd7a62;--r-sound:#7d9cbf;--r-form:#9d957f;--r-empty:#6b6451}
.crumb{font-family:var(--sans);font-size:12.5px;color:var(--faint);margin:26px 0 0}
.crumb a{text-decoration:none}
.crumb a:hover{color:var(--seal)}
.entry{margin:14px 0 0;border:1px solid var(--rule);background:var(--card);padding:42px 48px;position:relative;box-shadow:0 1px 0 var(--rule),0 24px 60px -40px var(--shadow);border-radius:var(--radius)}
.folio{position:absolute;top:16px;right:20px;font-family:var(--mono);font-size:9.5px;color:var(--faint);letter-spacing:.12em;text-transform:uppercase}
.ehead{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}
.term{font-family:var(--kai);font-size:64px;line-height:1}
.reading{font-family:var(--sans);font-size:14.5px;color:var(--mut)}
.emeta{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}
.compose{margin-top:12px;font-family:var(--kai);font-size:17px;color:var(--mut)}
.compose .c{font-size:21px;color:var(--ink)}
.compose .c.meaning{color:var(--r-meaning)}
.compose .c.sound{color:var(--r-sound)}
.compose .c.form{color:var(--r-form)}
.compose .c.empty{color:var(--r-empty)}
.compose a{text-decoration:none}
.reveal-zone{margin-top:14px;cursor:pointer;border:1px dashed var(--rule2);border-radius:8px;padding:12px 16px}
.reveal-zone .reveal-hint{font-family:var(--sans);font-size:11.5px;color:var(--faint)}
.reveal-zone .reveal-body{display:none;margin-top:10px}
.reveal-zone.peek .reveal-body,.reveal-zone.revealed .reveal-body{display:block}
.reveal-zone.peek .reveal-hint,.reveal-zone.revealed .reveal-hint{display:none}
.reveal-zone .reading{display:block;font-family:var(--sans);font-size:14.5px;color:var(--mut);margin-bottom:8px}
.defline{margin-top:4px;display:flex;gap:12px;align-items:baseline;flex-wrap:wrap}
.deftog{display:inline-flex;border:1px solid var(--rule2);border-radius:999px;overflow:hidden;font-family:var(--sans);font-size:10.5px;flex:none}
.deftog button{background:none;border:none;color:var(--mut);padding:4px 11px;cursor:pointer;font-family:inherit}
.deftog button.on{background:var(--seal-soft);color:var(--seal)}
.def-en{font-family:var(--sans);font-size:14.5px}
.def-zh{font-family:var(--kai);font-size:16.5px}
[data-def="en"] .def-zh{display:none}
[data-def="zh"] .def-en{display:none}

/* FORM + STORY duo cards */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.dcard{border:1px solid var(--rule);background:var(--paper);padding:20px 22px;border-radius:var(--radius)}
.dcard h2{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);display:flex;align-items:center;gap:9px;margin-bottom:14px;font-weight:400}
.tagchip{font-family:var(--kai);font-size:12.5px;letter-spacing:0;color:var(--paper);background:var(--seal);border-radius:4px;padding:2px 8px}
.tagchip.story{background:var(--r-form)}
.dcard h2 .sub{text-transform:none;letter-spacing:0;font-family:var(--sans);font-size:11px;color:var(--faint)}
.comp{display:flex;gap:12px;align-items:baseline;padding:5px 0;flex-wrap:wrap}
.comp .cg{font-family:var(--kai);font-size:27px;color:var(--ink);text-decoration:none}
.comp .rb{font-family:var(--kai);font-size:10.5px;color:var(--paper);border-radius:3px;padding:1px 6px;position:relative;top:-4px;background:var(--r-form)}
.comp .rb.meaning{background:var(--r-meaning)}
.comp .rb.sound{background:var(--r-sound)}
.comp .rb.empty{background:var(--r-empty)}
.comp .fn{font-family:var(--sans);font-size:12.5px;color:var(--mut)}
.comp .fn small{color:var(--faint);margin-left:6px}
.comp .cdet{font-family:var(--sans);font-size:11.5px;color:var(--faint);flex-basis:100%;padding-left:40px}
.driftrow{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:4px 0 4px 40px}
.dchip{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--paper);background:var(--r-sound);border-radius:3px;padding:2px 6px}
.dchip.grp{background:var(--seal-soft);color:var(--seal);border:1px solid var(--seal)}
.dchip.ax{background:var(--r-sound)}
.dchip.irr{background:var(--r-meaning)}
.driftnote{font-family:var(--sans);font-size:11px;color:var(--faint);margin-left:4px}
.folk{font-family:var(--mono);font-size:9px;color:var(--seal);border:1px solid var(--seal);border-radius:3px;padding:0 4px;margin-left:6px;vertical-align:middle}
.prose-zh{font-family:var(--kai);font-size:15.5px;line-height:1.9;margin-top:12px}
.prose-en{font-family:var(--sans);font-size:12.5px;line-height:1.75;color:var(--mut);margin-top:8px}
.sayline{font-family:var(--kai);font-size:16px;line-height:1.8;margin-top:10px}
.zhline{font-family:var(--kai);font-size:19px;line-height:1.85}
.zhline .meaning{color:var(--r-meaning)}
.zhline .sound{color:var(--r-sound)}
.zhline .form{color:var(--r-form)}
.gmark{display:inline-block;margin-top:14px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--mut);border:1px solid var(--rule);padding:3px 8px;background:var(--card);margin-right:6px}

.sect{margin-top:30px;border-top:1px solid var(--rule);padding-top:20px}
.slab{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--seal);margin-bottom:14px}
.slab .sub{text-transform:none;letter-spacing:0;font-family:var(--sans);font-size:11px;color:var(--faint);font-weight:400}

/* meanings tree */
.tree .node{display:flex;gap:10px;align-items:baseline;padding:4px 0;font-family:var(--sans);font-size:13px;color:var(--mut)}
.tree .node .k{font-family:var(--mono);font-size:9px;color:var(--faint)}
.tree .node .zh-s{font-family:var(--kai);font-size:16.5px;color:var(--ink)}
.tree .node.d1{padding-left:24px}
.tree .node.d2{padding-left:48px}
.tree .arrow{color:var(--seal)}
.common-tag{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;color:var(--seal);border:1px solid var(--seal);border-radius:3px;padding:1px 5px}
.notation{font-family:var(--sans);font-size:10.5px;color:var(--faint);margin-top:10px}
.mread{font-family:var(--sans);font-size:12.5px;color:var(--seal);margin:12px 0 4px}

/* examples */
.exrow{padding:10px 0;border-bottom:1px dotted var(--rule);cursor:pointer}
.exrow:last-child{border-bottom:none}
.exrow .row{display:flex;gap:12px;align-items:baseline}
.exrow .n{font-family:var(--mono);font-size:10px;color:var(--seal)}
.exrow .cn{font-family:var(--kai);font-size:18px;line-height:1.75}
.exrow .cn em{font-style:normal;color:var(--ink);border-bottom:2px solid var(--seal)}
.exrow .en{font-family:var(--sans);font-size:12px;color:var(--mut);margin:4px 0 0 24px;display:none}
.exrow .en .zhs,.exrow .en .ent{display:none}
.exrow.open .en{display:block}
.exrow.open .en .zhs{display:block;font-family:var(--kai);font-size:14px;color:var(--ink);margin-bottom:4px}
.exrow.open2 .en .ent{display:block}
.exrow:not(:has(.zhs)).open .en .ent{display:block}
.exrow .sref{font-family:var(--mono);font-size:9px;color:var(--faint);margin-left:8px}
[data-tr="always"] .exrow .en{display:block}
[data-tr="always"] .exrow .en .zhs,[data-tr="always"] .exrow .en .ent{display:block}
[data-tr="blur"] .exrow .en{display:block;filter:blur(5px);transition:filter .15s}
[data-tr="blur"] .exrow .en .zhs,[data-tr="blur"] .exrow .en .ent{display:block}
[data-tr="blur"] .exrow.open .en,[data-tr="blur"] .exrow.open2 .en{filter:none}
.exhint{font-family:var(--sans);font-size:11px;color:var(--faint);margin-bottom:10px}
.minileg{font-family:var(--sans);font-size:11px;color:var(--faint);margin-top:12px}
.trtog{float:right;display:inline-flex;border:1px solid var(--rule2);border-radius:999px;overflow:hidden;font-family:var(--sans);font-size:10px}
.trtog button{background:none;border:none;color:var(--mut);padding:3px 9px;cursor:pointer;font-family:inherit}
.trtog button.on{background:var(--seal-soft);color:var(--seal)}
.gw{border-bottom:1px dotted var(--seal);cursor:help;position:relative}
.gpop{position:absolute;left:0;bottom:calc(100% + 6px);background:var(--card);border:1px solid var(--rule2);border-radius:8px;padding:7px 11px;font-family:var(--sans);font-size:11.5px;color:var(--ink);white-space:nowrap;box-shadow:0 12px 30px -14px var(--shadow);z-index:40;display:none}
.gw.on .gpop{display:block}

/* related cards */
.rel{display:flex;gap:10px;flex-wrap:wrap}
.relc{border:1px solid var(--rule);background:var(--paper);padding:11px 15px;text-decoration:none;display:flex;flex-direction:column;gap:3px;min-width:130px;border-radius:var(--radius)}
a.relc:hover{background:var(--seal-soft)}
.relc .rg{font-family:var(--kai);font-size:21px;color:var(--ink)}
.relc .rg .shared{color:var(--seal)}
.relc .relf{font-family:var(--kai);font-size:12.5px;color:var(--mut)}
.relc .relf .shared{color:var(--seal)}
.relc .why .shared{color:var(--seal);font-family:var(--kai)}
.relc .rd{font-family:var(--sans);font-size:10.5px;color:var(--seal)}
.relc .why{font-family:var(--sans);font-size:11px;color:var(--mut)}
@media(max-width:720px){.duo{grid-template-columns:1fr}}

/* front page */
.hero{position:relative;padding:64px 0 26px;text-align:center}
.kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--seal)}
h1{font-size:42px;line-height:1.15;font-weight:600;letter-spacing:-.015em;margin-top:18px;font-family:var(--ming)}
h1 .k{font-family:var(--kai)}
.sub{margin:18px auto 36px;font-family:var(--sans);font-size:14.5px;line-height:1.7;color:var(--mut);max-width:54ch}
.quick{margin-top:16px;font-family:var(--sans);font-size:12.5px;color:var(--mut)}
.quick a{color:var(--seal);text-decoration:none;border-bottom:1px dotted var(--seal)}
.quick .sep{margin:0 12px;color:var(--faint)}
.loomline{margin:42px auto 0;max-width:560px;text-align:center}
.loom{display:flex;gap:5px}
.loom .seg{height:5px;flex:1;background:var(--rule);border-radius:2px}
.loom .seg.on{background:var(--seal)}
.loom .seg.weaving{background:repeating-linear-gradient(90deg,var(--seal) 0 5px,transparent 5px 10px);opacity:.55}
.loomcap{margin-top:12px;font-family:var(--sans);font-size:12.5px;color:var(--mut);line-height:1.6}
.loomcap b{color:var(--ink)}
.prin{padding:72px 0 30px}
.prin-h{font-size:28px;font-weight:600;text-align:center}
.prin-h .k{font-family:var(--kai);color:var(--seal)}
.prin-sub{text-align:center;font-family:var(--sans);font-size:13px;color:var(--mut);margin-top:10px;line-height:1.7}
.plist{margin-top:44px;border-top:1px solid var(--ink)}
.pitem{display:grid;grid-template-columns:52px 200px 1fr 110px;gap:20px;padding:20px 0;border-bottom:1px solid var(--rule);align-items:baseline}
.pitem .no{font-family:var(--mono);font-size:11px;color:var(--seal)}
.pitem h3{font-family:var(--sans);font-size:14.5px;font-weight:650}
.pitem p{font-family:var(--sans);font-size:12.5px;color:var(--mut);line-height:1.7}
.pitem p .k{font-family:var(--kai);color:var(--ink)}
.stat{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;text-align:right}
.stat.now{color:var(--seal)}
.stat.loom{color:var(--faint)}
.closing{text-align:center;padding:56px 0 36px}
.closing .big{font-family:var(--kai);font-size:26px;line-height:1.65}
.closing .small{margin-top:12px;font-family:var(--sans);font-size:12.5px;color:var(--mut)}
.cta{display:inline-block;margin-top:26px;font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--paper);background:var(--ink);padding:13px 32px;border-radius:2px;text-decoration:none}
.cta:hover{background:var(--seal)}

/* browse */
.bframework{margin-top:28px}
.bframe-h{font-family:var(--sans);font-size:18px;font-weight:700;border-bottom:2px solid var(--ink);padding-bottom:12px;margin-bottom:8px}
.bframe-h small{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.1em;margin-left:10px;font-weight:400}
.bband{margin-top:40px}
.bband-h{font-family:var(--sans);font-size:16px;font-weight:650;color:var(--seal);letter-spacing:.04em;margin-bottom:4px}
.bkind{margin-top:20px}
.bsec{margin-top:36px}
.bh{font-family:var(--sans);font-size:15px;font-weight:650;border-bottom:1px solid var(--ink);padding-bottom:10px}
.bh small{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.1em;margin-left:10px}
.bgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:16px;border-radius:var(--radius);overflow:hidden}
.bcell{background:var(--card);padding:12px 14px;text-decoration:none;display:block;border-radius:0}
.bcell:hover{background:var(--seal-soft)}
.bcell .g{font-family:var(--kai);font-size:23px}
.bcell .r{font-family:var(--sans);font-size:10.5px;color:var(--seal);margin-left:7px}
.bcell .e{font-family:var(--sans);font-size:10.5px;color:var(--mut);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bloom{font-family:var(--sans);font-size:12.5px;color:var(--faint);padding:14px 0}

/* prose pages */
.page{max-width:640px;margin:48px auto 0}
.page h1{font-size:30px;text-align:left;margin-top:0}
.page h2{font-size:17px;font-family:var(--sans);font-weight:650;margin:34px 0 10px}
.page p{font-family:var(--sans);font-size:14px;line-height:1.8;color:var(--mut);margin:12px 0}
.page p b,.page p .k{color:var(--ink)}
.page .k{font-family:var(--kai)}

footer{border-top:1px solid var(--ink);margin-top:auto;padding:40px 0 44px;display:flex;gap:16px;flex-wrap:wrap;font-family:var(--sans);font-size:11px;color:var(--faint)}
footer a{text-decoration:none;border-bottom:1px dotted var(--faint)}
footer a:hover{color:var(--seal)}

@media(max-width:720px){
  .entry{padding:28px 20px}
  .pitem{grid-template-columns:40px 1fr 86px}.pitem p{grid-column:2/4}
  h1{font-size:32px}.term{font-size:48px}
}

/* open head (reveal gate off by default; reveal-zone styles above kept for the future setting) */
.reveal-body .reading{display:block;margin-top:12px}

/* Chinese explanation text is opt-in: hidden while the entry is in EN mode */
[data-def="en"] .zhmeta{display:none}
.regmark{font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--mut);border:1px solid var(--rule);padding:1px 6px;background:var(--card);margin-left:8px;position:relative;top:-1px}
