
:root{--ink:#172033;--muted:#667085;--line:#dce7f5;--bg:#f7faff;--card:#fff;--blue:#1767d2;--blue2:#e8f1ff;--orange:#c66a00;--orange2:#fff4df;--shadow:0 18px 45px rgba(23,32,51,.10)}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#fff 0%,var(--bg) 56%,#eef6ff 100%);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",Meiryo,sans-serif;line-height:1.75}a{color:inherit}.site-header{position:sticky;top:0;z-index:20;display:flex;gap:14px;align-items:center;justify-content:space-between;padding:10px clamp(12px,4vw,28px);background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.brand{font-weight:900;text-decoration:none;letter-spacing:-.03em}.brand span{display:inline-flex;background:var(--blue);color:#fff;border-radius:12px;padding:3px 7px;margin-right:6px}.top-nav{display:flex;gap:7px;overflow-x:auto}.top-nav a{flex:0 0 auto;text-decoration:none;min-height:44px;padding:9px 12px;border-radius:999px;font-weight:800;color:#344054}.top-nav a.active,.top-nav a:hover{background:#172033;color:#fff}.wrap{width:min(1180px,100%);margin:0 auto;padding:18px clamp(12px,4vw,32px) 52px}.hero,.panel{border:1px solid var(--line);border-radius:34px;background:rgba(255,255,255,.92);box-shadow:var(--shadow);padding:clamp(18px,4vw,30px);margin-top:18px}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,320px);gap:22px;align-items:center}.hero.slim{display:block}.eyebrow{display:inline-flex;color:var(--blue);background:var(--blue2);border-radius:999px;padding:6px 11px;font-weight:900;font-size:.84rem}.hero h1{font-size:clamp(1.9rem,3.8vw,2.55rem);line-height:1.16;letter-spacing:-.04em;margin:14px 0 16px;max-width:18.5em}.hero-title .title-line{display:block}.hero-title .desktop-title{white-space:nowrap}.hero-title .mobile-title{display:none}.lead{font-size:clamp(.98rem,1.9vw,1.08rem);color:#344054;margin:0 0 20px;max-width:44em}.hero-actions,.unit-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border-radius:999px;padding:11px 16px;background:var(--blue);color:#fff;text-decoration:none;font-weight:900;border:0;box-shadow:0 10px 22px rgba(23,103,210,.18)}.btn.secondary{background:#172033}.btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--line);box-shadow:none}.btn.small{min-height:44px;padding:9px 12px;font-size:.9rem}.hero-panel{display:grid;grid-template-columns:auto 1fr;gap:8px 12px;background:#f5f9ff;border:1px solid var(--line);border-radius:26px;padding:18px}.hero-panel b{font-size:2rem;line-height:1;color:var(--blue)}.hero-panel span{align-self:center;color:var(--muted);font-weight:800}.section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}.section-head h2,.panel h2{font-size:clamp(1.2rem,3vw,1.8rem);letter-spacing:-.03em;line-height:1.25;margin:0}.section-head p{color:var(--muted);margin:6px 0 0}.chapter-grid,.unit-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.unit-grid.focus{grid-template-columns:repeat(4,minmax(0,1fr))}.chapter-card,.unit-card,.stat,.weak-box{display:block;background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;text-decoration:none;box-shadow:0 8px 22px rgba(23,32,51,.05);min-width:0}.chapter-card span{display:block;font-weight:900}.chapter-card b{display:block;font-size:1.55rem;color:var(--blue);line-height:1.1;margin:7px 0}.chapter-card p,.unit-card p,.note{color:var(--muted);margin:.4em 0 0}.unit-top,.unit-meta{display:flex;gap:7px;flex-wrap:wrap;align-items:center}.unit-no,.pill{display:inline-flex;min-height:28px;align-items:center;border-radius:999px;padding:4px 9px;background:var(--blue2);color:var(--blue);font-size:.78rem;font-weight:900}.pill.orange{background:var(--orange2);color:var(--orange)}.unit-card h3{font-size:1.08rem;line-height:1.38;margin:12px 0 6px}.unit-meta{margin:11px 0}.unit-meta span{font-size:.78rem;color:#475467;background:#f6f9ff;border-radius:999px;padding:3px 8px}.search{width:100%;min-height:48px;border:1px solid var(--line);border-radius:999px;padding:12px 16px;font-size:1rem;margin:0 0 15px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stat{text-align:center}.stat b{display:block;font-size:1.35rem;color:var(--blue)}.stat span{color:var(--muted);font-weight:800;font-size:.82rem}@media(max-width:900px){.hero{grid-template-columns:1fr}.chapter-grid,.unit-grid,.unit-grid.focus{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.wrap{padding:12px 12px 34px}.site-header{align-items:flex-start;flex-direction:column}.hero,.panel{border-radius:26px;padding:17px}.hero h1{font-size:clamp(1.75rem,8vw,2.12rem);line-height:1.18;letter-spacing:-.03em}.hero-title .desktop-title{display:none}.hero-title .mobile-title{display:block}.hero-title .mobile-title span{display:block}.chapter-grid,.unit-grid,.unit-grid.focus,.stats{grid-template-columns:1fr}.hero-actions .btn{flex:1 1 100%}.unit-actions .btn{flex:1 1 100%}.hero-panel{grid-template-columns:auto 1fr}.top-nav{width:100%}}
