:root{--font-body: "Inter", "Segoe UI", sans-serif;--font-heading: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;--color-bg: #f4efe5;--color-bg-alt: #efe6d5;--color-surface: rgba(255, 252, 245, .94);--color-surface-strong: #fffdf8;--color-sidebar: #1b2731;--color-sidebar-soft: #243543;--color-text: #17212b;--color-text-muted: #5e6a73;--color-text-soft: #7b8790;--color-border: rgba(94, 106, 115, .22);--color-border-strong: rgba(27, 39, 49, .14);--color-chat-accent: #1f7a78;--color-chat-accent-soft: rgba(31, 122, 120, .12);--color-practice: #c58d2d;--color-practice-soft: rgba(197, 141, 45, .14);--color-review: #7a5ea6;--color-review-soft: rgba(122, 94, 166, .14);--color-completed: #567c4d;--color-completed-soft: rgba(86, 124, 77, .14);--color-warning: #b65c4b;--color-warning-soft: rgba(182, 92, 75, .12);--color-info: #355c7d;--color-info-soft: rgba(53, 92, 125, .12);--shadow-soft: 0 14px 34px rgba(42, 48, 53, .08);--shadow-panel: 0 18px 44px rgba(42, 48, 53, .1);font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);text-rendering:optimizeLegibility}body{margin:0;background:radial-gradient(circle at top,#fff8e9d9,#f4efe5f2 42%,#efe6d5fa),linear-gradient(180deg,#ffffff3d,#fff0);min-height:100vh;color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{max-width:1200px;margin:0 auto;padding:24px}.shell{display:grid;grid-template-columns:280px 1fr;gap:24px}.mobile-nav{display:none}.sidebar{background:linear-gradient(180deg,#1b2731fa,#202f3bf5),linear-gradient(145deg,#1f7a7814,#c58d2d0f);color:#edf2f2;border-radius:20px;padding:20px;display:flex;flex-direction:column;gap:18px;box-shadow:0 18px 42px #121b2347;border:1px solid rgba(255,255,255,.06)}.sidebar.collapsed{max-height:72px;overflow:hidden}.sidebar label{color:#edf2f2d1}.sidebar input,.sidebar select{background:#0e171fa6;border:1px solid rgba(255,255,255,.08);color:#f8fbfb}.sidebar input::placeholder{color:#edf2f273}.brand{display:flex;gap:12px;align-items:center;justify-content:space-between}.sidebar-toggle{background:transparent;color:#bfe3dc;border:1px solid rgba(255,255,255,.1);width:36px;height:36px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:4px;flex-direction:column}.sidebar-toggle span{display:block;width:16px;height:2px;background:#bfe3dc;border-radius:999px;transition:transform .2s ease,opacity .2s ease}.sidebar-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.sidebar-toggle.open span:nth-child(2){opacity:0}.sidebar-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.brand h1,h2,h3{font-family:var(--font-heading);letter-spacing:-.01em}.brand h1{font-size:22px;margin:0;color:#f8fbfb}.brand p{margin:4px 0 0;font-size:12px;color:#edf2f294}.logo{width:46px;height:46px;border-radius:14px;background:linear-gradient(145deg,var(--color-chat-accent),#2d5c8b);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;box-shadow:inset 0 1px #ffffff2e}.sidebar-section{display:flex;flex-direction:column;gap:10px}.nav{background:#ffffff08;border:1px solid rgba(255,255,255,.09);color:#edf2f2;text-align:left;padding:11px 12px;border-radius:12px}.nav.active{background:linear-gradient(145deg,#1f7a78d9,#355c7de6);border-color:transparent;box-shadow:0 10px 22px #194a5352}.tiny-actions{display:flex;gap:8px}.tiny-actions button{flex:1;padding:8px 10px;font-size:12px}.link{background:transparent;color:#d6e4df;border:none;padding:0;text-align:left;font-size:12px;cursor:pointer}.advanced{display:flex;flex-direction:column;gap:10px}.status{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:#edf2f2d1}.pill{background:#567c4deb;color:#f8fbf8;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}.progress-mini{background:#0c141b4d;border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:10px;font-size:12px}.progress-mini ul{margin:8px 0 0;padding-left:16px}header{display:flex;flex-direction:column;gap:8px;margin-bottom:28px}h2{margin:0;font-size:24px}h3{margin:16px 0 8px;font-size:18px}.panel{background:linear-gradient(180deg,#fffcf5f2,#faf6efe6);border-radius:16px;padding:22px;box-shadow:var(--shadow-panel);border:1px solid var(--color-border);position:relative;isolation:isolate}.panel:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,#355c7d38,#1f7a781a)}.chat-panel:before{background:linear-gradient(90deg,#1f7a789e,#355c7d47)}.quiz-panel:before{background:linear-gradient(90deg,#c58d2dad,#7a5ea642)}.progress-panel:before{background:linear-gradient(90deg,#567c4da8,#1f7a7838)}.settings-panel:before{background:linear-gradient(90deg,#355c7d85,#5e6a7333)}.main{display:flex;flex-direction:column;gap:18px}.topbar{display:flex;align-items:center;background:linear-gradient(180deg,#fffcf5e6,#f8f3ebdb);border-radius:16px;padding:14px 18px;border:1px solid var(--color-border);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar p{margin:6px 0 0;color:var(--color-text-muted);font-size:12px}.topbar-title{display:flex;align-items:center;gap:12px}.topbar-icon{width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:var(--color-chat-accent-soft);color:var(--color-chat-accent);font-size:16px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--color-text-muted);font-weight:600}input,textarea,select{border-radius:10px;border:1px solid rgba(53,92,125,.18);padding:10px 12px;font-size:14px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;background:#fffdf8fa;color:var(--color-text)}select:focus,input:focus,textarea:focus{outline:none;border-color:#1f7a788c;box-shadow:0 0 0 3px #1f7a7824}input::placeholder,textarea::placeholder{color:var(--color-text-soft)}textarea{resize:vertical}button{padding:10px 16px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--color-chat-accent),#2d5c8b);color:#fff;cursor:pointer;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}button:hover:not(:disabled){background:linear-gradient(135deg,#176c6a,#244d72);box-shadow:0 10px 18px #233d502e;transform:translateY(-1px)}button:disabled{background:#b7b7b1;cursor:not-allowed}.secondary{background:#355c7d14;color:var(--color-text);border:1px solid rgba(53,92,125,.12)}.chat{background:linear-gradient(160deg,#fffcf5f2,#f9f4edeb);border-radius:18px;padding:18px;max-height:440px;overflow-y:auto;border:1px solid var(--color-border);box-shadow:inset 0 0 0 1px #fff6}.chat-panel .chat{background:radial-gradient(circle at top right,rgba(31,122,120,.08),transparent 38%),linear-gradient(160deg,#fffcf5f7,#f8f3ebed)}.message-row{display:flex;margin-bottom:14px}.message-row.user{justify-content:flex-end}.message{padding:12px 14px;border-radius:18px;font-size:14px;display:grid;grid-template-columns:32px 1fr;gap:10px;align-items:flex-start;max-width:min(80%,520px);box-shadow:var(--shadow-soft);border:1px solid var(--color-border);background:var(--color-surface-strong)}.message-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffffdb;border:1px solid var(--color-border);font-size:16px}.message-body{display:flex;flex-direction:column;gap:6px}.message-role{text-transform:uppercase;font-size:11px;letter-spacing:.08em;color:var(--color-text-muted);font-weight:700}.message-content{white-space:pre-wrap;line-height:1.58;color:var(--color-text)}.message-time{font-size:11px;color:var(--color-text-soft)}.message.user{background:linear-gradient(145deg,#1f7a781f,#355c7d14);border-color:#1f7a7833}.message.assistant{background:linear-gradient(160deg,#fffdf8fa,#f6f1eaeb);border-color:#355c7d24}.message.system{background:linear-gradient(160deg,#f2f7f6f5,#fffcf5f2);border-color:#1f7a7829}.empty-coach-card{background:radial-gradient(circle at top right,rgba(31,122,120,.1),transparent 42%),linear-gradient(160deg,#fffdf8fa,#f2f7f6e6)}.actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.status-chip.info{background:var(--color-info-soft);color:var(--color-info);border-color:#355c7d24}.status-chip.practice{background:var(--color-practice-soft);color:var(--color-practice);border-color:#c58d2d29}.status-chip.review{background:var(--color-review-soft);color:var(--color-review);border-color:#7a5ea624}.status-chip.completed{background:var(--color-completed-soft);color:var(--color-completed);border-color:#567c4d29}.mic{background:linear-gradient(145deg,var(--color-sidebar),var(--color-sidebar-soft));color:#f8fafc;border-radius:999px;min-width:56px;justify-content:center;box-shadow:0 8px 16px #0f172a33}.mic.live{background:linear-gradient(145deg,#b84d3b,#cf6a57)}.quiz-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;padding:2px 0 12px;border-bottom:1px solid rgba(197,141,45,.16)}.quiz-body{display:flex;flex-direction:column;gap:14px}.quiz-context-note{margin:8px 0 0;font-size:13px;color:var(--color-text-muted);line-height:1.5}.quiz-flow-note{margin:6px 0 0;font-size:12px;color:var(--color-text-soft);line-height:1.45}.question{background:linear-gradient(160deg,#fffbf2fa,#f7efdb9e);border-radius:14px;padding:14px;border:1px solid rgba(197,141,45,.2);box-shadow:var(--shadow-soft)}.quiz-panel .result{background:linear-gradient(160deg,#fffbf4fa,#f7f1e0bd);border-color:#c58d2d38}.chat-input{position:sticky;bottom:0;background:transparent;padding-top:12px}.chat-input-inner{display:flex;align-items:center;gap:12px;background:#fffcf5f0;border:1px solid var(--color-border);border-radius:18px;padding:10px 12px;box-shadow:0 12px 26px #2a303517;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.progress-panel ul{margin:12px 0 0;padding-left:18px}.settings-panel .advanced{margin-top:16px}.chat-input textarea{width:100%;min-height:44px;max-height:120px;border:none;background:transparent;padding:8px;resize:none}.chat-input textarea:focus{outline:none;box-shadow:none;border-color:transparent}.chat-actions{display:flex;align-items:center;gap:8px}.send{box-shadow:0 10px 18px #1f7a7838}.result,.progress{margin-top:12px;background:#fffbf4eb;border-radius:10px;padding:12px;border:1px solid var(--color-border)}.progress-panel .progress{background:radial-gradient(circle at top right,rgba(86,124,77,.08),transparent 34%),linear-gradient(180deg,#fffcf5f2,#f7f4eceb)}.progress-header-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px}.progress-stat{border:1px solid var(--color-border);border-radius:12px;padding:10px;background:#fffdf8db;display:grid;gap:4px}.progress-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-soft);font-weight:700}.progress-stat-value{font-size:20px;font-weight:700;color:var(--color-text);line-height:1.1}.progress-stat-sub{font-size:12px;color:var(--color-text-muted)}.sparkline-stat{align-content:start}.quiz-sparkline{width:100%;height:56px}.quiz-sparkline path{fill:none;stroke:var(--color-chat-accent);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.roadmap-wrap{margin-bottom:12px}.roadmap-bar{margin-top:6px;display:grid;grid-template-columns:repeat(auto-fit,minmax(16px,1fr));gap:4px}.roadmap-segment{height:10px;border-radius:999px;background:#355c7d2e}.roadmap-segment.info{background:#355c7d47}.roadmap-segment.practice{background:#c58d2d94}.roadmap-segment.completed{background:#567c4db8}.topic-list{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:12px}.topic-card{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px;border:1px solid var(--color-border);border-radius:14px;background:linear-gradient(160deg,#fffdf8fa,#f9f4edeb);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.topic-card:hover{transform:translateY(-1px);box-shadow:0 16px 30px #2a303514;border-color:#355c7d38}.topic-card-main{display:grid;gap:8px;min-width:0}.topic-card-title{font-weight:700;color:var(--color-text)}.topic-card-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13px;color:var(--color-text-muted)}.topic-mastery{font-size:12px;color:var(--color-text-soft)}.topic-card-note{font-size:13px;color:var(--color-text-muted);line-height:1.45}.mastery-bar{width:100%;height:8px;border-radius:999px;background:#355c7d24;overflow:hidden}.mastery-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1f7a78b8,#567c4dd1)}.topic-card-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.audio-debug{margin-top:12px;background:#fffcf5d1;border-radius:10px;padding:10px 12px;border:1px dashed rgba(53,92,125,.22);font-size:12px;color:var(--color-text-muted);display:grid;gap:4px}.chat-panel .audio-debug{background:#f8fcfbd1}.hint{font-size:13px;color:var(--color-text-muted)}@media(max-width:980px){.shell{grid-template-columns:1fr}.sidebar{position:sticky;top:12px;z-index:2}.sidebar.collapsed{max-height:72px}}@media(max-width:1023px)and (min-width:768px){.shell{grid-template-columns:88px 1fr}.sidebar{align-items:center}.sidebar-section{width:100%}.sidebar label,.sidebar .tiny-actions,.sidebar .advanced,.sidebar .progress-mini,.sidebar .status,.sidebar .link{display:none}.sidebar .nav{text-align:center}}@media(max-width:767px){.app{padding:16px}.shell{grid-template-columns:1fr}.sidebar{display:none}.main{padding-bottom:92px}.panel{padding:18px}.chat{max-height:calc(100vh - 320px)}.progress-panel .progress,.quiz-panel .result,.question{padding:14px}.topic-card,.quiz-header{flex-direction:column}.progress-header-grid{grid-template-columns:1fr}.topic-card-actions{width:100%;justify-content:stretch}.topic-card-actions button{flex:1}.chat-input{position:fixed;left:0;right:0;bottom:64px;padding:12px 16px;z-index:3}.chat-input-inner{border-radius:16px}.mobile-nav{position:fixed;left:0;right:0;bottom:0;height:64px;display:grid;grid-template-columns:repeat(4,1fr);background:#1b2731f5;color:#e7ecea;border-top:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:4}.mobile-nav button{background:transparent;border:none;color:inherit;font-size:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:none;transform:none}.mobile-nav button span{font-size:16px}.mobile-nav button.active{color:#bfe3dc}}
