:root{font-family:BIZ UDPGothic,Hiragino Sans,Yu Gothic,sans-serif;line-height:1.5;color:#1f2a20;background:radial-gradient(circle at top left,rgba(228,190,146,.24),transparent 32%),radial-gradient(circle at top right,rgba(103,160,132,.14),transparent 28%),linear-gradient(180deg,#f8f1e5,#efe3d3);--ink: #1f2a20;--muted: #667063;--line: rgba(31, 42, 32, .12);--panel: rgba(255, 251, 246, .9);--panel-strong: rgba(255, 255, 255, .88);--shadow: 0 16px 40px rgba(63, 45, 20, .08);--correct-bg: rgba(217, 245, 232, .95);--correct-line: rgba(41, 114, 82, .22);--incorrect-bg: rgba(255, 234, 228, .98);--incorrect-line: rgba(155, 75, 61, .22)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink)}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}#root{min-height:100vh}.app-shell{min-height:100vh;padding:24px}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:20px}.topbar h1,.hero-card h2,.panel-header h2,.panel-header h3{margin:0;font-family:BIZ UDPMincho,Yu Mincho,serif;font-weight:700}.eyebrow{margin:0 0 4px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:12px}.nav-tabs{display:flex;gap:8px;padding:8px;border-radius:999px;background:#ffffffad;border:1px solid rgba(255,255,255,.7);box-shadow:var(--shadow)}.nav-tabs button{padding:10px 16px;border-radius:999px;background:transparent;color:var(--muted)}.nav-tabs button.active{background:var(--ink);color:#fff}.flash{margin-bottom:16px;padding:14px 16px;border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow)}.flash.error{background:#ffedeaeb;color:#77291f}.flash.success{background:#ebfaf3eb;color:#205743}.workspace{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,420px);gap:20px;align-items:start}.workspace.single-column{grid-template-columns:minmax(0,1fr)}.main-panel,.detail-panel,.panel,.hero-card,.modal-card,.quick-log-sheet{background:var(--panel);border:1px solid rgba(255,255,255,.72);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.main-panel{border-radius:28px;padding:24px}.detail-panel{border-radius:28px;padding:20px;position:sticky;top:24px}.detail-panel.empty{display:flex;align-items:center;min-height:420px}.loading-state{display:grid;place-items:center;min-height:60vh;font-size:18px}.stack{display:grid;gap:20px}.split-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.hero-card,.panel,.modal-card,.quick-log-sheet{border-radius:24px;padding:22px}.hero-card{display:flex;justify-content:space-between;gap:20px;align-items:flex-end}.hero-copy,.subtle{color:var(--muted)}.hero-copy{margin-top:8px;max-width:44rem}.hero-actions,.inline-actions,.chip-row,.pill-row,.section-pills,.material-switcher,.section-tabs{display:flex;gap:10px;flex-wrap:wrap}.primary,.secondary,.ghost,.danger-text,.material-launch,.question-tile,.switch-chip,.section-tab,.pill-button{transition:transform .14s ease,background-color .14s ease,border-color .14s ease}.primary:hover,.secondary:hover,.ghost:hover,.danger-text:hover,.material-launch:hover,.question-tile:hover,.switch-chip:hover,.section-tab:hover,.pill-button:hover{transform:translateY(-1px)}.primary,.secondary,.ghost{padding:12px 18px;border-radius:14px}.primary{background:var(--ink);color:#fff}.primary.success{background:#255f48}.primary.danger{background:#9a4d42}.secondary{background:#ffffffe0;color:var(--ink);border:1px solid var(--line)}.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.danger-text{background:transparent;color:#a44f44;padding:10px 0}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card{border-radius:20px;padding:18px;background:var(--panel-strong);border:1px solid var(--line)}.stat-card p{margin:0 0 8px;color:var(--muted)}.stat-card strong{font-size:28px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.panel-subtitle{margin:0 0 10px;font-size:14px;color:var(--muted)}.card-list,.history-list{display:grid;gap:12px}.material-card,.review-card,.detail-card,.history-item,.empty-state{background:var(--panel-strong);border:1px solid var(--line);border-radius:20px}.material-card,.review-card,.detail-card,.history-item{padding:16px}.material-launch{width:100%;display:grid;gap:16px;text-align:left;background:transparent;padding:0}.material-type{margin:0 0 6px;color:var(--muted);font-size:13px}.material-card h3,.material-card h4,.review-card h3,.review-card h4,.empty-state h4{margin:0}.material-metrics,.mini-stats{display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.mini-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.material-metrics div,.mini-stats div{background:#ffffffdb;border-radius:16px;padding:10px}.material-metrics dt,.mini-stats dt{color:var(--muted);font-size:12px}.material-metrics dd,.mini-stats dd{margin:6px 0 0;font-size:18px;font-weight:700}.quick-metrics{margin-top:16px}.pill,.chip,.switch-chip,.section-tab,.pill-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;font-size:12px;background:#ffffffe6;border:1px solid var(--line)}.pill.muted,.chip.muted{color:var(--muted)}.chip.correct{background:var(--correct-bg);color:#215742}.chip.incorrect{background:var(--incorrect-bg);color:#8a3f34}.chip.due{background:#f8efd1eb;color:#7b611d}.switch-chip.active,.section-tab.active,.pill-button.active{background:var(--ink);color:#fff;border-color:var(--ink)}.question-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:10px}.question-tile{min-height:74px;display:grid;gap:4px;align-content:center;justify-items:center;border-radius:18px;background:#ffffffd6;border:1px solid var(--line);color:var(--ink)}.question-tile strong{font-size:16px}.question-tile span{font-size:11px;color:var(--muted)}.question-tile.correct{background:var(--correct-bg);border-color:var(--correct-line)}.question-tile.incorrect{background:var(--incorrect-bg);border-color:var(--incorrect-line)}.question-tile.active{outline:2px solid rgba(31,42,32,.72);outline-offset:2px}.quick-log-sheet{display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;bottom:16px}.review-card.full{display:grid;gap:14px}.review-main{display:flex;justify-content:space-between;gap:18px}.detail-card{display:grid;gap:12px}.hero-metric{font-size:30px;line-height:1}.history-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.history-overview-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.history-mini-list{display:grid;gap:10px}.history-day-launch{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:14px 16px;border-radius:18px;background:#ffffffdb;border:1px solid var(--line);color:var(--ink);text-align:left}.history-day-launch strong{font-size:22px}.history-progress{display:grid;gap:12px}.history-progress-bar{height:14px;border-radius:999px;background:#ffffffb8;border:1px solid var(--line);overflow:hidden}.history-progress-fill{height:100%;background:linear-gradient(90deg,#2f6a50,#7eb38a)}.milestone-row{display:flex;gap:8px;flex-wrap:wrap}.milestone-chip{min-width:44px;padding:6px 10px;border-radius:999px;text-align:center;background:#ffffffc7;border:1px solid var(--line);color:var(--muted)}.milestone-chip.achieved{background:var(--correct-bg);border-color:var(--correct-line);color:#215742}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendar-weekdays{margin-bottom:8px}.calendar-weekdays span{text-align:center;font-size:12px;color:var(--muted)}.calendar-cell{min-height:86px;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;padding:10px;border-radius:18px;background:#ffffffc2;border:1px solid var(--line);color:var(--ink)}.calendar-cell.outside{opacity:.45}.calendar-cell.has-record{background:#ffffffe6}.calendar-cell.today{border-color:#2f6a5066}.calendar-cell.selected{outline:2px solid rgba(31,42,32,.72);outline-offset:1px}.calendar-day-number{font-size:13px;color:var(--muted)}.calendar-study-value{font-size:28px;line-height:1}.empty-state{padding:24px;text-align:center}.empty-state p{margin:8px 0 0}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:8px}.field span{font-size:14px;color:var(--muted)}.text-input,.select-input,.text-area,.prompt-box{width:100%;border-radius:14px;border:1px solid var(--line);padding:12px 14px;background:#fffffff0;color:var(--ink)}.text-area,.prompt-box{resize:vertical}.prompt-box{min-height:180px}.mono-block{overflow-x:auto;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:#fffffff0;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:13px;white-space:nowrap}.modal-backdrop{position:fixed;inset:0;background:#1f2a2047;display:grid;place-items:start center;padding:24px;overflow-y:auto}.modal-card{width:min(720px,100%);max-height:calc(100vh - 48px);overflow-y:auto;margin:auto 0}@media(max-width:1100px){.workspace,.split-panel{grid-template-columns:1fr}.detail-panel{position:static}.stats-grid,.material-metrics,.history-overview-grid,.history-overview-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.app-shell{padding:16px}.topbar,.hero-card,.panel-header,.review-main,.quick-log-sheet{flex-direction:column;align-items:stretch}.nav-tabs{width:100%;overflow-x:auto}.stats-grid,.material-metrics,.mini-stats,.form-grid,.history-overview-grid,.history-overview-grid.compact{grid-template-columns:1fr}.question-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.calendar-toolbar{flex-direction:column;align-items:stretch}.calendar-weekdays,.calendar-grid{gap:6px}.calendar-cell{min-height:72px;padding:8px}.calendar-study-value{font-size:22px}.quick-log-sheet{bottom:8px}.modal-backdrop{padding:12px}.modal-card{max-height:calc(100vh - 24px)}}
