.admin-panel{display:flex;min-height:100vh;background:var(--bg-primary)}.admin-sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:1.5rem;overflow:hidden;white-space:nowrap;transition:width var(--transition-normal),padding var(--transition-normal)}.admin-sidebar.collapsed{width:0;padding-left:0;padding-right:0;border-right-color:transparent}.sidebar-header{display:flex;align-items:center;gap:.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-subtle);margin-bottom:1.5rem;color:var(--primary-color);font-weight:700;font-size:1.25rem}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem}.nav-item{position:relative;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;border-radius:.75rem;color:var(--text-secondary);font-size:.925rem;font-weight:500;cursor:pointer;transition:var(--transition-normal);text-align:left}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;border-radius:0 3px 3px 0;background:var(--primary-color);transition:transform var(--transition-normal)}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translate(2px)}.nav-item.active{background:var(--primary-light);color:var(--primary-color);font-weight:600}.nav-item.active:before{transform:translateY(-50%) scaleY(1)}.nav-item svg{flex-shrink:0}.logout-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--accent-danger-light);border:1px solid rgba(239,68,68,.2);border-radius:.75rem;color:var(--accent-danger);font-size:.925rem;font-weight:500;cursor:pointer;transition:var(--transition-normal)}.logout-btn:hover{background:var(--accent-danger);color:#fff}.admin-main{flex:1;padding:2rem;overflow-y:auto}.admin-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin:-2rem -2rem 2rem;padding:1.25rem 2rem;position:sticky;top:0;z-index:50;background:var(--bg-glass);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border-subtle)}.admin-header-left{display:flex;align-items:center;gap:.875rem;min-width:0}.admin-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:var(--transition-normal)}.sidebar-toggle:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:var(--transition-normal)}.refresh-btn:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:var(--transition-normal)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:56px;height:56px;border-radius:.75rem;display:flex;align-items:center;justify-content:center}.stat-card.total .stat-icon{background:var(--primary-light);color:var(--primary-color)}.stat-card.fake .stat-icon{background:var(--accent-danger-light);color:var(--accent-danger)}.stat-card.real .stat-icon{background:var(--accent-success-light);color:var(--accent-success)}.stat-card.pending .stat-icon{background:var(--accent-warning-light);color:var(--accent-warning)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.rate-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.5rem}.rate-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.rate-header h3{font-size:1rem;font-weight:600}.rate-bars{display:flex;flex-direction:column;gap:1rem}.rate-item{display:flex;flex-direction:column;gap:.5rem}.rate-label{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary);font-weight:500}.rate-bar-bg{height:10px;background:var(--bg-tertiary);border-radius:5px;overflow:hidden}.rate-bar-fill{height:100%;border-radius:5px;transition:width .8s ease}.rate-bar-fill.fake{background:linear-gradient(135deg,var(--accent-danger) 0%,#f87171 100%)}.rate-bar-fill.real{background:linear-gradient(135deg,var(--accent-success) 0%,#34d399 100%)}.search-bar{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.75rem;margin-bottom:1.5rem}.search-bar svg{color:var(--text-muted)}.search-bar input{flex:1;background:transparent;border:none;font-size:.925rem;color:var(--text-primary);outline:none}.search-bar input::placeholder{color:var(--text-muted)}.history-table-wrapper{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table-wrapper::-webkit-scrollbar,.keys-table-wrap::-webkit-scrollbar{height:8px}.history-table-wrapper::-webkit-scrollbar-thumb,.keys-table-wrap::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:999px}.history-table-wrapper::-webkit-scrollbar-track,.keys-table-wrap::-webkit-scrollbar-track{background:transparent}.history-table{width:100%;border-collapse:collapse}.history-table th,.history-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.history-table th{position:sticky;top:0;z-index:1;background:var(--bg-tertiary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.history-table tbody tr{transition:background var(--transition-fast)}.history-table tbody tr:hover{background:var(--bg-tertiary)}.history-table tbody tr:last-child td{border-bottom:none}.thumb-img{width:48px;height:48px;object-fit:cover;border-radius:.5rem;border:1px solid var(--border-subtle)}.id-cell{font-family:JetBrains Mono,monospace;font-size:.8rem;color:var(--text-muted)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.completed{background:var(--accent-success-light);color:var(--accent-success)}.status-badge.pending{background:var(--accent-warning-light);color:var(--accent-warning)}.status-badge.failed{background:var(--accent-danger-light);color:var(--accent-danger)}.result-pill{padding:.375rem .75rem;border-radius:50px;font-size:.75rem;font-weight:700;text-transform:uppercase}.result-pill.fake{background:var(--accent-danger-light);color:var(--accent-danger)}.result-pill.real{background:var(--accent-success-light);color:var(--accent-success)}.feedback-badge{font-size:.8rem;color:var(--text-muted)}.feedback-badge.correct{color:var(--accent-success)}.feedback-badge.incorrect{color:var(--accent-danger)}.loading-cell,.empty-cell{text-align:center;padding:3rem!important;color:var(--text-muted)}.table-spinner{width:24px;height:24px;border:3px solid var(--border-subtle);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto .5rem}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:var(--transition-normal)}.pagination button:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{font-size:.875rem;color:var(--text-secondary)}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.admin-panel{flex-direction:column}.admin-sidebar{width:100%;flex-direction:row;padding:1rem;gap:1rem}.sidebar-header{padding-bottom:0;border-bottom:none;margin-bottom:0}.sidebar-nav{flex-direction:row;gap:.5rem}.nav-item{padding:.5rem .75rem}.nav-item span{display:none}.stats-grid{grid-template-columns:1fr}.history-table-wrapper{overflow-x:auto}}.learning-content{display:flex;flex-direction:column;gap:1.5rem}.loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-muted);gap:1rem;text-align:center}.empty-state>svg{padding:1.25rem;border-radius:50%;background:var(--bg-tertiary);color:var(--text-muted)}.empty-state p{font-size:.95rem;font-weight:500;max-width:32ch}.admin-toast-wrap{position:fixed;top:1.5rem;right:1.5rem;z-index:1000;pointer-events:none}.admin-toast{display:flex;align-items:center;gap:.625rem;min-width:280px;max-width:380px;padding:.875rem 1rem;border-radius:.75rem;font-weight:500;font-size:.9rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-subtle);border-left:4px solid var(--text-muted);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toast-in .3s cubic-bezier(.21,1.02,.73,1)}.admin-toast.success{border-left-color:var(--accent-success)}.admin-toast.success .admin-toast-icon{color:var(--accent-success)}.admin-toast.error{border-left-color:var(--accent-danger)}.admin-toast.error .admin-toast-icon{color:var(--accent-danger)}.admin-toast-icon{display:flex;flex-shrink:0}.admin-toast-text{flex:1;line-height:1.4}.admin-toast-close{display:flex;flex-shrink:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.125rem;border-radius:.375rem;transition:var(--transition-fast)}.admin-toast-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}@keyframes toast-in{0%{opacity:0;transform:translate(20px) scale(.96)}to{opacity:1;transform:translate(0) scale(1)}}@media(max-width:640px){.admin-toast-wrap{top:auto;bottom:5.5rem;left:1rem;right:1rem}.admin-toast{max-width:none;width:100%}}.learning-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;padding-bottom:2rem}.image-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;overflow:hidden;transition:var(--transition-normal);display:flex;flex-direction:column}.image-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.image-preview{height:160px;width:100%;overflow:hidden;position:relative;background:var(--bg-tertiary)}.image-preview img{width:100%;height:100%;object-fit:cover}.label-badge{position:absolute;top:.75rem;right:.75rem;padding:.25rem .625rem;border-radius:50px;font-size:.75rem;font-weight:700;text-transform:uppercase;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.label-badge.fake{color:var(--accent-danger);border:1px solid var(--accent-danger)}.label-badge.real{color:var(--accent-success);border:1px solid var(--accent-success)}.delete-img-btn{position:absolute;top:.75rem;left:.75rem;width:32px;height:32px;border-radius:50%;background:#0009;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-normal);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0}.image-card:hover .delete-img-btn{opacity:1}.delete-img-btn:hover{background:var(--accent-danger);transform:scale(1.1)}.image-details{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;font-size:.85rem}.detail-label{color:var(--text-muted)}.detail-value{color:var(--text-primary);font-weight:500}.detail-value.mono{font-family:JetBrains Mono,monospace}.username-sm{font-size:.85rem;font-weight:500;color:var(--text-primary)}.learning-stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.25rem}.learning-stat-card .stat-header{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem;margin-bottom:.75rem}.learning-stat-card .stat-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.learning-stat-card .stat-value.warning{color:var(--accent-warning)}.learning-stat-card .stat-breakdown{display:flex;gap:.75rem;margin-top:.5rem;font-size:.8rem}.stat-breakdown .accepted{color:var(--accent-success)}.stat-breakdown .rejected{color:var(--accent-danger)}.stat-breakdown .trusted{color:var(--accent-success)}.stat-breakdown .suspicious{color:var(--accent-warning)}.thresholds-card,.pending-reviews-card,.errors-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.25rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.threshold-actions{display:flex;gap:.5rem}.action-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border:none;border-radius:.5rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition-normal)}.action-btn.recalibrate{background:var(--primary-light);color:var(--primary-color)}.action-btn.recalibrate:hover{background:var(--primary-color);color:#fff}.action-btn.rollback{background:var(--accent-warning-light);color:var(--accent-warning)}.action-btn.rollback:hover:not(:disabled){background:var(--accent-warning);color:#fff}.action-btn.rollback:disabled{opacity:.5;cursor:not-allowed}.action-btn.reset{background:var(--accent-danger-light);color:var(--accent-danger)}.action-btn.reset:hover{background:var(--accent-danger);color:#fff}.thresholds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.threshold-item{display:flex;flex-direction:column;gap:.25rem}.threshold-item .label{font-size:.8rem;color:var(--text-muted)}.threshold-item .value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.pending-reviews-list{display:flex;flex-direction:column;gap:.75rem}.review-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-tertiary);border-radius:.75rem;border-left:4px solid var(--accent-warning)}.review-info{flex:1}.review-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.job-id{font-family:monospace;font-size:.8rem;color:var(--text-muted)}.suspicion-badge{padding:.25rem .5rem;border-radius:50px;font-size:.7rem;font-weight:600}.suspicion-badge.high{background:var(--accent-danger-light);color:var(--accent-danger)}.suspicion-badge.medium{background:var(--accent-warning-light);color:var(--accent-warning)}.review-image-preview{margin:.5rem 0;width:120px;height:120px;overflow:hidden;border-radius:.5rem;border:1px solid var(--border-subtle);cursor:pointer;transition:transform .2s ease}.review-image-preview:hover{transform:scale(1.05)}.review-image-preview img{width:100%;height:100%;object-fit:cover}.review-details{display:flex;gap:1rem;font-size:.85rem;color:var(--text-secondary)}.review-reasons{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.reason-tag{padding:.25rem .5rem;background:var(--accent-danger-light);color:var(--accent-danger);border-radius:.25rem;font-size:.7rem}.review-actions{display:flex;gap:.5rem}.approve-btn,.reject-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border:none;border-radius:.5rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition-normal)}.approve-btn{background:var(--accent-success-light);color:var(--accent-success)}.approve-btn:hover{background:var(--accent-success);color:#fff}.reject-btn{background:var(--accent-danger-light);color:var(--accent-danger)}.reject-btn:hover{background:var(--accent-danger);color:#fff}.errors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.error-item{display:flex;flex-direction:column;align-items:center;padding:1.25rem;border-radius:.75rem;text-align:center}.error-item.false-positive{background:#ef44441a}.error-item.false-negative{background:#f59e0b1a}.error-item.hard-samples{background:var(--primary-light)}.error-type{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.error-count{font-size:2rem;font-weight:700;color:var(--text-primary)}.error-desc{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.nav-item .badge{background:var(--accent-danger);color:#fff;font-size:.7rem;padding:.125rem .5rem;border-radius:50px;margin-left:auto}.finetune-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.25rem}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.idle{background:var(--text-muted)}.status-dot.running{background:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light);animation:pulse 2s infinite}.status-dot.completed{background:var(--accent-success)}.status-dot.failed{background:var(--accent-danger)}.finetune-content{display:flex;flex-direction:column;gap:1.5rem}.finetune-controls{display:flex;align-items:flex-end;gap:1.5rem;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.control-group input[type=number]{background:var(--bg-tertiary);border:1px solid var(--border-subtle);padding:.5rem .75rem;border-radius:.5rem;color:var(--text-primary);width:80px}.control-group.checkbox{padding-bottom:.6rem}.control-group.checkbox label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.start-finetune-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-normal);margin-left:auto}.start-finetune-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.start-finetune-btn:disabled{opacity:.6;cursor:not-allowed}.finetune-status-details{background:var(--bg-tertiary);padding:1rem;border-radius:.75rem;border:1px solid var(--border-subtle)}.status-progress{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.progress-bar-bg{flex:1;height:8px;background:var(--bg-card);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-color);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.85rem;font-weight:600;color:var(--primary-color);min-width:3rem;text-align:right}.last-message{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem}.last-result{display:flex;gap:1.5rem;padding-top:.75rem;border-top:1px solid var(--border-subtle);font-size:.8rem;color:var(--text-muted)}.last-result .success{color:var(--accent-success);font-weight:600}.last-result .neutral{color:var(--text-secondary)}@keyframes pulse{0%{box-shadow:0 0 #4f46e566}70%{box-shadow:0 0 0 6px #4f46e500}to{box-shadow:0 0 #4f46e500}}@media(max-width:1024px){.learning-stats-grid,.thresholds-grid{grid-template-columns:repeat(2,1fr)}.errors-grid{grid-template-columns:1fr}}@media(max-width:768px){.learning-stats-grid{grid-template-columns:1fr}.threshold-actions{flex-wrap:wrap}.review-item{flex-direction:column;align-items:flex-start;gap:1rem}.image-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.api-keys-content{padding:2rem}.api-key-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card-mini{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.75rem}.stat-card-mini svg{color:var(--primary-color)}.stat-card-mini .stat-num{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-card-mini .stat-label{font-size:.8rem;color:var(--text-muted)}.users-content{display:flex;flex-direction:column}.users-table td{word-break:break-word}.users-table .user-identity{white-space:nowrap}.users-table td[data-label=Email]{word-break:break-all}.user-identity{display:flex;align-items:center;gap:.625rem}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex-shrink:0;border-radius:50%;background:var(--primary-light);color:var(--primary-color);font-size:.72rem;font-weight:700;letter-spacing:.02em;border:1px solid var(--border-subtle)}.user-name{font-weight:600;color:var(--text-primary)}.role-pill{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.role-pill.admin{background:var(--primary-light);color:var(--primary-color)}.role-pill.user{background:var(--bg-tertiary);color:var(--text-secondary)}.location-info{display:flex;flex-direction:column;gap:.125rem}.location-ip{font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--text-secondary)}.location-place{font-size:.78rem;color:var(--text-muted)}.device-cell{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.device-cell svg{flex-shrink:0;color:var(--text-muted)}.create-key-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}.create-key-card h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.create-key-form{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.key-input{flex:1;min-width:200px;padding:.75rem 1rem;border:1px solid var(--border-subtle);border-radius:.5rem;background:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;outline:none;transition:var(--transition-normal)}.key-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.rate-limit-group{display:flex;align-items:center;gap:.5rem}.rate-limit-group label{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.rate-select{padding:.75rem;border:1px solid var(--border-subtle);border-radius:.5rem;background:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;outline:none;cursor:pointer}.generate-btn{display:flex;align-items:center;gap:.375rem;padding:.75rem 1.25rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:var(--transition-normal);white-space:nowrap}.generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #da2b264d}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.revealed-key-card{background:var(--accent-warning-light);border:1px solid rgba(245,158,11,.3);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem;animation:fadeInUp .3s ease-out}.revealed-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:var(--accent-warning)}.revealed-header strong{color:var(--text-primary)}.revealed-key-card>p{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.key-display{display:flex;align-items:center;gap:.75rem;background:var(--bg-secondary);padding:.75rem 1rem;border-radius:.5rem;border:1px solid var(--border-subtle);margin-bottom:1rem}.key-display code{flex:1;font-family:JetBrains Mono,Fira Code,monospace;font-size:.825rem;color:var(--text-primary);word-break:break-all}.copy-key-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.375rem;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:var(--transition-normal);white-space:nowrap}.copy-key-btn:hover{background:var(--primary-light);color:var(--primary-color)}.dismiss-btn{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:var(--transition-normal)}.dismiss-btn:hover{background:var(--bg-tertiary)}.keys-table-wrap{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:.75rem}.keys-table{width:100%;border-collapse:collapse;font-size:.875rem}.keys-table th{text-align:left;padding:.875rem 1rem;background:var(--bg-tertiary);color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.keys-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);white-space:nowrap}.keys-table .key-name{font-weight:600}.key-prefix{font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:.25rem;border:1px solid var(--border-subtle)}.status-pill{display:inline-flex;padding:.25rem .625rem;border-radius:1rem;font-size:.75rem;font-weight:600}.status-pill.active{background:var(--accent-success-light);color:var(--accent-success)}.status-pill.inactive{background:var(--accent-danger-light);color:var(--accent-danger)}.inactive-row{opacity:.6}.actions-cell{display:flex;gap:.5rem}.action-btn{display:flex;align-items:center;justify-content:center;padding:.375rem;background:none;border:1px solid var(--border-subtle);border-radius:.375rem;cursor:pointer;transition:var(--transition-normal)}.action-btn.toggle{color:var(--accent-warning)}.action-btn.toggle:hover{background:var(--accent-warning-light);border-color:var(--accent-warning)}.action-btn.delete{color:var(--accent-danger)}.action-btn.delete:hover{background:var(--accent-danger-light);border-color:var(--accent-danger)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skeleton{display:block;position:relative;overflow:hidden;background:var(--bg-tertiary);border-radius:.5rem}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(125,125,135,.18),transparent);animation:shimmer 1.4s ease-in-out infinite}@keyframes shimmer{to{transform:translate(100%)}}.skeleton-row td{vertical-align:middle}.skeleton-card{overflow:hidden}.skeleton-card .skeleton-card-body{display:flex;flex-direction:column;gap:.5rem;padding:.875rem 1rem 1rem}@media(max-width:768px){.admin-panel{flex-direction:column}.admin-sidebar{position:fixed;bottom:0;left:0;right:0;width:100%;flex-direction:row;align-items:center;padding:.4rem .4rem calc(.4rem + env(safe-area-inset-bottom,0px));gap:0;border-right:none;border-top:1px solid var(--border-subtle);background:var(--bg-glass);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);z-index:60}.admin-sidebar.collapsed{width:100%;padding-left:.4rem;padding-right:.4rem}.sidebar-toggle,.sidebar-header{display:none}.sidebar-nav{flex:1;flex-direction:row;justify-content:space-around;gap:.2rem}.nav-item{flex:1;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem .2rem;font-size:.65rem;font-weight:500;border-radius:.5rem}.nav-item span{display:inline}.nav-item:hover{transform:none}.nav-item:before{top:0;left:50%;transform:translate(-50%) scaleX(0);width:55%;height:3px;border-radius:0 0 3px 3px}.nav-item.active:before{transform:translate(-50%) scaleX(1)}.nav-item .badge{position:absolute;top:.1rem;right:50%;margin-right:-1.3rem}.logout-btn{flex-direction:column;gap:.2rem;padding:.4rem .5rem;font-size:.65rem;background:transparent;border:none;color:var(--text-muted)}.logout-btn:hover{background:transparent;color:var(--accent-danger)}.admin-main{padding-bottom:5.5rem}.learning-stats-grid{grid-template-columns:1fr 1fr}.history-table-wrapper,.keys-table-wrap{border:none;background:transparent;overflow:visible}.history-table thead,.keys-table thead{display:none}.history-table tbody tr,.keys-table tbody tr{display:block;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.875rem;padding:.25rem;margin-bottom:.875rem}.history-table td,.keys-table td{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem 1rem;text-align:right;white-space:normal;word-break:break-word;border-bottom:1px solid var(--border-subtle)}.user-identity{justify-content:flex-end}.history-table tbody tr td:last-child,.keys-table tbody tr td:last-child{border-bottom:none}.history-table td:before,.keys-table td:before{content:attr(data-label);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);text-align:left}.history-table tbody tr:hover,.keys-table tbody tr:hover{background:var(--bg-card)}.actions-cell{justify-content:flex-end}}@media(max-width:480px){.learning-stats-grid,.thresholds-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none}.nav-item,.history-table tbody tr,.admin-toast{transition:none;animation:none}}.profile-page{min-height:100vh;background:var(--bg-primary);padding-bottom:4rem}.profile-topbar{max-width:960px;margin:0 auto;padding:1.5rem 1.5rem 0}.profile-back{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .875rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:var(--transition-normal)}.profile-back:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.profile-container{max-width:960px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.profile-hero{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;box-shadow:var(--shadow-sm)}.profile-avatar{flex-shrink:0;width:84px;height:84px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;color:#fff;background:var(--gradient-primary);box-shadow:var(--shadow-glow)}.profile-hero-info{min-width:0}.profile-hero-info h1{font-size:1.6rem;font-weight:700;color:var(--text-primary);line-height:1.2}.profile-handle{display:inline-block;color:var(--text-muted);font-size:.9rem;margin-top:.15rem}.profile-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin-top:.875rem}.profile-meta span{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--text-secondary)}.profile-meta svg{color:var(--text-muted)}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.profile-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow-sm)}.profile-card h2{display:flex;align-items:center;gap:.5rem;font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:1.25rem}.profile-card h2 svg{color:var(--primary-color)}.profile-field{display:block;margin-bottom:1rem}.profile-field span{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}.profile-field input{width:100%;padding:.75rem .875rem;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.625rem;color:var(--text-primary);font-size:.925rem;transition:var(--transition-normal)}.profile-field input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.profile-field input:disabled{opacity:.6;cursor:not-allowed}.profile-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:.625rem;font-weight:600;font-size:.925rem;cursor:pointer;border:none;transition:var(--transition-normal);margin-top:.25rem}.profile-btn.primary{background:var(--gradient-primary);color:#fff}.profile-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #da2b264d}.profile-btn:disabled{opacity:.55;cursor:not-allowed}.profile-spin{animation:spin 1s linear infinite}.profile-msg{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;border-radius:.625rem;font-size:.85rem;font-weight:500;margin-bottom:1rem}.profile-msg.success{background:var(--accent-success-light);color:var(--accent-success)}.profile-msg.error{background:var(--accent-danger-light);color:var(--accent-danger)}.profile-history-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.phs-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--bg-tertiary);border-radius:.75rem}.phs-num{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.phs-item.fake .phs-num{color:var(--accent-danger)}.phs-item.real .phs-num{color:var(--accent-success)}.phs-label{font-size:.78rem;color:var(--text-muted);margin-top:.2rem}.profile-history-empty{padding:2.5rem;text-align:center;color:var(--text-muted);font-size:.9rem}.profile-history-list{display:flex;flex-direction:column}.phl-row{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border-subtle)}.phl-row:last-child{border-bottom:none}.phl-thumb{width:44px;height:44px;object-fit:cover;border-radius:.5rem;border:1px solid var(--border-subtle);flex-shrink:0;background:var(--bg-tertiary)}.phl-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.phl-type{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phl-type svg{color:var(--text-muted);flex-shrink:0}.phl-date{font-size:.78rem;color:var(--text-muted)}.phl-result{display:flex;align-items:center;gap:.625rem;flex-shrink:0}.phl-pill{padding:.25rem .625rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.03em}.phl-pill.fake{background:var(--accent-danger-light);color:var(--accent-danger)}.phl-pill.real{background:var(--accent-success-light);color:var(--accent-success)}.phl-pill.pending{background:var(--bg-tertiary);color:var(--text-muted)}.phl-conf{font-size:.82rem;font-weight:600;color:var(--text-secondary);min-width:2.5rem;text-align:right}.profile-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem}.profile-pagination span{font-size:.85rem;color:var(--text-muted);font-weight:500}.profile-pagination button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;transition:var(--transition-normal)}.profile-pagination button:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.profile-pagination button:disabled{opacity:.4;cursor:not-allowed}@media(max-width:720px){.profile-grid{grid-template-columns:1fr}.profile-hero{flex-direction:column;text-align:center}.profile-meta{justify-content:center}}.lpx-page{--lpx-accent: #E5402A;--lpx-accent-d: #BC3422;--lpx-accent-t: #FBE4E1;--lpx-bg: #FCFBFA;--lpx-text: #1A1714;--lpx-text-2: #6B655C;--lpx-label: #43403A;--lpx-muted: #A8A29A;--lpx-border: #E2DED7;--lpx-border-light: #EBE7E1;--lpx-divider: #EAE6E0;--lpx-brand-bg: #FAF5EF;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;padding:clamp(20px,4vw,48px);font-family:Hanken Grotesk,system-ui,-apple-system,sans-serif;color:var(--lpx-text);background:var(--lpx-bg);overflow-y:auto;box-sizing:border-box}.lpx-page *,.lpx-page *:before,.lpx-page *:after{box-sizing:border-box}.lpx-page-glow{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(900px 460px at 50% -8%,rgba(229,64,42,.06),transparent 72%)}.lpx-shell{position:relative;margin:auto;width:min(960px,100%);display:flex;flex-direction:column;align-items:center;gap:22px}.lpx-card{width:100%;display:flex;flex-wrap:wrap;background:#fff;border:1px solid var(--lpx-border-light);border-radius:24px;overflow:hidden;box-shadow:0 1px 2px #14100c0a,0 40px 80px -34px #14100c47}.lpx-brand{flex:1 1 380px;position:relative;overflow:hidden;background:var(--lpx-brand-bg);color:var(--lpx-text);padding:clamp(36px,4vw,48px)}.lpx-brand-dots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.6;background-image:radial-gradient(rgba(20,16,12,.06) .5px,transparent .7px);background-size:7px 7px;-webkit-mask-image:radial-gradient(560px 460px at 40% 22%,#000,transparent 84%);mask-image:radial-gradient(560px 460px at 40% 22%,#000,transparent 84%)}.lpx-corner{position:absolute;width:15px;height:15px;opacity:.42;pointer-events:none}.lpx-corner.tr{right:24px;top:24px;border-right:1.5px solid var(--lpx-accent);border-top:1.5px solid var(--lpx-accent)}.lpx-corner.bl{left:24px;bottom:24px;border-left:1.5px solid var(--lpx-accent);border-bottom:1.5px solid var(--lpx-accent)}.lpx-cross{position:absolute;pointer-events:none}.lpx-cross.a{right:32px;top:92px;opacity:.3}.lpx-cross.b{right:46px;bottom:100px;opacity:.22}.lpx-coord{position:absolute;right:26px;bottom:30px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:9px;letter-spacing:.04em;color:#b8afa2;opacity:.85;pointer-events:none}.lpx-brand-inner{position:relative;display:flex;flex-direction:column;height:100%;min-height:480px}.lpx-logo{display:flex;align-items:center;gap:10px}.lpx-logo-mark{display:flex;align-items:center;justify-content:center;color:var(--lpx-accent)}.lpx-logo-text{font-size:19px;letter-spacing:-.02em;color:var(--lpx-text)}.lpx-logo-text b{font-weight:800}.lpx-logo-text span{font-weight:500}.lpx-brand-mid{margin:auto 0;padding:36px 0}.lpx-brand-rule{width:34px;height:3px;border-radius:2px;background:var(--lpx-accent);margin-bottom:22px}.lpx-brand-title{margin:0;font-size:clamp(2rem,3.3vw,2.55rem);font-weight:800;letter-spacing:-.035em;line-height:1;color:var(--lpx-text)}.lpx-brand-title em{font-style:normal;color:var(--lpx-accent)}.lpx-brand-sub{margin:20px 0 0;font-size:15px;line-height:1.6;color:var(--lpx-text-2);max-width:32ch}.lpx-brand-foot{display:inline-flex;align-items:center;gap:8px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;letter-spacing:.04em;color:#a39c92}.lpx-form-panel{flex:1 1 440px;display:flex;align-items:center;justify-content:center;padding:clamp(36px,4vw,52px) clamp(28px,4vw,48px)}.lpx-form-inner{width:100%;max-width:368px}.lpx-h1{margin:0;font-size:clamp(1.6rem,3vw,1.9rem);font-weight:700;letter-spacing:-.025em;line-height:1.1}.lpx-lede{margin:8px 0 0;font-size:15px;color:var(--lpx-text-2);line-height:1.5}.lpx-form{margin-top:26px}.lpx-field{margin-bottom:15px}.lpx-label{display:block;font-size:13px;font-weight:600;color:var(--lpx-label);margin-bottom:7px}.lpx-input-wrap{position:relative}.lpx-input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--lpx-muted);pointer-events:none;display:flex}.lpx-input{width:100%;font-family:inherit;font-size:15px;color:var(--lpx-text);background:#fff;border:1px solid var(--lpx-border);border-radius:11px;padding:13px 14px 13px 40px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.lpx-input.has-toggle{padding-right:42px}.lpx-input::placeholder{color:var(--lpx-muted)}.lpx-input:focus{border-color:var(--lpx-accent);box-shadow:0 0 0 3px var(--lpx-accent-t)}.lpx-pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--lpx-muted);padding:6px;display:flex;border-radius:7px;transition:color .15s ease}.lpx-pw-toggle:hover{color:var(--lpx-accent)}.lpx-forgot-row{display:flex;justify-content:flex-end;margin:-2px 0 16px}.lpx-link{background:none;border:none;cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:500;color:var(--lpx-text-2);padding:0;transition:color .15s ease}.lpx-link:hover{color:var(--lpx-accent)}.lpx-submit{width:100%;margin-top:4px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--lpx-accent);color:#fff;font-family:inherit;font-weight:600;font-size:15.5px;padding:14px;border:none;border-radius:12px;cursor:pointer;box-shadow:0 1px 2px #e5402a47,0 7px 18px #e5402a33;transition:transform .16s ease,box-shadow .16s ease}.lpx-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px #e5402a52,0 11px 26px #e5402a47}.lpx-submit:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.lpx-divider{display:flex;align-items:center;gap:14px;margin:22px 0}.lpx-divider span:first-child,.lpx-divider span:last-child{flex:1;height:1px;background:var(--lpx-divider)}.lpx-divider em{font-style:normal;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--lpx-muted)}.lpx-google-wrap{display:flex;justify-content:center;min-height:40px;overflow:visible}.lpx-switch{margin:22px 0 0;text-align:center;font-size:14.5px;color:var(--lpx-text-2)}.lpx-switch-btn{background:none;border:none;cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:600;color:var(--lpx-accent);padding:0}.lpx-switch-btn:hover{text-decoration:underline}.lpx-rules{display:flex;flex-direction:column;gap:6px;margin:-2px 0 15px}.lpx-rule{display:flex;align-items:center;gap:7px;font-size:12.5px}.lpx-rule svg{flex-shrink:0}.lpx-rule.invalid{color:var(--lpx-muted)}.lpx-rule.valid{color:#1f8a5b}.lpx-messages{margin-bottom:18px}.lpx-error,.lpx-success{padding:11px 13px;border-radius:10px;font-size:13.5px;line-height:1.45;text-align:center}.lpx-error{background:#fcedeb;border:1px solid #F6D3CE;color:#b5271e}.lpx-success{background:#f1f8f4;border:1px solid #D9EBE0;color:#1f8a5b}.lpx-footer{text-align:center;line-height:1.6}.lpx-footer div:first-child{font-size:13px;color:#8e887e}.lpx-footer div:last-child{font-size:13px;color:#a39c92}@media(max-width:760px){.lpx-brand-inner{min-height:auto}.lpx-brand-mid{padding:26px 0}.lpx-coord,.lpx-cross{display:none}}:root{--primary-color: #da2b26;--primary-hover: #b91c18;--primary-light: #fee2e2;--primary-glow: rgba(218, 43, 38, .15);--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-glass: rgba(255, 255, 255, .8);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent-success: #10b981;--accent-success-light: #d1fae5;--accent-danger: #ef4444;--accent-danger-light: #fee2e2;--accent-warning: #f59e0b;--accent-warning-light: #fef3c7;--border-subtle: #e2e8f0;--border-medium: #cbd5e1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-glow: 0 0 40px rgba(218, 43, 38, .15);--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, #ff6b67 100%);--gradient-subtle: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);--transition-fast: .15s ease;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-card: rgba(26, 26, 36, .9);--bg-glass: rgba(255, 255, 255, .03);--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #6b6b7b;--accent-success-light: rgba(16, 185, 129, .15);--accent-danger-light: rgba(239, 68, 68, .15);--accent-warning-light: rgba(245, 158, 11, .15);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .6);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .7);--shadow-glow: 0 0 40px rgba(218, 43, 38, .25);--gradient-subtle: linear-gradient(180deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%);--primary-light: rgba(218, 43, 38, .15)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,SF Pro Display,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(218,43,38,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(218,43,38,.02) 0%,transparent 50%);pointer-events:none;z-index:-1}[data-theme=dark] body:before{background:radial-gradient(circle at 20% 20%,rgba(218,43,38,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,107,103,.05) 0%,transparent 50%)}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 2rem}.main-layout{min-height:100vh;display:flex;flex-direction:column}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:.75rem;cursor:pointer;color:var(--text-secondary);transition:var(--transition-normal)}.theme-toggle:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color);transform:scale(1.05)}.theme-toggle svg{transition:transform var(--transition-normal)}.theme-toggle:hover svg{transform:rotate(15deg)}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);transition:background-color var(--transition-normal),border-color var(--transition-normal)}.header-content{display:flex;align-items:center;justify-content:space-between}.logo-section{display:flex;align-items:center;gap:.75rem}.logo-icon{color:var(--primary-color)}.logo-image{height:36px;width:auto}.brand-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;transition:color var(--transition-normal)}.brand-highlight{color:var(--primary-color)}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.925rem;padding:.5rem 1rem;border-radius:.5rem;transition:var(--transition-normal);display:inline-flex;align-items:center;gap:.375rem}.nav-link:hover{color:var(--primary-color);background:var(--primary-light)}.content-wrapper{flex:1;padding:4rem 2rem}.hero-section{text-align:center;margin-bottom:3rem;animation:fadeInUp .8s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-size:2.75rem;font-weight:800;margin-bottom:1rem;letter-spacing:-.03em;color:var(--text-primary);transition:color var(--transition-normal)}.hero-subtitle{font-size:1.125rem;color:var(--text-secondary);max-width:550px;margin:0 auto;line-height:1.7;transition:color var(--transition-normal)}.upload-card-wrapper{max-width:650px;margin:0 auto;background:var(--bg-card);padding:2.5rem;border-radius:1.25rem;border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);position:relative;animation:fadeInUp .8s ease-out .15s backwards;transition:background-color var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal)}.upload-zone{border:2px dashed var(--border-medium);border-radius:1rem;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-normal);background:var(--bg-tertiary);position:relative;overflow:hidden}.upload-zone:hover{border-color:var(--primary-color);background:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.upload-zone.dragging{border-color:var(--primary-color);background:var(--primary-light);box-shadow:var(--shadow-glow)}.upload-icon{color:var(--primary-color);margin-bottom:1.5rem;transition:var(--transition-normal)}.upload-zone:hover .upload-icon{transform:scale(1.1)}.upload-text-main{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;transition:color var(--transition-normal)}.upload-text-sub{font-size:.925rem;color:var(--text-muted);transition:color var(--transition-normal)}.result-container{background:var(--bg-card);border-radius:1.25rem;border:1px solid var(--border-subtle);box-shadow:var(--shadow-xl);overflow:hidden;animation:fadeInUp .6s ease-out;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.result-container.dashboard-card{width:100%;max-width:none;margin:0 auto;padding:0}.dashboard-header{padding:2rem 2.5rem;background:var(--gradient-subtle);border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;transition:background var(--transition-normal),border-color var(--transition-normal)}.status-badge-container{flex-shrink:0}.result-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:50px;font-weight:700;font-size:1rem;letter-spacing:.05em;text-transform:uppercase;transition:var(--transition-normal)}.result-fake{background:var(--accent-danger-light);color:#ef4444;border:1px solid rgba(239,68,68,.3)}[data-theme=dark] .result-fake{color:#f87171}.result-real{background:var(--accent-success-light);color:#10b981;border:1px solid rgba(16,185,129,.3)}[data-theme=dark] .result-real{color:#34d399}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border-subtle)}.card-section{background:var(--bg-secondary);padding:2.5rem;transition:background-color var(--transition-normal)}.card-section:hover{background:var(--bg-tertiary)}.col-span-2{grid-column:span 2}.section-title{font-size:.875rem;font-weight:600;color:var(--text-muted);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:.5rem;transition:color var(--transition-normal)}.section-title:before{content:"";width:3px;height:1em;background:var(--gradient-primary);border-radius:2px}.visual-evidence-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.evidence-item{position:relative}.evidence-label{font-weight:600;color:var(--text-secondary);margin-bottom:.875rem;font-size:.875rem;transition:color var(--transition-normal)}.heatmap-img{width:100%;border-radius:.75rem;border:1px solid var(--border-subtle);transition:var(--transition-normal);cursor:pointer}.heatmap-img:hover{border-color:var(--primary-color);box-shadow:var(--shadow-lg);transform:scale(1.02)}.no-heatmap{height:280px;background:var(--bg-tertiary);border-radius:.75rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);border:1px dashed var(--border-medium);font-size:.925rem;transition:background-color var(--transition-normal),color var(--transition-normal)}.metric-item{margin-bottom:1.5rem;padding:1.25rem;background:var(--bg-tertiary);border-radius:.75rem;border:1px solid var(--border-subtle);transition:var(--transition-normal)}.metric-item:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.metric-item:last-child{margin-bottom:0}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.metric-label{font-weight:600;color:var(--text-secondary);font-size:.925rem;transition:color var(--transition-normal)}.metric-value{font-family:JetBrains Mono,Fira Code,monospace;font-size:1.25rem;font-weight:700}.progress-bar-bg{height:8px;background:var(--border-subtle);border-radius:4px;overflow:hidden;transition:background-color var(--transition-normal)}.progress-bar-fill{height:100%;border-radius:4px;transition:width 1.2s cubic-bezier(.4,0,.2,1);background:var(--gradient-primary)}.progress-bar-fill.warning{background:linear-gradient(135deg,var(--accent-warning) 0%,#fbbf24 100%)}.metric-explainer{font-size:.8rem;color:var(--text-muted);margin-top:.75rem;line-height:1.5;transition:color var(--transition-normal)}.methodology-list{list-style:none;padding:0;margin:0}.methodology-item{display:flex;gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:.75rem;border:1px solid var(--border-subtle);transition:var(--transition-normal)}.methodology-item:hover{border-color:var(--accent-success);background:var(--accent-success-light)}.methodology-item:last-child{margin-bottom:0}.check-icon{background:var(--accent-success-light);color:var(--accent-success);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0;border:1px solid rgba(16,185,129,.3);transition:var(--transition-normal)}.methodology-item strong{display:block;font-size:.925rem;margin-bottom:.25rem;color:var(--text-primary);transition:color var(--transition-normal)}.methodology-item p{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.5;transition:color var(--transition-normal)}.feedback-section{padding:2rem 2.5rem;background:var(--bg-tertiary);border-top:1px solid var(--border-subtle);text-align:center;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.feedback-buttons{display:flex;justify-content:center;gap:1rem}.feedback-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:600;cursor:pointer;font-size:.925rem;transition:var(--transition-normal);background:var(--bg-secondary);border:1px solid var(--border-subtle)}.feedback-btn.correct{color:var(--accent-success);border-color:#10b9814d}.feedback-btn.correct:hover{background:var(--accent-success-light);border-color:var(--accent-success);transform:translateY(-2px);box-shadow:var(--shadow-md)}.feedback-btn.incorrect{color:var(--accent-danger);border-color:#ef44444d}.feedback-btn.incorrect:hover{background:var(--accent-danger-light);border-color:var(--accent-danger);transform:translateY(-2px);box-shadow:var(--shadow-md)}.feedback-success{color:var(--accent-success);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.reset-btn{display:flex;align-items:center;justify-content:center;width:100%;background:var(--gradient-primary);color:#fff;border:none;padding:1.25rem;font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition-normal)}.reset-btn:hover{opacity:.9;box-shadow:0 8px 24px #da2b2640}.spinner{width:48px;height:48px;border:4px solid var(--border-subtle);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-footer{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:1.5rem 0;text-align:center;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.app-footer p{color:var(--text-muted);font-size:.875rem;transition:color var(--transition-normal)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.col-span-2{grid-column:span 1}.visual-evidence-grid{grid-template-columns:1fr}}@media(max-width:768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.upload-card-wrapper{padding:1.5rem}.upload-zone{padding:3rem 1.5rem}.content-wrapper{padding:2rem 1rem}.dashboard-header{flex-direction:column;gap:1rem}.card-section{padding:1.5rem}.feedback-buttons{flex-direction:column}.feedback-btn{justify-content:center}}@media(max-width:480px){.container{padding:0 1rem}.content-wrapper{padding:1.5rem .75rem}.app-header{padding:.75rem 0}.header-content{flex-direction:column;gap:.75rem;align-items:center}.logo-section{width:100%;justify-content:center}.logo-image{height:48px}.brand-name{font-size:1.25rem}.nav-link{padding:.5rem .75rem;font-size:.75rem}.theme-toggle{width:36px;height:36px}.hero-section{margin-bottom:1.5rem}.hero-title{font-size:1.5rem;margin-bottom:.75rem}.hero-subtitle{font-size:.875rem;line-height:1.5}.upload-card-wrapper{padding:1rem;border-radius:1rem}.upload-zone{padding:2rem 1rem;border-radius:.75rem}.upload-icon svg{width:40px;height:40px}.upload-text-main{font-size:1rem}.upload-text-sub{font-size:.8rem}.result-container{border-radius:1rem}.dashboard-header{padding:1rem 1.25rem}.card-section{padding:1rem}.section-title{font-size:.75rem;margin-bottom:1rem}.metric-item{padding:1rem;margin-bottom:1rem}.metric-label{font-size:.85rem}.metric-value{font-size:1.125rem}.metric-explainer{font-size:.75rem}.methodology-item{padding:.875rem;gap:.75rem}.methodology-item strong{font-size:.85rem}.methodology-item p{font-size:.75rem}.check-icon{width:24px;height:24px;font-size:.75rem}.feedback-section{padding:1.25rem 1rem}.feedback-btn{padding:.625rem 1rem;font-size:.85rem}.reset-btn{padding:1rem;font-size:.9rem}.app-footer{padding:1rem 0}.app-footer p{font-size:.75rem}}.hidden{display:none!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--primary-color);color:#fff}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}
