*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.rounded{border-radius:.25rem}.border{border-width:1px}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--bg-primary:#fff;--bg-secondary:#f7f9fc;--text-primary:#0e1724;--text-secondary:#4a5568;--text-tertiary:#8896a8;--border-light:rgba(0,0,0,.07);--border-medium:rgba(0,0,0,.13);--blue:#185fa5;--blue-light:#e6f1fb;--blue-dark:#0f4880;--green-wa:#25d366;--green-wa-dark:#1ead52;--error:#d93025;--error-light:#fce8e6;--radius-sm:6px;--radius-lg:16px;--shadow-card:0 1px 3px rgba(0,0,0,.06),0 8px 28px rgba(0,0,0,.07);--transition:.18s ease;--bg:#fff;--bg2:#f7f9fc;--bg3:#eef2f8;--t1:#0e1724;--t2:#4a5568;--t3:#8896a8;--bl:rgba(0,0,0,.07);--bm:rgba(0,0,0,.11);--blueLt:#e6f1fb;--blueDk:#0f4880;--green:#1d9e75;--greenLt:#eaf3de;--greenTx:#2e6b0d;--amber:#d97706;--amberLt:#faeeda;--amberTx:#854f0b;--red:#d93025;--redLt:#fce8e6;--teal:#0f6e56;--tealLt:#e1f5ee;--purple:#6b4fbb;--purpleLt:#ede9f8;--purpleTx:#3d2880;--wa:#25d366;--waDk:#1ead52;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-pill:999px;--shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);--shadow-md:0 2px 8px rgba(0,0,0,.08),0 8px 24px rgba(0,0,0,.06);--tr:.18s ease;--sidebar-w:240px;--sidebar-icon-w:58px;--topbar-h:58px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;color:var(--t1);background:var(--bg2);overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}ul{list-style:none}.login-body{font-size:15px;color:var(--text-primary);background:var(--bg-secondary);min-height:100dvh;display:flex;flex-direction:column}.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--bg-primary);border-bottom:1px solid var(--border-light)}.nav-logo{font-size:17px;font-weight:600;letter-spacing:-.3px}.nav-logo span{color:var(--blue)}.nav-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary);transition:color var(--transition)}.nav-back:hover{color:var(--blue)}.page{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}.card-login{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);width:100%;max-width:400px;padding:36px 32px 32px}.card-logo{font-size:15px;font-weight:600;color:var(--text-tertiary);letter-spacing:-.2px;margin-bottom:20px}.card-logo span{color:var(--blue)}.card-heading{font-size:22px;font-weight:600;letter-spacing:-.4px;margin-bottom:6px}.card-sub{font-size:13.5px;color:var(--text-secondary);margin-bottom:28px;line-height:1.55}.form-group{margin-bottom:18px}label{display:block;font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--text-secondary);text-transform:uppercase}.label-row,label{margin-bottom:7px}.label-row{display:flex;align-items:center;justify-content:space-between}.label-row label{margin-bottom:0}.forgot{font-size:12px;font-weight:500;color:var(--blue);transition:opacity var(--transition)}.forgot:hover{opacity:.7}.input-wrap{position:relative}.input-icon{left:12px;pointer-events:none}.input-icon,.input-toggle{position:absolute;top:50%;transform:translateY(-50%);color:var(--text-tertiary);display:flex;align-items:center}.input-toggle{right:12px;background:none;border:none;padding:2px;transition:color var(--transition)}.input-toggle:hover{color:var(--text-primary)}input[type=email],input[type=password]{width:100%;padding:10px 12px 10px 38px;font-family:inherit;font-size:14px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}input[type=email]:focus,input[type=password]:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(24,95,165,.1)}input::-moz-placeholder{color:var(--text-tertiary)}input::placeholder{color:var(--text-tertiary)}.check-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.check-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--blue);cursor:pointer;flex-shrink:0}.form-error{display:none;background:var(--error-light);color:var(--error);font-size:13px;font-weight:500;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:18px;border:1px solid rgba(217,48,37,.15)}.form-error.show{display:block}.btn-login{width:100%;padding:12px;background:var(--blue);color:#fff;font-size:14.5px;font-weight:600;border:none;border-radius:var(--radius-sm);margin-top:4px;transition:background var(--transition),transform var(--transition)}.btn-login:hover{background:var(--blue-dark);transform:translateY(-1px)}.btn-login:active{transform:none}.divider{display:flex;align-items:center;gap:12px;margin:22px 0;font-size:12px;color:var(--text-tertiary);font-weight:500}.divider:after,.divider:before{content:"";flex:1;height:1px;background:var(--border-light)}.btn-wa{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;padding:11px;background:var(--green-wa);color:#fff;font-size:13.5px;font-weight:600;border:none;border-radius:var(--radius-sm);transition:background var(--transition),transform var(--transition)}.btn-wa:hover{background:var(--green-wa-dark);transform:translateY(-1px)}.trust-note{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-light);font-size:12px;color:var(--text-tertiary)}@media (max-width:480px){.card-login{padding:28px 20px 24px}}.app{display:flex;min-height:100dvh}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--bl);flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:width var(--tr),transform var(--tr);overflow:hidden}.sidebar,.sidebar-header{flex-shrink:0;display:flex}.sidebar-header{align-items:center;justify-content:space-between;padding:0 16px;height:var(--topbar-h);border-bottom:1px solid var(--bl)}.sidebar-logo{font-size:16px;font-weight:600;letter-spacing:-.3px;white-space:nowrap;overflow:visible;transition:opacity var(--tr);flex-shrink:1;min-width:0;display:flex;align-items:center}.sidebar-logo span{color:var(--blue)}.sidebar-collapse{padding:5px;border-radius:var(--r-sm);color:var(--t3);transition:background var(--tr),color var(--tr);flex-shrink:0}.sidebar-collapse:hover{background:var(--bg2);color:var(--t1)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--bl);border-radius:4px}.nav-section-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);padding:8px 20px 4px;white-space:nowrap;overflow:hidden;transition:opacity var(--tr)}.nav-divider{height:1px;background:var(--bl);margin:8px 12px}.nav-link{display:flex;align-items:center;gap:11px;padding:9px 16px;border-radius:var(--r-sm);margin:1px 8px;color:var(--t2);font-size:13.5px;font-weight:500;transition:background var(--tr),color var(--tr);white-space:nowrap;overflow:hidden;position:relative}.nav-link:hover{background:var(--bg2);color:var(--t1)}.nav-link.active{background:var(--blueLt);color:var(--blue)}.nav-section-btn{display:flex;align-items:center;gap:11px;padding:9px 16px;border-radius:var(--r-sm);margin:1px 8px;color:var(--t2);font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;position:relative;width:calc(100% - 16px);transition:background var(--tr),color var(--tr)}.nav-section-btn:hover{background:var(--bg2);color:var(--t1)}.nav-section-btn.active{background:var(--blueLt);color:var(--blue)}.nav-section-btn .nav-icon{flex-shrink:0;display:flex;align-items:center}.nav-section-btn .nav-label{overflow:hidden;transition:opacity var(--tr),max-width var(--tr);max-width:160px}.nav-section-btn .nav-badge{flex-shrink:0;background:var(--red);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--r-pill);transition:opacity var(--tr)}.nav-link.nav-sub{font-size:12.5px;font-weight:400;padding-top:7px;padding-bottom:7px;color:var(--t3)}.nav-link.nav-sub:hover{color:var(--t1)}.nav-link.nav-sub.active{background:var(--blueLt);color:var(--blue);font-weight:500}.app.collapsed .nav-link.nav-sub,.app.collapsed .nav-subnav{display:none}.app.collapsed .nav-section-btn{padding:9px;margin:1px auto;justify-content:center;width:40px}.app.collapsed .nav-section-btn .nav-badge,.app.collapsed .nav-section-btn .nav-label{opacity:0;max-width:0;overflow:hidden}.app.collapsed .nav-section-btn svg:last-child{display:none}.nav-link .nav-icon{flex-shrink:0;display:flex;align-items:center}.nav-link .nav-label{overflow:hidden;transition:opacity var(--tr),max-width var(--tr);max-width:160px}.nav-link .nav-badge{margin-left:auto;flex-shrink:0;background:var(--red);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--r-pill);transition:opacity var(--tr)}.sidebar-footer{padding:12px 0 8px;border-top:1px solid var(--bl);flex-shrink:0}.app.collapsed .sidebar{width:var(--sidebar-icon-w)}.app.collapsed .nav-label,.app.collapsed .sidebar-logo{opacity:0;max-width:0}.app.collapsed .nav-badge,.app.collapsed .nav-section-label{opacity:0}.app.collapsed .nav-link{padding:9px;margin:1px auto;justify-content:center;width:40px}.app.collapsed .main{margin-left:var(--sidebar-icon-w)}.app.collapsed .sidebar-collapse svg{transform:rotate(180deg)}.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left var(--tr)}.topbar{position:sticky;top:0;z-index:40;height:var(--topbar-h);background:var(--bg);border-bottom:1px solid var(--bl);display:flex;align-items:center;padding:0 24px;gap:16px}.topbar-hamburger{display:none;padding:5px;color:var(--t2);border-radius:var(--r-sm)}.topbar-hamburger:hover{background:var(--bg2)}.topbar-greeting{flex:1}.topbar-greeting h2{font-size:15px;font-weight:600;letter-spacing:-.2px}.topbar-greeting p{font-size:12px;color:var(--t3);margin-top:1px}.topbar-title-wrap{flex:1}.topbar-title-wrap h2{font-size:15px;font-weight:600;letter-spacing:-.2px}.topbar-title-wrap p{font-size:12px;color:var(--t3);margin-top:1px}.topbar-streak{display:flex;align-items:center;gap:6px;background:var(--amberLt);border:1px solid #f0d4a0;border-radius:var(--r-pill);padding:5px 12px;font-size:12.5px;font-weight:600;color:var(--amberTx)}.topbar-notif{position:relative;padding:7px;border-radius:var(--r-md);color:var(--t2);transition:background var(--tr)}.topbar-notif:hover{background:var(--bg2)}.notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--bg)}.topbar-avatar{width:34px;height:34px;border-radius:50%;background:var(--blueLt);color:var(--blue);font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.content{flex:1;padding:24px;display:flex;flex-direction:column;gap:20px;max-width:1200px}.onboarding-banner{background:linear-gradient(135deg,var(--blue) 0,#1e7bc4 100%);border-radius:var(--r-lg);padding:18px 22px;display:flex;align-items:center;gap:16px;color:#fff}.onboarding-banner .ob-icon{font-size:26px;flex-shrink:0}.onboarding-banner .ob-text{flex:1}.onboarding-banner .ob-text h3{font-size:15px;font-weight:600;margin-bottom:3px}.onboarding-banner .ob-text p{font-size:13px;opacity:.85;line-height:1.45}.btn-ob{background:hsla(0,0%,100%,.2);color:#fff;border:1px solid hsla(0,0%,100%,.35);border-radius:var(--r-sm);padding:8px 16px;font-size:13px;font-weight:600;white-space:nowrap;transition:background var(--tr);flex-shrink:0}.btn-ob:hover{background:hsla(0,0%,100%,.3)}.ob-dismiss{color:hsla(0,0%,100%,.6);padding:4px;flex-shrink:0;transition:color var(--tr)}.ob-dismiss:hover{color:#fff}.hidden{display:none!important}.section-title{font-size:13px;font-weight:600;color:var(--t2);letter-spacing:.03em;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-title span{flex:1}.section-title a{font-size:12px;color:var(--blue);font-weight:500;text-transform:none;letter-spacing:0}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.stat-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}.stat-label{font-size:11.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}.stat-value{font-size:28px;font-weight:600;letter-spacing:-1px;line-height:1}.stat-sub{font-size:12px;color:var(--t3);line-height:1.4}.stat-progress-row{display:flex;align-items:center;gap:8px}.stat-bar{flex:1;height:5px;background:var(--bg3);overflow:hidden;margin-top:4px}.stat-bar,.stat-bar-fill{border-radius:var(--r-pill)}.stat-bar-fill{height:100%;transition:width 1s ease}.stat-card.blue .stat-value{color:var(--blue)}.stat-card.green .stat-value{color:var(--green)}.stat-card.amber .stat-value{color:var(--amber)}.stat-card.red .stat-value{color:var(--red)}.stat-value.blue{color:var(--blue)}.stat-value.green{color:var(--green)}.stat-value.amber{color:var(--amber)}.two-col{grid-template-columns:1fr 1fr}.three-col,.two-col{display:grid;gap:14px}.three-col{grid-template-columns:1.2fr 1fr 1fr}.card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14px;font-weight:600;margin-bottom:14px}.card-action{font-size:12px;color:var(--blue);font-weight:500}.score-pill{display:inline-block;padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600}.pill-red{background:var(--redLt);color:var(--red)}.pill-amber{background:var(--amberLt);color:var(--amberTx)}.pill-blue{background:var(--blueLt);color:var(--blue)}.pill-green{background:var(--greenLt);color:var(--greenTx)}.pill-purple{background:var(--purpleLt);color:var(--purpleTx)}.skill-list{gap:14px}.skill-list,.skill-row{display:flex;flex-direction:column}.skill-row{gap:5px}.skill-meta{justify-content:space-between}.skill-meta,.skill-name{display:flex;align-items:center}.skill-name{font-size:13px;font-weight:500;gap:7px}.skill-icon{font-size:14px}.skill-score-row{display:flex;align-items:center;gap:6px}.skill-score{font-size:13px;font-weight:600}.skill-clb{font-size:11px;color:var(--t3)}.skill-bar{height:7px;background:var(--bg2);overflow:hidden}.skill-bar,.skill-bar-fill{border-radius:var(--r-pill)}.skill-bar-fill{height:100%;transition:width 1.2s ease}.bar-red{background:linear-gradient(90deg,var(--red),#e05a51)}.bar-amber{background:linear-gradient(90deg,var(--amber),#f0a030)}.bar-blue{background:linear-gradient(90deg,var(--blue),#27c)}.bar-green{background:linear-gradient(90deg,var(--green),#25b885)}.ring-wrap{padding:8px 0 16px}.ring,.ring-wrap{display:flex;align-items:center;justify-content:center}.ring{width:110px;height:110px;border-radius:50%;background:conic-gradient(var(--blue) 0 59%,var(--bg2) 59% 100%);position:relative}.ring:before{content:"";position:absolute;width:80px;height:80px;background:var(--bg);border-radius:50%}.ring-inner{position:relative;z-index:1;text-align:center}.ring-value{font-size:22px;font-weight:600;letter-spacing:-1px;color:var(--blue)}.ring-label{font-size:10px;color:var(--t3);font-weight:500}.task-list{display:flex;flex-direction:column;gap:8px}.task-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--r-md);background:var(--bg2);border:1px solid var(--bl);cursor:pointer;transition:background var(--tr)}.task-item:hover{background:var(--bg3)}.task-item.done{opacity:.55}.task-cb{width:17px;height:17px;border-radius:4px;border:2px solid var(--bm);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr)}.task-item.done .task-cb{background:var(--green);border-color:var(--green)}.task-cb svg{display:none}.task-item.done .task-cb svg{display:block}.task-text{font-size:13px;font-weight:500;flex:1}.task-item.done .task-text{text-decoration:line-through;color:var(--t3)}.task-duration,.task-meta{font-size:11px;color:var(--t3);margin-top:2px}.task-duration{white-space:nowrap}.plan-progress{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;background:var(--blueLt);border-radius:var(--r-md);border:1px solid rgba(24,95,165,.12)}.plan-progress-text{font-size:13px;font-weight:600;color:var(--blue)}.plan-progress-sub{font-size:11.5px;color:var(--t3)}.module-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.module-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:18px 16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px;transition:box-shadow var(--tr),transform var(--tr);cursor:pointer}.module-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.module-icon-wrap{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:20px}.module-name{font-size:14px;font-weight:600}.module-score-row{display:flex;align-items:baseline;gap:5px}.module-score{font-size:22px;font-weight:600;letter-spacing:-.5px}.module-max{font-size:12px;color:var(--t3)}.module-clb,.module-last{font-size:11.5px;color:var(--t3)}.btn-practice{width:100%;padding:8px;border-radius:var(--r-sm);font-size:12.5px;font-weight:600;border:none;transition:background var(--tr),transform var(--tr)}.btn-practice:hover{transform:translateY(-1px)}.mc-red{border-top:3px solid var(--red)}.mc-amber{border-top:3px solid var(--amber)}.mc-blue{border-top:3px solid var(--blue)}.mc-green{border-top:3px solid var(--green)}.mc-red .module-score{color:var(--red)}.mc-red .btn-practice{background:var(--redLt);color:var(--red)}.mc-amber .module-score{color:var(--amber)}.mc-amber .btn-practice{background:var(--amberLt);color:var(--amberTx)}.mc-blue .module-score{color:var(--blue)}.mc-blue .btn-practice{background:var(--blueLt);color:var(--blue)}.mc-green .module-score{color:var(--green)}.mc-green .btn-practice{background:var(--greenLt);color:var(--greenTx)}.mc-red .module-icon-wrap{background:var(--redLt)}.mc-amber .module-icon-wrap{background:var(--amberLt)}.mc-blue .module-icon-wrap{background:var(--blueLt)}.mc-green .module-icon-wrap{background:var(--greenLt)}.activity-table{width:100%;border-collapse:collapse;font-size:13px}.activity-table th{text-align:left;font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;padding:0 10px 10px;border-bottom:1px solid var(--bl)}.activity-table td{padding:10px;border-bottom:1px solid var(--bl);vertical-align:middle}.activity-table tr:last-child td{border-bottom:none}.activity-table tbody tr:hover td{background:var(--bg2)}.trend-up{color:var(--green)}.trend-down,.trend-up{display:inline-flex;align-items:center;gap:2px}.trend-down{color:var(--red)}.trend-flat{color:var(--t3);display:inline-flex;align-items:center;gap:2px}.insight-list{display:flex;flex-direction:column;gap:10px}.insight-card{border-radius:var(--r-md);padding:12px 14px;display:flex;gap:11px;align-items:flex-start;border:1px solid var(--bl)}.insight-icon{font-size:18px;flex-shrink:0;margin-top:1px}.insight-title{font-size:13px;font-weight:600;margin-bottom:3px}.insight-body{font-size:12.5px;color:var(--t2);line-height:1.5}.insight-card.warn{background:var(--amberLt);border-color:rgba(217,119,6,.18)}.insight-card.tip{background:var(--blueLt);border-color:rgba(24,95,165,.15)}.insight-card.good{background:var(--greenLt);border-color:rgba(29,158,117,.18)}.mock-top{display:grid;grid-template-columns:1fr 2fr;gap:14px;align-items:start}.mock-cta-card{background:linear-gradient(145deg,var(--blue) 0,#1e7bc4 100%);border-radius:var(--r-lg);padding:24px 20px;color:#fff;text-align:center;box-shadow:0 4px 16px rgba(24,95,165,.3)}.mock-cta-card h3{font-size:16px;font-weight:600;margin-bottom:6px}.mock-cta-card p{font-size:12.5px;opacity:.8;margin-bottom:18px;line-height:1.5}.btn-start-mock{background:#fff;color:var(--blue);font-size:13.5px;font-weight:600;padding:10px 20px;border-radius:var(--r-sm);transition:background var(--tr),transform var(--tr);display:inline-block}.btn-start-mock:hover{background:var(--blueLt);transform:translateY(-1px)}.mock-results-table{width:100%;border-collapse:collapse;font-size:13px}.mock-results-table th{text-align:left;font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;padding:0 10px 10px;border-bottom:1px solid var(--bl)}.mock-results-table td{padding:11px 10px;border-bottom:1px solid var(--bl);vertical-align:middle}.mock-results-table tr:last-child td{border-bottom:none}.mock-results-table tbody tr:hover td{background:var(--bg2)}.clb-chip{display:inline-block;padding:3px 9px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600}.score-mini{font-size:12px}.achievements-row{display:flex;gap:12px;flex-wrap:wrap}.badge-item{flex-direction:column;gap:6px;width:72px;text-align:center}.badge-icon,.badge-item{display:flex;align-items:center}.badge-icon{width:48px;height:48px;border-radius:50%;justify-content:center;font-size:22px;border:2px solid transparent;transition:transform var(--tr)}.badge-icon:hover{transform:scale(1.1)}.badge-item.earned .badge-icon{background:var(--amberLt);border-color:#f0d4a0}.badge-item.locked .badge-icon{background:var(--bg2);border-color:var(--bl);filter:grayscale(1);opacity:.45}.badge-label{font-size:11px;color:var(--t2);font-weight:500;line-height:1.3}.badge-item.locked .badge-label{color:var(--t3)}.chart-wrap{display:flex;align-items:flex-end;gap:6px;height:80px;padding:0 4px}.chart-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.chart-bar{width:100%;border-radius:4px 4px 0 0;background:var(--blueLt);border:1px solid rgba(24,95,165,.2);transition:height 1s ease;min-height:8px}.chart-bar.best{background:var(--blue);border-color:var(--blue)}.chart-day{font-size:10px;color:var(--t3)}.chart-score{font-size:10px;font-weight:600;color:var(--t2)}.sidebar-backdrop{display:none;position:fixed;inset:0;z-index:49;background:rgba(0,0,0,.4);backdrop-filter:blur(2px)}.sp-views{flex:1}.sp-view{display:none}.sp-view.active{display:block}.hub-content{padding:24px;display:flex;flex-direction:column;gap:20px;max-width:1100px}.module-page-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.breadcrumb{font-size:12px;color:var(--t3);flex-basis:100%}.breadcrumb a{color:var(--blue)}.breadcrumb span{margin:0 5px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.4px}.task-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.task-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px;transition:box-shadow var(--tr),transform var(--tr);cursor:pointer}.task-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.task-card-top{display:flex;align-items:flex-start;justify-content:space-between}.task-icon-wrap{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px}.task-card-name{font-size:16px;font-weight:600}.task-card-score{font-size:24px;font-weight:600;letter-spacing:-.5px}.task-card-score span{font-size:13px;color:var(--t3);font-weight:400;letter-spacing:0}.task-card-desc{font-size:12.5px;color:var(--t2);line-height:1.5}.task-card-reqs{display:flex;flex-direction:column;gap:5px}.req-row{display:flex;align-items:flex-start;gap:7px;font-size:12.5px;color:var(--t2)}.req-icon{flex-shrink:0;margin-top:1px}.task-card-meta{display:flex;align-items:center;gap:8px;margin-top:2px;flex-wrap:wrap}.task-card-time{font-size:12px;color:var(--t3)}.difficulty-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--r-pill)}.difficulty-badge.easy{background:var(--greenLt);color:var(--greenTx)}.difficulty-badge.medium{background:var(--amberLt);color:var(--amberTx)}.difficulty-badge.hard{background:var(--redLt);color:var(--red)}.tc-red{border-top:3px solid var(--red)}.tc-red .task-icon-wrap{background:var(--redLt)}.tc-red .task-card-score{color:var(--red)}.tc-red .btn-practice{background:var(--redLt);color:var(--red)}.tc-amber{border-top:3px solid var(--amber)}.tc-amber .task-icon-wrap{background:var(--amberLt)}.tc-amber .task-card-score{color:var(--amber)}.tc-amber .btn-practice{background:var(--amberLt);color:var(--amberTx)}.tc-blue{border-top:3px solid var(--blue)}.tc-blue .task-icon-wrap{background:var(--blueLt)}.tc-blue .task-card-score{color:var(--blue)}.tc-blue .btn-practice{background:var(--blueLt);color:var(--blue)}.tc-green{border-top:3px solid var(--green)}.tc-green .task-icon-wrap{background:var(--greenLt)}.tc-green .task-card-score{color:var(--green)}.tc-green .btn-practice{background:var(--greenLt);color:var(--greenTx)}.practice-wrap{display:flex;flex-direction:column;min-height:calc(100dvh - var(--topbar-h))}.session-header{background:var(--bg);border-bottom:1px solid var(--bl);padding:0 24px;gap:16px;height:52px;flex-shrink:0}.btn-exit,.session-header{display:flex;align-items:center}.btn-exit{gap:6px;font-size:13px;font-weight:600;color:var(--t2);padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--bl);transition:background var(--tr),color var(--tr);white-space:nowrap}.btn-exit:hover{background:var(--bg2);color:var(--t1)}.session-info{display:flex;flex-direction:column;flex:1;min-width:0}.session-task-name{font-size:13px;font-weight:600;color:var(--t1)}.session-q-count{font-size:11.5px;color:var(--t3)}.session-prog-bar{width:120px;height:5px;background:var(--bg3);border-radius:var(--r-pill);overflow:hidden;flex-shrink:0;position:relative}.session-prog-fill{height:100%;border-radius:var(--r-pill);background:var(--blue);transition:width var(--tr)}.session-timer{font-size:15px;font-weight:600;color:var(--t1);font-variant-numeric:tabular-nums;padding:5px 12px;border-radius:var(--r-sm);background:var(--bg2);border:1px solid var(--bl);white-space:nowrap;transition:background var(--tr),color var(--tr),border-color var(--tr)}.session-timer.urgent{background:var(--redLt);color:var(--red);border-color:rgba(217,48,37,.25)}.practice-body{flex:1;display:grid;grid-template-columns:1fr 380px;gap:0}.practice-body-reading{grid-template-columns:1fr}.practice-body-reading .question-panel{border-right:none;max-width:860px}.question-panel{padding:24px;border-right:1px solid var(--bl);overflow-y:auto}.recording-panel{padding:24px;background:var(--bg);display:flex;flex-direction:column;align-items:center;gap:20px}.q-type-badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--blue);background:var(--blueLt);border:1px solid rgba(24,95,165,.15);border-radius:var(--r-pill);padding:4px 12px;margin-bottom:14px;width:-moz-fit-content;width:fit-content}.q-instructions{background:var(--amberLt);border:1px solid rgba(217,119,6,.2);border-radius:var(--r-md);padding:12px 14px;font-size:13px;color:var(--amberTx);margin-bottom:18px;line-height:1.55}.q-instructions strong{font-weight:600}.q-passage{padding:22px;font-size:15px;line-height:1.75;color:var(--t1);font-weight:400}.audio-player-fake,.q-passage{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-lg)}.audio-player-fake{display:flex;align-items:center;gap:14px;padding:18px 22px}.audio-play-btn{width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--tr),transform var(--tr)}.audio-play-btn:hover{background:var(--blueDk);transform:scale(1.05)}.audio-waveform{gap:2px;height:32px;flex:1}.audio-bar{opacity:.3}.audio-bar.played{opacity:1}.audio-label{font-size:12px;color:var(--t3);flex-shrink:0}.img-chart{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-lg);padding:24px;text-align:center}.img-chart-title{font-size:13px;font-weight:600;color:var(--t2);margin-bottom:20px}.img-bars{display:flex;align-items:flex-end;justify-content:center;gap:16px;height:120px}.img-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px}.img-bar-val{font-size:11px;font-weight:600;color:var(--t2)}.img-bar-rect{width:32px;border-radius:4px 4px 0 0}.img-bar-label{font-size:10.5px;color:var(--t3);white-space:nowrap}.img-chart-note{font-size:11.5px;color:var(--t3);margin-top:12px}.img-real-card{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-lg);padding:16px;text-align:center}.img-real-title{font-size:13px;font-weight:600;color:var(--t2);margin-bottom:12px;line-height:1.4}.img-real-wrap{display:flex;justify-content:center;align-items:center}.img-real{max-width:100%;max-height:320px;width:auto;height:auto;border-radius:var(--r-md);-o-object-fit:contain;object-fit:contain}.q-question-block{background:var(--bg2);border-left:4px solid var(--blue);border-radius:0 var(--r-md) var(--r-md) 0;padding:16px 20px;font-size:16px;font-weight:500;color:var(--t1);line-height:1.5}.rec-state{display:none;flex-direction:column;align-items:center;gap:16px;width:100%}.rec-state.active{display:flex}.prep-label{font-size:13px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.08em}.prep-ring-wrap{position:relative;width:140px;height:140px}.prep-ring{width:140px;height:140px;background:conic-gradient(var(--blue) var(--prog,0),var(--bg3) 0);transition:background .1s}.prep-ring:before{content:"";position:absolute;width:108px;height:108px;background:var(--bg);border-radius:50%}.prep-ring-inner{position:relative;z-index:1;text-align:center}.prep-count{font-size:28px;font-weight:600;letter-spacing:-1px;color:var(--blue);line-height:1}.prep-count-label{font-size:11px;color:var(--t3)}.btn-skip-prep{font-size:13px;font-weight:600;color:var(--blue);padding:8px 18px;border-radius:var(--r-sm);border:1px solid var(--blueLt);background:var(--blueLt);transition:background var(--tr)}.btn-skip-prep:hover{background:#d0e8f8}.record-btn-wrap{position:relative;width:100px;height:100px}.record-btn,.record-btn-wrap{display:flex;align-items:center;justify-content:center}.record-btn{width:80px;height:80px;border-radius:50%;background:var(--red);color:#fff;font-size:28px;animation:pulse-ring 1.5s ease-out infinite;transition:transform var(--tr);z-index:1}.record-btn:hover{transform:scale(1.05)}.rec-timer{font-size:20px;font-weight:600;letter-spacing:-.3px;color:var(--t1);font-variant-numeric:tabular-nums}.waveform{display:flex;align-items:center;gap:3px;height:48px}.waveform-bar{width:4px;border-radius:2px;background:var(--red);opacity:.8;transform-origin:bottom;animation:wave 1s ease-in-out infinite}.btn-stop{padding:10px 24px;background:var(--red);color:#fff;border-radius:var(--r-sm);font-size:13.5px;font-weight:600;transition:background var(--tr),transform var(--tr)}.btn-stop:hover{background:#b52a1e;transform:translateY(-1px)}.spinner{width:44px;height:44px;border:3px solid var(--bl);border-top-color:var(--blue);border-radius:50%;animation:spin 1s linear infinite}.proc-label{font-size:14px;font-weight:500;color:var(--t2)}.mic-error-banner{display:none;background:var(--redLt);border:1px solid rgba(217,48,37,.2);border-radius:var(--r-md);padding:14px 16px;font-size:13px;color:var(--red);line-height:1.55;width:100%;flex-basis:100%;box-sizing:border-box}.mic-error-banner.visible{display:block}.mic-error-banner strong{font-weight:600;display:block;margin-bottom:4px}.feedback-body{max-width:760px}.feedback-body,.feedback-wrap{padding:24px;display:flex;flex-direction:column;gap:20px}.feedback-wrap{max-width:900px}.feedback-top{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}.score-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);flex-direction:column;gap:16px}.asq-result-icon,.score-card{display:flex;align-items:center}.asq-result-icon{width:100px;height:100px;border-radius:50%;justify-content:center;font-size:52px;font-weight:700}.asq-result-icon.asq-correct{background:rgba(29,158,117,.12);color:#1d9e75;border:3px solid #1d9e75}.asq-result-icon.asq-wrong{background:rgba(217,48,37,.1);color:#d93025;border:3px solid #d93025}.asq-result-label{font-size:22px;font-weight:700}.asq-result-label.asq-correct{color:#1d9e75}.asq-result-label.asq-wrong{color:#d93025}.score-ring-lg{width:140px;height:140px;border-radius:50%;background:conic-gradient(var(--blue) var(--score-pct,70%),var(--bg2) 0);display:flex;align-items:center;justify-content:center;position:relative}.score-ring-lg:before{content:"";position:absolute;width:108px;height:108px;background:var(--bg);border-radius:50%}.score-ring-inner{position:relative;z-index:1;text-align:center}.score-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0}.score-ring-num{font-size:24px;font-weight:600;letter-spacing:-1px;color:var(--blue)}.score-ring-denom{font-size:11px;color:var(--t3)}.score-big{font-size:32px;font-weight:600;letter-spacing:-1px;color:var(--blue);line-height:1}.score-max{font-size:13px;color:var(--t3)}.score-num{font-size:26px;font-weight:700;color:var(--blue);line-height:1}.score-denom{font-size:12px;color:var(--t3)}.score-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.criteria-col{display:flex;flex-direction:column;gap:14px}.criteria-title{font-size:13.5px;font-weight:600;color:var(--t1);margin-bottom:2px}.criteria-list{display:flex;flex-direction:column;gap:12px;width:100%}.criteria-row{display:flex;align-items:center;gap:10px}.criteria-name{font-size:12.5px;color:var(--t2);width:110px;flex-shrink:0}.criteria-bar{flex:1;height:7px;background:var(--bg3);border-radius:var(--r-pill);overflow:hidden}.criteria-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--blue),#27c);transition:width 1.2s ease}.criteria-score{font-size:12.5px;font-weight:600;color:var(--t1);width:42px;text-align:right;flex-shrink:0}.crit-row{display:flex;flex-direction:column;gap:5px}.crit-label-row{display:flex;align-items:center;justify-content:space-between}.crit-label{font-size:12.5px;color:var(--t2);font-weight:500}.crit-score{font-size:12.5px;font-weight:600;color:var(--blue)}.crit-bar{width:100%;height:8px;background:var(--bg3);overflow:hidden}.crit-bar,.crit-fill{border-radius:var(--r-pill)}.crit-fill{height:100%;background:var(--blue);width:0;transition:width 1.2s ease}.feedback-right{display:flex;flex-direction:column;gap:16px;flex:1;min-width:0}.ai-feedback-box{background:var(--blueLt);border:1px solid rgba(24,95,165,.15);border-radius:var(--r-lg);padding:18px 20px}.ai-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--blue);background:rgba(24,95,165,.12);border-radius:var(--r-pill);padding:3px 10px;margin-bottom:10px}.ai-feedback-text{font-size:13.5px;color:var(--t1);line-height:1.65}.ai-feedback-box p{font-size:13px;color:var(--t2);line-height:1.6}.model-answer{border:1px solid var(--bl);border-radius:var(--r-lg);overflow:hidden}.model-answer summary{padding:14px 18px;font-size:13px;font-weight:600;cursor:pointer;background:var(--bg2);display:flex;align-items:center;justify-content:space-between;list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.model-answer summary:hover{background:var(--bg3)}.model-answer summary:after{content:"▾";color:var(--t3);transition:transform var(--tr)}.model-answer[open] summary:after{transform:rotate(180deg)}.model-answer-body{padding:16px 18px;font-size:13.5px;line-height:1.7;color:var(--t2);background:var(--bg);border-top:1px solid var(--bl)}.model-answer-body p+p{margin-top:10px}.feedback-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-retry{flex:1;padding:11px;border-radius:var(--r-sm);border:1px solid var(--bl);background:var(--bg);font-size:13.5px;font-weight:600;color:var(--t2);transition:background var(--tr),border-color var(--tr)}.btn-retry:hover{background:var(--bg2);border-color:var(--bm)}.btn-next{flex:2;padding:11px;border-radius:var(--r-sm);background:var(--blue);color:#fff;font-size:13.5px;font-weight:600;transition:background var(--tr),transform var(--tr)}.btn-next:hover{background:var(--blueDk);transform:translateY(-1px)}.btn-secondary{background:var(--bg);border:1px solid var(--bm);color:var(--t2);font-size:13.5px;font-weight:600;border-radius:var(--r-lg);padding:11px 20px;font-family:inherit;cursor:pointer;transition:background var(--tr),color var(--tr),transform var(--tr)}.btn-secondary:hover{background:var(--bg2);color:var(--t1);transform:translateY(-1px)}.btn-primary{background:var(--blue);color:#fff;font-size:13.5px;font-weight:600;border-radius:var(--r-lg);padding:11px 22px;border:none;font-family:inherit;cursor:pointer;transition:background var(--tr),transform var(--tr),box-shadow var(--tr);box-shadow:0 2px 8px rgba(24,95,165,.22)}.btn-primary:hover{background:var(--blueDk);transform:translateY(-1px);box-shadow:0 5px 16px rgba(24,95,165,.28)}.complete-wrap{max-width:520px;margin:0 auto}.complete-body,.complete-wrap{padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.complete-body{justify-content:center;min-height:calc(100dvh - var(--topbar-h))}.complete-icon{font-size:56px}.complete-emoji{font-size:64px;line-height:1}.complete-title{font-size:24px;font-weight:600;letter-spacing:-.4px}.complete-sub{font-size:14px;color:var(--t2);line-height:1.6;max-width:380px}.complete-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%}.complete-stat{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow)}.complete-stat .val{font-size:24px;font-weight:600;color:var(--blue)}.complete-stat .lbl{font-size:11px;color:var(--t3);margin-top:2px}.complete-stat-tile{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:18px 24px;min-width:120px;box-shadow:var(--shadow)}.complete-stat-val{font-size:26px;font-weight:700;color:var(--blue)}.complete-stat-lbl{font-size:11.5px;color:var(--t3);margin-top:4px;font-weight:500}.complete-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.complete-progress-note{background:var(--greenLt);border:1px solid rgba(29,158,117,.2);border-radius:var(--r-md);padding:10px 18px;font-size:13px;color:var(--greenTx);font-weight:500}.btn-back-hub{padding:12px 28px;background:var(--blue);color:#fff;border-radius:var(--r-sm);font-size:14px;font-weight:600;transition:background var(--tr),transform var(--tr)}.btn-back-hub:hover{background:var(--blueDk);transform:translateY(-1px)}.ra-view{display:none}.ra-view.active{display:block}.hub-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px}.hub-title{font-size:24px;font-weight:600;letter-spacing:-.4px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600}.badge-amber{background:var(--amberLt);color:var(--amberTx)}.badge-blue{background:var(--blueLt);color:var(--blue)}.badge-green{background:var(--greenLt);color:var(--greenTx)}.badge-red{background:var(--redLt);color:var(--red)}.badge-society{background:#eef2fb;color:#3b5ac6}.badge-environment{background:var(--greenLt);color:var(--greenTx)}.badge-technology{background:var(--blueLt);color:var(--blue)}.badge-economics{background:var(--tealLt);color:var(--teal)}.badge-easy{background:var(--greenLt);color:var(--greenTx)}.badge-medium{background:var(--amberLt);color:var(--amberTx)}.badge-hard{background:var(--redLt);color:var(--red)}.rec-card{background:linear-gradient(135deg,#1567b8,#185fa5);border-radius:var(--r-xl);padding:24px;color:#fff;box-shadow:0 4px 20px rgba(24,95,165,.28);position:relative;overflow:hidden}.rec-card:before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:hsla(0,0%,100%,.06);pointer-events:none}.rec-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.75;margin-bottom:8px}.rec-title{font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:4px}.rec-meta{font-size:13px;opacity:.8;margin-bottom:6px}.rec-hint{font-size:12.5px;background:hsla(0,0%,100%,.14);border-radius:var(--r-md);padding:8px 12px;margin:14px 0;line-height:1.5}.btn-rec-start{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--blue);font-size:14px;font-weight:600;border-radius:var(--r-lg);padding:11px 22px;transition:transform var(--tr),box-shadow var(--tr);box-shadow:0 2px 8px rgba(0,0,0,.15);cursor:pointer;border:none;font-family:inherit}.btn-rec-start:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.18)}.passages-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.passage-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow);cursor:pointer;transition:box-shadow var(--tr),transform var(--tr);display:flex;flex-direction:column;gap:10px}.passage-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.passage-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.passage-badges{display:flex;gap:6px;flex-wrap:wrap}.passage-title{font-size:15px;font-weight:600;color:var(--t1)}.passage-preview{font-size:12.5px;color:var(--t3);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.passage-footer{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.passage-score-wrap{gap:8px}.donut-sm,.passage-score-wrap{display:flex;align-items:center}.donut-sm{width:36px;height:36px;border-radius:50%;flex-shrink:0;justify-content:center;font-size:9px;font-weight:600;color:var(--blue)}.passage-score-txt{font-size:12px;color:var(--t3)}.btn-start{background:var(--blueLt);color:var(--blue);font-size:12.5px;font-weight:600;border-radius:var(--r-sm);padding:7px 14px;border:none;cursor:pointer;font-family:inherit;transition:background var(--tr),transform var(--tr)}.btn-start:hover{background:#d0e7f8;transform:translateY(-1px)}.prep-body{padding:28px;display:flex;flex-direction:row;align-items:flex-start;flex-wrap:wrap;gap:20px;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.passage-box{flex:1;min-width:280px;background:var(--blueLt);border:1px solid rgba(24,95,165,.18);border-radius:var(--r-xl);padding:24px;box-sizing:border-box}.passage-box-label{font-size:11px;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:flex;align-items:center;gap:6px}.passage-text-large{font-size:17px;line-height:2;color:var(--t1);font-weight:400}.prep-timer-card{flex-shrink:0;width:240px;background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-xl);padding:20px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:14px}.prep-timer-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}.prep-ring{width:118px;height:118px;background:conic-gradient(var(--blue) var(--prog,100%),var(--bg3) var(--prog,100%));margin:0 auto}.prep-ring,.prep-ring-inner{border-radius:50%;display:flex;align-items:center;justify-content:center}.prep-ring-inner{width:86px;height:86px;background:var(--bg);flex-direction:column;gap:2px}.prep-unit{font-size:11px;color:var(--t3);font-weight:500}.mic-status-row{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--t2)}.mic-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.mic-dot.checking{background:var(--t3);animation:dotPulse 1.5s infinite}.mic-dot.granted{background:var(--green)}.mic-dot.denied{background:var(--red)}.prep-note{font-size:12px;color:var(--t3);text-align:center}.btn-skip{background:var(--bg2);border:1px solid var(--bl);color:var(--t2);font-size:13px;font-weight:600;border-radius:var(--r-md);padding:9px 20px;font-family:inherit;cursor:pointer;transition:background var(--tr),color var(--tr)}.btn-skip:hover{background:var(--bg3);color:var(--t1)}.rec-body{padding:28px;display:flex;flex-direction:row;align-items:flex-start;gap:20px;max-width:900px;margin:0 auto;width:100%}.passage-reading-box{flex:1;min-width:0;background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow)}.passage-reading-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.passage-reading{font-size:16.5px;line-height:2.1;color:var(--t1);letter-spacing:.01em}.rec-panel{flex-shrink:0;width:260px;background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-xl);padding:22px 20px;box-shadow:var(--shadow);flex-direction:column;gap:16px}.rec-panel,.rec-timer-row{display:flex;align-items:center}.rec-timer-row{gap:12px}.rec-dot{width:12px;height:12px;border-radius:50%;background:var(--red);animation:recPulse 1s infinite;display:inline-block}.rec-time-display{font-size:22px;font-weight:700;color:var(--t1);font-variant-numeric:tabular-nums;letter-spacing:-.5px}.rec-label-txt{font-size:12px;font-weight:600;color:var(--red);text-transform:uppercase;letter-spacing:.06em}.rec-prog-wrap{width:100%}.rec-prog-meta{display:flex;justify-content:flex-end;margin-bottom:5px}.rec-prog-maxlabel{font-size:11px;color:var(--t3)}.rec-prog-bar{height:5px;background:var(--bg3);border-radius:var(--r-pill);overflow:hidden;width:100%}.rec-prog-fill{height:100%;background:var(--blue);border-radius:var(--r-pill);transition:width 1s linear,background .3s}.rec-prog-fill.urgent{background:var(--red)}.ra-waveform-wrap{flex-direction:column;gap:8px}.ra-waveform,.ra-waveform-wrap{width:100%;display:flex;align-items:center}.ra-waveform{justify-content:center;gap:3px;height:64px}.ra-wv-bar{width:5px;border-radius:3px;background:var(--blue);height:4px;transition:height .08s ease;flex-shrink:0}.vol-label{font-size:11.5px;color:var(--t3)}.silence-banner{background:var(--amberLt);border:1px solid rgba(217,119,6,.22);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--amberTx);display:none;width:100%;text-align:center}.silence-banner.visible{display:block}.processing-body{justify-content:center;min-height:calc(100dvh - var(--topbar-h));padding:40px 24px;gap:24px}.processing-body,.spinner-wrap{display:flex;flex-direction:column;align-items:center}.spinner-wrap{gap:20px}.processing-title{font-size:17px;font-weight:600;color:var(--t1);text-align:center}.processing-sub{font-size:13px;color:var(--t3);text-align:center;max-width:320px;line-height:1.6}.proc-steps{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.proc-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--t3);opacity:0;transition:opacity .4s}.proc-step.done{color:var(--green);opacity:1}.proc-step.active{color:var(--blue);opacity:1}.proc-step-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;border:1.5px solid}.proc-step.done .proc-step-icon{background:var(--greenLt);border-color:var(--green)}.proc-step.active .proc-step-icon{background:var(--blueLt);border-color:var(--blue)}.proc-spinner-sm{width:12px;height:12px;border-radius:50%;border:2px solid var(--blueLt);border-top-color:var(--blue);animation:spin .8s linear infinite}.score-header-card{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow)}.score-header-inner{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start}.score-ring-col{flex-direction:column;gap:10px}.pb-player,.score-ring-col{display:flex;align-items:center}.pb-player{gap:12px}.pb-btn{width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--tr),transform var(--tr);flex-shrink:0;font-size:16px;font-family:inherit}.pb-btn:hover{background:var(--blueDk);transform:scale(1.05)}.pb-track{flex:1;height:5px;background:var(--bg3);overflow:hidden;cursor:pointer;position:relative}.pb-fill,.pb-track{border-radius:var(--r-pill)}.pb-fill{height:100%;background:var(--blue);width:0;transition:width .3s linear}.pb-time{font-size:12px;color:var(--t3);font-variant-numeric:tabular-nums;white-space:nowrap}.pb-note{font-size:11.5px;color:var(--t3);margin-top:10px}.analysis-legend{gap:16px;flex-wrap:wrap;margin-bottom:14px;font-size:12px;color:var(--t2)}.analysis-legend,.legend-item{display:flex;align-items:center}.legend-item{gap:5px}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot-red{width:10px;height:10px;border-radius:2px;background:var(--redLt);border:1px solid var(--red)}.legend-dot-amber{width:10px;height:10px;border-radius:2px;background:var(--amberLt);border-bottom:2px solid var(--amber)}.legend-dot-green{width:10px;height:10px;border-radius:50%;background:var(--green)}.legend-dot-missed{width:10px;height:10px;border-radius:2px;background:#fee2e2;border:1px solid #b91c1c}.legend-dot-extra{width:10px;height:10px;border-radius:2px;background:#fef9c3;border:1px solid #a16207}.analysis-passage{font-size:14.5px;line-height:2.3;color:var(--t1)}.ra-word{display:inline;border-radius:3px;padding:0 2px;line-height:2.2;font-size:14.5px;cursor:default}.ra-word.w-correct{background:#dcfce7;color:#166534}.ra-word.w-error{background:var(--redLt);color:var(--red);cursor:pointer;font-weight:500}.ra-word.w-error:hover{background:#f9c4c0}.ra-word.w-mispronounced{background:#ffedd5;color:#c2410c;cursor:pointer;font-weight:500}.ra-word.w-mispronounced:hover{background:#fed7aa}.ra-word.w-missed{background:#fee2e2;color:#b91c1c;cursor:pointer;text-decoration:line-through;font-weight:500}.ra-word.w-missed:hover{background:#fecaca}.ra-word.w-extra{background:#fef9c3;color:#92400e;cursor:pointer;font-style:italic}.ra-word.w-extra:hover{background:#fef08a}.ra-word.w-hesit{-webkit-text-decoration:underline wavy var(--amber);text-decoration:underline wavy var(--amber);cursor:pointer}.ra-word.w-hesit:hover{background:var(--amberLt)}.word-tip{position:fixed;z-index:1000;width:280px;background:#1a2332;color:#fff;border-radius:var(--r-md);padding:14px 16px;box-shadow:0 8px 32px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .15s}.word-tip.visible{opacity:1;pointer-events:all}.word-tip-word{font-size:18px;font-weight:600;margin-bottom:4px}.word-tip-ipa{font-size:13px;color:#a0aec0;margin-bottom:8px}.word-tip-syllable{font-size:14px;color:#e2e8f0;letter-spacing:.05em;margin-bottom:8px}.word-tip-advice{font-size:12.5px;color:#cbd5e0;line-height:1.5;padding-top:8px;border-top:1px solid hsla(0,0%,100%,.12)}.word-tip-close{position:absolute;top:10px;right:12px;cursor:pointer;color:#a0aec0;font-size:18px;line-height:1}.word-tip-close:hover{color:#fff}.ai-suggestion-box{background:var(--blueLt);border:1px solid rgba(24,95,165,.15);border-radius:var(--r-lg);padding:16px 18px}.ai-suggestion-list{list-style:none;display:flex;flex-direction:column;gap:10px}.ai-suggestion-list li{font-size:13px;color:var(--t1);line-height:1.6;display:flex;gap:9px;align-items:flex-start}.ai-bullet{font-size:15px;flex-shrink:0;margin-top:1px}.pron-grid{display:flex;flex-direction:column}.pron-row{display:grid;grid-template-columns:150px 1fr;gap:6px 14px;padding:12px 0;border-bottom:1px solid var(--bl);align-items:start;font-size:13px}.pron-row:last-child{border-bottom:none}.pron-word{font-weight:600;color:var(--t1)}.pron-ipa{font-size:12.5px;color:var(--blue);font-style:italic}.pron-syl{color:var(--t2);letter-spacing:.07em;font-size:12.5px;grid-column:2}.pron-tip{color:var(--t3);font-size:12px;line-height:1.5;grid-column:2;margin-top:2px}.practice-body-writing{flex:1;display:grid;grid-template-columns:1fr 1.1fr;overflow:hidden}.prompt-panel{padding:24px;overflow-y:auto;border-right:1px solid var(--bl);display:flex;flex-direction:column;gap:16px}.prompt-label{font-size:11.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}.q-passage p+p{margin-top:12px}.q-essay-prompt{background:linear-gradient(135deg,var(--amberLt) 0,#fff8ee 100%);border:1px solid rgba(217,119,6,.25);border-radius:var(--r-lg);padding:22px}.q-essay-prompt .ep-label{font-size:11px;font-weight:600;color:var(--amberTx);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.q-essay-prompt .ep-question{font-size:15.5px;font-weight:600;color:var(--t1);line-height:1.55;margin-bottom:14px}.q-essay-prompt .ep-task{font-size:13px;color:var(--t2);line-height:1.55}.structure-guide{background:var(--blueLt);border:1px solid rgba(24,95,165,.15);border-radius:var(--r-md);padding:14px 16px}.structure-guide .sg-title{font-size:12px;font-weight:600;color:var(--blue);margin-bottom:8px}.structure-guide .sg-row{display:flex;align-items:baseline;gap:8px;font-size:12.5px;color:var(--t2);padding:3px 0}.structure-guide .sg-part{font-weight:600;color:var(--blue);width:110px;flex-shrink:0}.structure-guide .sg-words{font-size:11px;color:var(--t3);margin-left:auto}.editor-panel{display:flex;flex-direction:column;background:var(--bg)}.editor-toolbar{display:flex;align-items:center;gap:8px;padding:10px 18px;border-bottom:1px solid var(--bl);flex-shrink:0}.toolbar-btn{padding:5px 10px;border-radius:var(--r-sm);font-size:12px;font-weight:600;color:var(--t2);background:var(--bg2);border:1px solid var(--bl);transition:background var(--tr)}.toolbar-btn:hover{background:var(--bg3)}.toolbar-sep{width:1px;height:18px;background:var(--bl);margin:0 2px}.toolbar-hint{flex:1;font-size:12px;color:var(--t3)}.auto-save-indicator{font-size:11.5px;color:var(--green);font-weight:500;display:flex;align-items:center;gap:4px}.writing-area-wrap{flex:1;display:flex;flex-direction:column;padding:20px;overflow:hidden}.writing-area{flex:1;width:100%;resize:none;border:none;outline:none;font-family:Inter,sans-serif;font-size:14.5px;line-height:1.8;color:var(--t1);background:transparent;min-height:0}.writing-area::-moz-placeholder{color:var(--t3)}.writing-area::placeholder{color:var(--t3)}.editor-footer{flex-shrink:0;padding:14px 18px;border-top:1px solid var(--bl);display:flex;flex-direction:column;gap:10px;background:var(--bg)}.wc-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.wc-left{display:flex;flex-direction:column;gap:5px;flex:1}.wc-bar{flex:1;height:6px;background:var(--bg3);overflow:hidden;width:100%}.wc-bar,.wc-fill{border-radius:var(--r-pill)}.wc-fill{height:100%;transition:width .3s ease,background .3s ease;background:var(--t3)}.wc-fill.short{background:var(--amber)}.wc-fill.ok{background:var(--green)}.wc-fill.over{background:var(--red)}.wc-meta{display:flex;align-items:center;gap:8px;font-size:12px}.wc-count{font-weight:600}.wc-target-txt{color:var(--t3)}.wc-status{font-size:11px;font-weight:600;padding:2px 7px;border-radius:var(--r-pill)}.wc-status.ok{background:var(--greenLt);color:var(--greenTx)}.wc-status.low{background:var(--amberLt);color:var(--amberTx)}.wc-status.over{background:var(--redLt);color:var(--red)}.wc-text{font-size:12px;color:var(--t3);white-space:nowrap;font-variant-numeric:tabular-nums}.wc-target{font-size:11.5px;color:var(--t3)}.btn-submit{padding:10px 24px;background:var(--amber);color:#fff;border-radius:var(--r-sm);font-size:13.5px;font-weight:600;transition:background var(--tr),transform var(--tr);white-space:nowrap;flex-shrink:0}.btn-submit:hover{background:#b8620a;transform:translateY(-1px)}.btn-submit:disabled{background:var(--t3);cursor:not-allowed;transform:none}.swt-warning{display:none;font-size:12px;color:var(--red);font-weight:500;padding:6px 10px;background:var(--redLt);border-radius:var(--r-sm)}.annotated-wrap{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);overflow:hidden}.annotated-header{padding:12px 16px;background:var(--bg2);border-bottom:1px solid var(--bl);font-size:12.5px;font-weight:600;color:var(--t2);display:flex;align-items:center;gap:8px}.annotated-body{padding:16px 18px;font-size:13.5px;line-height:1.8;color:var(--t1)}.annotated-legend{display:flex;gap:14px;padding:10px 16px;border-top:1px solid var(--bl);background:var(--bg2);flex-wrap:wrap}mark.err{background:#fce8e6;color:var(--red);-webkit-text-decoration:underline wavy var(--red);text-decoration:underline wavy var(--red)}mark.err,mark.good{border-radius:3px;padding:1px 2px}mark.good{background:var(--greenLt);color:var(--greenTx)}mark.coh{background:var(--blueLt);color:var(--blue);border-radius:3px;padding:1px 2px}.improvement-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}.improvement-item{display:flex;gap:8px;font-size:13px}.imp-icon{flex-shrink:0;margin-top:1px}.fib-passage{font-size:15px;line-height:2.1;color:var(--t1);background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:22px}.fib-blank{display:inline-flex;align-items:center;justify-content:center;min-width:110px;height:30px;border:2px dashed var(--bm);border-radius:var(--r-sm);background:var(--bg2);cursor:pointer;padding:0 8px;font-size:13.5px;font-weight:500;color:var(--t1);vertical-align:middle;margin:0 3px;transition:all var(--tr);position:relative}.fib-blank:empty:before{content:"drop here";font-size:11px;color:var(--t3);font-weight:400;font-style:italic}.fib-blank.drag-over{border-color:var(--blue);background:var(--blueLt)}.fib-blank.filled{border-style:solid;border-color:var(--blue);background:var(--blueLt);color:var(--blue)}.fib-blank.correct{border-color:var(--green)!important;background:var(--greenLt)!important;color:var(--greenTx)!important}.fib-blank.wrong{border-color:var(--red)!important;background:var(--redLt)!important;color:var(--red)!important}.fib-blank.selected-target{border-color:var(--blue);background:var(--blueLt);animation:pulse-border .6s ease infinite}.word-bank{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-lg);padding:16px 18px}.word-bank-label{font-size:11.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.word-bank-chips{display:flex;flex-wrap:wrap;gap:8px}.word-chip{padding:6px 14px;background:var(--bg);border:1.5px solid var(--bl);border-radius:var(--r-sm);font-size:13.5px;font-weight:500;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all var(--tr);box-shadow:0 1px 3px rgba(0,0,0,.05)}.word-chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blueLt)}.word-chip.selected{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 2px 8px rgba(24,95,165,.3)}.word-chip.used{opacity:.3;cursor:default;pointer-events:none}.word-chip:active{cursor:grabbing}.rfib-passage{font-size:15px;line-height:2.2;border:1px solid var(--bl);border-radius:var(--r-lg);padding:22px}.fib-select,.rfib-passage{color:var(--t1);background:var(--bg)}.fib-select{display:inline-block;border:2px solid var(--bm);border-radius:var(--r-sm);padding:3px 24px 3px 8px;font-family:Inter,sans-serif;font-size:13.5px;font-weight:500;cursor:pointer;vertical-align:middle;margin:0 3px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238896a8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;transition:border-color var(--tr),background-color var(--tr)}.fib-select:focus{outline:none;border-color:var(--blue)}.fib-select.answered{border-color:var(--blue);background-color:var(--blueLt)}.fib-select.correct{border-color:var(--green)!important;background-color:var(--greenLt)!important;color:var(--greenTx)!important}.fib-select.wrong{border-color:var(--red)!important;background-color:var(--redLt)!important;color:var(--red)!important}.reorder-dual-layout{display:grid;grid-template-columns:1fr 1fr;border:1.5px solid var(--bl);border-radius:var(--r-lg);overflow:hidden}.reorder-panel{display:flex;flex-direction:column}.reorder-panel:first-child{border-right:1.5px solid var(--bl)}.reorder-panel-header{background:#2d8c5e;color:#fff;font-size:14px;font-weight:700;padding:13px 20px;text-align:center;letter-spacing:.06em}.reorder-panel-body{flex:1;display:flex;flex-direction:column;transition:background var(--tr)}.reorder-panel-body.drag-over-panel{background:rgba(45,140,94,.06)}.reorder-src-tile{padding:14px 18px;font-size:13.5px;line-height:1.65;color:var(--t1);cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-bottom:1px solid var(--bl);transition:background var(--tr),opacity var(--tr)}.reorder-src-tile:last-child{border-bottom:none}.reorder-src-tile:hover{background:var(--bg2)}.reorder-src-tile.dragging{opacity:.35;cursor:grabbing}.reorder-src-tile.in-target:hover{background:#f0f9f4}.reorder-empty-panel-hint{padding:32px 20px;font-size:13px;color:var(--t3);text-align:center;font-style:italic}.reorder-target-slot{min-height:72px;border-bottom:1px solid var(--bl);display:flex;align-items:stretch;transition:background var(--tr)}.reorder-target-slot:last-child{border-bottom:none}.reorder-target-slot.drag-over{background:rgba(45,140,94,.12)}.reorder-target-slot.filled .reorder-src-tile{flex:1;border-bottom:none}.reorder-slot-empty-hint{display:flex;align-items:center;padding:14px 18px;font-size:12.5px;color:var(--t3);font-style:italic}.q-picker-anchor{position:relative;cursor:pointer;display:flex;align-items:center;gap:5px;padding:2px 4px;border-radius:var(--r-sm);transition:background var(--tr)}.q-picker-anchor:hover{background:var(--bg2)}.q-picker-hint{font-size:10px;color:var(--t3);line-height:1}.q-picker-dropdown{position:absolute;top:calc(100% + 8px);left:0;z-index:200;background:var(--bg);border:1.5px solid var(--bl);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:12px;min-width:280px}.q-picker-title{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.q-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px}.q-picker-btn{width:100%;aspect-ratio:1;border-radius:var(--r-sm);background:var(--bg2);border:1px solid var(--bl);font-size:11.5px;font-weight:600;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),color var(--tr),border-color var(--tr)}.q-picker-btn:hover{background:var(--blueLt);color:var(--blue);border-color:rgba(24,95,165,.25)}.q-picker-btn.current{background:var(--blue);color:#fff;border-color:var(--blue)}.q-jump-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);z-index:200;background:var(--bg);border:1.5px solid var(--bl);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:14px 16px;min-width:220px}.q-jump-row{display:flex;gap:8px;align-items:center;margin:8px 0 6px}.q-jump-input{flex:1;border:1.5px solid var(--bl);border-radius:var(--r-sm);padding:7px 10px;font-size:15px;font-weight:600;color:var(--t1);background:var(--bg2);outline:none;width:0;text-align:center;transition:border-color var(--tr)}.q-jump-input:focus{border-color:var(--blue);background:var(--bg)}.q-jump-input::-webkit-inner-spin-button,.q-jump-input::-webkit-outer-spin-button{-webkit-appearance:none}.q-jump-btn{padding:7px 16px;background:var(--blue);color:#fff;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;border:none;white-space:nowrap;transition:opacity var(--tr)}.q-jump-btn:hover{opacity:.88}.q-jump-hint{font-size:11px;color:var(--t3);text-align:center}.submit-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 0 4px}.submit-hint{font-size:12.5px;color:var(--t3)}.answer-review{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);overflow:hidden}.answer-review-header{padding:12px 16px;background:var(--bg2);border-bottom:1px solid var(--bl);font-size:12.5px;font-weight:600;color:var(--t2)}.answer-review-body{padding:16px 18px;font-size:14px;line-height:2.1}.ans-correct-word{background:var(--greenLt);color:var(--greenTx);border:1.5px solid rgba(29,158,117,.3);border-radius:var(--r-sm)}.ans-correct-word,.ans-wrong-word{padding:1px 8px;font-weight:600;display:inline-block;margin:0 2px}.ans-wrong-word{background:var(--redLt);color:var(--red);border:1.5px solid rgba(217,48,37,.2);border-radius:var(--r-sm)}.ans-correction{font-size:inherit;color:var(--t1);font-weight:700;display:inline;margin-left:2px}.audio-player{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow)}.audio-player-inner{display:flex;align-items:center;gap:16px}.audio-play-btn-lg{width:48px;height:48px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--tr),transform var(--tr);border:none;cursor:pointer}.audio-play-btn-lg:hover{background:var(--blueDk);transform:scale(1.05)}.audio-play-btn-lg.playing{background:var(--red)}.audio-info{flex:1;min-width:0}.audio-title{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:6px}.audio-progress-wrap{display:flex;align-items:center;gap:10px}.audio-progress-bar{flex:1;height:4px;background:var(--bg3);border-radius:var(--r-pill);overflow:hidden;cursor:pointer}.audio-progress-fill{height:100%;background:var(--blue);border-radius:var(--r-pill);transition:width .5s linear}.audio-time{font-size:11.5px;color:var(--t3);font-variant-numeric:tabular-nums;white-space:nowrap}.audio-waveform{display:flex;align-items:center;gap:2.5px;height:28px;margin-top:8px}.audio-bar{width:3px;border-radius:2px;background:var(--blue);opacity:.35;transform-origin:bottom;transition:opacity .2s}.audio-bar.active{opacity:1}.audio-waveform.playing .audio-bar{animation:audioWave .8s ease-in-out infinite}.audio-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);margin-top:10px}.audio-badge.playing{background:var(--redLt);color:var(--red)}.audio-badge.done{background:var(--greenLt);color:var(--greenTx)}.audio-badge.waiting{background:var(--bg3);color:var(--t3)}.sst-textarea{width:100%;min-height:140px;padding:14px;font-family:inherit;font-size:13.5px;line-height:1.7;color:var(--t1);border:1.5px solid var(--bl);border-radius:var(--r-md);resize:none;transition:border-color var(--tr);background:var(--bg)}.sst-textarea:focus{outline:none;border-color:var(--blue)}.mcm-passage{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-md);padding:16px;font-size:13.5px;line-height:1.7;color:var(--t1);margin-bottom:4px}.mcm-question{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:12px}.mcm-options{display:flex;flex-direction:column;gap:8px}.mcm-option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1.5px solid var(--bl);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--tr),background var(--tr);background:var(--bg)}.mcm-option.selected,.mcm-option:hover{border-color:var(--blue);background:var(--blueLt)}.mcm-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--blue);flex-shrink:0;margin-top:2px;cursor:pointer}.mcm-option-text{font-size:13.5px;color:var(--t1);line-height:1.5}.mcm-hint{font-size:12px;color:var(--t3);margin-top:8px}.hiw-transcript{font-size:14.5px;line-height:2.1;color:var(--t1);padding:16px;background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-md)}.hiw-word{display:inline;cursor:pointer;border-radius:3px;padding:0 2px;transition:background var(--tr),color var(--tr)}.hiw-word:hover{background:var(--amberLt)}.hiw-word.selected{background:var(--redLt);color:var(--red);font-weight:600;text-decoration:underline;text-decoration-style:wavy}.hiw-hint{font-size:12px;color:var(--t3);margin-top:10px}.wfd-input{width:100%;padding:14px;font-family:inherit;font-size:14px;line-height:1.7;color:var(--t1);border:1.5px solid var(--bl);border-radius:var(--r-md);transition:border-color var(--tr)}.wfd-input:focus{outline:none;border-color:var(--blue)}.wfd-hint{font-size:12px;margin-top:8px}.btn-skip-audio{padding:8px 16px;font-size:12.5px;font-weight:500;color:var(--t3);border:1px solid var(--bl);border-radius:var(--r-sm);transition:background var(--tr),color var(--tr)}.btn-skip-audio:hover{background:var(--bg2);color:var(--t2)}.processing-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:16px}.processing-text{font-size:14px;color:var(--t2);font-weight:500}.answer-review-box{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r-md);padding:16px}.answer-review-title{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--t1)}.answer-review-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--bl);font-size:13px}.answer-review-row:last-child{border-bottom:none}.answer-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;margin-top:1px}.icon-correct{background:var(--greenLt);color:var(--greenTx)}.icon-wrong{background:var(--redLt);color:var(--red)}.answer-label{font-weight:600;color:var(--t2);min-width:72px}.answer-text-correct{color:var(--greenTx)}.answer-text-wrong{color:var(--red)}.answer-text-note{font-size:12px;color:var(--t3);margin-top:3px}.hiw-review-word{display:inline;border-radius:3px;padding:1px 3px;margin:1px}.hiw-review-word.correct-changed{background:var(--greenLt);color:var(--greenTx);font-weight:600}.hiw-review-word.missed{background:var(--amberLt);color:var(--amberTx);text-decoration:line-through}.hiw-review-word.false-pos{background:var(--redLt);color:var(--red)}@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(217,48,37,.45)}70%{box-shadow:0 0 0 22px rgba(217,48,37,0)}to{box-shadow:0 0 0 0 rgba(217,48,37,0)}}@keyframes wave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}@keyframes pulse-border{0%,to{border-color:var(--blue)}50%{border-color:var(--blueDk)}}@keyframes dotPulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes recPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes audioWave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@media (max-width:1100px){.module-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}.mock-top{grid-template-columns:1fr}}@media (max-width:1000px){.practice-body{grid-template-columns:1fr}.recording-panel{border-right:none;border-top:1px solid var(--bl)}.feedback-body{padding:16px}}@media (max-width:960px){.practice-body-writing{grid-template-columns:1fr}.prompt-panel{border-right:none;border-bottom:1px solid var(--bl);max-height:45vh}.practice-wrap{height:auto}}@media (max-width:900px){.three-col,.two-col{grid-template-columns:1fr}.task-type-grid{grid-template-columns:1fr 1fr}.reorder-dual-layout{grid-template-columns:1fr}.reorder-panel:first-child{border-right:none;border-bottom:1.5px solid var(--bl)}}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:var(--sidebar-w)!important}.sidebar.open{transform:translateX(0)}.sidebar-backdrop.open{display:block}.main{margin-left:0!important}.topbar-hamburger{display:flex}.topbar-greeting h2{font-size:14px}.topbar-streak span.streak-label{display:none}.content,.hub-content{padding:16px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-grid-3{grid-template-columns:1fr 1fr}.module-grid{grid-template-columns:repeat(2,1fr);gap:10px}.onboarding-banner{flex-wrap:wrap}.passages-grid,.pron-row,.score-header-inner,.task-type-grid{grid-template-columns:1fr}.pron-syl,.pron-tip{grid-column:1}.feedback-actions button{width:100%}.session-prog-bar{display:none}.score-ring-col{align-items:flex-start;flex-direction:row;align-items:center}}@media (max-width:560px){.stat-grid{grid-template-columns:1fr 1fr}.stat-grid-3{grid-template-columns:1fr}.topbar-streak{padding:5px 8px}.complete-stats{grid-template-columns:1fr 1fr 1fr}.session-prog-bar{display:none}}@media (max-width:480px){.passages-grid,.stat-grid-3{grid-template-columns:1fr}.complete-stats{flex-direction:column;align-items:center}.feedback-body,.hub-content,.prep-body,.rec-body{padding:14px}.prep-body{flex-direction:column;flex-wrap:nowrap}.prep-timer-card{width:100%}.passage-box{min-width:0;width:100%}.rec-body{flex-direction:column;flex-wrap:nowrap}.rec-panel{width:100%}.passage-reading-box{min-width:0;width:100%}}.wfd-playing,.wfd-prep{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0}.wfd-playing p{font-size:15px;color:var(--t2);font-weight:500}.wfd-typing-area{display:flex;flex-direction:column;gap:10px;padding:8px 0}.wfd-hint{font-size:13px;color:var(--t3);font-weight:500;margin:0}.wfd-textarea{width:100%;min-height:100px;padding:14px 16px;background:var(--bg2);border:1.5px solid var(--bl);border-radius:var(--r-md);color:var(--t1);font-size:15px;font-family:inherit;resize:vertical;line-height:1.6}.wfd-textarea:focus{outline:none;border-color:var(--blue)}.wfd-meta{font-size:12px;color:var(--t3)}.wfd-feedback{flex-direction:column;gap:20px;padding:8px 0;width:100%}.wfd-feedback,.wfd-score-ring{display:flex;align-items:center}.wfd-score-ring{width:100px;height:100px;border-radius:50%;background:conic-gradient(var(--blue) var(--score,0),var(--bg3) 0);justify-content:center;position:relative}.wfd-score-ring:before{content:"";position:absolute;width:76px;height:76px;border-radius:50%;background:var(--bg1)}.wfd-score-ring span{position:relative;z-index:1}.wfd-label,.wfd-score-ring span{font-size:18px;font-weight:700;color:var(--t1)}.wfd-word-check{background:var(--bg2);border:1px solid var(--bl);border-radius:var(--r-md);padding:16px;width:100%}.wfd-section-title{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.wfd-words{display:flex;flex-wrap:wrap;gap:6px}.wfd-word{padding:3px 10px;border-radius:20px;font-size:14px;font-weight:500}.wfd-correct{background:rgba(29,158,117,.15);color:#1d9e75;border:1px solid rgba(29,158,117,.3)}.wfd-wrong{background:rgba(217,48,37,.12);color:#d93025;border:1px solid rgba(217,48,37,.25);text-decoration:line-through}.wfd-correct-answer{background:rgba(29,158,117,.08);border:1.5px solid rgba(29,158,117,.3);border-radius:var(--r-md);padding:16px;width:100%}.wfd-correct-text{font-size:15px;color:var(--t1);font-weight:500;line-height:1.6;margin-top:6px}.rts-scenario-card{background:var(--bg2);border:1.5px solid var(--bl);border-radius:var(--r-lg);padding:20px 22px;display:flex;flex-direction:column;gap:12px}.rts-scenario-label{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}.rts-scenario-text{font-size:15px;color:var(--t1);line-height:1.7;font-weight:400}.rts-prep-hint{color:var(--amber,#f59e0b);background:rgba(245,158,11,.1);border-left:3px solid var(--amber,#f59e0b)}.rts-prep-hint,.rts-recording-hint{font-size:13px;font-weight:500;padding:8px 12px;border-radius:var(--r-sm)}.rts-recording-hint{color:var(--red,#d93025);background:rgba(217,48,37,.08);border-left:3px solid var(--red,#d93025)}.tc-green:hover{box-shadow:0 4px 20px rgba(29,158,117,.12)}@media (min-width:1100px){.task-type-grid{grid-template-columns:repeat(3,1fr)}}