#root{width:100%;min-height:100%}.app-shell{position:relative;min-height:100vh;color:var(--foreground);background:radial-gradient(circle at 4% 2%,rgb(var(--primary-rgb) / .08),transparent 33%),radial-gradient(circle at 96% 5%,rgb(var(--chart-2-rgb) / .1),transparent 36%),linear-gradient(180deg,var(--background) 0%,#f6f9fe 100%)}.app-layout{display:flex}.sidebar-panel{width:13.75rem;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:20;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid var(--sidebar-border);background:linear-gradient(180deg,var(--sidebar) 0%,#f7f9fe 100%);box-shadow:6px 0 16px #0b22450d}.brand-panel{padding:1.3rem .95rem .9rem;border-bottom:1px solid var(--sidebar-border);background:radial-gradient(circle at 98% -4%,rgb(var(--primary-rgb) / .15),transparent 48%),#f7f9fe}.brand-home-btn{width:100%;border:0;display:block;text-align:left;cursor:pointer}.brand-home-btn:focus-visible{outline:2px solid rgb(42 86 245 / .4);outline-offset:-2px}.brand-overline{margin:0;font-size:.61rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#2f63eb}.brand-title{margin:.42rem 0 .2rem;font-family:var(--display-font);font-size:1.46rem;line-height:1.2;letter-spacing:-.02em;color:#0f204a}.brand-desc{margin:0;font-size:.74rem;color:#5f6f8f}.sidebar-nav{display:flex;flex-direction:column;gap:.36rem;padding:.9rem .58rem}.nav-item{border:1px solid transparent;border-radius:.66rem;min-height:2.62rem;width:100%;padding:.42rem .62rem;display:flex;align-items:center;justify-content:flex-start;gap:.52rem;text-align:left;background:transparent;color:#526380;font-size:.82rem;font-weight:600;transition:all .22s ease}.nav-item:hover{border-color:#d8e2f6;background:#f1f5fc;color:#1337ec}.nav-item.active{border-color:#cad9ff;background:#e9f0ff;color:#1c54df;box-shadow:none}.nav-icon{width:1.1rem;height:1.1rem;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem}.material-symbols-outlined,.material-icons-round{line-height:1}.app-icon{width:1em;height:1em;display:inline-block;vertical-align:middle;flex-shrink:0}.sidebar-foot{margin:.55rem .58rem .72rem;border:1px solid #dbe4f4;border-radius:.72rem;background:#f2f5fc;padding:.72rem}.sidebar-foot-title{margin:0;font-size:.68rem;font-weight:600;color:#5f6f8f}.goal-track{margin-top:.52rem;height:.3rem;border-radius:999px;overflow:hidden;background:#d8e4fb}.goal-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1337ec,#4e77ff)}.progress-pill{margin-top:.5rem;display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .56rem;font-size:.66rem;font-weight:800;color:#1f4ed4;background:#e4ecff}.content-panel{flex:1;min-width:0;margin-left:13.75rem;overflow-y:auto;max-height:100vh;padding:1.42rem 1.38rem}.content-inner{max-width:70rem;margin:0 auto;display:grid}.page-section{position:relative;display:grid;gap:1rem}.page-section>*{opacity:1;transform:none}.surface-card{border:1px solid var(--border);border-radius:.74rem;background:var(--card);box-shadow:0 2px 8px #0e23480f}.hero-card{padding:1.16rem 1.22rem;border-color:#d6e0f2;background:var(--card)}.hero-actions{display:flex;align-items:center;gap:.8rem}.hero-progress{display:inline-flex;flex-direction:column;align-items:flex-end;gap:.2rem}.hero-progress-label{font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6980ac}.hero-progress-wrap{display:inline-flex;align-items:center;gap:.42rem}.hero-progress-value{font-family:var(--display-font);font-size:1.56rem;font-weight:700;line-height:1;color:#2a56f5}.hero-progress-ring{--progress-track: #dfe6f2;width:2rem;height:2rem;border-radius:999px;position:relative}.hero-progress-ring:after{content:"";position:absolute;inset:3px;border-radius:999px;background:#f8f9fc}.section-title{margin:0;font-family:var(--display-font);font-size:clamp(1.18rem,2.1vw,1.66rem);line-height:1.25;letter-spacing:-.02em;color:#0f224f}.section-desc{margin:.46rem 0 0;font-size:.88rem;line-height:1.55;color:#5b6f96}.card-title{margin:0;font-size:.96rem;font-weight:700;line-height:1.3;color:#142956}.action-btn{border:0;border-radius:.58rem;display:inline-flex;align-items:center;justify-content:center;gap:.36rem;font-size:.82rem;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .2s ease,background-color .2s ease,color .2s ease}.action-btn:hover{transform:translateY(-1px)}.action-btn-primary{min-height:2.42rem;padding:.5rem .92rem;color:#fff;background:#2a56f5;box-shadow:0 6px 15px #2a56f547}.action-btn-primary:hover{box-shadow:0 9px 18px #2a56f557}.action-btn-small{min-height:2rem;padding:.42rem .76rem;color:#fff;background:#2a56f5;box-shadow:0 6px 14px #2a56f547}.action-btn-gradient{min-height:3rem;padding:.84rem 1.1rem;color:#fff;background:#2a56f5;box-shadow:0 9px 20px #2a56f540}.action-btn-ghost{min-height:3rem;padding:.84rem 1.1rem;color:#244170;border:1px solid #d9e1f2;background:#f7f9fd}.action-btn-ghost:hover{background:#edf2fb;box-shadow:0 7px 16px #1b3a761a}.metric-card{position:relative;overflow:hidden;min-height:8.6rem;padding:1.04rem}.metric-card:after{content:"";position:absolute;width:120px;height:120px;right:-44px;top:-44px;border-radius:999px}.metric-card-ready:after{background:radial-gradient(circle,rgb(201 210 226 / .46),transparent 72%)}.metric-card-studying:after{background:radial-gradient(circle,rgb(var(--chart-2-rgb) / .24),transparent 72%)}.metric-card-complete:after{background:radial-gradient(circle,rgb(73 195 147 / .25),transparent 72%)}.metric-label{margin:0;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#5e739c}.metric-value{font-family:var(--display-font);font-size:clamp(1.84rem,3.5vw,2.2rem);line-height:1;color:#122a59}.metric-unit{font-size:.72rem;color:#7d8fb0}.chart-card{padding:1.04rem}.chart-container{position:relative;width:100%;max-width:580px;height:284px;margin:.62rem auto 0}.section-head{padding:1.04rem}.dashboard-view .sidebar-panel{width:16rem;background:var(--card);border-right-color:#e2e8f0;box-shadow:0 1px 2px #0f172a0f}.dashboard-view .brand-panel{padding:1.5rem;background:transparent}.dashboard-view .brand-overline{font-size:.72rem;letter-spacing:.12em}.dashboard-view .brand-title{margin-top:.28rem;font-size:1.9rem}.dashboard-view .brand-desc{font-size:.86rem}.dashboard-view .sidebar-nav{padding:0 .75rem .75rem;gap:.25rem}.dashboard-view .nav-item{min-height:2.75rem;padding:.55rem .68rem;font-size:.9rem;color:#475569}.dashboard-view .nav-item:hover{background:#f8fafc;color:#0f172a}.dashboard-view .nav-item.active{border-color:#bfdbfe;background:#eff6ff;color:#2563eb;box-shadow:0 1px 2px #0f172a0a}.dashboard-view .sidebar-foot{margin:1rem;border-radius:.75rem;border-color:#f1f5f9;background:#f8fafc;padding:1rem}.dashboard-view .sidebar-foot-title{text-align:center}.dashboard-view .goal-track{height:.5rem;background:#e2e8f0}.dashboard-view .goal-fill{background:#3b82f6}.dashboard-view .progress-pill{width:100%;justify-content:center;color:#475569;background:transparent;padding-top:.5rem}.dashboard-view .content-panel{margin-left:16rem;padding:2rem;background:#f8fafc80}.dashboard-view .content-inner{max-width:80rem}.dashboard-view .page-section{gap:1.5rem}.dashboard-hero{border-radius:.75rem;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0206170d,0 2px 4px -2px #0206170d;padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.dashboard-hero-copy{min-width:0}.dashboard-view .dashboard-hero .section-title{font-size:2rem}.dashboard-view .dashboard-hero .section-desc{margin-top:.42rem;font-size:1rem;color:#64748b}.dashboard-hero-btn{min-height:2.75rem;padding-inline:1.25rem;border-radius:.5rem;background:#2563eb;box-shadow:0 10px 15px -3px #2563eb40}.dashboard-hero-btn .material-icons-round{font-size:1.05rem}.dashboard-metrics-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem}.dashboard-metric-card{position:relative;border-radius:.75rem;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0206170d,0 2px 4px -2px #0206170d;min-height:9rem;padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.dashboard-metric-icon{position:absolute;top:.85rem;right:.85rem;color:#94a3b8;opacity:.12}.dashboard-metric-icon .material-icons-round{font-size:3.4rem}.metric-icon-blue{color:#3b82f6}.metric-icon-emerald{color:#10b981}.dashboard-metric-label{font-size:.95rem;font-weight:600;color:#64748b}.metric-label-blue{color:#2563eb}.metric-label-emerald{color:#059669}.dashboard-metric-value{display:flex;align-items:baseline;gap:.24rem}.dashboard-metric-number{font-size:2.25rem;line-height:1;letter-spacing:-.03em;font-weight:700;color:#1e293b}.dashboard-metric-unit{font-size:.9rem;color:#94a3b8}.dashboard-chart-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem;padding-bottom:2rem}.dashboard-chart-card{border-radius:.75rem;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0206170d,0 2px 4px -2px #0206170d;min-height:26.25rem;padding:1.5rem;display:flex;flex-direction:column}.dashboard-chart-card .card-title{font-size:1.12rem;color:#0f172a}.dashboard-donut-wrap{flex:1;display:flex;align-items:center;justify-content:center}.dashboard-donut{position:relative;width:16rem;height:16rem}.dashboard-donut-svg{width:100%;height:100%;transform:rotate(-90deg)}.dashboard-donut-track{stroke:#e2e8f0;stroke-width:12}.dashboard-donut-fill{stroke:#3b82f6;stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .8s ease}.dashboard-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.dashboard-donut-value{font-size:2.25rem;font-weight:700;color:#1e293b;line-height:1}.dashboard-donut-label{margin-top:.3rem;font-size:.74rem;font-weight:600;color:#64748b}.dashboard-donut-legend{margin-top:1rem;display:flex;justify-content:center;gap:1.5rem;font-size:.86rem;color:#64748b}.legend-item{display:inline-flex;align-items:center;gap:.45rem}.legend-dot{width:.65rem;height:.65rem;border-radius:999px}.legend-dot-blue{background:#3b82f6}.legend-dot-gray{background:#cbd5e1}.dashboard-domain-bars{flex:1;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding:0 1rem 2rem}.domain-bar-group{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.domain-bar-track{width:100%;border-radius:.5rem .5rem 0 0;background:#f1f5f9;height:100%;overflow:hidden;display:flex;align-items:flex-end}.domain-bar-fill{width:100%;background:#3b82f6cc;transition:height .6s ease}.domain-bar-label{margin-top:.75rem;min-height:2.5rem;font-size:.86rem;font-weight:500;color:#64748b;text-align:center;line-height:1.25}.domain-bar-tip{position:absolute;top:-1.9rem;font-size:.7rem;color:#fff;background:#1e293b;padding:.14rem .38rem;border-radius:.3rem;opacity:0;transition:opacity .2s ease}.domain-bar-group:hover .domain-bar-tip{opacity:1}.dashboard-domain-axis{border-top:1px solid #f1f5f9;padding-top:.9rem;display:flex;justify-content:space-between;font-size:.72rem;color:#94a3b8}@media(min-width:768px){.dashboard-metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.dashboard-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.controls-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.controls-header-copy{max-width:46rem}.controls-progress-view{display:flex;align-items:center;gap:.55rem;margin-bottom:.2rem}.controls-progress-label{font-size:.76rem;font-weight:600;color:#64779a}.controls-progress-value{font-size:1.55rem;font-weight:800;color:#1a47ee}.controls-toolbar{display:flex;align-items:center;gap:.75rem;padding:.9rem}.controls-search-shell{position:relative;flex:1;min-width:0}.controls-search-icon{position:absolute;left:.72rem;top:50%;transform:translateY(-50%);font-size:1.1rem;color:#91a1bf}.controls-search-input{width:100%;border:0;border-radius:.7rem;background:#f1f4fa;padding:.68rem .72rem .68rem 2.2rem;color:#1f345e;font-size:.84rem}.controls-search-input:focus{outline:2px solid rgb(var(--primary-rgb) / .22)}.controls-search-input::placeholder{color:#90a1be}.controls-toolbar-actions{display:flex;align-items:center;gap:.5rem}.controls-select-box{position:relative;border:1px solid #dbe4f4;border-radius:.7rem;background:#f8fafd;display:inline-flex;align-items:center;gap:.2rem;padding:.36rem 2rem .36rem .6rem;min-height:2.3rem}.controls-select-prefix{font-size:.78rem;font-weight:600;color:#4f6389;white-space:nowrap}.controls-select-input{appearance:none;-webkit-appearance:none;border:0;background:transparent;color:#2b406b;font-size:.79rem;font-weight:600;padding-right:.2rem;cursor:pointer}.controls-select-input:focus{outline:none}.controls-select-icon{position:absolute;right:.56rem;top:50%;transform:translateY(-50%);font-size:1.02rem;color:#7388af;pointer-events:none}.controls-more-btn{border:1px solid #dbe4f4;border-radius:.7rem;background:#f8fafd;color:#3f557f;min-height:2.3rem;padding:.36rem .72rem;display:inline-flex;align-items:center;gap:.32rem;font-size:.78rem;font-weight:600}.controls-more-btn .material-symbols-outlined{font-size:1rem}.controls-more-btn.active{border-color:#2a56f5;background:#edf2ff;color:#1847df}.controls-table-shell{overflow:hidden;border-color:#dbe4f4}.controls-table-modern{width:100%;border-collapse:collapse}.controls-table-modern th{background:#f8fafd;border-bottom:1px solid #dfe7f5;padding:.84rem .9rem;font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6f82a6}.control-head-id{width:6.4rem}.control-head-domain{width:14rem}.control-head-actions{width:13rem;text-align:right}.controls-table-modern td{border-bottom:1px solid #edf2fb;padding:.78rem .9rem}.control-row:hover{background:#f9fbff}.control-id-cell{white-space:nowrap}.control-id-chip{display:inline-flex;align-items:center;border-radius:.42rem;background:#eef3fb;color:#607596;padding:.18rem .52rem;font-size:.76rem;font-family:var(--font-mono);font-weight:600}.control-name-cell{min-width:18rem}.control-title{font-size:.88rem;font-weight:600;color:#1b315c}.control-subline{margin-top:.2rem;font-size:.72rem;color:#7f92b3}.domain-pill{display:inline-flex;align-items:center;gap:.34rem;border-radius:999px;padding:.24rem .65rem;font-size:.72rem;font-weight:600;white-space:nowrap}.domain-pill-dot{width:.35rem;height:.35rem;border-radius:999px}.domain-pill-1{background:#eaf2ff;color:#2c64bf}.domain-pill-1 .domain-pill-dot{background:#4d83db}.domain-pill-2{background:#f0ebff;color:#7b4ec5}.domain-pill-2 .domain-pill-dot{background:#8f5fe0}.domain-pill-3{background:#e9faf7;color:#1b8a7a}.domain-pill-3 .domain-pill-dot{background:#2ab7a1}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .58rem;font-size:.71rem;font-weight:600;white-space:nowrap;border:1px solid transparent}.status-ready{color:#5f718f;background:#eef2f8;border-color:#dde5f2}.status-studying{color:#b96828;background:#fff0e0;border-color:#ffe0c0}.status-complete{color:#17866a;background:#e0f7ef;border-color:#c8eddc}.status-review{color:#6e56ba;background:#efe8ff;border-color:#ddd2ff}.bookmark-btn{border:0;background:transparent;color:#9aaac6;width:2rem;height:2rem;border-radius:.56rem;display:inline-flex;align-items:center;justify-content:center}.bookmark-btn .material-symbols-outlined{font-size:1.15rem}.bookmark-btn:hover,.bookmark-btn.active{color:#2a56f5;background:#eaf1ff}.control-action{border:1px solid transparent;border-radius:.56rem;min-height:2rem;padding:.38rem .76rem;margin-left:.3rem;font-size:.76rem;font-weight:700;display:inline-flex;align-items:center;gap:.28rem}.control-action .material-symbols-outlined{font-size:.95rem}.control-action-primary{color:#fff;background:#2a56f5;box-shadow:0 4px 12px #2a56f53d}.control-action-ghost{color:#3c4f76;background:#f8fafd;border-color:#dbe4f4}.controls-empty-row td{padding:1.2rem .9rem;text-align:center;color:#7b8fb3;font-size:.84rem}.controls-footer{display:flex;align-items:center;justify-content:space-between;gap:.85rem;border-top:1px solid #dfe7f5;padding:.82rem .9rem}.controls-footer-count{margin:0;font-size:.8rem;color:#5f7399}.controls-pagination{display:inline-flex;align-items:center}.pagination-btn{min-width:2rem;min-height:1.8rem;border:1px solid #dbe4f4;background:#fff;color:#667ca3;font-size:.78rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.pagination-btn+.pagination-btn{margin-left:-1px}.pagination-btn:first-child{border-radius:.5rem 0 0 .5rem}.pagination-btn:last-child{border-radius:0 .5rem .5rem 0}.pagination-btn.active{border-color:#2a56f5;background:#edf2ff;color:#1f48da;position:relative;z-index:1}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn .material-symbols-outlined{font-size:1rem}.pagination-ellipsis{pointer-events:none}.prompt-tab-row{display:flex;flex-wrap:wrap;gap:.44rem}.prompt-tab{border:1px solid #d8e2f2;border-radius:.66rem;padding:.52rem .82rem;font-size:.78rem;font-weight:700;color:#3c5a87;background:#f5f8fd;transition:all .2s ease}.prompt-tab:hover{background:#edf2fb}.prompt-tab.active{color:#fff;border-color:#2a56f5;background:#2a56f5;box-shadow:0 6px 14px #2a56f53b}.prompt-lab-card{padding:1.15rem}.prompt-text{color:#4c6288;line-height:1.68;font-size:.91rem}.prompt-subtitle{margin:0;font-size:.84rem;font-weight:700;color:#1f3f71}.prompt-box{border:1px solid #244ac4;background:linear-gradient(180deg,#182f59,#13284e);color:#eff5ff;font-family:var(--font-mono);box-shadow:inset 0 0 0 1px #8eacff42}.prompt-code{min-height:380px}.trainer-card{position:relative;padding:1.18rem}.trainer-title{margin:0 0 1.1rem;font-size:1.04rem;font-weight:700;color:#183565}.form-label{display:block;margin-bottom:.38rem;font-size:.8rem;font-weight:700;color:#3f5f8d}.modern-select{border-radius:.66rem;border:1px solid #d5deed;padding:.68rem .86rem;color:#223e72;background:#f8fafd;box-shadow:inset 0 1px #11234f0d;transition:border-color .2s ease,box-shadow .2s ease}.modern-select:focus{outline:none;border-color:#1f48e4;box-shadow:0 0 0 3px #1337ec26}.difficulty-btn{flex:1;min-height:2.7rem;border-radius:.66rem;border:1px solid #d5deed;color:#385883;background:#f6f9fd;font-size:.79rem;font-weight:700;transition:all .2s ease}.difficulty-btn:hover{background:#edf2fb}.difficulty-btn.active{color:#fff;border-color:#2a56f5;background:#2a56f5;box-shadow:0 8px 16px #2a56f540}.trainer-hint{color:#6077a0}.toast-pop{visibility:hidden;min-width:250px;margin-left:-125px;position:fixed;z-index:50;left:50%;bottom:2rem;border-radius:999px;padding:.82rem .98rem;text-align:center;font-size:.79rem;line-height:1.35;color:#fff;border:1px solid rgb(107 143 240 / .38);background:#2a56f5;box-shadow:0 10px 20px #0a19383d}.toast-pop.show{visibility:visible;animation:toast-in .3s ease,toast-out .4s 2.5s ease}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:#9cb5ea #eef4ff}.custom-scrollbar::-webkit-scrollbar{width:9px;height:9px}.custom-scrollbar::-webkit-scrollbar-track{background:#eef4ff}.custom-scrollbar::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,#2a56f5,#6a8aff)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@keyframes toast-out{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,8px)}}@media(max-width:980px){.app-layout{display:block}.sidebar-panel{position:static;width:100%;box-shadow:none;border-right:0;border-bottom:1px solid var(--sidebar-border)}.brand-panel{padding:1rem}.brand-title{margin-top:.42rem;font-size:1.34rem}.brand-desc{font-size:.76rem}.sidebar-nav{padding:.78rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.nav-item{min-height:3.1rem;padding:.52rem .48rem;font-size:.74rem;line-height:1.2;flex-direction:column;justify-content:center;gap:.24rem}.nav-icon{width:.92rem;height:.92rem}.sidebar-foot{margin:.45rem .78rem .86rem;padding:.72rem}.sidebar-foot-title{font-size:.67rem}.content-panel{margin-left:0;max-height:none;overflow-y:visible;padding:.9rem}.content-inner{max-width:none}.hero-card,.surface-card,.section-head,.prompt-lab-card,.trainer-card{border-radius:.88rem;padding:1rem}.hero-actions{width:100%;justify-content:space-between}.hero-progress{align-items:flex-start}.hero-progress-value{font-size:1.28rem}.hero-progress-ring{width:1.72rem;height:1.72rem}.dashboard-view .content-panel{padding:.9rem}.dashboard-hero{padding:1.15rem;flex-direction:column;align-items:flex-start}.dashboard-view .dashboard-hero .section-title{font-size:1.42rem}.dashboard-view .dashboard-hero .section-desc{font-size:.86rem}.dashboard-hero-btn{width:100%}.dashboard-metric-card{min-height:8.25rem;padding:1rem}.dashboard-metric-number{font-size:2rem}.dashboard-chart-card{min-height:0;padding:1rem}.dashboard-donut{width:12.5rem;height:12.5rem}.dashboard-donut-value{font-size:1.9rem}.dashboard-donut-legend{gap:.9rem;font-size:.78rem;flex-wrap:wrap}.dashboard-domain-bars{height:16rem;padding:0 .2rem 1.2rem;gap:.65rem}.domain-bar-label{font-size:.73rem}.metric-card{padding:.98rem}.metric-value{font-size:2.06rem}.chart-container{height:240px}.controls-header-row{align-items:flex-start;flex-direction:column;gap:.65rem}.controls-progress-view{margin-bottom:0}.controls-toolbar{flex-direction:column;align-items:stretch}.controls-toolbar-actions{width:100%;flex-wrap:wrap}.controls-select-box,.controls-more-btn{flex:1;min-width:11.5rem}.controls-table-shell{height:auto!important;max-height:none}.controls-head{display:none}.controls-table-modern,.controls-table-modern tbody,.controls-table-modern tr,.controls-table-modern td{display:block;width:100%}.control-row{border:1px solid #dbe4f2;border-radius:.86rem;margin-bottom:.55rem;box-shadow:0 4px 11px #0f27580f;background:#fbfdff;padding:.45rem .64rem .6rem}.controls-table-modern td{border:0;padding:.26rem 0}.control-id-cell{order:1}.control-name-cell{order:2;font-size:.88rem;line-height:1.42}.control-domain-cell{order:3;display:block}.control-status-cell{order:4}.control-actions-cell{order:5;display:flex;justify-content:flex-end;padding-top:.42rem}.controls-footer{flex-direction:column;align-items:flex-start;gap:.6rem}.controls-footer-count{font-size:.74rem}.controls-pagination{width:100%;overflow-x:auto;padding-bottom:.15rem}.prompt-tab-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.3rem;scroll-snap-type:x proximity}.prompt-tab{flex:0 0 auto;white-space:nowrap;scroll-snap-align:start;font-size:.74rem;padding:.47rem .72rem}.prompt-code{min-height:300px;font-size:.79rem}.difficulty-btn{min-height:2.42rem;font-size:.75rem}.toast-pop{width:calc(100% - 1.5rem);max-width:420px;margin-left:0;transform:translate(-50%)}}@media(prefers-color-scheme:dark){.app-shell{color:#e6eeff;background:radial-gradient(circle at 8% 4%,rgb(76 120 255 / .14),transparent 40%),radial-gradient(circle at 94% 8%,rgb(39 90 230 / .14),transparent 40%),linear-gradient(180deg,#08162c,#0a1a33)}.sidebar-panel{background:linear-gradient(180deg,#102441,#0f213b);border-right-color:#24395f;box-shadow:10px 0 22px #01060e5c}.brand-panel{border-bottom-color:#24395f}.brand-overline{color:#87a4ff}.brand-title{color:#f2f7ff}.brand-desc,.sidebar-foot-title{color:#9ab0d8}.nav-item{color:#b6c7e8}.nav-item:hover{border-color:#2f4670;color:#d7e6ff;background:#18325a}.nav-item.active{color:#f0f5ff;border-color:#4a68ba;background:#23477f}.sidebar-foot{border-color:#2b4369;background:#122a4d}.goal-track{background:#22395f}.content-panel{background:transparent}.surface-card{border-color:#233d63;background:#10223f;box-shadow:0 4px 12px #02081240}.hero-card{border-color:#2d4e85;background:#102647}.dashboard-view .sidebar-panel{border-right-color:#334155;background:#1e293b;box-shadow:0 1px 2px #02061766}.dashboard-view .brand-panel{background:transparent}.dashboard-view .nav-item{color:#94a3b8}.dashboard-view .nav-item:hover{background:#1e293b80;color:#f8fafc}.dashboard-view .nav-item.active{border-color:#3b82f659;background:#3b82f633;color:#60a5fa}.dashboard-view .sidebar-foot{border-color:#334155;background:#1e293b80}.dashboard-view .goal-track{background:#334155}.dashboard-view .progress-pill{color:#cbd5e1}.dashboard-view .content-panel{background:#0f172a80}.dashboard-hero,.dashboard-metric-card,.dashboard-chart-card{border-color:#334155;background:#1e293b;box-shadow:0 4px 6px -1px #02061740,0 2px 4px -2px #02061733}.dashboard-view .dashboard-hero .section-desc,.dashboard-metric-label,.dashboard-metric-unit,.dashboard-donut-label,.dashboard-donut-legend,.domain-bar-label,.dashboard-domain-axis{color:#94a3b8}.dashboard-metric-number,.dashboard-donut-value{color:#f8fafc}.dashboard-metric-icon{color:#64748b}.dashboard-hero-btn{background:#2563eb}.dashboard-donut-track{stroke:#334155}.dashboard-donut-fill{stroke:#3b82f6}.legend-dot-gray{background:#475569}.domain-bar-track{background:#334155}.domain-bar-tip{background:#0f172a}.dashboard-domain-axis{border-top-color:#334155}.section-title,.card-title,.trainer-title{color:#f0f5ff}.section-desc,.metric-label,.metric-unit,.prompt-text,.form-label,.trainer-hint,.controls-head th{color:#9eb0d3}.hero-progress-label{color:#a5b9dd}.hero-progress-value,.metric-value{color:#f0f5ff}.hero-progress-ring:after{background:#102647}.hero-progress-ring{--progress-track: #2b446e}.action-btn-ghost{color:#d5e4ff;border-color:#2d4c7f;background:#152d52}.action-btn-ghost:hover{background:#1a3865;box-shadow:0 10px 22px #01081070}.controls-progress-label,.controls-progress-view{color:#abc0e6}.controls-search-input,.controls-select-box,.controls-more-btn{background:#17335d;border-color:#33527f;color:#d6e4ff}.controls-search-input::placeholder,.controls-search-icon,.controls-select-prefix,.controls-select-icon{color:#93add8}.controls-select-input{color:#d6e4ff}.controls-more-btn.active{border-color:#4f7bf6;background:#1d3e73;color:#d9e7ff}.controls-table-shell{border-color:#2a426b}.controls-table-modern th{background:#132a4d;border-bottom-color:#233d67;color:#95abcf}.controls-table-modern td{border-bottom-color:#1d3458}.control-row:hover{background:#14305a}.control-id-chip{background:#1a355f;color:#b8c9ea}.control-title,.control-name-cell{color:#e4ecff}.control-subline{color:#9eb0d3}.domain-pill-1,.domain-pill-2,.domain-pill-3{color:#dbe7ff;background:#1c3968}.status-ready{color:#b8c8e8;background-color:#24395f;border-color:#2c4a79}.status-studying{color:#ffd7b8;background-color:#6a4f3a;border-color:#7a5d45}.status-complete{color:#cff7e5;background-color:#1e6550;border-color:#2f7a65}.status-review{color:#e7dcff;background-color:#4d4386;border-color:#5e53a0}.bookmark-btn{color:#90a7ce}.bookmark-btn:hover,.bookmark-btn.active{color:#bcd3ff;background:#254a86}.control-action-primary{background:#4f7bf6;box-shadow:0 4px 12px #4f7bf64d}.control-action-ghost{color:#d3e2ff;background:#18335e;border-color:#315584}.controls-footer{border-top-color:#233d67}.controls-footer-count{color:#9eb0d3}.pagination-btn{border-color:#33527f;background:#17335d;color:#c4d6f8}.pagination-btn.active{border-color:#5b84f9;background:#264a87;color:#eaf2ff}.prompt-tab{border-color:#2d4c7d;color:#c8d7f5;background:#18335e}.prompt-tab:hover{background:#204170}.prompt-box{border-color:#325fc5;background:linear-gradient(180deg,#0d1932,#111f3b);color:#e8f1ff}.modern-select,.difficulty-btn{border-color:#33527f;color:#d6e4ff;background:#17335d;box-shadow:none}.modern-select:focus{border-color:#4f7bf6;box-shadow:0 0 0 3px #4f7bf642}.custom-scrollbar{scrollbar-color:#4572d7 #102544}.custom-scrollbar::-webkit-scrollbar-track{background:#102544}.custom-scrollbar::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3f6fe0,#6b8df5)}@media(max-width:980px){.control-row{border-color:#2c4a7c;background:#102746;box-shadow:none}.control-title{color:#e8f1ff}.control-subline{color:#a8bddf}}}.hidden{display:none!important}.relative{position:relative}.absolute{position:absolute}.top-0{top:0}.right-0{right:0}.flex{display:flex}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.gap-2{gap:.5rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-8{padding:2rem}.pt-4{padding-top:1rem}.mt-4{margin-top:1rem}.mx-auto{margin-left:auto;margin-right:auto}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.min-h-\[400px\]{min-height:400px}.max-w-2xl{max-width:42rem}.rounded-lg{border-radius:.5rem}.overflow-x-auto{overflow-x:auto}.text-center{text-align:center}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.leading-relaxed{line-height:1.625}.list-disc{list-style-type:disc}.list-inside{list-style-position:inside}.whitespace-pre-wrap{white-space:pre-wrap}@media(min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.app-shell{background:radial-gradient(circle at 4% 3%,rgb(59 130 246 / .07),transparent 34%),radial-gradient(circle at 96% 4%,rgb(30 64 175 / .08),transparent 32%),linear-gradient(180deg,#f8fafc,#f1f5f9)}.sidebar-panel,.dashboard-view .sidebar-panel{width:16rem;border-right:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0f}.brand-panel,.dashboard-view .brand-panel{padding:1.5rem;border-bottom:1px solid #f1f5f9;background:#fff}.brand-overline,.dashboard-view .brand-overline{font-size:.72rem;letter-spacing:.12em;color:#3b82f6}.brand-title,.dashboard-view .brand-title{margin:.28rem 0 .16rem;font-size:1.6rem;color:#0f172a;letter-spacing:-.015em}.brand-desc,.dashboard-view .brand-desc{font-size:.86rem;color:#64748b}.sidebar-nav,.dashboard-view .sidebar-nav{padding:.6rem .75rem .9rem;gap:.25rem}.nav-item,.dashboard-view .nav-item{min-height:2.75rem;padding:.55rem .72rem;border-radius:.66rem;border:1px solid transparent;color:#475569;font-size:.9rem}.nav-item:hover,.dashboard-view .nav-item:hover{border-color:#e2e8f0;background:#f8fafc;color:#0f172a}.nav-item.active,.dashboard-view .nav-item.active{border-color:#bfdbfe;background:#eff6ff;color:#2563eb;box-shadow:0 1px 2px #0f172a0a}.sidebar-foot,.dashboard-view .sidebar-foot{margin:1rem;padding:1rem;border-radius:.75rem;border:1px solid #f1f5f9;background:#f8fafc}.sidebar-foot-title,.dashboard-view .sidebar-foot-title{text-align:center;font-size:.72rem;color:#64748b}.goal-track,.dashboard-view .goal-track{height:.5rem;background:#e2e8f0}.goal-fill,.dashboard-view .goal-fill{background:#3b82f6}.progress-pill,.dashboard-view .progress-pill{width:100%;justify-content:center;margin-top:.55rem;padding:0;font-size:.75rem;font-weight:700;color:#475569;background:transparent}.content-panel,.dashboard-view .content-panel{margin-left:16rem;padding:2rem;background:#f8fafc80}.content-inner,.dashboard-view .content-inner{max-width:80rem}.page-section,.dashboard-view .page-section{gap:1.5rem}.surface-card{border-radius:.75rem;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0206170d,0 2px 4px -2px #0206170d}.section-title{font-size:clamp(1.5rem,2.4vw,2rem);color:#0f172a}.section-desc{margin-top:.4rem;font-size:1rem;color:#64748b}.card-title{font-size:1.12rem;color:#0f172a}.action-btn{border-radius:.5rem;font-size:.88rem;font-weight:600}.action-btn-primary{min-height:2.75rem;padding:.6rem 1.25rem;background:#2563eb;box-shadow:0 10px 15px -3px #2563eb40}.action-btn-small{min-height:2.25rem;padding:.48rem .95rem;background:#2563eb}.action-btn-gradient{min-height:2.9rem;padding:.75rem 1rem;background:#2563eb}.action-btn-ghost{min-height:2.9rem;padding:.75rem 1rem;color:#334155;border-color:#e2e8f0;background:#fff}.action-btn-ghost:hover{background:#f8fafc}.dashboard-hero{padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.dashboard-view .dashboard-hero .section-title{font-size:clamp(1.55rem,2.5vw,1.92rem)}.dashboard-view .dashboard-hero .section-desc{font-size:1rem}.dashboard-hero-btn{min-height:2.75rem;border-radius:.5rem}.dashboard-metrics-grid{gap:1.5rem}.dashboard-metric-card{min-height:9rem;padding:1.5rem}.dashboard-metric-icon{top:.8rem;right:.8rem;opacity:.12}.dashboard-metric-icon .material-icons-round{font-size:3.6rem}.dashboard-metric-label{font-size:.95rem}.dashboard-metric-number{font-size:2.3rem}.dashboard-chart-card{min-height:26.25rem;padding:1.5rem}.dashboard-donut{width:16rem;height:16rem}.dashboard-donut-value{font-size:2.4rem}.dashboard-donut-label{font-size:.78rem}.dashboard-donut-legend{margin-top:1rem;font-size:.88rem}.dashboard-domain-bars{padding:0 1rem 2rem}.domain-bar-track{background:#f1f5f9}.domain-bar-fill{background:#3b82f6cc}.domain-bar-label{color:#64748b}.dashboard-domain-axis{border-top:1px solid #f1f5f9;color:#94a3b8}.controls-header-row{align-items:flex-end;justify-content:space-between;gap:1rem}.controls-header-copy{max-width:48rem}.controls-progress-view{display:flex;align-items:center;gap:.85rem;margin-bottom:.2rem}.controls-progress-copy{display:flex;flex-direction:column;align-items:flex-end;gap:.08rem}.controls-progress-label{font-size:.84rem;font-weight:500;color:#64748b}.controls-progress-value{font-size:1.72rem;font-weight:700;line-height:1;color:#2563eb}.controls-progress-ring{width:3rem;height:3rem;position:relative}.controls-progress-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.controls-progress-ring-track{fill:none;stroke:#e2e8f0;stroke-width:4}.controls-progress-ring-fill{fill:none;stroke:#2563eb;stroke-width:4;stroke-linecap:round;transition:stroke-dasharray .5s ease}.controls-toolbar{padding:1rem;gap:.75rem}.controls-search-input{min-height:2.75rem;border-radius:.75rem;background:#f1f5f9;color:#0f172a;font-size:.9rem;padding-left:2.35rem}.controls-search-icon{left:.75rem;color:#94a3b8}.controls-select-box{min-height:2.75rem;border-radius:.75rem;border-color:#e2e8f0;background:#f1f5f9;padding:.4rem 2rem .4rem .72rem}.controls-select-prefix{font-size:.82rem;color:#475569}.controls-select-input{font-size:.83rem;color:#334155}.controls-select-icon{color:#64748b}.controls-more-btn{min-height:2.75rem;border-radius:.75rem;border-color:#e2e8f0;background:#f1f5f9;color:#334155;font-size:.83rem}.controls-more-btn.active{border-color:#93c5fd;background:#dbeafe;color:#2563eb}.table-shell,.controls-table-shell{border-color:#e2e8f0}.controls-table{width:100%;border-collapse:collapse}.controls-table-modern th{padding:1rem 1.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#64748b;background:#f8fafc99;border-bottom:1px solid #e2e8f0}.control-head-id{width:6.5rem}.control-head-name{text-align:center}.control-head-domain{width:16rem}.control-head-state{width:8rem}.control-head-actions{width:14rem;text-align:right}.controls-table-modern td{padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.control-row-clickable{cursor:pointer}.control-row{transition:background-color .2s ease}.control-row:hover{background:#f8fafc}.control-id-chip{border-radius:.375rem;padding:.22rem .62rem;font-size:.82rem;color:#475569;background:#f1f5f9}.control-name-cell{min-width:18rem;text-align:center}.control-title{font-size:.92rem;color:#0f172a}.control-subline{font-size:.78rem;color:#64748b}.domain-pill{font-size:.75rem;gap:.38rem}.domain-pill-1{color:#1d4ed8;background:#eff6ff}.domain-pill-1 .domain-pill-dot{background:#3b82f6}.domain-pill-2{color:#6d28d9;background:#f5f3ff}.domain-pill-2 .domain-pill-dot{background:#8b5cf6}.domain-pill-3{color:#047857;background:#ecfdf5}.domain-pill-3 .domain-pill-dot{background:#10b981}.status-pill{font-size:.74rem}.status-ready{color:#475569;border-color:#e2e8f0;background:#f1f5f9}.status-studying{color:#c2410c;border-color:#fed7aa;background:#fff7ed}.status-complete{color:#047857;border-color:#bbf7d0;background:#ecfdf5}.status-review{color:#6d28d9;border-color:#ddd6fe;background:#f5f3ff}.control-actions-cell{text-align:right;white-space:nowrap}.bookmark-btn{width:2.2rem;height:2.2rem;border-radius:.65rem;color:#94a3b8}.bookmark-btn:hover,.bookmark-btn.active{color:#2563eb;background:#dbeafe}.bookmark-btn.active .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 600,"GRAD" 0,"opsz" 20}.control-action{min-height:2.25rem;padding:.42rem .88rem;border-radius:.5rem;font-size:.81rem}.control-action-primary{background:#2563eb;box-shadow:0 1px 2px #2563eb42}.control-action-ghost{color:#475569;border-color:#e2e8f0;background:#fff}.control-action-ghost:hover{background:#f8fafc}.controls-footer{padding:.95rem 1.5rem;border-top:1px solid #e2e8f0}.controls-footer-count{font-size:.84rem;color:#64748b}.pagination-btn{min-width:2.15rem;min-height:2.05rem;font-size:.82rem;border-color:#e2e8f0;color:#64748b}.pagination-btn.active{border-color:#93c5fd;background:#dbeafe;color:#1d4ed8}.control-detail-shell{display:grid;gap:1rem;padding:1.5rem}.control-detail-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.control-detail-back{min-height:2.4rem;padding:.42rem .88rem}.control-detail-back .material-symbols-outlined{font-size:1rem}.control-detail-badges{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.control-detail-head{display:grid;gap:.24rem}.control-detail-id{margin:0;font-family:var(--font-mono);font-size:.82rem;color:#2563eb}.control-detail-title{margin:0}.control-detail-sub{margin:0;color:#64748b;font-size:.86rem}.control-detail-content{border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem;background:#f8fafc}.control-detail-content .card-title{margin-bottom:.62rem;display:flex;align-items:center;gap:.4rem}.detail-title-symbol{color:#2563eb;font-weight:800;font-size:.86rem}.control-detail-text{margin:0;color:#1e293b;line-height:1.72;font-size:.92rem;white-space:pre-line}.control-detail-grid{display:grid;gap:.75rem;grid-template-columns:repeat(2,minmax(0,1fr))}.control-detail-content-list{align-content:start}.control-detail-criterion{border-color:#dbe7ff;background:#f5f8ff}.control-detail-list{margin:0;padding:0;list-style:none;display:grid;gap:.58rem}.control-detail-list-item{display:grid;grid-template-columns:1.1rem minmax(0,1fr);align-items:flex-start;gap:.46rem}.detail-item-icon{margin-top:.06rem;font-size:1rem;color:#2563eb}.control-detail-list-criterion .detail-item-icon{color:#1d4ed8}.detail-item-text{color:#334155;line-height:1.66;font-size:.89rem;white-space:pre-line}.keyword-line{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.36rem}.keyword-lead{color:#1d4ed8;font-weight:800}.keyword-chip{display:inline-flex;align-items:center;padding:.14rem .46rem;border-radius:999px;font-size:.77rem;font-weight:700;color:#1d4ed8;border:1px solid #cadcff;background:#e3ecff}.keyword-inline{color:#2563eb;font-weight:700}.control-detail-list li{margin:0}input[type=checkbox]{appearance:none;-webkit-appearance:none;width:1.05rem;height:1.05rem;border-radius:.24rem;border:1.5px solid #cbd5e1;background:#fff;display:inline-grid;place-content:center;cursor:pointer;transition:border-color .2s ease,background-color .2s ease}input[type=checkbox]:before{content:"";width:.56rem;height:.56rem;transform:scale(0);transition:transform .14s ease;background:#2563eb;clip-path:polygon(14% 52%,0 67%,39% 100%,100% 24%,85% 10%,39% 71%)}input[type=checkbox]:checked{border-color:#2563eb;background:#dbeafe}input[type=checkbox]:checked:before{transform:scale(1)}.scenario-select-shell{position:relative}.scenario-select{appearance:none;-webkit-appearance:none;min-height:2.9rem;border-radius:.75rem;border-color:#e2e8f0;background:#f8fafc;color:#1e293b;padding-right:2.4rem}.scenario-select-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#64748b;font-size:1.1rem}.scenario-preview-shell{border:1px solid #e2e8f0;border-radius:.75rem;background:#f8fafc;padding:.75rem}.scenario-preview-head{display:inline-flex;align-items:center;gap:.32rem;margin-bottom:.5rem;font-size:.8rem;font-weight:600;color:#475569}.scenario-preview-head .material-symbols-outlined{font-size:1rem}.scenario-preview-box{width:100%;min-height:12rem;resize:vertical;border-radius:.66rem;border:1px solid #d5deed;background:#fff;color:#1e293b;padding:.72rem .8rem;font-size:.82rem;line-height:1.58;box-shadow:inset 0 1px #11234f0d}.scenario-preview-box:focus{outline:none;border-color:#1f48e4;box-shadow:0 0 0 3px #1337ec26}.section-head,.prompt-lab-card,.trainer-card{padding:1.5rem}.prompt-tab{border-radius:.66rem;font-size:.8rem}.prompt-box{border-color:#1e40af;background:linear-gradient(180deg,#13284e,#10223f)}.modern-select,.difficulty-btn{border-color:#e2e8f0;background:#f8fafc}.toast-pop{border-radius:.75rem}@media(max-width:980px){.sidebar-panel,.dashboard-view .sidebar-panel{position:static;width:100%;border-right:0;border-bottom:1px solid #e2e8f0;box-shadow:none}.sidebar-nav,.dashboard-view .sidebar-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.nav-item,.dashboard-view .nav-item{min-height:3.1rem;padding:.52rem .5rem;font-size:.74rem;flex-direction:column;justify-content:center;gap:.26rem}.sidebar-foot,.dashboard-view .sidebar-foot{margin:.75rem}.content-panel,.dashboard-view .content-panel{margin-left:0;max-height:none;overflow-y:visible;padding:1rem}.dashboard-hero{padding:1.25rem;flex-direction:column;align-items:flex-start}.dashboard-hero-btn{width:100%}.dashboard-chart-card{min-height:0;padding:1rem}.dashboard-donut{width:12.5rem;height:12.5rem}.dashboard-domain-bars{height:16rem;padding:0 .2rem 1.3rem;gap:.7rem}.domain-bar-label{font-size:.73rem}.controls-header-row{flex-direction:column;align-items:flex-start;gap:.7rem}.controls-progress-view{margin-bottom:0}.controls-progress-copy{align-items:flex-start}.controls-progress-ring{width:2.65rem;height:2.65rem}.controls-toolbar{flex-direction:column;align-items:stretch}.controls-toolbar-actions{width:100%;flex-wrap:wrap}.controls-select-box,.controls-more-btn{min-width:11rem;flex:1}.controls-table-shell{height:auto!important;max-height:none}.controls-head{display:none}.controls-table-modern,.controls-table-modern tbody,.controls-table-modern tr,.controls-table-modern td{display:block;width:100%}.control-row{border:1px solid #e2e8f0;border-radius:.86rem;margin:.5rem;padding:.5rem .75rem .65rem;background:#fff;box-shadow:0 4px 6px -1px #0206170d}.controls-table-modern td{border:0;padding:.26rem 0}.control-id-cell{order:1}.control-name-cell{order:2;min-width:0}.control-domain-cell{order:3}.control-status-cell{order:4}.control-actions-cell{order:5;display:flex;justify-content:flex-end;padding-top:.44rem}.controls-footer{flex-direction:column;align-items:flex-start;padding:.9rem 1rem}.control-detail-shell{padding:1rem}.control-detail-top{align-items:flex-start;flex-direction:column}.control-detail-back{width:100%}.control-detail-content{padding:.88rem}.control-detail-grid{grid-template-columns:1fr}.control-detail-list-item{grid-template-columns:1rem minmax(0,1fr);gap:.38rem}.scenario-preview-box{min-height:10rem}.controls-pagination{width:100%;overflow-x:auto;padding-bottom:.18rem}}@media(prefers-color-scheme:dark){.app-shell{background:radial-gradient(circle at 8% 4%,rgb(59 130 246 / .2),transparent 42%),radial-gradient(circle at 95% 6%,rgb(37 99 235 / .16),transparent 40%),linear-gradient(180deg,#0f172a,#111827)}.sidebar-panel,.dashboard-view .sidebar-panel{border-right-color:#334155;background:#1e293b;box-shadow:0 1px 2px #02061766}.brand-panel,.dashboard-view .brand-panel{border-bottom-color:#334155;background:#1e293b}.brand-overline,.dashboard-view .brand-overline{color:#60a5fa}.brand-title,.dashboard-view .brand-title{color:#f8fafc}.brand-desc,.sidebar-foot-title,.dashboard-view .brand-desc,.dashboard-view .sidebar-foot-title,.nav-item,.dashboard-view .nav-item{color:#94a3b8}.nav-item:hover,.dashboard-view .nav-item:hover{border-color:#334155;background:#1e293b8c;color:#f8fafc}.nav-item.active,.dashboard-view .nav-item.active{border-color:#3b82f659;background:#3b82f633;color:#60a5fa}.sidebar-foot,.dashboard-view .sidebar-foot{border-color:#334155;background:#1e293b94}.goal-track,.dashboard-view .goal-track{background:#334155}.progress-pill,.dashboard-view .progress-pill{color:#cbd5e1}.content-panel,.dashboard-view .content-panel{background:#0f172a80}.surface-card,.dashboard-hero,.dashboard-metric-card,.dashboard-chart-card{border-color:#334155;background:#1e293b;box-shadow:0 4px 6px -1px #02061747,0 2px 4px -2px #02061740}.section-title,.card-title,.trainer-title,.control-title,.dashboard-metric-number,.dashboard-donut-value{color:#f8fafc}.section-desc,.controls-progress-label,.dashboard-donut-label,.dashboard-donut-legend,.dashboard-metric-label,.dashboard-metric-unit,.dashboard-domain-axis,.domain-bar-label,.control-subline,.controls-footer-count,.controls-table-modern th{color:#94a3b8}input[type=checkbox]{border-color:#475569;background:#1f2937}input[type=checkbox]:before{background:#60a5fa}input[type=checkbox]:checked{border-color:#60a5fa;background:#3b82f63d}.control-detail-sub,.control-detail-id{color:#94a3b8}.action-btn-ghost{color:#d6e4ff;border-color:#334155;background:#1f2937}.action-btn-ghost:hover{background:#273549}.controls-progress-ring-track{stroke:#334155}.controls-progress-ring-fill{stroke:#60a5fa}.controls-search-input,.controls-select-box,.controls-more-btn,.control-action-ghost,.pagination-btn,.modern-select,.difficulty-btn{border-color:#334155;background:#1f2937;color:#dbeafe}.controls-search-input::placeholder,.controls-search-icon,.controls-select-prefix,.controls-select-icon{color:#93add8}.controls-select-input{color:#dbeafe}.scenario-select{border-color:#334155;background:#1f2937;color:#dbeafe}.scenario-select-icon{color:#93add8}.scenario-preview-shell{border-color:#334155;background:#1f2937}.scenario-preview-head{color:#94a3b8}.scenario-preview-box{border-color:#334155;background:#0f172a;color:#dbeafe;box-shadow:none}.controls-more-btn.active,.pagination-btn.active{border-color:#60a5fa99;background:#3b82f638;color:#bfdbfe}.controls-table-shell,.controls-footer{border-color:#334155}.controls-table-modern th{background:#1e293bb3;border-bottom-color:#334155}.controls-table-modern td{border-bottom-color:#334155}.control-detail-content{border-color:#334155;background:#1f2937}.control-detail-criterion{border-color:#1e3a8a;background:#1e3a8a33}.control-detail-text{color:#e2e8f0}.control-detail-list{color:#d1d5db}.detail-item-icon,.detail-title-symbol{color:#93c5fd}.detail-item-text{color:#d1d5db}.keyword-lead,.keyword-inline{color:#bfdbfe}.keyword-chip{color:#bfdbfe;border-color:#3b82f6;background:#1e40af4d}.control-row:hover{background:#1e293b80}.control-id-chip{background:#1f2937;color:#cbd5e1}.domain-pill-1{color:#bfdbfe;background:#1e40af47}.domain-pill-1 .domain-pill-dot{background:#60a5fa}.domain-pill-2{color:#ddd6fe;background:#6d28d942}.domain-pill-2 .domain-pill-dot{background:#a78bfa}.domain-pill-3{color:#bbf7d0;background:#05966940}.domain-pill-3 .domain-pill-dot{background:#34d399}.status-ready{color:#cbd5e1;border-color:#475569;background:#334155}.status-studying{color:#fed7aa;border-color:#9a3412;background:#9a341259}.status-complete{color:#bbf7d0;border-color:#065f46;background:#065f4659}.status-review{color:#ddd6fe;border-color:#6d28d9;background:#6d28d94d}.bookmark-btn{color:#94a3b8}.bookmark-btn:hover,.bookmark-btn.active{color:#bfdbfe;background:#3b82f633}.control-action-primary{background:#3b82f6;box-shadow:0 1px 2px #3b82f659}.prompt-box{border-color:#325fc5;background:linear-gradient(180deg,#0d1932,#111f3b);color:#e8f1ff}.dashboard-donut-track{stroke:#334155}.dashboard-donut-fill{stroke:#60a5fa}.legend-dot-gray{background:#64748b}.domain-bar-track{background:#334155}.dashboard-domain-axis{border-top-color:#334155}.domain-bar-tip{background:#0f172a}@media(max-width:980px){.sidebar-panel,.dashboard-view .sidebar-panel{border-bottom-color:#334155}.control-row{border-color:#334155;background:#1e293b;box-shadow:none}}}.top-action-menu{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.top-action-btn{min-height:2.2rem;padding:.46rem .78rem;font-size:.78rem}.top-action-btn .material-symbols-outlined{font-size:.96rem}.top-action-btn-danger{border-color:#fecaca;color:#b91c1c;background:#fff5f5}.top-action-btn-danger:hover{border-color:#fda4af;color:#991b1b;background:#ffe4e6}.auth-inline-alert{margin-bottom:.75rem}.auth-shell{border-color:#dbe4f4;background:linear-gradient(180deg,#f8fbff,#f3f8ff);padding:1rem 1.1rem;display:grid;gap:.75rem}.auth-state{display:grid;gap:.5rem}.auth-state-warning .auth-title{color:#b45309}.auth-state-success .auth-title{color:#0f4f98}.auth-title{margin:0;font-size:.95rem;font-weight:700;color:#1e3a8a}.auth-desc{margin:0;font-size:.82rem;color:#4b5f83;line-height:1.55}.auth-user-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.auth-user-email{margin:.22rem 0 0;font-size:.84rem;color:#1e293b}.auth-logout-btn{min-height:2.2rem}.auth-user-actions{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.auth-history-btn,.auth-toggle-btn{min-height:2.2rem;padding:.46rem .82rem}.auth-mode-row{display:inline-flex;align-items:center;border:1px solid #d9e2f6;border-radius:.68rem;overflow:hidden;width:fit-content}.auth-mode-btn{border:0;background:#f8fafc;color:#475569;min-height:2rem;padding:.32rem .75rem;font-size:.8rem;font-weight:700}.auth-mode-btn.active{background:#e5efff;color:#1d4ed8}.auth-form{display:grid;gap:.52rem;max-width:26rem}.auth-form-wrap{display:grid;gap:.6rem}.auth-field{display:grid;gap:.24rem;font-size:.76rem;font-weight:600;color:#475569}.auth-field input{min-height:2.35rem;border:1px solid #d6e2f2;border-radius:.64rem;padding:.45rem .68rem;font-size:.84rem;color:#1e293b;background:#fff}.auth-field input:focus{outline:2px solid rgb(59 130 246 / .3)}.auth-submit-btn{width:fit-content;min-width:6.4rem}.auth-error,.auth-notice{margin:0;font-size:.79rem;border-radius:.56rem;padding:.42rem .58rem}.auth-error{color:#b42318;background:#fee4e2}.auth-notice{color:#0f4f98;background:#e7f0ff}.controls-reset-btn{border:1px solid #dbe4f4;border-radius:.7rem;background:#f8fafd;color:#3f557f;min-height:2.3rem;padding:.36rem .72rem;display:inline-flex;align-items:center;gap:.32rem;font-size:.78rem;font-weight:600}.controls-reset-btn .material-symbols-outlined{font-size:1rem}.controls-reset-btn:hover{border-color:#93c5fd;background:#e8f1ff;color:#1e40af}.controls-reset-btn:disabled{opacity:.56;cursor:not-allowed}.controls-history-shell{border-color:#dbe4f4;padding:.95rem 1rem;display:grid;gap:.68rem}.controls-history-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem;flex-wrap:wrap}.controls-history-head .card-title{margin:0}.controls-history-refresh{border:1px solid #dbe4f4;border-radius:.58rem;background:#f8fafd;color:#3f557f;min-height:2rem;padding:.3rem .6rem;font-size:.76rem;font-weight:600;display:inline-flex;align-items:center;gap:.28rem}.controls-history-refresh .material-symbols-outlined{font-size:.96rem}.controls-history-refresh:disabled{opacity:.56;cursor:not-allowed}.controls-history-empty{margin:0;font-size:.82rem;color:#64748b}.controls-history-list{margin:0;padding:0;list-style:none;display:grid;gap:.44rem}.controls-history-item{border:1px solid #e5edf9;border-radius:.62rem;background:#f8fbff;padding:.5rem .6rem;display:flex;align-items:center;justify-content:space-between;gap:.62rem;flex-wrap:wrap}.controls-history-main{display:inline-flex;align-items:center;gap:.5rem;min-width:0}.controls-history-id{font-family:var(--font-mono);font-size:.76rem;color:#4b5f83;background:#eef3fb;border-radius:.38rem;padding:.14rem .42rem}.controls-history-name{font-size:.82rem;color:#1e293b;font-weight:600}.controls-history-meta{display:inline-flex;align-items:center;gap:.32rem;font-size:.76rem;color:#475569}.controls-history-meta .material-symbols-outlined{font-size:.92rem}.controls-history-meta time{margin-left:.18rem;color:#6b7280}.control-action:disabled{opacity:.58;cursor:not-allowed;box-shadow:none}@media(max-width:980px){.top-action-menu{margin-bottom:.65rem;gap:.42rem}.top-action-btn{flex:1 1 calc(50% - .42rem);justify-content:center;min-width:7.6rem}.top-action-btn-danger{flex-basis:100%}.auth-shell{padding:.9rem}.auth-form{max-width:none}.controls-reset-btn{min-height:2.2rem}.controls-history-item{align-items:flex-start}}@media(prefers-color-scheme:dark){.top-action-btn{border-color:#334155;background:#1f2937;color:#d1d5db}.top-action-btn:hover{background:#111827;color:#e2e8f0}.top-action-btn-danger{border-color:#7f1d1d;color:#fecaca;background:#7f1d1d52}.top-action-btn-danger:hover{background:#7f1d1d73;color:#fee2e2}.auth-shell{border-color:#334155;background:linear-gradient(180deg,#132036,#16263f)}.auth-title{color:#bfdbfe}.auth-desc,.auth-field{color:#94a3b8}.auth-user-email{color:#e2e8f0}.auth-mode-row,.auth-field input,.controls-reset-btn,.controls-history-refresh,.controls-history-item{border-color:#334155}.auth-mode-btn,.auth-field input,.controls-reset-btn,.controls-history-refresh,.controls-history-item{background:#1f2937;color:#d1d5db}.auth-mode-btn.active{background:#1e40af61;color:#bfdbfe}.controls-reset-btn:hover,.controls-history-refresh:hover{background:#1e40af47;color:#bfdbfe}.auth-error{color:#fecaca;background:#991b1b57}.auth-notice{color:#bfdbfe;background:#1e40af57}.controls-history-empty,.controls-history-meta,.controls-history-meta time{color:#94a3b8}.controls-history-id{color:#cbd5e1;background:#0f172a}.controls-history-name{color:#e2e8f0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
