@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap";@import"https://fonts.googleapis.com/css2?family=Manrope:wght@200..800&display=swap";@import"https://fonts.googleapis.com/css2?family=Geologica:wght@100..900&display=swap";.loading-overlay[data-v-80be6336]{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background:var(--bg-body);display:flex;align-items:center;justify-content:center;z-index:999999;overflow:hidden}.loading-screen[data-v-80be6336]{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.loading-container[data-v-80be6336]{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);padding:var(--space-5)}.loading-spinner[data-v-80be6336]{position:relative;width:100px;height:100px}.spinner-ring[data-v-80be6336]{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid transparent;animation:spin-80be6336 1.5s cubic-bezier(.68,-.55,.265,1.55) infinite}.spinner-ring[data-v-80be6336]:nth-child(1){border-top-color:var(--color-primary);animation-delay:0s}.spinner-ring[data-v-80be6336]:nth-child(2){border-right-color:var(--color-info);animation-delay:.2s;width:80%;height:80%;top:10%;left:10%}.spinner-ring[data-v-80be6336]:nth-child(3){border-bottom-color:var(--color-success);animation-delay:.4s;width:60%;height:60%;top:20%;left:20%}.spinner-logo[data-v-80be6336]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:32px;color:var(--color-primary);animation:pulse-80be6336 1.5s ease-in-out infinite}.loading-text[data-v-80be6336]{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.loading-title[data-v-80be6336]{background:var(--gradient-primary);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:var(--font-weight-semibold)}.loading-dots[data-v-80be6336]{display:flex;gap:4px}.loading-dots span[data-v-80be6336]{width:6px;height:6px;border-radius:50%;background:var(--color-primary);animation:bounce-80be6336 1.4s ease-in-out infinite}.loading-dots span[data-v-80be6336]:nth-child(1){animation-delay:0s}.loading-dots span[data-v-80be6336]:nth-child(2){animation-delay:.2s}.loading-dots span[data-v-80be6336]:nth-child(3){animation-delay:.4s}.loading-message[data-v-80be6336]{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:var(--space-2);text-align:center;max-width:300px}@keyframes spin-80be6336{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-80be6336{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.1);opacity:.7}}@keyframes bounce-80be6336{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}@media (max-width: 768px){.loading-spinner[data-v-80be6336]{width:70px;height:70px}.spinner-logo[data-v-80be6336]{font-size:24px}.loading-text[data-v-80be6336]{font-size:var(--font-size-sm)}.loading-message[data-v-80be6336]{font-size:var(--font-size-xs)}}@media (min-width: 768px) and (max-width: 1024px){.loading-spinner[data-v-80be6336]{width:85px;height:85px}.spinner-logo[data-v-80be6336]{font-size:28px}}:root{--color-white: #fff;--color-black: #000;--color-primary: #1e6f9f;--color-primary-dark: #155a85;--color-primary-darker: #0e4568;--color-primary-light: rgba(30, 111, 159, .12);--color-primary-lighter: rgba(30, 111, 159, .05);--color-primary-shadow: rgba(30, 111, 159, .25);--color-success: #10b981;--color-success-dark: #059669;--color-success-darker: #047857;--color-success-light: rgba(16, 185, 129, .15);--color-success-lighter: rgba(16, 185, 129, .08);--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-danger-darker: #b91c1c;--color-danger-light: rgba(239, 68, 68, .15);--color-danger-lighter: rgba(239, 68, 68, .08);--color-danger-shadow: rgba(239, 68, 68, .25);--color-warning: #f59e0b;--color-warning-dark: #d97706;--color-warning-light: rgba(245, 158, 11, .15);--color-warning-lighter: rgba(245, 158, 11, .08);--color-info: #0ea5e9;--color-info-dark: #0284c7;--color-info-light: rgba(14, 165, 233, .15);--color-info-lighter: rgba(14, 165, 233, .08);--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--text-primary: var(--color-gray-800);--text-secondary: var(--color-gray-600);--text-muted: var(--color-gray-500);--text-light: var(--color-gray-400);--bg-body: #f0f3f7;--bg-card: #ffffff;--border-color: #cbd5e0;--border-light: #f1f5f9;--gradient-primary: linear-gradient(135deg, #1e6f9f 0%, #155a84 100%);--gradient-secondary: linear-gradient(135deg, #1e6f9f 0%, #073f62 100%);--gradient-card: linear-gradient(135deg, var(--color-white) 0%, var(--color-gray-50) 100%);--gradient-success: linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);--gradient-danger: linear-gradient(135deg, var(--color-danger) 0%, var(--color-danger-dark) 100%);--gradient-warning: linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);--gradient-info: linear-gradient(135deg, var(--color-info) 0%, var(--color-info-dark) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px -2px rgba(0, 0, 0, .05), 0 2px 4px -2px rgba(0, 0, 0, .06);--shadow-lg: 0px 10px 10px -10px rgba(33, 35, 38, .1);--shadow-xxl: 0px 5px 10px 2px rgba(34, 60, 80, .2);--radius-s: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-xxl: 36px;--radius-full: 9999px;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-14: 56px;--space-16: 64px;--space-18: 72px;--space-19: 80px;--space-100: 100px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast: all .2s ease;--transition-slow: all .4s ease;--transition-slow-color: background-color 1s ease-in-out;--z-index-100: 100;--z-index-modal: 1000;--z-index-toast: 1000;--z-index-tooltip: 1100;--font-1: "Inter", sans-serif;--font-2: "Manrope", sans-serif;--font-3: "Geologica", sans-serif;--font-4: "JetBrains Mono", monospace;--font-size-xxs: 10px;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-md: 18px;--font-size-lg: 20px;--font-size-xl: 24px;--font-size-2xl: 28px;--font-size-3xl: 32px;--font-size-4xl: 40px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75}[data-theme=dark]{--color-white: #0f172a;--color-black: #f1f5f9;--color-primary: #60a5fa;--color-primary-dark: #3b82f6;--color-primary-darker: #2563eb;--color-primary-light: rgba(96, 165, 250, .15);--color-primary-lighter: rgba(96, 165, 250, .08);--color-primary-shadow: rgba(96, 165, 250, .3);--color-success: #34d399;--color-success-dark: #10b981;--color-success-light: rgba(52, 211, 153, .15);--color-danger: #f87171;--color-danger-dark: #ef4444;--color-danger-light: rgba(255, 123, 123, .285);--color-danger-shadow: rgba(248, 113, 113, .3);--color-warning: #fbbf24;--color-warning-dark: #f59e0b;--color-warning-light: rgba(251, 191, 36, .15);--color-info: #38bdf8;--color-info-dark: #0ea5e9;--color-info-light: rgba(56, 189, 248, .15);--color-gray-50: #0f172a;--color-gray-100: #1e293b;--color-gray-200: #334155;--color-gray-300: #475569;--color-gray-400: #64748b;--color-gray-500: #94a3b8;--color-gray-600: #cbd5e1;--color-gray-700: #e2e8f0;--color-gray-800: #f1f5f9;--color-gray-900: #f8fafc;--text-primary: var(--color-gray-800);--text-secondary: var(--color-gray-500);--text-muted: var(--color-gray-400);--text-light: var(--color-gray-400);--bg-body: var(--color-gray-50);--bg-card: var(--color-gray-100);--border-color: var(--color-gray-200);--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-secondary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-info) 100%);--gradient-card: linear-gradient(135deg, var(--color-gray-100) 0%, var(--color-gray-50) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -2px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4)}*{padding:0;margin:0;border:0;box-sizing:border-box}*,*:before,*:after{box-sizing:border-box}:focus,:active{outline:none}a:focus,a:active{outline:none}nav,footer,header,aside{display:block}html,body{height:100%;width:100%;font-size:100%;line-height:1;-ms-text-size-adjust:100%;-moz-text-size-adjust:100%;-webkit-text-size-adjust:100%}input,button,textarea{font-family:inherit}input::-ms-clear{display:none}button{cursor:pointer;background:none;border:none}button::-moz-focus-inner{padding:0;border:0}a,a:visited,a:hover{text-decoration:none}ul li{list-style:none}img{vertical-align:top}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}body{background:var(--bg-body);color:var(--text-primary);font-family:var(--font-3);font-size:14px;line-height:1.5;min-height:100vh;transition:var(--transition);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:.4375rem;height:.4375rem}::-webkit-scrollbar-thumb{background-color:var(--color-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background-color:var(--color-primary-dark)}::-webkit-scrollbar-track{background-color:var(--bg-body)}body{scrollbar-width:thin;scrollbar-color:var(--color-primary) var(--bg-body)}.container{width:100%;padding:0 var(--space-4);margin:0 auto}.container-wrap{margin-top:var(--space-6)}@media (min-width: 768px){.container{max-width:720px;padding:0 var(--space-5)}}@media (min-width: 1024px){.container{max-width:960px}}@media (min-width: 1280px){.container{max-width:1200px}}@media (min-width: 1536px){.container{max-width:1400px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-weight:600;font-size:.875rem;background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:var(--transition-fast)}.btn:hover{background:var(--color-primary-dark);color:var(--color-white)}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--color-primary-light);color:var(--color-primary)}.btn-danger{background:var(--gradient-danger);color:var(--color-white)}.btn-danger:hover{box-shadow:0 4px 12px var(--color-danger-shadow)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:1rem}.btn-sm{width:32px;height:32px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);font-size:var(--font-size-xs)}.btn-block{width:100%;margin-top:var(--space-8)}.btn:disabled,.btn.disabled{opacity:.6;pointer-events:none;cursor:not-allowed}.btn-close{width:var(--space-8);height:var(--space-8);border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:1rem;padding:0}.btn-close:hover{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.main-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:var(--z-index-100)}.main-header .container{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);min-height:56px;gap:var(--space-3)}.main-header h1{font-size:1.25rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:var(--space-2)}.main-header h1 i{color:var(--color-primary);-webkit-text-fill-color:var(--color-primary)}@media (min-width: 768px){.main-header .container{padding:var(--space-4) var(--space-5);min-height:70px;gap:var(--space-4)}.main-header h1{font-size:1.5rem}}@media (min-width: 1024px){.main-header h1{font-size:1.75rem}}.user-info{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.user-info button,.user-info .theme-toggle,.user-info .logout-btn,.user-info .back-btn,.user-info .api-test-header-btn{width:36px;height:36px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);font-size:1rem}.user-info button:hover,.user-info .theme-toggle:hover,.user-info .back-btn:hover,.user-info .api-test-header-btn:hover{background:var(--color-primary-dark);color:var(--color-white)}.user-info .logout-btn:hover{background:var(--color-danger);border-color:var(--color-danger)}@media (min-width: 768px){.user-info{gap:var(--space-3)}.user-info button,.user-info .theme-toggle,.user-info .logout-btn,.user-info .back-btn,.user-info .api-test-header-btn{width:40px;height:40px;font-size:1.1rem}}.dashboard-nav{display:flex;gap:var(--space-2);margin:var(--space-4) 0;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color);flex-wrap:wrap}.nav-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;transition:var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);font-size:.875rem}.nav-link i{font-size:1rem}.nav-link span{display:none}.nav-link:hover{background:var(--color-primary-light);color:var(--color-primary)}.nav-link.active{background:var(--color-primary);color:#fff}@media (min-width: 640px){.nav-link span{display:inline}.nav-link{padding:var(--space-2) var(--space-4)}}.dashboard-header{margin-top:var(--space-4)}.dashboard-header h1{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.dashboard-header p{color:var(--text-secondary);font-size:.875rem}@media (min-width: 768px){.dashboard-header h1{font-size:1.75rem}}@media (min-width: 1024px){.dashboard-header h1{font-size:2rem}}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-top:var(--space-6)}@media (min-width: 480px){.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-5)}}@media (min-width: 1024px){.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6)}}.widget{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-3);border:1px solid var(--border-color);transition:var(--transition-fast);text-decoration:none;color:inherit;cursor:pointer}.widget:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.widget h3{margin-bottom:var(--space-2);font-size:1.125rem;font-weight:600;display:flex;align-items:center;gap:var(--space-2)}.widget h3 i{color:var(--color-primary)}.widget p{color:var(--text-secondary);font-size:.875rem;line-height:1.4;margin-bottom:var(--space-3);overflow-wrap:break-word;word-break:break-word;text-wrap:balance;white-space:normal}.widget-link{display:inline-flex;align-items:center;margin-top:auto;gap:var(--space-2);color:var(--color-primary);font-size:.875rem;font-weight:500;transition:var(--transition-fast);text-decoration:none}.widget:hover .widget-link{gap:var(--space-3)}@media (min-width: 768px){.widget{padding:var(--space-4)}}.form-group{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.form-group label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:0}.required{color:var(--color-danger);margin-left:2px}.form-input,.form-group input,.form-group textarea,.form-select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-body);color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.5;transition:var(--transition-fast);box-sizing:border-box}.form-input:focus,.form-group input:focus,.form-group textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder,.form-group input::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width: 768px){.form-row.split-columns{grid-template-columns:1fr 1fr}}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-3) var(--space-4);position:sticky;bottom:0;background:var(--bg-card);border-top:1px solid var(--border-color);margin-top:auto}.error-message{margin-top:var(--space-2);color:var(--color-danger);font-size:var(--font-size-xs);display:flex;align-items:center;gap:var(--space-1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:var(--space-4)}.modal-container{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:500px;height:auto;max-height:85vh;box-shadow:var(--shadow-xxl);border:1px solid var(--border-color);display:flex;flex-direction:column;animation:modalSlideUp .3s ease}.modal-container.modal-lg{max-width:700px}.modal-container.modal-sm{max-width:350px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);background:var(--bg-card);border-bottom:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0;flex-shrink:0;position:sticky;top:0;z-index:10}.modal-header h3{font-size:1.125rem;font-weight:600;display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary);margin:0}.modal-header h3 i{color:var(--color-primary)}.modal-close{width:32px;height:32px;border:1px solid var(--border-color);padding:0;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);border-radius:var(--radius-sm)}.modal-close:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.modal-body-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.modal-body-wrapper::-webkit-scrollbar{width:6px}.modal-body-wrapper::-webkit-scrollbar-track{background:var(--border-light);border-radius:var(--radius-full)}.modal-body-wrapper::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--radius-full)}.modal-body{padding:var(--space-4)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);background:var(--bg-card);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-shrink:0;position:sticky;bottom:0;z-index:10}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(var(--space-5)) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (min-width: 768px){.modal-header{padding:var(--space-5) var(--space-6)}.modal-header h3{font-size:1.25rem}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6)}}@media (max-width: 768px){.modal-overlay{padding:var(--space-2);align-items:center}.modal-container{max-width:calc(100% - var(--space-2));max-height:90vh}.modal-body{padding:var(--space-3)}.modal-header,.modal-footer{padding:var(--space-3) var(--space-4)}}.loading-modal .modal-container{text-align:center}.loading-content{padding:var(--space-5);text-align:center}.spinner{width:60px;height:60px;border:4px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--space-5)}.success-icon{font-size:60px;color:var(--color-success);margin-bottom:var(--space-5)}.loading-text{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.result-message{padding:var(--space-3);border-radius:var(--radius-md);margin:var(--space-4) 0;font-size:.875rem}.result-message.success{background:var(--color-success-light);color:var(--color-success)}.result-message.error{background:var(--color-danger-light);color:var(--color-danger)}.confirm-message{font-size:1rem;line-height:1.5;color:var(--text-primary);text-align:center;padding:var(--space-2)}@keyframes spin{to{transform:rotate(360deg)}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-5);padding:var(--space-3);padding-bottom:var(--space-19)}.page-btn{padding:var(--space-2) var(--space-3);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:var(--transition-fast)}.page-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{padding:var(--space-2);color:var(--text-secondary);font-size:var(--font-size-sm)}.loading-screen{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:9999}.terminal-spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--color-success-light);border-radius:50%;border-top-color:var(--color-success);animation:spin 1s ease-in-out infinite;margin-right:var(--space-2)}.toast{position:fixed;bottom:var(--space-4);right:var(--space-4);left:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--color-white);font-weight:600;box-shadow:var(--shadow-lg);z-index:var(--z-index-toast);opacity:0;transform:translateY(100px);transition:var(--transition-fast);max-width:calc(100% - var(--space-8))}.toast.show{opacity:1;transform:translateY(0)}.toast.success{background:var(--gradient-success)}.toast.error{background:var(--gradient-danger)}@media (min-width: 768px){.toast{bottom:var(--space-6);right:var(--space-6);left:auto;max-width:400px}}.hidden{display:none!important}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.dashboard-welcome{padding:var(--space-4) 0}.welcome-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md);text-align:center;max-width:560px;margin:0 auto}.welcome-icon{width:64px;height:64px;margin:0 auto var(--space-4);border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:28px}.welcome-card h2{margin:0 0 var(--space-3);color:var(--text-primary);font-size:var(--font-size-xl)}.welcome-role{color:var(--text-secondary);margin:0 0 var(--space-4)}.welcome-hint{color:var(--text-muted);margin:0;line-height:1.6}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-body);padding:var(--space-4);position:relative}.login-wrapper{width:100%;max-width:100%;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-5);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-6)}.login-logo{width:56px;height:56px;background:var(--color-primary-light);color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto var(--space-3);transition:transform .3s ease}.login-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.login-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin:var(--space-2) 0 0}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:var(--space-3);color:var(--text-secondary);pointer-events:none;transition:color .2s;z-index:1}.form-input{width:100%;height:44px;padding:var(--space-2) var(--space-3) var(--space-2) 40px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-body);color:var(--text-primary);font-size:var(--font-size-base);transition:var(--transition-fast);box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.input-wrapper:focus-within .input-icon{color:var(--color-primary)}.toggle-password-btn{position:absolute;right:var(--space-2);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;z-index:2;min-width:32px;min-height:32px}.toggle-password-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.error-message{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}.btn-block{width:100%;margin-top:var(--space-4);height:44px;display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--font-size-base)}.login-footer{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-color);text-align:center}.help-text{margin:0;font-size:var(--font-size-xs);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:var(--space-2);line-height:1.4}.help-text i{color:var(--color-primary);flex-shrink:0}.theme-toggle-fixed{position:fixed;top:var(--space-4);right:var(--space-4);width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);font-size:1rem;z-index:1000;box-shadow:var(--shadow-sm)}.theme-toggle-fixed:hover{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}@media (min-width: 768px){.login-wrapper{max-width:420px}.login-card{padding:var(--space-10) var(--space-8)}.login-logo{width:72px;height:72px;font-size:32px;margin-bottom:var(--space-4)}.login-title{font-size:1.75rem;margin-bottom:var(--space-2)}.theme-toggle-fixed{top:var(--space-5);right:var(--space-5);width:40px;height:40px;font-size:1.2rem}}.not-found-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-body);padding:var(--space-4)}.not-found-content{text-align:center;max-width:100%;padding:var(--space-4)}.error-code{font-size:80px;font-weight:var(--font-weight-extrabold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--space-4)}.error-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.error-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-8);line-height:var(--line-height-relaxed)}.error-actions{display:flex;flex-direction:column;gap:var(--space-3);justify-content:center}.error-actions .btn{width:100%}@media (min-width: 480px){.error-code{font-size:100px}.error-title{font-size:var(--font-size-2xl)}.error-actions{flex-direction:row;gap:var(--space-4)}.error-actions .btn{width:auto}}@media (min-width: 768px){.not-found-content{max-width:500px;padding:0}.error-code{font-size:120px}.error-title{font-size:var(--font-size-3xl)}.error-description{font-size:var(--font-size-base)}}@media (min-width: 1024px){.error-code{font-size:140px}.error-title{font-size:2.5rem}}
