.profile-page{max-width:680px;padding:2rem}.profile-header{align-items:center;gap:1.25rem;margin-bottom:2.5rem;display:flex}.profile-avatar{background:var(--navy);color:#fff;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.3rem;font-weight:700;display:flex}.profile-header h2{color:var(--text);font-size:1.5rem;font-weight:500}.profile-email{color:var(--text-muted);margin-top:.15rem;font-size:.9rem}.profile-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.25rem;padding:1.5rem;animation:.35s forwards fadeUp}.profile-section-title{color:var(--text);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1rem;font-weight:600;display:flex}.profile-section-title svg{color:var(--navy);opacity:.7}.profile-form{flex-direction:column;display:flex}.profile-field{margin-bottom:1.25rem}.profile-field label{color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase;margin-bottom:.45rem;font-size:.82rem;font-weight:600;display:block}.profile-field input,.profile-field select{background:var(--ice);border:none;border-bottom:2px solid var(--border);width:100%;height:48px;color:var(--text);border-radius:0;outline:none;padding:0 1rem;font-family:inherit;font-size:.95rem;transition:border-color .15s}.profile-field input:focus,.profile-field select:focus{border-bottom-color:var(--navy)}.profile-field input:disabled{opacity:.6;cursor:not-allowed}.profile-hint{color:var(--text-muted);margin-top:.3rem;font-size:.75rem;font-style:italic;display:block}.profile-phone-group{gap:0;display:flex}.profile-phone-prefix{text-align:center;background:var(--steel-light);border-bottom:2px solid var(--border);width:76px;color:var(--navy);flex-shrink:0;justify-content:center;align-items:center;font-size:.95rem;font-weight:600;display:flex}.profile-phone-group input{flex:1}.profile-btn{background:var(--navy);color:#fff;cursor:pointer;border:none;border-radius:10px;align-self:flex-start;padding:.85rem 2rem;font-family:inherit;font-size:.92rem;font-weight:600;transition:all .2s;box-shadow:0 4px 16px #0a3a8e26}.profile-btn:hover{background:var(--navy-mid);transform:translateY(-1px)}.profile-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.profile-success{color:var(--success);background:var(--success-bg);border-radius:8px;margin-bottom:1rem;padding:.6rem .85rem;font-size:.85rem}.profile-error{color:var(--error);background:var(--error-bg);border-radius:8px;margin-bottom:1rem;padding:.6rem .85rem;font-size:.85rem}.profile-info-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.profile-info-item{flex-direction:column;gap:.2rem;display:flex}.profile-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:600}.profile-info-value{color:var(--text);font-family:IBM Plex Mono,monospace;font-size:.95rem;font-weight:600}.header-user-btn{color:var(--crystal-30);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.3rem .5rem;font-family:inherit;font-size:.82rem;transition:background .15s;display:flex}.header-user-btn:hover{background:var(--navy-80)}.header-dropdown{top:calc(var(--header-h) - 4px);background:var(--bg);border:1px solid var(--border);z-index:200;border-radius:10px;min-width:200px;animation:.15s forwards fadeUp;position:absolute;right:.5rem;overflow:hidden;box-shadow:0 8px 32px #0000001f}.header-dropdown-item{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.6rem;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.88rem;text-decoration:none;transition:background .1s;display:flex}.header-dropdown-item:hover{background:var(--ice)}.header-dropdown-item svg{color:var(--text-muted);flex-shrink:0}.header-dropdown-divider{background:var(--border);height:1px;margin:.25rem 0}.header-dropdown-item.danger,.header-dropdown-item.danger svg{color:var(--error)}@media (width<=768px){.profile-page{padding:1.5rem 1rem}.profile-info-grid{grid-template-columns:1fr}}.header{height:var(--header-h);background:var(--navy-100);z-index:100;border-bottom:1px solid var(--navy-80);justify-content:space-between;align-items:center;padding:0 1rem 0 0;display:flex;position:fixed;top:0;left:0;right:0}.header-brand{color:#fff;letter-spacing:.02em;height:100%;min-width:var(--sidebar-w);border-right:1px solid var(--navy-80);align-items:center;gap:.6rem;padding:0 1rem;font-size:.875rem;font-weight:600;text-decoration:none;display:flex}.header-brand img{object-fit:contain;width:30px;height:30px}.header-brand-text{letter-spacing:.02em;flex-direction:column;font-size:.95rem;font-weight:600;line-height:1.1;display:flex}.header-brand-text small{color:var(--crystal-50);letter-spacing:.03em;font-size:.55rem;font-style:italic;font-weight:300}.header-right{align-items:center;gap:1rem;display:flex}.header-user{color:var(--crystal-30);align-items:center;gap:.5rem;font-size:.82rem;display:flex}.avatar{background:var(--navy);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;display:flex}.btn-icon{width:36px;height:36px;color:var(--crystal-50);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--navy-80);color:#fff}.mobile-menu-btn{width:36px;height:36px;color:var(--crystal-50);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;display:none}.mobile-menu-btn:hover{background:var(--navy-80);color:#fff}.layout{margin-top:var(--header-h);min-height:calc(100vh - var(--header-h));display:flex}.sidebar{width:var(--sidebar-w);background:var(--navy-90);border-right:1px solid var(--navy-80);top:var(--header-h);z-index:50;flex-direction:column;transition:transform .3s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;bottom:0;left:0;overflow-y:auto}.sidebar-nav{flex:1;padding:.75rem 0}.nav-section-label{color:var(--navy-50);letter-spacing:.12em;text-transform:uppercase;padding:.75rem 1rem .4rem;font-size:.6rem;font-weight:700}.nav-item{height:46px;color:var(--crystal-40);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:0 1rem;font-family:inherit;font-size:.9rem;font-weight:400;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-item:hover{background:var(--navy-80);color:#fff}.nav-item.active{background:var(--navy-80);color:#fff;font-weight:500}.nav-item.active:before{content:"";background:var(--crystal-50);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-stats{border-top:1px solid var(--navy-80);padding:1rem}.sidebar-stat{justify-content:space-between;align-items:center;padding:.35rem 0;font-size:.8rem;display:flex}.sidebar-stat-label{color:var(--navy-50)}.sidebar-stat-value{color:var(--crystal-30);font-family:IBM Plex Mono,monospace;font-weight:600}.sidebar-overlay{z-index:45;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}.main-content{margin-left:var(--sidebar-w);min-height:calc(100vh - var(--header-h));background:var(--bg);flex:1;position:relative}@media (width<=900px){.filter-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block}.main-content{margin-left:0}.mobile-menu-btn{display:inline-flex}.header-brand{border-right:none;min-width:auto;padding:0 .75rem}.header-brand-text{display:none}}.login-screen{background:var(--bg);min-height:100vh;display:flex}.login-left{background:var(--navy-100);color:#fff;flex-direction:column;flex:1;justify-content:center;padding:4rem 3.5rem;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(at 30% 20%,#3068b826 0%,#0000 60%),radial-gradient(at 70% 80%,#4080d01a 0%,#0000 50%);position:absolute;inset:0}.login-left>*{z-index:1;position:relative}.login-left-brand{align-items:center;gap:1rem;margin-bottom:2.5rem;display:flex}.login-left-brand img{object-fit:contain;border-radius:16px;width:90px;height:90px}.login-left-brand-text h1{letter-spacing:.04em;color:#fff;font-size:2.3rem;font-weight:700;line-height:1.1}.login-left-brand-text p{color:var(--crystal-40);letter-spacing:.03em;margin-top:.2rem;font-size:.95rem;font-style:italic;font-weight:300}.login-left-headline{color:#fff;max-width:460px;margin-bottom:2.5rem;font-size:2.1rem;font-weight:300;line-height:1.4}.login-left-headline strong{font-weight:600}.login-features{flex-direction:column;gap:1.35rem;margin-bottom:2.5rem;display:flex}.login-feature{align-items:flex-start;gap:1rem;display:flex}.login-feature-icon{background:#ffffff14;border:1px solid #ffffff1a;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.1rem;display:flex}.login-feature-text h3{color:#fff;margin-bottom:.25rem;font-size:1.08rem;font-weight:600}.login-feature-text p{color:var(--crystal-40);font-size:.92rem;line-height:1.55}.login-stats{border-top:1px solid #ffffff14;gap:2rem;padding-top:2rem;display:flex}.login-stat-item{flex-direction:column;display:flex}.login-stat-val{color:#fff;font-family:IBM Plex Mono,monospace;font-size:1.7rem;font-weight:700}.login-stat-label{color:var(--crystal-50);margin-top:.2rem;font-size:.82rem}.login-right{background:var(--bg);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;justify-content:center;width:640px;padding:3rem 4rem;display:flex}.login-right-header{margin-bottom:2rem}.login-right-header h2{color:var(--text);letter-spacing:-.01em;font-size:1.9rem;font-weight:500}.login-right-header p{color:var(--text-muted);margin-top:.45rem;font-size:1.02rem}.login-tabs{gap:0;margin-bottom:1.75rem;display:flex}.login-tab{text-align:center;color:var(--text-muted);cursor:pointer;border:1.5px solid var(--border);background:var(--bg);flex:1;padding:.9rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .15s;position:relative}.login-tab:first-child{border-right:none;border-radius:8px 0 0 8px}.login-tab:last-child{border-radius:0 8px 8px 0}.login-tab:hover{color:var(--navy)}.login-tab.active{background:var(--navy);color:#fff;border-color:var(--navy);font-weight:600}.login-form{flex-direction:column;display:flex}.form-group{margin-bottom:1.35rem}.form-group label{color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase;margin-bottom:.5rem;font-size:.88rem;font-weight:600;display:block}.form-group input,.form-group select{background:var(--ice);border:none;border-bottom:2px solid var(--border);width:100%;height:54px;color:var(--text);border-radius:0;outline:none;padding:0 1.1rem;font-family:inherit;font-size:1rem;transition:border-color .15s}.form-group input::placeholder{color:var(--steel)}.form-group input:focus,.form-group select:focus{border-bottom-color:var(--navy)}.phone-input-group{gap:0;display:flex}.phone-prefix{text-align:center;background:var(--steel-light);border-bottom:2px solid var(--border);width:80px;color:var(--navy);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:600;display:flex}.phone-input-group input{flex:1}.btn-login{cursor:pointer;background:var(--navy);color:#fff;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;height:56px;margin-top:.75rem;padding:0 2rem;font-family:inherit;font-size:1.05rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 16px #0a3a8e26}.btn-login:hover{background:var(--navy-mid);transform:translateY(-1px);box-shadow:0 6px 24px #0a3a8e40}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{color:var(--error);background:var(--error-bg);border-radius:8px;margin-bottom:1rem;padding:.65rem .9rem;font-size:.88rem}.login-switch{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.95rem}.login-switch button{color:var(--navy);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:underline}.login-switch button:hover{color:var(--navy-mid)}.login-divider{color:var(--text-muted);align-items:center;gap:1rem;margin:1.25rem 0;font-size:.82rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}@media (width<=900px){.login-screen{flex-direction:column}.login-left{min-height:auto;padding:2.5rem 2rem}.login-left-headline{margin-bottom:1.5rem;font-size:1.4rem}.login-features{gap:1rem;margin-bottom:1.5rem}.login-stats{gap:1.5rem;padding-top:1.25rem}.login-stat-val{font-size:1.2rem}.login-right{border-left:none;border-top:1px solid var(--border);width:100%;padding:2rem 1.5rem}}@media (width<=480px){.login-left{padding:2rem 1.25rem}.login-right{padding:1.5rem 1.25rem}.login-stats{flex-wrap:wrap;gap:1rem}}.home-page{max-width:900px;padding:2rem}.home-section{margin-bottom:2rem}.home-section-title{color:var(--text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.95rem;font-weight:600;display:flex}.home-section-title svg{color:var(--navy);opacity:.6}.resume-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;display:grid}.resume-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:1rem 1.25rem;animation:.35s forwards fadeUp;display:flex}.resume-card-top{justify-content:space-between;align-items:center;display:flex}.resume-progress{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.resume-progress-fill{background:var(--navy);border-radius:2px;height:100%;transition:width .3s}.resume-btn{border:1.5px solid var(--navy);color:var(--navy);cursor:pointer;background:0 0;border-radius:6px;padding:.4rem .8rem;font-family:inherit;font-size:.72rem;font-weight:600;transition:all .15s}.resume-btn:hover{background:var(--navy);color:#fff}.study-tree{flex-direction:column;gap:.5rem;display:flex}.study-semester{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.study-semester-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;transition:background .15s;display:flex}.study-semester-header:hover{background:var(--gray-10)}.study-semester-name{color:var(--text);font-size:.85rem;font-weight:600}.study-semester-stats{color:var(--text-muted);font-family:IBM Plex Mono,monospace;font-size:.72rem}.study-modules{border-top:1px solid var(--border)}.study-module-row{border-bottom:1px solid var(--border);align-items:center;gap:1rem;padding:.6rem 1.25rem .6rem 2rem;font-size:.82rem;display:flex}.study-module-row:last-child{border-bottom:none}.study-module-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.study-module-bar{background:var(--border);border-radius:2px;flex-shrink:0;width:80px;height:4px;overflow:hidden}.study-module-bar-fill{border-radius:2px;height:100%;transition:width .3s}.study-module-pct{text-align:right;min-width:35px;font-family:IBM Plex Mono,monospace;font-size:.72rem;font-weight:600}.study-module-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:4px;flex-shrink:0;padding:.25rem .5rem;font-family:inherit;font-size:.65rem;font-weight:600;transition:all .15s}.study-module-btn:hover{border-color:var(--navy);color:var(--navy)}.home-empty{text-align:center;color:var(--text-muted);background:var(--gray-10);border-radius:var(--radius);padding:2rem;font-size:.85rem}@media (width<=768px){.home-page{padding:1.5rem 1rem}.resume-cards{grid-template-columns:1fr}.study-module-row{flex-wrap:wrap;gap:.5rem;padding-left:1.25rem}.study-module-bar{width:60px}}.setup-panel{max-width:740px;margin:1.5rem auto;padding:0 2rem}.setup-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);animation:.35s forwards fadeUp;overflow:hidden}.setup-card-header{border-bottom:1px solid var(--border);color:var(--navy);align-items:center;gap:.5rem;padding:1.1rem 1.5rem;font-size:.95rem;font-weight:600;display:flex}.setup-card-body{padding:1.75rem}.filter-grid{grid-template-columns:1fr 1fr 1fr;gap:1.15rem;margin-bottom:1.75rem;display:grid}.filter-group label{color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase;margin-bottom:.4rem;font-size:.78rem;font-weight:600;display:block}.filter-group select{background:var(--ice);border:none;border-bottom:2px solid var(--border);width:100%;height:44px;color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%230A3A8E' d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:0;outline:none;padding:0 28px 0 .85rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.filter-group select:focus{border-bottom-color:var(--navy)}.slider-group{margin-bottom:1.75rem}.slider-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;justify-content:space-between;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:flex}.slider-group label span{color:var(--navy);font-family:IBM Plex Mono,monospace;font-size:.95rem}input[type=range]{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--navy);cursor:pointer;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 6px #0a3a8e4d}.toggle-group{gap:0;margin-bottom:1.75rem;display:flex}.toggle-option{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;padding:.6rem 1.15rem;font-family:inherit;font-size:.9rem;transition:all .15s}.toggle-option:first-child{border-right:none;border-radius:8px 0 0 8px}.toggle-option:last-child{border-radius:0 8px 8px 0}.toggle-option.active{background:var(--navy);color:#fff;border-color:var(--navy)}.setup-actions{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:1.15rem;display:flex}.btn-start{background:var(--navy);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.9rem 2.25rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.btn-start:hover{background:var(--navy-mid);transform:translateY(-1px);box-shadow:0 4px 16px #0a3a8e33}.btn-start:disabled{opacity:.5;cursor:not-allowed;transform:none}.question-count-badge{color:var(--text-muted);font-family:IBM Plex Mono,monospace;font-size:.88rem}.question-count-badge strong{color:var(--navy)}.page-header{max-width:780px;padding:2rem 2rem 0}.page-header h2{color:var(--text);letter-spacing:-.02em;font-size:1.6rem;font-weight:300}.page-header p{color:var(--text-muted);margin-top:.3rem;font-size:.9rem}@media (width<=900px){.filter-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.filter-grid{grid-template-columns:1fr}.setup-panel{padding:1rem}.page-header{padding:1.5rem 1rem 0}}.progress-strip{top:var(--header-h);z-index:30;background:var(--ice);height:4px;position:sticky}.progress-strip-fill{background:linear-gradient(90deg, var(--navy), var(--navy-mid));border-radius:0 2px 2px 0;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.question-area{flex-direction:column;width:100%;max-width:680px;margin:0 auto;padding:2.5rem 2rem 9rem;display:flex}.q-meta{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.q-tag{text-transform:uppercase;letter-spacing:.8px;border-radius:5px;padding:4px 10px;font-size:.65rem;font-weight:700}.q-tag.mcq,.q-tag.qcm{background:var(--ice);color:var(--navy)}.q-module{color:var(--text-muted);font-size:.8rem}.q-stem{color:var(--text);margin-bottom:.6rem;font-size:1.6rem;font-weight:500;line-height:1.5}.q-instruction{color:var(--text-muted);margin-bottom:2rem;font-size:.82rem}.options{flex-direction:column;gap:.625rem;display:flex}.opt{border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);align-items:center;gap:1rem;padding:1.2rem 1.35rem;transition:all .2s cubic-bezier(.22,1,.36,1);display:flex;position:relative;overflow:hidden}.opt:hover:not(.disabled){border-color:var(--steel);transform:translateY(-1px);box-shadow:0 4px 12px #0a3a8e0f}.opt.selected{border-color:var(--navy);background:var(--navy);color:#fff;transform:translateY(-1px);box-shadow:0 4px 20px #0a3a8e33}.opt.selected .opt-letter{color:#fff;background:#fff3;border-color:#ffffff4d}.opt.selected .opt-text{color:#fff}.opt.correct{border-color:var(--success);background:var(--success-bg);color:var(--success-dark);box-shadow:none;transform:none}.opt.correct .opt-letter{background:var(--success);color:#fff;border-color:var(--success)}.opt.correct .opt-text{color:var(--success-dark)}.opt.incorrect{border-color:var(--error);background:var(--error-bg);color:var(--error-dark);box-shadow:none;transform:none}.opt.incorrect .opt-letter{background:var(--error);color:#fff;border-color:var(--error)}.opt.incorrect .opt-text{color:var(--error-dark)}.opt.missed{border-color:var(--success);background:var(--success-bg);border-style:dashed}.opt.missed .opt-letter{color:var(--success);border-color:var(--success);background:0 0}.opt.missed .opt-text{color:var(--success-dark)}.opt.disabled{pointer-events:none}.opt.faded{opacity:.45}.opt-letter{border:1.5px solid var(--border);width:36px;height:36px;color:var(--text-secondary);z-index:1;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;transition:all .2s;display:flex;position:relative}.opt-text{color:var(--text);z-index:1;font-size:1.05rem;font-weight:450;line-height:1.45;transition:color .2s;position:relative}.opt-result-icon{z-index:1;opacity:0;margin-left:auto;font-size:1.1rem;transition:opacity .2s;position:relative}.opt.correct .opt-result-icon,.opt.incorrect .opt-result-icon,.opt.missed .opt-result-icon{opacity:1}.question-nav{flex-wrap:wrap;justify-content:center;gap:5px;margin-top:2rem;display:flex}.qnav-pill{border:1.5px solid var(--border);background:var(--bg);width:38px;height:38px;color:var(--gray-60);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-family:IBM Plex Mono,monospace;font-size:.78rem;font-weight:500;transition:all .15s;display:flex}.qnav-pill:hover{border-color:var(--navy);color:var(--navy)}.qnav-pill.current{border-color:var(--navy);background:var(--navy);color:#fff}.qnav-pill.answered-correct{background:var(--success-bg);border-color:var(--success);color:var(--success)}.qnav-pill.answered-incorrect{background:var(--error-bg);border-color:var(--error);color:var(--error)}.qnav-pill.answered-pending{background:var(--ice);border-color:var(--navy);color:var(--navy)}.kbd-hint{text-align:center;color:var(--text-muted);letter-spacing:.3px;margin-top:1.5rem;font-size:.72rem}.kbd{border:1px solid var(--border);background:var(--ice);border-radius:4px;margin:0 1px;padding:2px 7px;font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;display:inline-block}.bottom-bar{bottom:0;left:var(--sidebar-w);z-index:90;background:var(--bg);border-top:1px solid var(--border);position:fixed;right:0}.bottom-inner{align-items:center;gap:1rem;max-width:680px;margin:0 auto;padding:1rem 2rem;display:flex}.btn-check{border-radius:var(--radius);letter-spacing:.3px;text-transform:uppercase;cursor:pointer;border:none;flex:1;padding:1.1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.btn-check.primary{background:var(--navy);color:#fff;box-shadow:0 4px 16px #0a3a8e33}.btn-check.primary:hover{background:var(--navy-mid);transform:translateY(-1px);box-shadow:0 6px 24px #0a3a8e4d}.btn-check.primary:disabled{background:var(--border);color:var(--text-muted);box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{border:2px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;padding:1.1rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:500;transition:all .15s}.btn-secondary:hover{border-color:var(--steel);color:var(--text)}.feedback-panel{bottom:0;left:var(--sidebar-w);z-index:150;transition:transform .4s cubic-bezier(.22,1,.36,1);position:fixed;right:0;transform:translateY(100%);box-shadow:0 -8px 32px #00000014}.feedback-panel.show{transform:translateY(0)}.feedback-inner{max-width:780px;margin:0 auto;padding:1.5rem 2rem 1.25rem}.feedback-panel.correct-panel{background:var(--success-bg);border-top:3px solid var(--success)}.feedback-panel.incorrect-panel{background:var(--error-bg);border-top:3px solid var(--error)}.fb-top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.fb-title{align-items:center;gap:.5rem;font-size:1.15rem;font-weight:700;display:flex}.correct-panel .fb-title{color:var(--success-dark)}.incorrect-panel .fb-title{color:var(--error-dark)}.fb-btn-next{cursor:pointer;color:#fff;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:10px;padding:.75rem 1.75rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .15s}.correct-panel .fb-btn-next{background:var(--success)}.correct-panel .fb-btn-next:hover{background:var(--success-dark)}.incorrect-panel .fb-btn-next{background:var(--error)}.incorrect-panel .fb-btn-next:hover{background:var(--error-dark)}.fb-text{max-width:640px;font-size:.92rem;line-height:1.6}.correct-panel .fb-text{color:var(--success-dark)}.incorrect-panel .fb-text{color:var(--error-dark)}.fb-stats{border-top:1px solid #0000000f;gap:1.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}.fb-stat{font-size:.78rem;font-weight:500}.fb-stat-val{font-family:IBM Plex Mono,monospace;font-size:1.1rem;font-weight:600}.correct-panel .fb-stat{color:var(--success-dark)}.incorrect-panel .fb-stat{color:var(--error-dark)}.fb-rating{align-items:center;gap:.75rem;margin-top:.75rem;display:flex}.fb-rating-label{opacity:.7;font-size:.7rem}.fb-rating-btn{cursor:pointer;background:#fff9;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.8rem;transition:all .15s;display:flex}.fb-rating-btn:hover:not(:disabled){background:#ffffffe6;transform:scale(1.15)}.fb-rating-btn.active{background:#fffffff2;transform:scale(1.2);box-shadow:0 2px 8px #0000001a}.fb-rating-btn:disabled{cursor:default;opacity:.5}.fb-rating-btn.active:disabled{opacity:1}@media (width<=768px){.question-area{padding:2rem 1rem 8rem}.q-stem{font-size:1.35rem}.bottom-bar{left:0}.bottom-inner{padding:.75rem 1rem}.feedback-panel{left:0}}.analytics-page{max-width:1000px;padding:2rem}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.kpi-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem;animation:.35s forwards fadeUp}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem;font-size:.78rem;font-weight:600}.kpi-value{color:var(--navy);font-family:IBM Plex Mono,monospace;font-size:1.85rem;font-weight:600}.kpi-value.green{color:var(--success)}.kpi-value.red{color:var(--error)}.chart-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;animation:.35s forwards fadeUp;overflow:hidden}.chart-header{border-bottom:1px solid var(--border);color:var(--navy);padding:1.1rem 1.5rem;font-size:.95rem;font-weight:600}.chart-body{padding:1.5rem}.chart-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.weak-area-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.85rem 0;display:flex}.weak-area-item:last-child{border-bottom:none}.weak-area-name{color:var(--text);font-size:.95rem;font-weight:500}.weak-area-meta{color:var(--text-muted);margin-top:.2rem;font-size:.8rem}.weak-area-accuracy{border-radius:6px;padding:.3rem .7rem;font-family:IBM Plex Mono,monospace;font-size:.92rem;font-weight:600}.weak-area-accuracy.low{background:var(--error-bg);color:var(--error)}.weak-area-accuracy.medium{color:#92400e;background:#fef3c7}.weak-area-accuracy.high{background:var(--success-bg);color:var(--success)}.analytics-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:4rem 2rem;display:flex}.analytics-empty h3{color:var(--text);margin-bottom:.5rem;font-size:1.3rem;font-weight:500}.analytics-empty p{color:var(--text-muted);max-width:400px;font-size:.95rem}@media (width<=768px){.analytics-page{padding:1.5rem 1rem}.chart-grid{grid-template-columns:1fr}}.review-page{max-width:840px;padding:2rem}.session-list{flex-direction:column;gap:.85rem;display:flex}.session-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:inherit;justify-content:space-between;align-items:center;padding:1.15rem 1.4rem;text-decoration:none;transition:all .15s;animation:.35s forwards fadeUp;display:flex}.session-card:hover{border-color:var(--steel);transform:translateY(-1px);box-shadow:0 2px 8px #0a3a8e0f}.session-card-left{flex-direction:column;gap:.35rem;display:flex}.session-mode-badge{text-transform:uppercase;letter-spacing:.8px;border-radius:5px;margin-right:.5rem;padding:3px 9px;font-size:.68rem;font-weight:700;display:inline-block}.session-mode-badge.practice{background:var(--ice);color:var(--navy)}.session-mode-badge.exam{color:#6b3fa0;background:#f0ebf8}.session-date{color:var(--text-muted);font-size:.85rem}.session-card-right{text-align:right}.session-score{font-family:IBM Plex Mono,monospace;font-size:1.3rem;font-weight:600}.session-detail{color:var(--text-muted);margin-top:.2rem;font-size:.8rem}.filter-tabs{gap:0;margin-bottom:1.5rem;display:flex}.filter-tab{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;padding:.6rem 1.35rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .15s}.filter-tab:first-child{border-right:none;border-radius:8px 0 0 8px}.filter-tab:last-child{border-radius:0 8px 8px 0}.filter-tab:not(:first-child):not(:last-child){border-right:none}.filter-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.review-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.review-back-btn{color:var(--navy);cursor:pointer;background:0 0;border:none;align-items:center;gap:.4rem;padding:.4rem 0;font-family:inherit;font-size:.9rem;font-weight:500;display:inline-flex}.review-back-btn:hover{text-decoration:underline}.review-question-list{flex-direction:column;gap:1.1rem;display:flex}.review-question-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);animation:.35s forwards fadeUp;overflow:hidden}.review-question-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.85rem 1.35rem;font-size:.88rem;display:flex}.review-question-stem{color:var(--text);padding:1.1rem 1.35rem;font-size:1.02rem;line-height:1.55}.review-options{flex-direction:column;gap:.5rem;padding:0 1.35rem 1.1rem;display:flex}.review-option{border-radius:8px;align-items:center;gap:.7rem;padding:.6rem .85rem;font-size:.95rem;display:flex}.review-option.correct{background:var(--success-bg);color:var(--success-dark)}.review-option.incorrect{background:var(--error-bg);color:var(--error-dark)}.review-option.missed{background:var(--success-bg);color:var(--success-dark);border:1px dashed var(--success)}.review-option-key{min-width:22px;font-family:IBM Plex Mono,monospace;font-size:.82rem;font-weight:600}@media (width<=768px){.review-page{padding:1.5rem 1rem}}.marketplace-page{max-width:960px;padding:2rem}.marketplace-header{margin-bottom:1.75rem}.marketplace-header h2{color:var(--text);letter-spacing:-.02em;font-size:1.6rem;font-weight:400}.marketplace-header p{color:var(--text-muted);margin-top:.3rem;font-size:.9rem}.mp-tabs{gap:0;margin-bottom:1.75rem;display:flex}.mp-tab{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;padding:.6rem 1.35rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .15s}.mp-tab:first-child{border-right:none;border-radius:8px 0 0 8px}.mp-tab:last-child{border-radius:0 8px 8px 0}.mp-tab:not(:first-child):not(:last-child){border-right:none}.mp-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.mp-university-group{margin-bottom:2rem}.mp-university-name{color:var(--navy);align-items:center;gap:.5rem;margin-bottom:.85rem;font-size:1rem;font-weight:600;display:flex}.mp-product-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem;display:grid}.mp-product-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:1.25rem;transition:all .2s;animation:.35s forwards fadeUp;position:relative}.mp-product-card:hover:not(.purchased):not(.selected){border-color:var(--steel);transform:translateY(-2px);box-shadow:0 4px 16px #0a3a8e14}.mp-product-card.selected{border-color:var(--navy);background:var(--ice);box-shadow:0 4px 20px #0a3a8e1f}.mp-product-card.purchased{border-color:var(--success);background:var(--success-bg);cursor:default}.mp-product-top{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.mp-product-name{color:var(--text);font-size:1.05rem;font-weight:600}.mp-product-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:5px;padding:3px 8px;font-size:.65rem;font-weight:700}.mp-product-badge.owned{background:var(--success-bg);color:var(--success)}.mp-product-badge.selected-badge{background:var(--ice);color:var(--navy)}.mp-product-meta{color:var(--text-muted);margin-bottom:.75rem;font-size:.82rem}.mp-product-price{color:var(--navy);font-family:IBM Plex Mono,monospace;font-size:1.15rem;font-weight:600}.mp-product-price.free{color:var(--success)}.mp-cart-bar{bottom:0;left:var(--sidebar-w);z-index:100;background:var(--navy-100);color:#fff;border-top:2px solid var(--navy-80);transition:transform .35s cubic-bezier(.22,1,.36,1);position:fixed;right:0;transform:translateY(100%)}.mp-cart-bar.visible{transform:translateY(0)}.mp-cart-inner{justify-content:space-between;align-items:center;max-width:960px;margin:0 auto;padding:1rem 2rem;display:flex}.mp-cart-info{align-items:center;gap:1.5rem;display:flex}.mp-cart-count{color:var(--crystal-40);font-size:.88rem}.mp-cart-total{font-family:IBM Plex Mono,monospace;font-size:1.2rem;font-weight:600}.mp-cart-btn{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:.75rem 2rem;font-family:inherit;font-size:.92rem;font-weight:600;transition:all .15s}.mp-cart-btn:hover{background:var(--success-dark)}.mp-cart-btn:disabled{opacity:.5;cursor:not-allowed}.mp-confirmation{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);text-align:center;max-width:600px;margin:2rem auto;padding:2rem;animation:.35s forwards fadeUp}.mp-confirmation h3{color:var(--text);margin-bottom:.5rem;font-size:1.3rem;font-weight:500}.mp-confirmation p{color:var(--text-muted);margin-bottom:1.25rem;font-size:.9rem}.mp-payment-info{background:var(--ice);text-align:left;border-radius:10px;margin-bottom:1.25rem;padding:1.25rem}.mp-payment-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.mp-payment-row:last-child{border-bottom:none}.mp-payment-label{color:var(--text-muted);font-size:.82rem;font-weight:500}.mp-payment-value{color:var(--text);font-family:IBM Plex Mono,monospace;font-size:.92rem;font-weight:600}.mp-orders-section{margin-top:2.5rem}.mp-orders-section h3{color:var(--text);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.mp-order-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:1.1rem 1.35rem;animation:.35s forwards fadeUp}.mp-order-top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.mp-order-id{color:var(--text);font-family:IBM Plex Mono,monospace;font-size:.85rem;font-weight:600}.mp-order-date{color:var(--text-muted);font-size:.8rem}.mp-order-status{text-transform:uppercase;letter-spacing:.5px;border-radius:5px;padding:3px 10px;font-size:.68rem;font-weight:700}.mp-order-status.pending{color:#92400e;background:#fef3c7}.mp-order-status.confirmed{background:var(--success-bg);color:var(--success)}.mp-order-status.cancelled{background:var(--error-bg);color:var(--error)}.mp-order-items{color:var(--text-muted);font-size:.85rem}.mp-order-total{color:var(--navy);margin-top:.3rem;font-family:IBM Plex Mono,monospace;font-size:.95rem;font-weight:600}@media (width<=768px){.marketplace-page{padding:1.5rem 1rem}.mp-product-grid{grid-template-columns:1fr}.mp-cart-bar{left:0}.mp-cart-inner{flex-direction:column;gap:.75rem;padding:.75rem 1rem}}.admin-page{max-width:1100px;padding:2rem}.admin-header{margin-bottom:1.75rem}.admin-header h2{color:var(--text);font-size:1.6rem;font-weight:400}.admin-header p{color:var(--text-muted);margin-top:.3rem;font-size:.9rem}.admin-tabs{gap:0;margin-bottom:1.75rem;display:flex}.admin-tab{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;padding:.65rem 1.35rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .15s}.admin-tab:first-child{border-right:none;border-radius:8px 0 0 8px}.admin-tab:last-child{border-radius:0 8px 8px 0}.admin-tab:not(:first-child):not(:last-child){border-right:none}.admin-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.admin-search{margin-bottom:1.25rem}.admin-search input{background:var(--ice);border:none;border-bottom:2px solid var(--border);width:100%;max-width:400px;height:44px;color:var(--text);border-radius:0;outline:none;padding:0 1rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.admin-search input:focus{border-bottom-color:var(--navy)}.admin-search input::placeholder{color:var(--steel)}.admin-filter-bar{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.admin-filter-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:.4rem 1rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .15s}.admin-filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}.admin-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.85rem 1rem}.admin-table tr:hover td{background:var(--gray-10)}.admin-table .mono{font-family:IBM Plex Mono,monospace;font-weight:600}.admin-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:5px;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-block}.admin-badge.pending{color:#92400e;background:#fef3c7}.admin-badge.confirmed{background:var(--success-bg);color:var(--success)}.admin-badge.cancelled{background:var(--error-bg);color:var(--error)}.admin-badge.active{background:var(--success-bg);color:var(--success)}.admin-badge.blocked{background:var(--error-bg);color:var(--error)}.admin-badge.admin-role{background:var(--ice);color:var(--navy)}.admin-action-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;margin-right:.35rem;padding:.35rem .75rem;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .15s}.admin-action-btn:hover{border-color:var(--navy);color:var(--navy)}.admin-action-btn.approve{border-color:var(--success);color:var(--success)}.admin-action-btn.approve:hover{background:var(--success);color:#fff}.admin-action-btn.deny{border-color:var(--error);color:var(--error)}.admin-action-btn.deny:hover{background:var(--error);color:#fff}.admin-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.admin-kpi{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem;animation:.35s forwards fadeUp}.admin-kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem;font-size:.78rem;font-weight:600}.admin-kpi-value{color:var(--navy);font-family:IBM Plex Mono,monospace;font-size:1.85rem;font-weight:600}.admin-kpi-value.green{color:var(--success)}.admin-empty{text-align:center;color:var(--text-muted);padding:3rem;font-size:.9rem}@media (width<=768px){.admin-page{padding:1.5rem 1rem}.admin-table{font-size:.8rem}.admin-table th,.admin-table td{padding:.6rem .5rem}}:root{--navy:#0a3a8e;--navy-deep:#051e4d;--navy-mid:#1250b8;--navy-100:#0f2447;--navy-90:#163264;--navy-80:#1e4280;--navy-70:#2656a0;--navy-60:#3068b8;--navy-50:#4080d0;--crystal-60:#6b8fad;--crystal-50:#8baac4;--crystal-40:#a3c0d6;--crystal-30:#b8d1e3;--steel:#99adc8;--steel-light:#c8d4e4;--ice:#edf1f7;--bg:#fff;--text:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--border:#e2e8f0;--gray-10:#f4f4f4;--gray-20:#e0e0e0;--gray-50:#8d8d8d;--gray-60:#6f6f6f;--gray-70:#525252;--success:#16a34a;--success-bg:#f0fdf4;--success-dark:#15803d;--error:#dc2626;--error-bg:#fef2f2;--error-dark:#b91c1c;--radius:14px;--sidebar-w:260px;--header-h:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.35s forwards fadeUp}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:IBM Plex Sans,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--crystal-40);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--crystal-60)}.mono{font-family:IBM Plex Mono,monospace}
