/* ============================================================
   Tabika 2.0 — 和風ミニマル design system
   ============================================================ */
:root{
  --paper:#FAF7F1; --paper2:#F2EDE2; --card:#FFFFFF;
  --ink:#26221B; --ink2:#6E6557; --ink3:#A29887;
  --line:#E7DFCF; --line2:#D9CEB9;
  --shu:#B84A32; --shu-soft:#F6E4DD; --shu-deep:#9A3A26;
  --ai:#39586B;  --ai-soft:#E4ECF0;
  --matcha:#5F7A4E; --matcha-soft:#E9EEE1;
  --kin:#A8823F; --kin-soft:#F4ECD9;
  --murasaki:#6E5687; --murasaki-soft:#ECE5F2;
  --serif:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP","Noto Serif SC","Songti SC","SimSun",serif;
  --sans:"Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic Medium","Yu Gothic","PingFang SC","Noto Sans JP","Noto Sans SC","Microsoft YaHei",sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --rad:12px; --rad-s:8px;
  --shadow:0 1px 2px rgba(38,34,27,.05),0 10px 28px -14px rgba(38,34,27,.14);
  --maxw:1120px;
}
[data-theme="dark"]{
  --paper:#1A1814; --paper2:#211E18; --card:#242019;
  --ink:#EAE3D4; --ink2:#ABA08C; --ink3:#7C7263;
  --line:#373228; --line2:#464034;
  --shu:#D0674E; --shu-soft:#3B2721; --shu-deep:#E07B62;
  --ai:#7FA3B8;  --ai-soft:#232D33;
  --matcha:#8FAA7C; --matcha-soft:#272D21;
  --kin:#C4A25F; --kin-soft:#332C1D;
  --murasaki:#A48BC0; --murasaki-soft:#2C2533;
  --card:#242019;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 28px -14px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  line-height:1.75;font-size:16px;transition:background .25s,color .25s}
img{max-width:100%}
a{color:var(--ai);text-decoration:none}
a:hover{color:var(--shu)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.4;margin:0 0 .5em}
p{margin:.4em 0 1em}
::selection{background:var(--shu-soft)}

/* ---------- ruby 注音 ---------- */
ruby{ruby-position:over}
rt{font-size:.52em;color:var(--ink2);font-family:var(--sans);font-weight:400;letter-spacing:.02em;user-select:none}
body.hide-ruby rt{visibility:hidden}
body.hide-cn .cn{filter:blur(5px);cursor:pointer;transition:filter .15s;border-radius:4px}
body.hide-cn .cn:hover,body.hide-cn .cn:active{filter:none}
.roma{font-family:var(--mono);font-size:.82em;color:var(--ink3);letter-spacing:.02em}
.jp{line-height:2.1}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
main{min-height:60vh;padding-bottom:72px}
section{margin:44px 0}

/* ---------- header ---------- */
#hdr{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr-in{max-width:var(--maxw);margin:0 auto;padding:0 22px;display:flex;align-items:center;gap:18px;height:60px}
.logo{display:flex;align-items:center;gap:10px;color:var(--ink);flex-shrink:0}
.logo:hover{color:var(--ink)}
.seal{width:36px;height:36px;background:var(--shu);color:#FBF6EE;border-radius:9px;
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);
  font-size:20px;font-weight:700;box-shadow:inset 0 0 0 1.5px rgba(251,246,238,.35)}
.logo b{font-family:var(--serif);font-size:19px;letter-spacing:.04em}
.logo small{display:block;font-size:10.5px;color:var(--ink3);letter-spacing:.14em;line-height:1;margin-top:2px}
nav.main{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;flex:1}
nav.main::-webkit-scrollbar{display:none}
nav.main a{padding:7px 11px;border-radius:8px;font-size:14.5px;color:var(--ink2);white-space:nowrap}
nav.main a:hover{background:var(--paper2);color:var(--ink)}
nav.main a.on{color:var(--shu);font-weight:600;position:relative}
nav.main a.on::after{content:"";position:absolute;left:11px;right:11px;bottom:2px;height:2px;background:var(--shu);border-radius:2px}
.hdr-tools{display:flex;gap:6px;flex-shrink:0}
.tgl{border:1px solid var(--line2);background:var(--card);color:var(--ink2);border-radius:99px;
  padding:4px 11px;font-size:12.5px;cursor:pointer;font-family:var(--sans);transition:all .15s;white-space:nowrap}
.tgl:hover{border-color:var(--ink3)}
.tgl[aria-pressed="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- page head / hero ---------- */
.page-head{padding:46px 0 8px}
.kicker{font-family:var(--serif);color:var(--shu);letter-spacing:.35em;font-size:13.5px;margin-bottom:10px}
.page-head h1{font-size:clamp(28px,4.5vw,40px);letter-spacing:.03em}
.page-head .desc{color:var(--ink2);max-width:640px;font-size:15.5px}
.hero{padding:64px 0 40px;position:relative}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(var(--line2) 1px,transparent 1.5px);background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,transparent);mask-image:linear-gradient(180deg,transparent,#000 30%,transparent)}
.hero h1{font-size:clamp(34px,6vw,56px);letter-spacing:.04em;line-height:1.3}
.hero .accent{color:var(--shu)}
.tate{writing-mode:vertical-rl;font-family:var(--serif);letter-spacing:.3em;color:var(--ink3);
  font-size:13px;position:absolute;right:6px;top:70px;height:200px;border-right:1px solid var(--line2);padding-right:10px}
@media(max-width:760px){.tate{display:none}}

/* ---------- cards & grids ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:22px 24px;box-shadow:var(--shadow)}
.grid2{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid3{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid4{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
a.card{color:var(--ink);transition:transform .15s,border-color .15s}
a.card:hover{transform:translateY(-3px);border-color:var(--line2);color:var(--ink)}
.card .ic{font-size:26px;line-height:1;margin-bottom:10px}
.card h3{font-size:17.5px;margin-bottom:4px}
.card .sub{color:var(--ink2);font-size:13.5px;margin:0}

/* ---------- section titles ---------- */
.sec-title{display:flex;align-items:baseline;gap:12px;margin:0 0 18px;font-size:24px}
.sec-title::before{content:"";width:5px;height:24px;background:var(--shu);border-radius:3px;align-self:center;flex-shrink:0}
.sec-title small{font-family:var(--sans);font-size:13px;color:var(--ink3);font-weight:400;letter-spacing:.06em}

/* ---------- badges / chips ---------- */
.lv{display:inline-flex;align-items:center;font-size:11.5px;font-weight:700;border-radius:6px;
  padding:1px 8px;letter-spacing:.05em;vertical-align:2px}
.lv.n5{background:var(--matcha-soft);color:var(--matcha)}
.lv.n4{background:var(--ai-soft);color:var(--ai)}
.lv.n3{background:var(--kin-soft);color:var(--kin)}
.lv.n2{background:var(--shu-soft);color:var(--shu)}
.lv.n1{background:var(--murasaki-soft);color:var(--murasaki)}
.freq{color:var(--kin);font-size:12px;letter-spacing:2px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.chip{border:1px solid var(--line2);background:var(--card);color:var(--ink2);border-radius:99px;
  padding:5px 14px;font-size:13.5px;cursor:pointer;font-family:var(--sans);transition:all .12s}
.chip:hover{border-color:var(--ink3);color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tag{display:inline-block;font-size:11.5px;color:var(--ink3);border:1px solid var(--line);border-radius:5px;padding:0 6px}

/* ---------- callouts ---------- */
.note,.tip,.warn{border-radius:var(--rad-s);padding:14px 18px;margin:16px 0;font-size:14.5px;border-left:4px solid}
.note{background:var(--ai-soft);border-color:var(--ai)}
.tip{background:var(--matcha-soft);border-color:var(--matcha)}
.warn{background:var(--shu-soft);border-color:var(--shu)}
.note b:first-child,.tip b:first-child,.warn b:first-child{display:block;margin-bottom:2px}

/* ---------- tables ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:14.5px;background:var(--card);border-radius:var(--rad-s);overflow:hidden;border:1px solid var(--line)}
.tbl th{background:var(--paper2);font-family:var(--serif);font-weight:600;text-align:left;padding:10px 14px;font-size:13.5px;letter-spacing:.05em}
.tbl td{padding:10px 14px;border-top:1px solid var(--line);vertical-align:top}
.tbl-wrap{overflow-x:auto;margin:14px 0;border-radius:var(--rad-s)}

/* ---------- buttons / inputs ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line2);background:var(--card);
  color:var(--ink);border-radius:9px;padding:9px 18px;font-size:14.5px;cursor:pointer;font-family:var(--sans);transition:all .15s}
.btn:hover{border-color:var(--ink3);transform:translateY(-1px)}
.btn.primary{background:var(--shu);border-color:var(--shu);color:#FBF6EE}
.btn.primary:hover{background:var(--shu-deep);border-color:var(--shu-deep);color:#FBF6EE}
.search{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line2);
  border-radius:11px;padding:10px 16px;margin:14px 0}
.search input{border:0;outline:0;background:none;flex:1;font-size:15.5px;color:var(--ink);font-family:var(--sans)}
.search input::placeholder{color:var(--ink3)}
.spk{border:0;background:none;cursor:pointer;font-size:15px;color:var(--ink3);padding:2px 5px;border-radius:6px;line-height:1;vertical-align:middle}
.spk:hover{color:var(--shu);background:var(--shu-soft)}

/* ---------- 例句 example block ---------- */
.ex{background:var(--paper2);border-radius:var(--rad-s);padding:12px 16px;margin:10px 0}
.ex .jp{font-size:17px;display:block}
.ex .cn{color:var(--ink2);font-size:13.5px;display:block;margin-top:2px}
.nat{display:inline-block;font-size:11px;font-weight:700;border-radius:4px;padding:0 5px;margin-left:6px;vertical-align:2px}
.nat.best{background:var(--matcha-soft);color:var(--matcha)}
.nat.ok{background:var(--ai-soft);color:var(--ai)}
.nat.formal{background:var(--kin-soft);color:var(--kin)}
.nat.bad{background:var(--shu-soft);color:var(--shu)}

/* ---------- accordion ---------- */
details.acc{background:var(--card);border:1px solid var(--line);border-radius:var(--rad-s);margin:10px 0;overflow:hidden}
details.acc summary{cursor:pointer;padding:14px 18px;font-weight:600;list-style:none;display:flex;align-items:center;gap:10px;font-size:15.5px}
details.acc summary::-webkit-details-marker{display:none}
details.acc summary::after{content:"＋";margin-left:auto;color:var(--ink3);font-size:15px;transition:transform .2s}
details.acc[open] summary::after{content:"−"}
details.acc .acc-body{padding:2px 18px 16px;border-top:1px dashed var(--line)}

/* ---------- dialogue 对话 ---------- */
.dlg{display:flex;flex-direction:column;gap:12px;margin:16px 0}
.dlg .line{display:flex;gap:12px;align-items:flex-start}
.dlg .who{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:700;font-size:14px;margin-top:4px}
.dlg .who.a{background:var(--shu-soft);color:var(--shu)}
.dlg .who.b{background:var(--ai-soft);color:var(--ai)}
.dlg .bub{background:var(--card);border:1px solid var(--line);border-radius:4px 14px 14px 14px;padding:10px 16px;max-width:640px}
.dlg .bub .jp{font-size:16.5px;display:block}
.dlg .bub .cn{color:var(--ink2);font-size:13px;display:block;margin-top:2px}

/* ---------- kana 五十音 ---------- */
.kana-tbl{display:grid;gap:6px;margin:18px 0}
.kana-cell{background:var(--card);border:1px solid var(--line);border-radius:10px;text-align:center;
  padding:9px 2px 7px;cursor:pointer;transition:all .12s;user-select:none;min-width:0}
.kana-cell:hover{border-color:var(--shu);transform:translateY(-2px);box-shadow:var(--shadow)}
.kana-cell.empty{visibility:hidden}
.kana-cell .k{font-size:24px;font-family:var(--serif);line-height:1.25;display:block}
.kana-cell .r{font-size:11px;color:var(--ink3);font-family:var(--mono);display:block}
.kana-cell.hd{background:none;border:0;cursor:default;color:var(--ink3);font-size:12px;display:flex;align-items:center;justify-content:center}
.kana-cell.hd:hover{transform:none;box-shadow:none}

/* ---------- vocab 词汇卡 ---------- */
.vlist{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin:18px 0}
.vcard{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 16px 9px;display:flex;flex-direction:column}
.vcard .w{font-size:20px;font-family:var(--serif);line-height:2;overflow-wrap:anywhere}
.vcard .cn{font-size:13.5px;color:var(--ink2);margin-top:2px;flex:1;line-height:1.6}
.vcard .foot{display:flex;align-items:center;gap:8px;margin-top:8px;border-top:1px dashed var(--line);padding-top:6px}
.vcard .foot .spk{margin-left:auto}
.root-group{margin:20px 0}
.root-head{display:flex;align-items:baseline;gap:12px;border-bottom:2px solid var(--line2);padding-bottom:6px;margin-bottom:12px}
.root-head .rk{font-size:26px;font-family:var(--serif);color:var(--shu)}
.root-head .rm{color:var(--ink2);font-size:13.5px}

/* ---------- flashcard ---------- */
.flash{max-width:420px;margin:20px auto;perspective:1000px}
.flash-card{background:var(--card);border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow);
  min-height:230px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;padding:26px;text-align:center}
.flash-card .big{font-size:40px;font-family:var(--serif);line-height:1.8}
.flash-ans{color:var(--ink2)}

/* ---------- quiz ---------- */
.quiz-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}
.quiz-opts .btn{justify-content:center;font-size:17px;padding:13px}
.quiz-opts .btn.right{background:var(--matcha-soft);border-color:var(--matcha);color:var(--matcha)}
.quiz-opts .btn.wrong{background:var(--shu-soft);border-color:var(--shu);color:var(--shu)}
.quiz-q{font-size:64px;font-family:var(--serif);text-align:center;margin:10px 0}

/* ---------- steps / path ---------- */
.path{counter-reset:step;padding:0;margin:12px 0;list-style:none}
.path li{counter-increment:step;display:flex;gap:12px;padding:7px 0;align-items:baseline}
.path li::before{content:counter(step);flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:var(--paper2);border:1px solid var(--line2);color:var(--ink2);font-size:12px;
  display:inline-flex;align-items:center;justify-content:center;transform:translateY(3px)}

/* ---------- stats ---------- */
.stats{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--rad-s);padding:14px 22px;text-align:center;flex:1;min-width:120px}
.stat b{display:block;font-size:26px;font-family:var(--serif);color:var(--shu)}
.stat span{font-size:12.5px;color:var(--ink2)}

/* ---------- misc ---------- */
.muted{color:var(--ink2)}.small{font-size:13.5px}
.center{text-align:center}
hr.wave{border:0;height:1px;background:var(--line2);margin:36px 0}
kbd.pt{font-family:var(--serif);background:var(--paper2);border:1px solid var(--line2);border-radius:6px;padding:1px 8px;font-size:.92em}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.count-note{font-size:13px;color:var(--ink3);margin:4px 0 14px}

/* ---------- footer ---------- */
#ftr{border-top:1px solid var(--line);background:var(--paper2);padding:30px 0 40px;margin-top:40px}
#ftr .wrap{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
#ftr .muted{font-size:13px}
#ftr nav{display:flex;flex-wrap:wrap;gap:14px;font-size:13.5px}

@media(max-width:640px){
  body{font-size:15px}
  .hdr-in{gap:10px;padding:0 14px}
  .logo b{font-size:17px}.logo small{display:none}
  .wrap{padding:0 16px}
  .kana-cell .k{font-size:19px}
  .quiz-q{font-size:52px}
  .card{padding:18px}
  .hdr-tools .tgl{padding:4px 8px;font-size:11.5px}
}
