@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box}*{margin:0;padding:0}html{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.5}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ol,ul{list-style:none}a{color:inherit;text-decoration:none}table{border-collapse:collapse;border-spacing:0}button{cursor:pointer;background:0 0;border:none}:root{--color-bg:#0c0f1a;--color-surface:#131824;--color-surface-2:#1a2035;--color-surface-3:#212840;--color-border:#252e48;--color-border-subtle:#1a2035;--color-primary:#4a9eda;--color-primary-hover:#5baee6;--color-primary-dim:#4a9eda26;--color-accent:#52c4a8;--color-accent-hover:#65d0b5;--color-accent-dim:#52c4a826;--color-text:#d0d8e8;--color-text-black:#1b1b1e;--color-text-secondary:#8494af;--color-text-muted:#4a5670;--color-success:#3fb96e;--color-warning:#d4960a;--color-danger:#e85555;--color-info:#4a9eda;--color-success-dim:#3fb96e26;--color-warning-dim:#d4960a26;--color-danger-dim:#e8555526;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.0625rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:3px;--radius:6px;--radius-lg:10px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000080;--shadow:0 4px 16px #00000080;--shadow-lg:0 8px 32px #000000a6;--shadow-inset:inset 0 1px 2px #0000004d;--transition-fast:.1s ease;--transition:.18s ease;--transition-slow:.3s ease;--sidebar-width:220px;--header-height:56px;--content-max-width:1440px;--panel-padding:var(--space-6)}@media (prefers-color-scheme:light){:root:not([data-theme=dark]){--color-bg:#f2f5fb;--color-surface:#fff;--color-surface-2:#edf1f8;--color-surface-3:#e4eaf5;--color-border:#d5ddef;--color-border-subtle:#eaeff9;--color-primary:#2878b5;--color-primary-hover:#3488c8;--color-primary-dim:#2878b51f;--color-accent:#33a488;--color-accent-hover:#3eb89a;--color-accent-dim:#33a4881f;--color-text:#18202f;--color-text-secondary:#4a5670;--color-text-muted:#8494af;--color-success:#258f50;--color-warning:#a86c00;--color-danger:#c23c3c;--color-info:#2878b5;--color-success-dim:#258f501f;--color-warning-dim:#a86c001f;--color-danger-dim:#c23c3c1f;--shadow-sm:0 1px 3px #00000012;--shadow:0 4px 16px #00000017;--shadow-lg:0 8px 32px #00000021;--shadow-inset:inset 0 1px 2px #0000000d}}:root[data-theme=light]{--color-bg:#f2f5fb;--color-surface:#fff;--color-surface-2:#edf1f8;--color-surface-3:#e4eaf5;--color-border:#d5ddef;--color-border-subtle:#eaeff9;--color-primary:#2878b5;--color-primary-hover:#3488c8;--color-primary-dim:#2878b51f;--color-accent:#33a488;--color-accent-hover:#3eb89a;--color-accent-dim:#33a4881f;--color-text:#18202f;--color-text-secondary:#4a5670;--color-text-muted:#8494af;--color-success:#258f50;--color-warning:#a86c00;--color-danger:#c23c3c;--color-info:#2878b5;--color-success-dim:#258f501f;--color-warning-dim:#a86c001f;--color-danger-dim:#c23c3c1f;--shadow-sm:0 1px 3px #00000012;--shadow:0 4px 16px #00000017;--shadow-lg:0 8px 32px #00000021;--shadow-inset:inset 0 1px 2px #0000000d}@media (prefers-color-scheme:light){:root:not([data-theme=dark]) .loading-overlay-text{text-shadow:0 0 12px #2878b566,0 0 32px #2878b533}}:root[data-theme=light] .loading-overlay-text{text-shadow:0 0 12px #2878b566,0 0 32px #2878b533}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:var(--font-weight-semibold);line-height:var(--leading-tight);color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{color:var(--color-text-secondary);line-height:var(--leading-relaxed)}a{color:var(--color-primary);transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}code,kbd,samp,pre{font-family:var(--font-mono);font-size:var(--text-sm)}code{background:var(--color-surface-2);border-radius:var(--radius-sm);color:var(--color-accent);padding:.15em .4em}pre{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-4);overflow-x:auto}pre code{color:var(--color-text);background:0 0;padding:0}strong{font-weight:var(--font-weight-semibold)}em{font-style:italic}small,.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-layout{flex:1;min-height:0;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);top:var(--header-height);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;bottom:0;left:0;overflow-y:auto}.main-content{min-width:0;margin-left:var(--sidebar-width);min-height:calc(100vh - var(--header-height));flex-direction:column;flex:1;display:flex;overflow-x:hidden}.page-content{padding:var(--space-8) var(--panel-padding);max-width:var(--content-max-width);flex:1;width:100%}.app-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 var(--space-6);align-items:center;gap:var(--space-4);z-index:200;display:flex;position:sticky;top:0}.app-header .logo{align-items:center;gap:var(--space-3);font-weight:var(--font-weight-semibold);font-size:var(--text-base);color:var(--color-text);display:flex}.app-header .logo img{width:28px;height:auto}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.card-header{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);overflow-x:auto}table{width:100%;font-size:var(--text-sm);color:var(--color-text)}thead{background:var(--color-surface-2)}thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}tbody tr{border-bottom:1px solid var(--color-border-subtle);transition:background var(--transition-fast)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--color-surface-2)}tbody td{padding:var(--space-3) var(--space-4);vertical-align:middle;color:var(--color-text)}.td-mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary)}.td-muted{color:var(--color-text-muted);font-size:var(--text-sm)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-input,input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],input[type=url],input[type=date],textarea,select{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:var(--text-sm);font-family:var(--font-sans);line-height:var(--leading-normal);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus,input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=search]:focus,input[type=url]:focus,input[type=date]:focus,textarea:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim)}.form-input::placeholder,input::placeholder,textarea::placeholder{color:var(--color-text-muted)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238494af' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);cursor:pointer}textarea{resize:vertical;min-height:100px}.btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:var(--font-weight-medium);font-family:var(--font-sans);white-space:nowrap;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);cursor:pointer;border:1px solid #0000;outline:none;line-height:1;display:inline-flex}.btn:focus-visible{box-shadow:0 0 0 3px var(--color-primary-dim)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-accent{background:var(--color-accent);color:#0c0f1a;border-color:var(--color-accent)}.btn-accent:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-ghost{color:var(--color-text-secondary);border-color:var(--color-border);background:0 0}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text);border-color:var(--color-border)}.btn-danger{color:var(--color-danger);border-color:var(--color-danger);background:0 0}.btn-danger:hover{background:var(--color-danger-dim)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-medium);align-items:center;padding:.15em .55em;line-height:1.4;display:inline-flex}.badge-primary{background:var(--color-primary-dim);color:var(--color-primary)}.badge-accent{background:var(--color-accent-dim);color:var(--color-accent)}.badge-success{background:var(--color-success-dim);color:var(--color-success)}.badge-warning{background:var(--color-warning-dim);color:var(--color-warning)}.badge-danger{background:var(--color-danger-dim);color:var(--color-danger)}.badge-muted{background:var(--color-surface-3);color:var(--color-text-muted)}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.page-header h1{font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);margin:0}.page-header p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.page-header-actions{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.tabs{gap:var(--space-1);border-bottom:1px solid var(--color-border);padding-bottom:0;display:flex}.tab-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius) var(--radius) 0 0;transition:color var(--transition), border-color var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;display:inline-flex}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}hr{border:none;border-top:1px solid var(--color-border-subtle);margin:var(--space-6) 0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border)}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.w-full{width:100%}.mt-auto{margin-top:auto}.auth-page{background-color:var(--color-bg);min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-page:before,.auth-page:after{content:"";filter:blur(90px);pointer-events:none;border-radius:50%;position:absolute}.auth-page:before{background:radial-gradient(circle, var(--color-primary) 0%, transparent 70%);opacity:.12;width:480px;height:480px;top:-120px;right:-120px}.auth-page:after{background:radial-gradient(circle, var(--color-accent) 0%, transparent 70%);opacity:.1;width:360px;height:360px;bottom:-80px;left:-80px}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-lg), 0 0 0 1px #4a9eda0a;z-index:1;position:relative}.auth-logo{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.auth-logo-icon{margin-bottom:var(--space-2);filter:drop-shadow(0 0 12px #4a9eda66);font-size:2.5rem;line-height:1}.auth-logo-name{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);letter-spacing:.1em;background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.auth-logo-sub{font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:.14em;text-transform:uppercase}.auth-divider{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-full);width:48px;height:2px;margin:var(--space-4) auto var(--space-8)}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-input-group{align-items:center;display:flex;position:relative}.auth-input-icon{left:var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm);pointer-events:none;z-index:1;position:absolute}.auth-input-group input{padding-left:2.2rem}.auth-pw-toggle{right:var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;line-height:1;position:absolute}.auth-pw-toggle:hover{color:var(--color-text-secondary)}.auth-footer{margin-top:calc(-1 * var(--space-2));justify-content:flex-end;align-items:center;display:flex}.auth-link{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition-fast)}.auth-link:hover{color:var(--color-primary)}.auth-submit{width:100%;padding:var(--space-3);margin-top:var(--space-2);font-size:var(--text-base);justify-content:center;gap:var(--space-2)}.auth-back-link{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-5);transition:color var(--transition-fast);cursor:pointer;text-decoration:none;display:inline-flex}.auth-back-link:hover{color:var(--color-primary)}.auth-title{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.auth-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-5);line-height:var(--leading-relaxed)}.auth-success-state{text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.auth-success-icon{background:var(--color-success-dim);width:60px;height:60px;color:var(--color-success);margin-bottom:var(--space-2);border-radius:50%;justify-content:center;align-items:center;font-size:1.75rem;display:flex}.auth-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-nav{padding:var(--space-4) var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast), color var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;text-decoration:none;display:flex}.sidebar-nav-item:hover{background:var(--color-surface-2);color:var(--color-text)}.sidebar-nav-item.active{background:var(--color-primary-dim);color:var(--color-primary)}.sidebar-nav-item i{font-size:var(--text-base);text-align:center;flex-shrink:0;width:18px}.header-logo-icon{font-size:1.3rem;line-height:1}.header-user{align-items:center;gap:var(--space-4);margin-left:auto;display:flex}.header-user-info{text-align:right}.header-user-name{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:1.2}.header-user-role{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:capitalize}.stats-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);align-items:center;gap:var(--space-4);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);display:flex}.stat-card:hover{border-color:var(--color-border);box-shadow:var(--shadow)}.stat-card-icon{border-radius:var(--radius);width:46px;height:46px;font-size:var(--text-xl);flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-card-icon--primary{background:var(--color-primary-dim);color:var(--color-primary)}.stat-card-icon--accent{background:var(--color-accent-dim);color:var(--color-accent)}.stat-card-icon--success{background:var(--color-success-dim);color:var(--color-success)}.stat-card-icon--warning{background:var(--color-warning-dim);color:var(--color-warning)}.stat-card-value{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);line-height:1.1;font-family:var(--font-mono)}.stat-card-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:var(--space-1)}.dashboard-grid{gap:var(--space-6);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.quick-links{gap:var(--space-1);flex-direction:column;display:flex}.quick-link-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius);cursor:pointer;transition:background var(--transition-fast);display:flex}.quick-link-card:hover{background:var(--color-surface-2)}.quick-link-icon{font-size:var(--text-lg);color:var(--color-primary);flex-shrink:0;width:22px}.quick-link-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:1.2}.quick-link-desc{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.quick-link-arrow{color:var(--color-text-muted);font-size:var(--text-sm);flex-shrink:0;margin-left:auto}.status-list{gap:var(--space-3);flex-direction:column;display:flex}.status-item{align-items:center;gap:var(--space-3);display:flex}.status-item-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-inline-value{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);text-align:right;min-width:52px}#save-button-right{background:var(--color-primary);color:#fff;cursor:pointer;transition:background var(--transition-fast);border:none;border-radius:999px;padding:10px 28px;font-size:.92rem;font-weight:500}#save-button-right:hover{background:var(--color-primary-hover)}.theme-toggle{position:relative}.theme-toggle-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface-2);width:30px;height:30px;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-sm);transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;display:flex}.theme-toggle-btn:hover{color:var(--color-text);border-color:var(--color-border)}.theme-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:100;flex-direction:column;gap:2px;min-width:120px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.theme-dropdown-item{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;font-size:var(--text-sm);text-align:left;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:6px 10px;display:flex}.theme-dropdown-item:hover{background:var(--color-surface-2);color:var(--color-text)}.theme-dropdown-item.active{color:var(--color-primary);background:var(--color-primary-dim)}.auth-theme-corner{top:var(--space-5);right:var(--space-5);z-index:2;position:absolute}#alert-portal{z-index:9999;pointer-events:none;flex-direction:column;gap:.6rem;width:340px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast-alert{pointer-events:all;-webkit-backdrop-filter:blur(10px);border-radius:14px;align-items:flex-start;gap:.75rem;width:100%;padding:.875rem 1rem;font-family:Poppins,sans-serif;font-size:.875rem;line-height:1.45;animation:.22s toast-slide-in;display:flex;box-shadow:0 8px 32px #0000002e}.toast-alert--error{color:#fff;background-color:#780a0ae0;border:1px solid #dc3c3c59}.toast-alert--success{color:#fff;background-color:#0a5a0ae0;border:1px solid #3cb43c59}.toast-alert__text{color:inherit;flex:1;margin:0}.toast-alert__dismiss{color:#ffffffb3;cursor:pointer;background:0 0;border:none;flex-shrink:0;margin-top:-1px;padding:0;font-size:1.25rem;line-height:1;transition:color .15s}.toast-alert__dismiss:hover{color:#fff}@keyframes toast-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.confirm-dialog-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog-box{background:var(--color-surface);border:1.5px solid var(--color-border);box-shadow:var(--shadow-lg);text-align:center;border-radius:18px;width:100%;max-width:400px;padding:36px 40px 32px}.confirm-dialog-icon-wrap{background:#d9b96d26;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex}.confirm-dialog-icon-wrap i{color:var(--color-accent);font-size:1.6rem}.confirm-dialog-title{color:var(--color-text);margin:0 0 8px;font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600}.confirm-dialog-message{color:var(--color-text-secondary);margin:0 0 28px;font-family:Poppins,sans-serif;font-size:.92rem;line-height:1.5}.confirm-dialog-buttons{justify-content:center;gap:10px;display:flex}.confirm-dialog-cancel-btn{border:1.5px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:999px;padding:10px 28px;font-family:Poppins,sans-serif;font-size:.92rem;font-weight:500;transition:background .15s}.confirm-dialog-cancel-btn:hover{background:var(--color-surface-2)}.loading-overlay{z-index:9999;background:#0000000d;justify-content:center;align-items:center;animation:.35s forwards overlay-fade-in;display:flex;position:fixed;inset:0}.loading-overlay--out{animation:.35s forwards overlay-fade-out}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes overlay-fade-out{0%{opacity:1}to{opacity:0}}.loading-overlay-text{letter-spacing:.18em;text-transform:uppercase;color:var(--color-primary);text-shadow:0 0 12px #0641f373,0 0 32px #0641f340;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;animation:1.5s ease-in-out infinite loading-pulse}@keyframes loading-pulse{0%{opacity:.65;text-shadow:0 0 8px #0641f359,0 0 24px #0641f32e}50%{opacity:1;text-shadow:0 0 16px #0641f399,0 0 48px #0641f359}to{opacity:.65;text-shadow:0 0 8px #0641f359,0 0 24px #0641f32e}}.legacy-form{gap:var(--space-5);flex-direction:column;display:flex}.form-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5)}.form-section .section-title{margin:0 0 var(--space-3) 0;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.8rem;font-weight:700}.form-row{gap:var(--space-3);flex-wrap:wrap;align-items:flex-start;display:flex}.field-group{flex-direction:column;flex:160px;gap:4px;min-width:120px;display:flex}.field-group label{color:var(--color-text-muted);font-size:.78rem;font-weight:500}.field-group.fg-wide{flex:2 260px}.field-group.fg-narrow{flex:0 110px}.form-actions{align-items:center;gap:var(--space-3);padding-top:var(--space-2);display:flex}.taxon-selected{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-3) var(--space-4);flex-direction:column;gap:4px;display:flex}.taxon-selected-name{font-size:1rem}.taxon-info-row{gap:var(--space-3);color:var(--color-text-secondary);padding:var(--space-2) 0;flex-wrap:wrap;font-size:.82rem;display:flex}.typeahead-dropdown{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:1000;max-height:280px;margin:0;padding:4px 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.typeahead-dropdown li{padding:var(--space-2) var(--space-3);cursor:pointer;font-size:.9rem}.typeahead-dropdown li:hover{background:var(--color-surface-3)}.flag-grid{gap:var(--space-2);flex-direction:column;display:flex}.flag-row{gap:var(--space-4);flex-wrap:wrap;display:flex}.flag-item{align-items:center;gap:var(--space-2);font-size:.88rem;display:flex}.flag-label{color:var(--color-text-secondary);text-align:right;min-width:100px}.flag-item label{cursor:pointer;align-items:center;gap:4px;display:flex}.image-uploader{gap:var(--space-3);flex-direction:column;display:flex}.image-preview-row{gap:var(--space-2);flex-wrap:wrap;display:flex}.image-preview-thumb{border-radius:var(--radius);border:2px solid var(--color-border);width:80px;height:80px;position:relative;overflow:hidden}.image-preview-thumb.is-primary{border-color:var(--color-primary)}.image-preview-thumb img{object-fit:cover;width:100%;height:100%}.primary-badge{background:var(--color-primary);color:#fff;text-align:center;padding:1px 0;font-size:.65rem;position:absolute;bottom:0;left:0;right:0}.upload-drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;cursor:pointer;color:var(--color-text-muted);font-size:.9rem;transition:border-color .15s,background .15s}.upload-drop-zone:hover{border-color:var(--color-primary);background:var(--color-primary-dim)}.typeahead-dropdown li.highlighted{background:var(--color-surface-3)}.wizard-hint{color:var(--color-text-muted);margin-top:-8px;font-size:.78rem}.flag-wizard-list{gap:var(--space-2);flex-direction:column;max-width:380px;display:flex}.flag-wizard-row{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-1) 0;border-bottom:1px solid var(--color-border-subtle);display:flex}.flag-wizard-label{color:var(--color-text);text-transform:capitalize;min-width:120px;font-size:.9rem}.flag-pill-group{border:1px solid var(--color-border);border-radius:var(--radius-full);display:flex;overflow:hidden}.flag-pill{color:var(--color-text-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:none;padding:4px 16px;font-size:.82rem;font-weight:600;transition:background .1s,color .1s}.flag-pill:hover{background:var(--color-surface-3);color:var(--color-text)}.flag-pill.active-yes{color:#34d399;background:#10b98133}.flag-pill.active-no{color:#f87171;background:#ef444426}.map-picker{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);flex-direction:column;display:flex;overflow:hidden}.map-picker-map{position:relative}.map-picker-map .leaflet-container{z-index:0}.map-picker-geocoding{z-index:900;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);pointer-events:none;padding:4px 12px;font-size:.8rem;position:absolute;top:8px;left:50%;transform:translate(-50%)}.map-picker-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);gap:var(--space-2);flex-direction:column;display:flex}.map-picker-input-row{align-items:center;gap:var(--space-2);display:flex}.map-picker-coord-label{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem;font-weight:500}.map-picker-clear{white-space:nowrap;font-size:.8rem}.map-picker-coords-display{gap:var(--space-4);font-size:.8rem;font-family:var(--font-mono,monospace);color:var(--color-text-secondary);display:flex}.map-picker-hint{color:var(--color-text-muted);margin:0;font-size:.75rem}.map-picker-loading{padding:var(--space-5);text-align:center;color:var(--color-text-muted);font-size:.9rem}.map-picker-btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);width:34px;height:34px;color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:background .15s,color .15s;display:flex}.map-picker-btn:hover{background:var(--color-surface-3);color:var(--color-primary)}.map-modal-overlay{z-index:3000;-webkit-backdrop-filter:blur(4px);padding:var(--space-4);background:#0f172a8c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.map-modal-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:min(700px,95vw);max-height:90vh;display:flex;overflow:hidden}.map-modal-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.map-modal-header h3{margin:0;font-size:1rem;font-weight:600}.map-modal-body{flex:1;min-height:0;overflow:hidden}.map-modal-body .map-picker{border:none;border-radius:0;height:100%}.map-modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);flex-shrink:0;display:flex}.modal-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:0 4px;font-size:1.4rem;line-height:1}.modal-close:hover{color:var(--color-text)}.image-drop-zone{justify-content:center;align-items:center;gap:var(--space-2);border:2px dashed var(--color-border);border-radius:var(--radius);padding:var(--space-5);margin-bottom:var(--space-4);cursor:default;flex-direction:column;min-height:80px;transition:border-color .15s,background .15s;display:flex}.image-drop-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-dim)}.image-gallery-grid{gap:var(--space-3);flex-wrap:wrap;display:flex}.image-card{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);flex-direction:column;align-items:center;gap:4px;width:140px;padding:6px;transition:border-color .15s;display:flex}.image-card-primary{border-color:var(--color-primary)}.image-card-thumb{cursor:pointer;border-radius:calc(var(--radius) - 2px);background:var(--color-surface-3);width:128px;height:128px;position:relative;overflow:hidden}.image-card-thumb img{object-fit:cover;width:100%;height:100%;transition:opacity .15s;display:block}.image-card-thumb:hover img{opacity:.85}.image-primary-badge{background:var(--color-primary);color:#fff;letter-spacing:.04em;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600;position:absolute;bottom:4px;left:4px}.image-card-controls{flex-wrap:wrap;align-items:center;gap:1px;width:100%;display:flex}.image-card-controls .btn{font-size:var(--text-xs);min-width:0;padding:3px 5px}.mode-toggle{gap:4px;display:flex}.wizard-container{gap:var(--space-5);max-width:640px;padding:var(--space-6) 0;flex-direction:column;margin:0 auto;display:flex;position:relative}.wizard-progress{background:var(--color-border);border-radius:2px;height:4px;overflow:hidden}.wizard-progress-bar{background:var(--color-primary);border-radius:2px;height:100%;transition:width .3s}.wizard-step-counter{color:var(--color-text-muted);text-align:right;font-size:.8rem}.wizard-content{gap:var(--space-4);flex-direction:column;min-height:160px;display:flex}.wizard-step-label{color:var(--color-text);font-size:1.5rem;font-weight:700}.wizard-field{width:100%;padding:var(--space-3) var(--space-3)!important;font-size:1.1rem!important}.wizard-nav{justify-content:space-between;align-items:center;display:flex}.wizard-legend{bottom:var(--space-4);right:var(--space-5);gap:var(--space-3);color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-sm);font-size:.78rem;display:flex;position:fixed}.wizard-legend span:before{content:"";background:var(--color-border);width:1px;height:.8em;margin-right:var(--space-3);vertical-align:middle;display:inline-block}.wizard-legend span:first-child:before{display:none}.bundle-wizard-grid{gap:var(--space-3);flex-wrap:wrap;display:flex}.btn-ghost{border:1px solid var(--color-border);color:var(--color-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius);cursor:pointer;background:0 0;font-size:.9rem;transition:background .15s}.btn-ghost:hover{background:var(--color-surface-3)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.alert-success{color:#34d399;border-radius:var(--radius);padding:var(--space-3) var(--space-4);background:#10b9811a;border:1px solid #10b98166;font-size:.9rem}[data-theme=light] .alert-success{color:#065f46}@keyframes skeleton-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg, var(--color-surface-2) 25%, var(--color-surface-3) 50%, var(--color-surface-2) 75%);border-radius:var(--radius-sm);background-size:1200px 100%;animation:1.6s ease-in-out infinite skeleton-shimmer}.static-page-content img{border-radius:var(--radius);max-width:100%;height:auto;margin:var(--space-6) auto;display:block}.static-page-content p{margin:0 0 var(--space-4)}.static-page-content h2,.static-page-content h3{color:var(--color-text);margin:var(--space-6) 0 var(--space-3)}.static-page-content a{color:var(--color-primary);text-decoration:underline}.static-page-content a:hover{color:var(--color-primary-hover)}@media (width<=1280px){:root{--sidebar-width:200px}.page-content{padding:var(--space-6) var(--space-6)}}@media (width<=1024px){:root{--sidebar-width:0px}.sidebar{transition:transform var(--transition-slow);transform:translate(-100%)}.sidebar.open{width:220px;box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{margin-left:0}.page-content{padding:var(--space-6) var(--space-4)}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header-actions{justify-content:flex-start;width:100%}}@media (width<=768px){h1,h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}.page-content{padding:var(--space-4) var(--space-3)}.card{padding:var(--space-4);border-radius:var(--radius)}.card-grid{grid-template-columns:1fr}thead th,tbody td{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-group-mobile{flex-direction:column;width:100%}.btn-group-mobile .btn{justify-content:center;width:100%}}@media (width<=480px){.app-header{padding:0 var(--space-3)}.page-content{padding:var(--space-3) var(--space-2)}}
