:root{color-scheme:light;--bg: #f6f8fb;--surface: #ffffff;--surface-strong: #fdfefe;--text: #111827;--muted: #61708a;--border: #dbe4ef;--border-strong: #c6d3e1;--blue: #1d6fd9;--blue-dark: #164f9e;--blue-soft: #e8f2ff;--green: #16825d;--green-soft: #e6f6ef;--amber: #ac6b08;--amber-soft: #fff5df;--red: #c83d37;--red-soft: #ffeceb;--shadow: 0 18px 55px rgba(28, 52, 84, .11);--radius: 8px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#f8fbff 0%,var(--bg) 290px),var(--bg)}a{color:inherit;text-decoration:none}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:72px;padding:14px clamp(18px,4vw,54px);background:#f8fbffe0;border-bottom:1px solid rgba(219,228,239,.78);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:inline-flex;align-items:center;gap:12px;font-weight:760;letter-spacing:0}.brand-mark{display:grid;place-items:center;width:36px;height:36px;border-radius:8px;color:#fff;background:var(--blue);box-shadow:0 8px 22px #1d6fd940;font-size:.8rem}.page{width:min(1120px,calc(100% - 36px));margin:0 auto;padding:44px 0 72px}.home-page{width:min(1040px,calc(100% - 36px))}.page-heading,.deck-header,.study-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px}.page-heading h1,.deck-header h1,.study-header h1,.session-complete h1{margin:0;color:var(--text);font-size:clamp(2rem,5vw,3.6rem);line-height:1.02;letter-spacing:0}.study-header h1{max-width:820px;font-size:clamp(1.8rem,4vw,3rem)}.page-heading p,.deck-header p,.session-complete p,.empty-state p{max-width:650px;margin:10px 0 0;color:var(--muted);line-height:1.55}.preview-pill,.auth-note,.auth-message,.deck-source,.session-kicker{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;color:var(--muted);background:var(--surface);font-size:.78rem;font-weight:680}.deck-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:16px}.deck-card{display:flex;min-height:230px;flex-direction:column;justify-content:space-between;padding:22px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 10px 32px #1c34540f;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.deck-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--shadow)}.deck-card-main{display:flex;justify-content:space-between;gap:16px}.deck-card h2{margin:12px 0 0;font-size:1.35rem;line-height:1.2}.deck-card p{margin:18px 0 24px;color:var(--muted);line-height:1.5}.deck-card-footer,.card-row-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;color:var(--muted);font-size:.85rem}.performance-mark{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:720}.performance-mark>span{width:10px;height:10px;border-radius:999px;background:#8ea0b8}.performance-strong>span,.tone-strong{background:var(--green)}.performance-steady>span,.tone-steady{background:var(--blue)}.performance-shaky>span,.tone-shaky{background:var(--amber)}.performance-weak>span,.tone-weak{background:var(--red)}.performance-new>span,.tone-new{background:#8ea0b8}.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:24px;color:var(--muted);font-weight:720}.deck-header{align-items:center}.mastery-card,.session-progress{display:grid;place-items:center;flex:0 0 auto;width:132px;min-height:108px;border-radius:var(--radius);color:#fff;box-shadow:0 16px 38px #1d6fd92e}.grade-graph{flex:0 1 360px;min-width:300px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 14px 42px #1c345414}.grade-graph-summary{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.grade-graph-summary span{display:block;color:var(--muted);font-size:.78rem;font-weight:760}.grade-graph-summary strong{display:block;margin-top:4px;font-size:2.35rem;line-height:1}.grade-graph-summary p{margin:0;color:var(--muted);font-size:.9rem;font-weight:720}.grade-bar{display:flex;gap:3px;height:13px;margin:18px 0 14px;overflow:hidden;border-radius:999px;background:#d9e2ee}.grade-segment{min-width:3px}.grade-segment.grade-new,.legend-item.grade-new i{background:#95a4b8}.grade-segment.grade-again,.legend-item.grade-again i{background:var(--red)}.grade-segment.grade-hard,.legend-item.grade-hard i{background:var(--amber)}.grade-segment.grade-good,.legend-item.grade-good i{background:var(--blue)}.grade-segment.grade-easy,.legend-item.grade-easy i{background:var(--green)}.grade-legend{display:flex;flex-wrap:wrap;gap:8px 12px}.legend-item{display:inline-flex;align-items:center;gap:6px;color:var(--muted);background:transparent;font-size:.78rem;font-weight:720}.legend-item i{width:8px;height:8px;border-radius:999px}.mastery-card strong,.session-progress strong{font-size:2rem;line-height:1}.mastery-card span,.session-progress span{font-size:.8rem;font-weight:760;opacity:.86}.action-strip{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.primary-action,.secondary-action,.quiet-action,.icon-text-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 16px;border-radius:var(--radius);border:1px solid transparent;font-weight:760;line-height:1}.primary-action{color:#fff;background:var(--blue);box-shadow:0 12px 24px #1d6fd933}.primary-action:hover{background:var(--blue-dark)}.secondary-action,.icon-text-button{color:var(--text);background:var(--surface);border-color:var(--border)}.quiet-action{color:var(--muted);background:transparent;border-color:var(--border)}.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:20px 0 34px}.stat-chip{display:block;width:100%;min-height:84px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}button.stat-chip:hover{transform:translateY(-1px);border-color:#a6cdf8;box-shadow:0 12px 28px #1d6fd914}.stat-chip.is-active{border-color:#8fc1f5;background:var(--blue-soft);box-shadow:0 12px 28px #1d6fd921}.stat-chip strong{display:block;font-size:1.45rem}.stat-chip span{display:block;margin-top:6px;color:var(--muted);font-size:.84rem;font-weight:700}.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:12px}.section-title h2{margin:0;font-size:1.25rem}.section-title span,.section-actions span{color:var(--muted);font-size:.9rem}.section-actions{display:inline-flex;align-items:center;gap:10px}.reset-filter-button{min-height:34px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);color:var(--blue);background:var(--surface);font-size:.86rem;font-weight:760}.reset-filter-button:hover{border-color:#a6cdf8;background:var(--blue-soft)}.card-list{display:grid;gap:10px}.card-row{display:grid;grid-template-columns:6px 1fr auto;gap:16px;align-items:stretch;min-height:128px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.card-row.is-hidden{background:#f2f5f9}.card-row-status{border-radius:999px;background:var(--blue)}.card-row.is-hidden .card-row-status{background:#98a6b8}.card-row-body h3{margin:10px 0 8px;font-size:1.02rem;line-height:1.35}.card-row-body p{margin:0;color:var(--muted);line-height:1.45}.card-edit-form{display:grid;gap:10px;margin-top:10px}.card-edit-form label{display:grid;gap:5px;color:var(--muted);font-size:.78rem;font-weight:760}.card-edit-form input,.card-edit-form select,.card-edit-form textarea{width:100%;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--ink);font:inherit;font-size:.92rem;line-height:1.35;padding:9px 10px}.card-edit-form textarea{min-height:78px;resize:vertical}.card-row-actions,.study-card-toolbar>div{display:flex;align-items:flex-start;gap:8px}.icon-button{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);background:var(--surface)}.icon-button:hover,.icon-button.is-active{color:var(--blue);border-color:#b9d6f7;background:var(--blue-soft)}.icon-button.danger,.icon-button.danger:hover{color:var(--red);border-color:#ffc4c0;background:var(--red-soft)}.study-page{width:min(940px,calc(100% - 36px))}.study-header{align-items:center}.session-progress{width:112px;min-height:92px;background:var(--blue)}.study-card,.session-complete,.empty-state{padding:clamp(20px,5vw,34px);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.empty-state.compact{min-height:120px;box-shadow:none}.study-card-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px;color:var(--muted);font-size:.9rem;font-weight:750}.answer-grid{display:grid;gap:12px}.answer-button{width:100%;min-height:58px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface-strong);text-align:left;font-weight:720;line-height:1.3}.answer-button:hover:not(:disabled),.answer-button.is-selected{border-color:#a6cdf8;background:var(--blue-soft)}.answer-button.is-correct{border-color:#98d8bd;background:var(--green-soft)}.grade-panel{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;margin-top:20px;padding:16px;border-radius:var(--radius)}.grade-panel.correct{color:var(--green);background:var(--green-soft)}.grade-panel.incorrect{color:var(--red);background:var(--red-soft)}.grade-panel p{margin:4px 0 0;color:var(--text);line-height:1.45}.session-complete{text-align:center}.session-complete h1{margin-top:14px}.session-complete p{margin:12px auto 0}.complete-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:28px}.auth-form,.auth-user{display:flex;align-items:center;gap:8px}.auth-form input{width:190px;min-height:40px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.auth-user span{max-width:220px;overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem}.empty-state{display:grid;place-items:center;min-height:240px;text-align:center}.empty-state h1{margin:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:760px){.topbar,.page-heading,.deck-header,.study-header{align-items:flex-start;flex-direction:column}.topbar{gap:14px}.auth-form{width:100%;flex-wrap:wrap}.auth-form input{flex:1 1 180px}.mastery-card,.session-progress,.grade-graph{width:100%;min-width:0;min-height:78px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.card-row{grid-template-columns:5px 1fr}.card-row-actions{grid-column:2}.grade-panel{grid-template-columns:1fr}}@media(max-width:480px){.page,.home-page,.study-page{width:min(100% - 24px,1120px);padding-top:28px}.stats-grid{grid-template-columns:1fr}.deck-card{min-height:210px}}
