.auth-wrapper{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--c-primary);font-family:var(--font-family)}.auth-card{background:#fffffff7;border-radius:var(--radius-2xl);padding:40px 36px;width:420px;max-width:92vw;box-shadow:var(--shadow-xl)}.auth-header{text-align:center;margin-bottom:24px}.auth-logo{display:inline-flex;align-items:center;gap:9px;margin-bottom:6px}.auth-logo img{width:36px;height:36px}.auth-logo-text{font-size:26px;font-weight:var(--fw-bold);color:var(--c-primary)}.auth-subtitle{color:var(--c-text-muted);font-size:var(--fs-base)}.auth-tabs{display:flex;margin-bottom:18px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--c-border)}.auth-tab{flex:1;padding:10px;border:none;font-size:var(--fs-base);font-weight:var(--fw-semibold);cursor:pointer;font-family:var(--font-family);transition:var(--transition)}.auth-tab--active{background:var(--c-accent);color:#fff}.auth-tab--inactive{background:var(--c-surface-alt);color:var(--c-text-muted)}.auth-google-btn{width:100%;padding:12px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:var(--fw-semibold);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px;color:#334155;font-family:var(--font-family);transition:var(--transition)}.auth-google-btn:hover{background:var(--c-surface-hover)}.auth-google-btn:disabled{cursor:wait}.auth-divider{display:flex;align-items:center;gap:12px;margin-bottom:16px}.auth-divider-line{flex:1;height:1px;background:var(--c-border)}.auth-divider-text{font-size:var(--fs-sm);color:var(--c-text-faint)}.auth-field{margin-bottom:14px}.auth-label{font-size:12px;font-weight:var(--fw-semibold);color:var(--c-text-muted);display:block;margin-bottom:5px}.auth-input{width:100%;padding:12px 14px;border:1px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-md);background:var(--c-surface-alt);font-family:var(--font-family)}.auth-input--error{border-color:var(--c-error)}.auth-pass-wrapper{position:relative}.auth-pass-wrapper .auth-input{padding-right:42px}.auth-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--c-text-faint);display:flex;align-items:center;padding:2px}.auth-strength{margin-bottom:8px}.auth-strength-bars{display:flex;gap:3px;margin-bottom:4px}.auth-strength-bar{flex:1;height:4px;border-radius:2px;background:var(--c-border);transition:background .2s}.auth-strength-label{font-size:var(--fs-sm);font-weight:var(--fw-semibold)}.auth-error{background:var(--c-error-light);border:1px solid var(--c-error-border);color:var(--c-error);padding:10px 12px;border-radius:var(--radius-md);font-size:12px;margin-bottom:14px}.auth-success{background:var(--c-success-light);border:1px solid var(--c-success-border);color:var(--c-success);padding:10px 12px;border-radius:var(--radius-md);font-size:12px;margin-bottom:14px}.auth-google-hint{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-xl);padding:14px 16px;margin-bottom:14px;text-align:center}.auth-google-hint-icon{font-size:24px;margin-bottom:4px}.auth-google-hint-title{font-size:var(--fs-base);font-weight:var(--fw-bold);color:#1e40af;margin-bottom:4px}.auth-google-hint-text{font-size:12px;color:#3b82f6}.auth-submit{width:100%;padding:13px;background:var(--c-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:var(--fw-semibold);cursor:pointer;font-family:var(--font-family);transition:var(--transition)}.auth-submit:hover:not(:disabled){filter:brightness(1.1)}.auth-submit:disabled{opacity:.7;cursor:wait}.auth-forgot{background:none;border:none;color:var(--c-accent);font-size:12px;font-weight:var(--fw-semibold);cursor:pointer;padding:0;font-family:var(--font-family)}.auth-reset-title{font-size:var(--fs-md);font-weight:var(--fw-semibold);margin-bottom:10px;color:var(--c-primary)}.auth-reset-back{width:100%;padding:10px;background:var(--c-surface-hover);border:none;border-radius:var(--radius-md);font-size:var(--fs-base);cursor:pointer;color:var(--c-text-muted);font-family:var(--font-family)}.auth-match{font-size:var(--fs-sm);margin-top:4px;font-weight:var(--fw-semibold)}.auth-match--ok{color:var(--c-success)}.auth-match--err{color:var(--c-error)}.auth-footer{text-align:center;margin-top:14px;font-size:10px;color:var(--c-text-faint);line-height:1.6}.auth-footer a{color:var(--c-accent);text-decoration:none;font-weight:var(--fw-semibold)}.auth-version{text-align:center;margin-top:4px;font-size:10px;color:#cbd5e1}:root{--c-primary: #0a3d2f;--c-accent: #0d9488;--c-accent-light: #ccfbf1;--c-bg: #f0f5f3;--c-surface: #ffffff;--c-surface-alt: #f8faf9;--c-surface-hover: #f1f5f9;--c-text: #1e293b;--c-text-secondary: #475569;--c-text-muted: #64748b;--c-text-faint: #94a3b8;--c-border: #e2e8f0;--c-border-light: #f1f5f9;--c-success: #059669;--c-success-light: #f0fdf4;--c-success-border: #bbf7d0;--c-warning: #f59e0b;--c-warning-dark: #d97706;--c-warning-light: #fffbeb;--c-error: #dc2626;--c-error-light: #fef2f2;--c-error-border: #fecaca;--c-purple: #7c3aed;--c-purple-light: #ede9fe;--c-purple-border: #c4b5fd;--c-info: #3498db;--c-info-light: #f0f9ff;--c-sidebar-text: rgba(255, 255, 255, .55);--c-sidebar-active: #5eead4;--c-sidebar-active-bg: rgba(94, 234, 212, .12);--c-sidebar-border: rgba(255, 255, 255, .1);--font-family: "DM Sans", system-ui, -apple-system, sans-serif;--fs-xs: 9px;--fs-sm: 11px;--fs-base: 13px;--fs-md: 14px;--fs-lg: 16px;--fs-xl: 18px;--fs-2xl: 20px;--fs-3xl: 24px;--fs-4xl: 28px;--fs-5xl: 36px;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--radius-sm: 4px;--radius: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-2xl: 16px;--radius-3xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .25);--transition: all .15s ease;--transition-slow: all .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.input{width:100%;padding:10px 14px;border:1px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-md);font-family:var(--font-family);background:var(--c-surface-alt);color:var(--c-text);transition:var(--transition);outline:none}.input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px #0d94881a}.input::placeholder{color:var(--c-text-faint)}.input-sm{padding:6px 10px;font-size:var(--fs-base)}.select{width:100%;padding:10px 14px;border:1px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-md);font-family:var(--font-family);background:var(--c-surface);color:var(--c-text);cursor:pointer;outline:none;transition:var(--transition)}.select:focus{border-color:var(--c-accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:var(--fw-semibold);font-family:var(--font-family);cursor:pointer;transition:var(--transition);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--c-accent);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-success{background:var(--c-success);color:#fff}.btn-error{background:var(--c-error);color:#fff}.btn-purple{background:var(--c-purple);color:#fff}.btn-ghost{background:var(--c-surface-hover);color:var(--c-text-muted);border:1px solid var(--c-border)}.btn-ghost:hover:not(:disabled){background:var(--c-border)}.btn-sm{padding:4px 8px;font-size:var(--fs-sm);border-radius:var(--radius)}.btn-lg{padding:14px 28px;font-size:15px;font-weight:var(--fw-bold);border-radius:var(--radius-lg)}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-xl);padding:var(--sp-6)}.card-sm{padding:var(--sp-4);border-radius:var(--radius-lg)}.label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--c-text-muted);margin-bottom:var(--sp-1)}.badge{display:inline-block;padding:1px 6px;border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:var(--fw-semibold)}.badge-success{background:var(--c-success-light);color:var(--c-success)}.badge-error{background:var(--c-error-light);color:var(--c-error)}.badge-purple{background:var(--c-purple-light);color:var(--c-purple)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.text-center{text-align:center}.w-full{width:100%}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fi{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;top:16px;right:16px;z-index:999;padding:10px 18px;border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:var(--fw-medium);color:#fff;box-shadow:var(--shadow-md);animation:fi .3s ease}.toast-ok{background:var(--c-success)}.toast-er{background:var(--c-error)}.modal-overlay{position:fixed;inset:0;z-index:1001;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px);padding:20px}.modal-content{background:var(--c-surface);border-radius:var(--radius-3xl);padding:36px 28px;max-width:92vw;box-shadow:var(--shadow-xl);text-align:center}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-text-faint);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--c-text-muted)}select{appearance:auto}input:focus,select:focus,textarea:focus{outline:2px solid var(--c-accent);outline-offset:-1px}@media (max-width: 768px){.peff-legend-sidebar{display:none!important}.peff-fon-layout{flex-direction:column!important}}@media print{body{font-size:12px}button{display:none!important}}button,input,select,textarea{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
