*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-dark:#1e2432;--blue:#ff663d;--blue-mid:#ff7a59;--blue-light:#c6def0;--blue-xlight:#e9f6ff;--green:#2f9d69;--green-light:#43a047;--red:#d64a4a;--red-light:#ff5e3d;--amber:#f4d44d;--amber-light:#fff8d9;--gray-50:#fbfcfe;--gray-100:#e6f0f7;--gray-200:#d6dce5;--gray-300:#b7c2d1;--gray-500:#697386;--gray-700:#2f3948;--gray-800:#1d2733;--gray-900:#151b25;--white:#ffffff;--shadow-sm:0 2px 6px rgba(19,33,68,.08);--shadow-md:0 8px 24px rgba(19,33,68,.12);--shadow-lg:0 18px 48px rgba(12,24,48,.16);--radius:18px;--sidebar-w:104px;--sidebar-bg:#24272f;--topbar-h:76px;--tabbar-h:54px;--app-gutter:18px;--safe-top:env(safe-area-inset-top,0px);--safe-right:env(safe-area-inset-right,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);font-size:15px}html{color-scheme:light}html.theme-dark{color-scheme:dark;--blue-dark:#0f1520;--blue:#ff734f;--blue-mid:#ff8a69;--blue-light:#223040;--blue-xlight:#1d2a3a;--green:#81c784;--green-light:#a5d6a7;--red:#ef9a9a;--red-light:#ffab91;--amber:#ffcc80;--amber-light:#3d3028;--gray-50:#141b28;--gray-100:#0d1320;--gray-200:#1a2333;--gray-300:#2f3d52;--gray-500:#8ea0b8;--gray-700:#ccd6e6;--gray-800:#e6edf8;--gray-900:#f2f7ff;--white:#1a2333;--sidebar-bg:#0f141d;--shadow-sm:0 1px 2px rgba(0,0,0,.35);--shadow-md:0 4px 14px rgba(0,0,0,.42);--shadow-lg:0 12px 36px rgba(0,0,0,.55)}html.theme-dark .btn-outline{background:#ffffff12;border-color:var(--gray-300);color:var(--gray-800)}html.theme-dark .btn-primary{background:#c65a45;color:#fff}html.theme-dark .btn-success{background:#256d2b;color:#ecfdf5}html.theme-dark .btn-danger{background:#b71c1c;color:#fef2f2}html.theme-dark .btn-google{background:#ffffff14;border-color:var(--gray-300);color:var(--gray-800)}html.theme-dark .modal-close{background:var(--gray-300);color:var(--gray-900)}html.theme-dark input:not([type=radio]):not([type=checkbox]):focus,html.theme-dark select:focus,html.theme-dark textarea:focus{box-shadow:0 0 0 3px #6495ed47;border-color:var(--blue-mid)}html.theme-dark .banner-backup{background:#f57c0033;color:#ffb74d}html.theme-dark .banner-trial{background:var(--blue-xlight);color:var(--blue-mid)}html.theme-dark .banner-expired{background:#ef53502e;color:#fca5a5}html.theme-dark .badge-green{background:#4caf5038;color:#a5d6a7}html.theme-dark .badge-amber{background:#ffa7262e;color:#ffcc80}html.theme-dark .badge-red{background:#e5737333;color:#fca5a5}html.theme-dark .badge-blue{background:var(--blue-xlight);color:var(--blue-mid)}html.theme-dark .badge-gray{background:var(--gray-200);color:var(--gray-700)}html.theme-dark .table-wrap{background:var(--white);border-color:var(--gray-300)}html.theme-dark th{background:#ffffff08;border-bottom-color:var(--gray-300);color:var(--gray-500)}html.theme-dark td{color:var(--gray-700);border-bottom-color:var(--gray-300)}html.theme-dark .action-dropdown-menu{border-color:var(--gray-300);box-shadow:0 10px 30px #00000073}html.theme-dark .modal-overlay{background:#02060c9e}html.theme-dark .modal,html.theme-dark .phrase-dialog,html.theme-dark .more-sheet{border-color:#2a2f3a}html.theme-dark .modal-header,html.theme-dark .modal-footer,html.theme-dark .phrase-dialog-header,html.theme-dark .phrase-dialog-footer,html.theme-dark .more-sheet-item{border-color:var(--gray-300)}html.theme-dark .modal-close{background:#ffffff14;border-color:var(--gray-300);color:var(--gray-800)}html.theme-dark .badge{border-color:transparent}html.theme-dark .badge-green{border-color:#81c78473}html.theme-dark .badge-amber{border-color:#ffcc8066}html.theme-dark .badge-red{border-color:#ef9a9a73}html.theme-dark .badge-blue{border-color:#5f92e073}html.theme-dark .badge-gray{border-color:#94a3b866}html.theme-dark .phrase-card{background:#ffffff0f}html.theme-dark .phrase-card.selected-adequate{background:#4caf502e;border-color:var(--green-light)}html.theme-dark .phrase-card.selected-developing{background:#ffa72626;border-color:var(--amber)}html.theme-dark .phrase-card.selected-difficulty{background:#e573732e;border-color:var(--red-light)}html.theme-dark .action-menu-item:hover:not(.danger),html.theme-dark .action-menu-item:focus-visible:not(.danger){background:#ffffff14}html.theme-dark .action-menu-item.danger:hover,html.theme-dark .action-menu-item.danger:focus-visible{background:#e5737326}html.theme-dark .tabbar{border-top-color:#ffffff1f}html,body{width:100%;max-width:100%;overflow-x:hidden;overflow-y:hidden;overscroll-behavior:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}body{font-family:Segoe UI,Inter,-apple-system,BlinkMacSystemFont,Roboto,system-ui,sans-serif;background:var(--gray-100);color:var(--gray-900);min-height:100vh;min-height:100dvh;padding:0;user-select:none;-webkit-user-select:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.45}html.auth-mode,body.auth-mode{overflow-y:auto;overscroll-behavior:auto}input,select,textarea,[contenteditable=true]{user-select:text;-webkit-user-select:text;-webkit-touch-callout:default}#auth-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#d5e7f4;padding:var(--app-gutter);overflow-y:auto}.auth-landing-wrap{width:min(1280px,100%);display:grid;grid-template-columns:minmax(0,1fr) 430px;gap:24px;align-items:start}.auth-landing-main{color:var(--gray-800);background:#f7fbff;border:1px solid var(--gray-200);border-radius:28px;padding:30px;box-shadow:var(--shadow-lg)}.auth-landing-hero{margin-bottom:20px}.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}.auth-logo-left{justify-content:flex-start}.auth-logo svg{width:40px;height:40px;flex-shrink:0}.auth-logo-text{font-size:24px;font-weight:800;letter-spacing:-.3px}.auth-kicker{display:inline-flex;padding:6px 10px;border:1px solid var(--gray-300);border-radius:999px;font-size:12px;font-weight:600;margin-bottom:12px}.auth-hero-title{font-size:34px;line-height:1.15;letter-spacing:-.4px;margin-bottom:12px;max-width:18ch}.auth-hero-subtitle{font-size:16px;line-height:1.6;color:var(--gray-700);max-width:65ch}.auth-hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.auth-landing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0 18px}.auth-feature-card{border:1px solid var(--gray-200);border-radius:14px;padding:14px;background:#fff}.auth-feature-card h3{font-size:15px;line-height:1.3;margin-bottom:6px}.auth-feature-card p{font-size:13px;line-height:1.5;color:var(--gray-700)}.auth-how{margin-bottom:16px}.auth-how h2,.auth-conversion-band h2{font-size:20px;line-height:1.2;margin-bottom:10px}.auth-how-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.auth-step-card{border-radius:14px;border:1px solid var(--gray-200);background:#fff;padding:14px}.auth-step-card span{width:28px;height:28px;border-radius:999px;background:#fff;color:var(--blue-dark);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-bottom:8px}.auth-step-card h3{font-size:14px;line-height:1.3;margin-bottom:6px}.auth-step-card p{font-size:13px;line-height:1.45;color:var(--gray-700)}.auth-conversion-band{border-radius:16px;border:1px solid #ffd0bf;background:#fff1eb;padding:16px}.auth-conversion-band p{font-size:14px;color:var(--gray-700)}.auth-card{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.auth-header{background:#1f2430;padding:18px var(--app-gutter) 16px;text-align:center;color:#fff}.auth-pane-toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;background:#ffffff1f;border-radius:10px;padding:4px;margin-bottom:10px}.auth-pane-toggle button{border:none;background:transparent;color:#ffffffe6;font-size:13px;font-weight:700;border-radius:8px;min-height:36px;cursor:pointer}.auth-pane-toggle button.active{background:#fff;color:var(--blue-dark)}.auth-subtitle{font-size:12px;opacity:.85}.auth-body{padding:24px var(--app-gutter)}.auth-title{font-size:20px;font-weight:700;color:var(--blue-dark);margin-bottom:20px}.auth-footer{padding:0 var(--app-gutter) 24px;text-align:center;font-size:12px;color:var(--gray-500)}.auth-credit{margin-top:6px;font-size:11px}.auth-credit a{color:var(--red-light);font-weight:700;text-decoration:none}.auth-credit a:hover{text-decoration:underline}.auth-switch{text-align:center;margin-top:20px;font-size:14px;color:var(--gray-500)}.auth-switch a{color:var(--blue);cursor:pointer;text-decoration:none;font-weight:600}#verify-screen{min-height:100vh;min-height:100dvh;display:none;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--blue-dark),var(--blue));padding:var(--app-gutter);overflow-y:auto}.verify-card{background:var(--white);border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:440px;width:100%;padding:32px 24px;text-align:center}#app-screen{display:none;position:fixed;top:0;right:0;bottom:0;left:0;height:100vh;min-height:100dvh;flex-direction:column;background:var(--gray-100);overflow:hidden;padding:0}.topbar{background:var(--white);color:var(--gray-800);display:flex;align-items:center;height:calc(var(--topbar-h) + var(--safe-top));padding:var(--safe-top) 24px 0 16px;gap:12px;flex-shrink:0;position:sticky;top:0;z-index:90;border:2px solid #2a2f3a;border-bottom:1px solid var(--gray-200);border-radius:0}.topbar-menu{display:none;background:transparent;border:none;color:var(--gray-800);padding:8px;border-radius:12px;cursor:pointer;min-height:44px;min-width:44px;align-items:center;justify-content:center}.topbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.topbar-logo{font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--gray-900)}.topbar-spacer{flex:1}.topbar-notify{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-700)}.topbar-notify svg{width:16px;height:16px}.topbar-profile{display:flex;align-items:center;gap:8px;min-width:0}.topbar-avatar{width:34px;height:34px;border-radius:999px;background:#ffd9c8;color:#a33b1f;font-size:12px;font-weight:700;display:grid;place-items:center;flex-shrink:0}.topbar-user{font-size:13px;font-weight:600;color:var(--gray-800);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-btn{background:#252a33;border:none;color:#fff;padding:8px 16px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s;min-height:40px}.topbar-theme-toggle{display:inline-flex;align-items:center;justify-content:center;background:var(--gray-50);border:1px solid var(--gray-200);color:var(--gray-700);padding:8px;border-radius:12px;cursor:pointer;min-height:44px;min-width:44px;flex-shrink:0}.topbar-theme-toggle svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.app-body{display:flex;flex:1;overflow:hidden;max-width:100%;border:2px solid #2a2f3a;border-top:none;border-radius:0;background:var(--gray-50)}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;padding-top:8px}.sidebar-backdrop{display:none}.nav-section{padding:16px 0 6px;font-size:9px;font-weight:700;letter-spacing:.8px;color:#ffffff61;text-transform:uppercase;text-align:center}.nav-item{display:flex;align-items:center;justify-content:center;gap:0;padding:11px;color:#ffffffbf;cursor:pointer;border-radius:16px;margin:4px 12px;font-size:0;transition:background .12s;min-height:52px}.nav-item svg{width:20px;height:20px;flex-shrink:0;opacity:.86}.nav-item.active{background:#f4d44d;color:#151b25;font-weight:600}.nav-item.active svg{opacity:1}.sidebar-bottom{margin-top:auto;padding:12px 8px}.subscription-badge{background:#ffffff1a;border-radius:12px;padding:12px 14px;font-size:11px;color:#fffc;margin-bottom:8px;text-align:center;line-height:1.35;overflow-wrap:normal;word-break:normal}.subscription-badge.warn{background:#f57c0040}.subscription-badge.expired{background:#c628284d}.sub-label{display:flex;align-items:center;gap:4px;font-weight:700;font-size:11px;margin-bottom:2px}.sub-label svg{flex-shrink:0}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--app-gutter) 24px calc(var(--tabbar-h) + var(--safe-bottom) + 16px);display:flex;flex-direction:column;gap:14px;max-width:100%;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--gray-50)}.main-content.page-enter{animation:pageSlideIn .2s ease}.tabbar{display:none;background:var(--white);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid rgba(0,0,0,.12);height:calc(var(--tabbar-h) + var(--safe-bottom));padding:4px 0 calc(2px + var(--safe-bottom));position:sticky;bottom:0;z-index:95;grid-template-columns:repeat(5,minmax(0,1fr));gap:0}.tabbar-item{border:none;background:transparent;color:var(--gray-500);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;border-radius:0;min-height:0;min-width:44px;font-size:10px;font-weight:500;cursor:pointer;padding:2px 2px 0;transition:color .15s}.tabbar-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;transition:all .15s}.tabbar-item.active{color:var(--blue);font-weight:600}.tabbar-item.active svg{stroke-width:2.2}.tabbar-label{line-height:1;white-space:nowrap;letter-spacing:-.1px;margin-top:1px}.banner{border-radius:var(--radius);padding:14px var(--app-gutter);display:flex;align-items:center;gap:10px;font-size:13px;border:none}.banner-backup{background:#fff3e0;color:#e65100;margin-top:12px}.banner-trial{background:var(--blue-xlight);color:var(--blue-dark)}.banner-expired{background:#ffebee;color:var(--red)}.banner button{margin-left:auto;flex-shrink:0;font-size:13px}.card{background:var(--white);border-radius:var(--radius);box-shadow:none;border:.5px solid var(--gray-200);overflow:visible}.card-header{padding:16px var(--app-gutter);border-bottom:.5px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;gap:10px}.card-title{font-size:20px;font-weight:700;color:var(--gray-900);letter-spacing:-.2px}.card-body{padding:var(--app-gutter)}.table-wrap{width:100%;max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;border:1px solid var(--gray-200);border-radius:14px;background:var(--white)}table{width:100%;min-width:100%;border-collapse:collapse;font-size:13px}th{background:var(--gray-50);padding:11px 14px;text-align:left;font-weight:700;font-size:11px;color:var(--gray-500);border-bottom:1px solid var(--gray-200);text-transform:uppercase;letter-spacing:.45px}td{padding:12px 14px;border-bottom:.5px solid var(--gray-200);vertical-align:middle;color:var(--gray-700)}tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:6px;align-items:center}.action-dropdown{position:relative;display:inline-block}.action-dropdown>summary.action-dropdown-summary{display:inline-flex;align-items:center;justify-content:center;gap:4px;list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none}.action-dropdown>summary.action-dropdown-summary::-webkit-details-marker{display:none}.action-dropdown>summary.action-dropdown-summary::marker{content:""}.action-dropdown-menu{position:absolute;right:0;top:calc(100% + 4px);min-width:172px;background:var(--white);border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 10px 30px #19243b29;padding:6px;z-index:96;display:flex;flex-direction:column;gap:2px}.action-dropdown-menu.is-fixed{position:fixed;right:auto;z-index:220}.action-menu-item{width:100%;text-align:left;justify-content:flex-start;display:inline-flex;align-items:center;border:none;background:transparent;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--gray-900);min-height:44px;-webkit-tap-highlight-color:transparent}.action-menu-item:hover,.action-menu-item:focus-visible{background:var(--gray-50);outline:none}.action-menu-item.danger{color:var(--red-light)}.action-menu-item.danger:hover,.action-menu-item.danger:focus-visible{background:#ffebee}.records-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}.records-filter-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.students-filter-row{display:flex;gap:8px;flex-wrap:wrap}.students-filter-row>*{flex:1 1 160px;min-width:0}.form-row{display:flex;gap:12px;margin-bottom:14px}.form-row.col1{flex-direction:column}.form-group{display:flex;flex-direction:column;gap:6px;flex:1}label{font-size:13px;font-weight:600;color:var(--gray-700)}input:not([type=radio]):not([type=checkbox]),select,textarea{border:1px solid var(--gray-300);border-radius:14px;padding:12px 14px;font-size:15px;width:100%;font-family:inherit;transition:border .15s,box-shadow .15s;background:var(--gray-50);color:var(--gray-900);min-height:48px}input:not([type=radio]):not([type=checkbox]):focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #2b5ba81f;background:var(--white)}input[type=radio],input[type=checkbox]{width:auto;min-height:0;padding:0;border:none;border-radius:0;background:transparent;accent-color:var(--blue);flex-shrink:0}textarea{resize:vertical;min-height:90px}.form-hint{font-size:12px;color:var(--gray-500)}.form-warn{display:block;margin-bottom:12px;padding:10px 12px;border-radius:10px;background:var(--amber-light);border:1px solid #ffd699;color:#7a4b00;font-size:12px;line-height:1.5}.ai-trial-counter{font-size:.85rem;color:var(--gray-500);margin-left:auto;margin-right:8px}.ai-trial-counter.exhausted{color:var(--amber)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border-radius:14px;border:none;cursor:pointer;font-size:15px;font-weight:600;font-family:inherit;transition:transform .1s,opacity .1s;min-height:48px;min-width:48px;-webkit-tap-highlight-color:transparent;position:relative;letter-spacing:-.1px}.btn-primary{background:var(--red-light);color:#fff}.btn-success{background:var(--green);color:#fff}.btn-danger{background:var(--red-light);color:#fff}.btn-outline{background:var(--gray-50);border:.5px solid var(--gray-300);color:var(--gray-700)}.btn-sm{padding:10px 14px;font-size:13px;min-height:44px;font-weight:600;border-radius:10px}.btn-google{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-700);width:100%;justify-content:center;padding:14px;font-size:15px;margin-bottom:16px;font-weight:600;border-radius:12px}.btn-google svg{width:20px;height:20px}.divider{display:flex;align-items:center;gap:10px;margin-bottom:16px;color:var(--gray-500);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:.5px;background:var(--gray-300)}.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--gray-300);margin:10px auto 0;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182761;z-index:100;display:none;align-items:flex-end;justify-content:center;padding:0}.modal-overlay.open{display:flex}.modal{background:var(--white);border-radius:20px 20px 0 0;width:100%;max-width:none;max-height:92dvh;overflow:hidden;display:flex;flex-direction:column;min-height:0;transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);border:2px solid #2a2f3a}.modal-overlay.open .modal{transform:translateY(0)}.modal-header{padding:8px 20px 14px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-title{font-size:17px;font-weight:700;color:var(--gray-900)}.modal-close{display:inline-flex;background:var(--gray-50);border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-700);width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;line-height:1}.modal-body{padding:20px var(--app-gutter);flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-footer{padding:14px var(--app-gutter) calc(14px + var(--safe-bottom));border-top:1px solid var(--gray-200);display:flex;gap:8px;flex-shrink:0}.modal-footer:empty{display:none;padding:0;border:none}.modal-footer .btn{flex:1}.modal-overlay.modal-overlay--high{z-index:210}.premium-upsell-modal{position:relative;border-radius:20px;max-width:520px;margin:0 auto;max-height:90dvh}.modal-overlay.modal-overlay--high{align-items:center;padding:16px}.premium-upsell-close{position:absolute;top:12px;right:12px;z-index:1}.premium-upsell-body{padding-top:8px}.premium-upsell-header{text-align:center;margin-bottom:14px}.premium-upsell-header h2{margin:8px 0 6px;font-size:22px;font-weight:800;color:var(--gray-900)}.premium-upsell-header svg{color:var(--amber);margin:0 auto;display:block}.premium-upsell-kicker{font-size:14px;color:var(--gray-600);line-height:1.5;margin:0}.premium-upsell-prices{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}.premium-price-pill{font-size:13px;background:var(--gray-100);padding:8px 14px;border-radius:999px;color:var(--gray-800)}.premium-price-pill-year{background:var(--blue-xlight);color:var(--blue)}.premium-benefits{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:12px}.premium-benefits li{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.5;color:var(--gray-800)}.premium-benefits li svg{flex-shrink:0;color:var(--green);margin-top:2px}.premium-upsell-actions{display:flex;flex-direction:column;gap:10px;padding-bottom:4px}.ai-compare-grid{display:grid;gap:12px;margin-top:4px}.ai-compare-panel{display:flex;flex-direction:column;min-height:0}.ai-compare-label{font-size:12px;font-weight:700;color:var(--gray-700);margin-bottom:6px}.ai-compare-text{flex:1;min-height:120px;max-height:42dvh;overflow-y:auto;padding:10px 12px;border:.5px solid var(--gray-200);border-radius:10px;font-size:14px;line-height:1.55;white-space:pre-wrap;word-break:break-word;background:var(--gray-50);color:var(--gray-800);margin:0;font-family:inherit}.ai-compare-hint{color:var(--gray-500);font-style:italic;display:flex;align-items:center}@media(min-width:640px){.ai-compare-grid{grid-template-columns:1fr 1fr;align-items:stretch}}.section-heading{font-size:22px;font-weight:700;color:var(--gray-900);letter-spacing:-.3px}.mb-16{margin-bottom:14px}.text-muted{color:var(--gray-500)}.text-sm{font-size:12px}.page-shell{padding-top:15px}.page-heading{display:block}.page-stack-item{margin-bottom:12px}.card-title-inline{display:inline-flex;align-items:center;gap:8px}.card-body-compact{padding:12px}.page-empty-text{color:var(--gray-500);font-size:13px}.page-empty-text-mb{margin-bottom:16px}.reports-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.report-result-scroll{overflow-y:auto;max-height:60vh}.table-cell-empty{text-align:center;color:var(--gray-500);padding:20px}.table-cell-center{text-align:center}.table-cell-compact{font-size:12px}.table-user-name{font-weight:600}.table-user-meta{font-size:11px;color:var(--gray-500)}.table-badge-spaced{margin-left:4px}.badge{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;line-height:1;border:1px solid transparent}.badge-green{background:#e8f5e9;color:var(--green);border-color:#b7dfba}.badge-amber{background:#fff3e0;color:#b26a14;border-color:#ffd9a8}.badge-red{background:#ffebee;color:var(--red);border-color:#f2b4b4}.badge-blue{background:var(--blue-xlight);color:#2e5f90;border-color:#b9d5ec}.badge-gray{background:var(--gray-50);color:var(--gray-700);border-color:var(--gray-200)}.flex{display:flex}.gap-8{gap:8px}.items-center{align-items:center}.justify-between{justify-content:space-between}.settings-section{background:var(--white);border-radius:var(--radius);border:.5px solid var(--gray-200);padding:20px var(--app-gutter);margin-bottom:12px}.settings-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:4px}.settings-title svg{flex-shrink:0}.settings-sub{font-size:13px;color:var(--gray-500);margin-bottom:16px}.strength-bar{height:4px;border-radius:2px;margin-top:4px;background:var(--gray-200);overflow:hidden}.strength-fill{height:100%;border-radius:2px;transition:width .3s,background .3s}.toast-wrap{position:fixed;bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 12px);left:var(--app-gutter);right:var(--app-gutter);z-index:999;display:flex;flex-direction:column;align-items:center;gap:8px}.toast{display:flex;align-items:center;gap:8px;justify-content:center;padding:14px 20px;border-radius:14px;color:#fff;font-size:14px;font-weight:500;box-shadow:0 4px 20px #0003;animation:toastSlideUp .25s ease;max-width:380px;width:100%;text-align:center}.toast-success{background:#2e7d32f2}.toast-error{background:#c62828f2}.toast-info{background:#1565c0f2}@keyframes toastSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.waiting-indicator{position:fixed;bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 12px);left:var(--app-gutter);right:var(--app-gutter);z-index:98;display:none;text-align:center;pointer-events:none}.waiting-indicator.show{display:block}.waiting-indicator{color:transparent}.waiting-indicator.show{color:#fff}.waiting-indicator.show{background:#212121e6;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.2px;box-shadow:0 4px 14px #0003;width:fit-content;margin:0 auto;display:inline-flex;align-items:center;gap:8px}.waiting-indicator.show:before{content:"";width:12px;height:12px;border-radius:999px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:waitingSpin .8s linear infinite}@keyframes waitingSpin{to{transform:rotate(360deg)}}.admin-stat{background:var(--white);border-radius:var(--radius);border:.5px solid var(--gray-200);padding:16px;text-align:center;flex:1;min-width:100px}.admin-stat-val{font-size:26px;font-weight:800;color:var(--gray-900)}.admin-stat-label{font-size:11px;color:var(--gray-500);margin-top:4px;text-transform:uppercase;letter-spacing:.3px}.stat-grid{display:flex;gap:10px;flex-wrap:wrap}.rec-item{background:var(--white);border-radius:var(--radius);border:.5px solid var(--gray-200);padding:14px var(--app-gutter);margin-bottom:10px;position:relative}.rec-item-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rec-date{font-size:12px;color:var(--gray-500)}.rec-axis{font-size:12px;font-weight:700;color:var(--blue)}.rec-bim{font-size:11px;background:var(--blue-xlight);color:var(--blue);padding:2px 8px;border-radius:10px;font-weight:600}.rec-text{font-size:14px;line-height:1.6;white-space:pre-wrap;color:var(--gray-700)}.rec-ctx{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--gray-500);margin-top:6px;font-style:italic}.rec-ctx svg{flex-shrink:0;margin-top:2px;opacity:.85}.rec-actions{display:flex;justify-content:flex-end;margin-top:10px;padding-top:10px;border-top:.5px solid var(--gray-200)}.phrase-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:none;align-items:flex-end;justify-content:center;padding:0}.phrase-overlay.open{display:flex}.phrase-dialog{background:var(--white);border-radius:20px 20px 0 0;width:100%;max-width:none;max-height:92dvh;min-height:0;overflow:hidden;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);border:2px solid #2a2f3a}.phrase-overlay.open .phrase-dialog{transform:translateY(0)}.phrase-dialog-header{padding:6px var(--app-gutter) 14px;border-bottom:.5px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.phrase-dialog-title{font-size:17px;font-weight:700;color:var(--gray-900)}.phrase-dialog-body{padding:var(--app-gutter);overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}.phrase-dialog-footer{padding:14px var(--app-gutter) calc(14px + var(--safe-bottom));border-top:.5px solid var(--gray-200);display:flex;gap:8px;flex-shrink:0}.phrase-dialog-footer .btn{flex:1}.subitem-section{margin-bottom:12px;border:.5px solid var(--gray-200);border-radius:12px;overflow:hidden}.subitem-name{font-size:14px;font-weight:700;color:var(--gray-900);padding:12px var(--app-gutter);background:var(--gray-50);border-bottom:.5px solid var(--gray-200)}.phrase-options{padding:8px;display:flex;flex-direction:column;gap:6px}.phrase-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:all .12s;font-size:14px;line-height:1.5;min-height:48px}.phrase-card.selected-adequate{border-color:var(--green);background:#e8f5e9}.phrase-card.selected-developing{border-color:var(--amber);background:var(--amber-light)}.phrase-card.selected-difficulty{border-color:var(--red);background:#ffebee}.phrase-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0;margin-top:2px}.phrase-icon svg{display:block}.phrase-icon-adequate{color:var(--green)}.phrase-icon-developing{color:var(--amber)}.phrase-icon-difficulty{color:var(--red)}.phrase-text{flex:1;color:var(--gray-700)}.phrase-legend{display:flex;gap:14px;padding:8px 0 12px;font-size:12px;color:var(--gray-500)}.phrase-legend span{display:flex;align-items:center;gap:4px}.strength-0,.strength-1{background:var(--red-light)}.strength-2{background:var(--amber)}.strength-3,.strength-4{background:var(--green-light)}.card-relatorio{margin-bottom:14px;position:sticky;top:8px;z-index:40;background:var(--white);border:.5px solid var(--gray-200)}button,[role=button],.btn,.nav-item,.phrase-card,.topbar-btn,.topbar-theme-toggle,.modal-close,.tabbar-item,.more-sheet-item,.auth-switch a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}button:active,.btn:active,.nav-item:active,.phrase-card:active,.topbar-btn:active,.topbar-theme-toggle:active,.tabbar-item:active,.more-sheet-item:active{transform:scale(.96);opacity:.7}.modal-close:active{transform:scale(.9);opacity:.7}a:active{opacity:.7}@media(hover:hover){.btn-primary:hover{background:#e14e30}.btn-success:hover{background:#1b5e20}.btn-danger:hover{background:var(--red)}.btn-outline:hover{background:var(--gray-100)}html.theme-dark .btn-outline:hover{background:#ffffff1f}html.theme-dark .btn-primary:hover{background:#b84f3a}html.theme-dark .btn-success:hover{background:#1b5e20}html.theme-dark .btn-danger:hover{background:#8b1515}html.theme-dark .btn-google:hover{background:#ffffff1f}html.theme-dark .modal-close:hover,html.theme-dark .modal-close:focus-visible{background:#ffffff24;color:var(--gray-900)}.nav-item:hover{background:#ffffff1a;color:#fff}}*{scrollbar-width:none}*::-webkit-scrollbar{display:none;width:0;height:0}.main-content:has(.alunos-page){overflow-y:hidden;min-height:0}.alunos-page{flex:1;min-height:0;display:flex;flex-direction:column;padding-top:15px}.alunos-page .alunos-table-card{flex:1;min-height:0;display:flex;flex-direction:column;margin-bottom:0;overflow:hidden}.alunos-page .alunos-table-scroll{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--gray-300) var(--gray-50)}.alunos-page .alunos-table-scroll::-webkit-scrollbar{display:block;width:10px;height:10px}.alunos-page .alunos-table-scroll::-webkit-scrollbar-track{background:var(--gray-50);border-radius:6px}.alunos-page .alunos-table-scroll::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:6px}.alunos-page .alunos-table-scroll::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.more-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:160;display:none;align-items:flex-end;justify-content:center}.more-sheet-overlay.open{display:flex}.more-sheet{width:100%;max-height:72dvh;overflow-y:auto;background:var(--white);border-radius:20px 20px 0 0;padding:0 var(--app-gutter) calc(var(--app-gutter) + var(--safe-bottom));transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);border:2px solid #2a2f3a}.more-sheet-overlay.open .more-sheet{transform:translateY(0)}.more-sheet-title{font-size:17px;font-weight:700;color:var(--gray-900);padding:6px 4px 14px}.more-sheet-item{width:100%;display:flex;align-items:center;gap:12px;border:none;background:transparent;border-radius:12px;padding:14px 12px;color:var(--gray-700);font-size:16px;cursor:pointer;min-height:52px;font-weight:500;border-bottom:.5px solid var(--gray-200)}.more-sheet-item:last-child{border-bottom:none}.more-sheet-item.active{color:var(--blue);font-weight:700}@keyframes pageSlideIn{0%{opacity:.92;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@media(max-width:1024px){:root{--app-gutter:16px}#app-screen{height:100dvh;padding:0}.tabbar{display:grid;position:fixed;left:0;right:0;bottom:0;background:var(--white);backdrop-filter:none;-webkit-backdrop-filter:none}.topbar-menu{display:inline-flex}.topbar{padding:var(--safe-top) calc(12px + var(--safe-right)) 0 calc(12px + var(--safe-left));gap:8px;border:none;border-bottom:1px solid var(--gray-200);border-radius:0}.topbar-brand{display:flex;gap:8px}.topbar-brand svg{width:28px;height:28px}.topbar-logo{font-size:21px}.topbar-notify{display:none}.topbar-user{max-width:100px;font-size:12px}.app-body{position:relative}.sidebar{position:fixed;top:calc(var(--topbar-h) + var(--safe-top));left:0;bottom:0;z-index:120;width:min(82vw,300px);max-width:100%;transform:translate3d(-100%,0,0);transition:transform .25s cubic-bezier(.32,.72,0,1);box-shadow:var(--shadow-lg)}.nav-item{justify-content:flex-start;gap:10px;font-size:14px;margin:2px 8px;border-radius:12px;padding:11px 14px}.nav-section{text-align:left;padding:16px 14px 6px}.sidebar-bottom{padding:12px 8px}.sidebar-backdrop{position:fixed;inset:calc(var(--topbar-h) + var(--safe-top)) var(--safe-right) var(--safe-bottom) var(--safe-left);z-index:110;background:#00000059}body.sidebar-open .sidebar{transform:translateZ(0)}body.sidebar-open .sidebar-backdrop{display:block}.main-content{padding:var(--app-gutter) calc(var(--app-gutter) + var(--safe-right)) calc(var(--tabbar-h) + var(--safe-bottom) + 12px) calc(var(--app-gutter) + var(--safe-left))}.banner{flex-wrap:wrap}.banner button{margin-left:0;width:100%}.form-row{flex-direction:column}.settings-section{padding:var(--app-gutter)}.toast-wrap{left:var(--app-gutter);right:var(--app-gutter);bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 12px)}.toast{max-width:none}.card-relatorio{position:static;top:auto}#rpt-result{max-height:none!important}.records-grid,.records-filter-grid,.reports-filter-grid{grid-template-columns:1fr}.table-actions{flex-wrap:wrap}.table-actions>.btn{flex:1 1 auto;justify-content:center}.students-filter-row>*{flex:1 1 100%}.topbar-btn{padding:8px 14px;font-size:13px}.auth-landing-wrap{grid-template-columns:1fr;gap:14px}.auth-landing-main{padding:18px}.auth-landing-grid{grid-template-columns:1fr 1fr}.auth-how-steps{grid-template-columns:1fr}.auth-card{max-width:100%}.modal-overlay{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.modal{max-height:92dvh}.modal .modal-footer{padding-bottom:calc(14px + var(--safe-bottom) + 4px)}.phrase-overlay{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.phrase-dialog{max-height:92dvh}.phrase-dialog .phrase-dialog-footer{padding-bottom:calc(14px + var(--safe-bottom) + 4px)}.more-sheet-overlay{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.more-sheet{max-height:72dvh;padding-bottom:calc(var(--app-gutter) + var(--safe-bottom))}}@media(display-mode:standalone){html,body{background:var(--white)}}@media(max-width:1024px)and (display-mode:standalone){.tabbar{height:auto;min-height:calc(var(--tabbar-h) + var(--safe-bottom));padding:4px 4px max(8px,var(--safe-bottom));align-items:end}.tabbar-item{justify-content:flex-end;padding-top:2px;padding-bottom:2px;min-height:0}}@media(max-width:768px){#auth-screen,#verify-screen{padding:calc(12px + var(--safe-top)) calc(12px + var(--safe-right)) calc(12px + var(--safe-bottom)) calc(12px + var(--safe-left))}.verify-card{padding:24px 18px}.auth-header,.auth-body,.auth-footer{padding-left:var(--app-gutter);padding-right:var(--app-gutter)}.auth-hero-title{font-size:28px}.auth-hero-subtitle{font-size:15px}.auth-landing-grid{grid-template-columns:1fr}.auth-hero-cta .btn{width:100%}.auth-title{font-size:18px}.card-header{padding:12px var(--app-gutter)}.card-body{padding:var(--app-gutter)}.section-heading{font-size:24px}.topbar-brand svg{width:26px;height:26px}.topbar-logo{font-size:20px}.topbar-user,.topbar-profile{display:none}.topbar{padding:var(--safe-top) calc(10px + var(--safe-right)) 0 calc(10px + var(--safe-left))}}@media(min-width:1025px){:root{--app-gutter:20px}.modal{max-width:540px;border-radius:20px;margin-bottom:5vh}.modal.modal--ai-compare{max-width:min(920px,96vw)}.modal-overlay{align-items:center}.modal-footer .btn{flex:unset}.phrase-overlay{align-items:center}.phrase-dialog{max-width:720px;border-radius:20px;margin-bottom:5vh}.phrase-dialog-footer .btn{flex:unset}.sheet-handle{display:none}.topbar-menu,.tabbar{display:none!important}.main-content{padding:var(--app-gutter) var(--app-gutter) calc(var(--app-gutter) + 20px)}.topbar{top:0}}#root{min-height:100vh;min-height:100dvh}
