@import "https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--font-heading:"Hanken Grotesk", -apple-system, sans-serif;--font-body:"Hanken Grotesk", -apple-system, sans-serif;--font-mono:"IBM Plex Mono", "Courier New", monospace;--bg-main:oklch(97.2% .006 85);--bg-sidebar:oklch(22.5% .013 75);--bg-header:oklch(98.5% .005 85);--bg-card:white;--bg-card-hover:oklch(98% .004 85);--bg-input:oklch(98.5% .004 85);--bg-sidebar-item:oklch(32% .015 75);--border-color:oklch(91% .008 80);--border-focus:oklch(50% .07 195);--color-primary:oklch(50% .07 195);--color-primary-hover:oklch(45% .07 195);--color-secondary:oklch(50% .07 195);--color-accent:oklch(74% .13 80);--color-danger:oklch(58% .19 27);--color-quarantine:oklch(52% .15 305);--text-main:oklch(26% .012 70);--text-muted:oklch(55% .01 70);--text-inverse:white;--sidebar-text:oklch(92% .008 80);--sidebar-muted:oklch(65% .01 80);--badge-healthy-bg:oklch(95.5% .035 150);--badge-healthy-text:oklch(43% .1 150);--badge-monitoring-bg:oklch(96% .05 85);--badge-monitoring-text:oklch(50% .1 70);--badge-ill-bg:oklch(95.5% .04 30);--badge-ill-text:oklch(50% .17 27);--badge-quarantine-bg:oklch(95.5% .04 305);--badge-quarantine-text:oklch(46% .13 305);--shadow-sm:0 1px 3px oklch(50% .02 80/.08);--shadow-md:0 4px 16px oklch(50% .02 80/.12);--shadow-lg:0 8px 32px oklch(50% .02 80/.16);--glass-bg:white;--glass-border:oklch(91% .008 80);--radius-sm:9px;--radius-md:13px;--radius-lg:15px;--transition-fast:.12s ease;--transition-normal:.2s cubic-bezier(.4, 0, .2, 1)}body.light-theme{--bg-main:oklch(97.2% .006 85);--bg-sidebar:white;--bg-header:white;--bg-card:white;--bg-card-hover:oklch(97% .004 85);--bg-input:oklch(98.5% .004 85);--bg-sidebar-item:oklch(94% .008 80);--border-color:oklch(88% .008 80);--border-focus:oklch(50% .07 195);--text-main:oklch(26% .012 70);--text-muted:oklch(55% .01 70);--sidebar-text:oklch(26% .012 70);--sidebar-muted:oklch(55% .01 70);--glass-bg:white;--glass-border:oklch(88% .008 80)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}*{scrollbar-width:thin;scrollbar-color:oklch(80% .008 80) transparent}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:oklch(82% .008 80);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:oklch(70% .01 80)}body{font-family:var(--font-body);background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:600;line-height:1.25}button,input,textarea,select{color:inherit;font-family:inherit}a{color:var(--color-primary);text-decoration:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulseDot{0%{box-shadow:0 0 oklch(60% .13 150/.5)}70%{box-shadow:0 0 0 6px oklch(60% .13 150/0)}to{box-shadow:0 0 oklch(60% .13 150/0)}}@keyframes pulseBorder{0%{box-shadow:0 0 oklch(50% .07 195/.4)}70%{box-shadow:0 0 0 6px oklch(50% .07 195/0)}to{box-shadow:0 0 oklch(50% .07 195/0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes floatGlow{0%,to{opacity:.6;transform:translateY(0)scale(1)}50%{opacity:1;transform:translateY(-20px)scale(1.05)}}.animate-fade{animation:fadeIn var(--transition-normal) both}.animate-slide{animation:slideIn var(--transition-normal) both}.animate-spin{animation:1s linear infinite spin}.app-layout{background:var(--bg-main);height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg-sidebar);width:236px;color:var(--sidebar-text);flex-direction:column;flex-shrink:0;padding:22px 0;display:flex;overflow-y:auto}body.light-theme .sidebar{border-right:1px solid var(--border-color)}.sidebar-brand{border-bottom:1px solid oklch(30% .013 75);align-items:center;gap:11px;margin-bottom:14px;padding:0 22px 22px;display:flex}body.light-theme .sidebar-brand{border-bottom-color:var(--border-color)}.sidebar-brand-icon{color:#fff;width:34px;height:34px;font-size:17px;font-weight:800;font-family:var(--font-heading);letter-spacing:-.01em;background:oklch(55% .07 195);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-name{letter-spacing:-.01em;color:var(--sidebar-text);font-size:15px;font-weight:700;line-height:1.2}.sidebar-brand-sub{color:var(--sidebar-muted);font-size:11px;font-family:var(--font-mono);margin-top:1px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:0 14px;display:flex}.sidebar-nav-item{color:oklch(72% .01 80);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);-webkit-user-select:none;user-select:none;text-align:left;background:0 0;border:none;border-radius:9px;justify-content:space-between;align-items:center;width:100%;padding:9px 14px;font-size:14px;font-weight:500;display:flex}.sidebar-nav-item:hover{color:var(--sidebar-text);background:oklch(28% .013 75)}body.light-theme .sidebar-nav-item:hover{color:var(--text-main);background:oklch(94% .006 80)}.sidebar-nav-item.active{background:var(--bg-sidebar-item);color:#fff;font-weight:600}body.light-theme .sidebar-nav-item.active{background:var(--color-primary);color:#fff}.sidebar-nav-item .nav-badge{color:#fff;font-size:10px;font-weight:700;font-family:var(--font-mono);background:oklch(58% .19 27);border-radius:20px;padding:1px 6px}.sidebar-footer{border-top:1px solid oklch(30% .013 75);margin-top:16px;padding:16px 22px 0}body.light-theme .sidebar-footer{border-top-color:var(--border-color)}.sidebar-status-card{background:oklch(28% .013 75);border-radius:11px;flex-direction:column;gap:9px;padding:13px 14px;display:flex}body.light-theme .sidebar-status-card{border:1px solid var(--border-color);background:oklch(96% .005 80)}.sidebar-user{align-items:center;gap:10px;padding:14px 2px 0;display:flex}.sidebar-user-avatar{color:#fff;background:oklch(50% .06 160);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border-color);background:var(--bg-header);z-index:50;height:68px;box-shadow:var(--shadow-sm);flex-shrink:0;align-items:center;gap:18px;padding:0 28px;display:flex}.topbar-search{flex:1;max-width:420px;position:relative}.topbar-search input{border:1px solid var(--border-color);background:var(--bg-input);width:100%;height:40px;color:var(--text-main);font-size:13.5px;font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:10px;outline:none;padding:0 14px 0 36px}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-search input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px oklch(50% .07 195/.12)}.topbar-search-icon{color:var(--text-muted);pointer-events:none;align-items:center;font-size:14px;display:flex;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.topbar-right{align-items:center;gap:14px;margin-left:auto;display:flex}.topbar-datetime{text-align:right;line-height:1.25}.topbar-datetime-day{color:var(--text-main);font-size:13px;font-weight:600}.topbar-datetime-time{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.view-body{flex:1;overflow-y:auto}.view-inner{padding:26px 28px 60px}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-panel{padding:18px}.card-title{color:var(--text-main);justify-content:space-between;align-items:center;margin-bottom:13px;font-size:14px;font-weight:700;display:flex}.card-title h3{letter-spacing:-.01em;font-size:14px;font-weight:700}.stat-grid{grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:22px;display:grid}.dashboard-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}.stat-card{border:1px solid var(--border-color);transition:box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fff;border-radius:13px;padding:15px 16px}.stat-card:hover{box-shadow:var(--shadow-md);border-color:oklch(83% .01 80)}.stat-label{color:var(--text-muted);font-size:12px;font-weight:500;line-height:1.3}.stat-value{font-size:27px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em;color:var(--text-main);margin-top:5px;line-height:1.1}.stat-card-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stat-card-primary .stat-label{color:oklch(85% .04 195)}.stat-card-primary .stat-value{color:#fff}.stat-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-primary);background:oklch(95.5% .035 195);justify-content:center;align-items:center;margin-bottom:10px;display:flex}.stat-icon.secondary{color:oklch(50% .1 220);background:oklch(95.5% .04 220)}.stat-icon.accent{background:var(--badge-monitoring-bg);color:var(--badge-monitoring-text)}.stat-icon.danger{background:var(--badge-ill-bg);color:var(--badge-ill-text)}.panel-grid{grid-template-columns:1.35fr 1fr;gap:18px;display:grid}.attention-strip{border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;align-items:center;gap:14px;margin-bottom:18px;padding:14px 18px;display:flex}.attention-strip-label{text-transform:uppercase;letter-spacing:.07em;color:var(--badge-ill-text);white-space:nowrap;align-items:center;gap:8px;font-size:12px;font-weight:700;display:flex}.attention-dot{background:oklch(60% .13 150);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-out infinite pulseDot}.attention-dot.red{background:oklch(58% .19 27);animation-name:pulseDot}.attention-cards-scroll{flex:1;gap:10px;padding-bottom:2px;display:flex;overflow-x:auto}.attention-card{background:var(--badge-ill-bg);border-radius:var(--radius-md);border:1px solid oklch(88% .04 30);flex-shrink:0;min-width:170px;padding:9px 14px}.attention-card-id{font-family:var(--font-mono);color:var(--badge-ill-text);font-size:11px;font-weight:600}.attention-card-name{color:var(--text-main);margin:2px 0 1px;font-size:13px;font-weight:600}.attention-card-loc{color:var(--text-muted);font-size:11px}.filter-chips{flex-wrap:wrap;gap:7px;margin-bottom:16px;display:flex}.filter-chip{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:20px;padding:5px 13px;font-size:13px;font-weight:500}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.view-toggle{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;display:flex;overflow:hidden}.view-toggle-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:5px 14px;font-size:13px;font-weight:500}.view-toggle-btn:hover{color:var(--text-main);background:var(--bg-card-hover)}.view-toggle-btn.active{background:var(--color-primary);color:#fff;font-weight:600}.bird-cards-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:4px;display:grid}.bird-card{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fff;padding:15px 16px}.bird-card:hover{box-shadow:var(--shadow-md);border-color:oklch(80% .01 80)}.bird-card-id{font-family:var(--font-mono);color:var(--color-primary);margin-bottom:3px;font-size:11px;font-weight:600}.bird-card-name{color:var(--text-main);margin-bottom:2px;font-size:15px;font-weight:700}.bird-card-species{color:var(--text-muted);margin-bottom:10px;font-size:12px}.bird-card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;display:flex}.form-group{margin-bottom:18px}.form-row{grid-template-columns:1fr 1fr;gap:18px;display:grid}.form-row-three{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}label{color:var(--text-muted);letter-spacing:.01em;margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],select,textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-main);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);font-size:14px;font-family:var(--font-body);outline:none;padding:10px 13px}input[type=text]:focus,input[type=number]:focus,input[type=date]:focus,input[type=email]:focus,input[type=password]:focus,select:focus,textarea:focus{border-color:var(--border-focus);background:#fff;box-shadow:0 0 0 3px oklch(50% .07 195/.12)}select{cursor:pointer}textarea{resize:vertical;min-height:96px;line-height:1.5}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);font-size:14px;font-weight:600;font-family:var(--font-body);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:7px;padding:9px 18px;line-height:1;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{border-color:var(--border-color);color:var(--text-main);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:oklch(80% .01 80)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:oklch(53% .19 27);border-color:oklch(53% .19 27)}.btn-icon-only{border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;color:var(--text-muted);transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:#fff;justify-content:center;align-items:center;padding:7px;display:inline-flex}.btn-icon-only:hover{color:var(--text-main);border-color:var(--color-primary);background:var(--bg-card-hover)}.badge{letter-spacing:.01em;border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-success{background:var(--badge-healthy-bg);color:var(--badge-healthy-text)}.badge-warning{background:var(--badge-monitoring-bg);color:var(--badge-monitoring-text)}.badge-danger{background:var(--badge-ill-bg);color:var(--badge-ill-text)}.badge-purple{background:var(--badge-quarantine-bg);color:var(--badge-quarantine-text)}.badge-info{color:oklch(40% .08 195);background:oklch(95.5% .04 195)}.badge-secondary{color:var(--text-muted);background:oklch(95% .004 80)}.status-pill{text-transform:uppercase;letter-spacing:.05em;border:1px solid;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.status-pill-healthy{background:var(--badge-healthy-bg);color:var(--badge-healthy-text);border-color:oklch(87% .05 150)}.status-pill-monitoring{background:var(--badge-monitoring-bg);color:var(--badge-monitoring-text);border-color:oklch(88% .07 80)}.status-pill-ill{background:var(--badge-ill-bg);color:var(--badge-ill-text);border-color:oklch(88% .06 30)}.status-pill-quarantine{background:var(--badge-quarantine-bg);color:var(--badge-quarantine-text);border-color:oklch(88% .06 305)}.status-pill-live{background:var(--badge-healthy-bg);color:var(--badge-healthy-text);border-color:oklch(87% .05 150)}.status-pill-dot{background:oklch(60% .13 150);border-radius:50%;width:6px;height:6px;animation:2s ease-out infinite pulseDot}.data-table-wrap{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:14px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:12px 15px}.data-table th{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);background:oklch(97.5% .004 85);font-size:11px;font-weight:700}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr:last-child td{border-bottom:none}.search-bar{gap:10px;margin-bottom:18px;display:flex}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--border-color);width:2px;position:absolute;top:8px;bottom:8px;left:5px}.timeline-item{margin-bottom:22px;position:relative}.timeline-dot{background:var(--border-color);border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;top:5px;left:-24px}.timeline-dot.active{background:var(--color-primary);box-shadow:0 0 0 3px oklch(50% .07 195/.2)}.timeline-header{justify-content:space-between;align-items:flex-start;margin-bottom:5px;display:flex}.timeline-title{color:var(--text-main);font-size:14px;font-weight:600}.timeline-meta{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.timeline-body{color:var(--text-muted);font-size:13px;line-height:1.55}.alert{border-radius:var(--radius-sm);border-left:4px solid;align-items:flex-start;gap:11px;margin-bottom:16px;padding:13px 16px;font-size:13.5px;display:flex}.alert-success{background:var(--badge-healthy-bg);color:var(--badge-healthy-text);border-color:oklch(60% .13 150)}.alert-warning{background:var(--badge-monitoring-bg);border-color:var(--color-accent);color:var(--badge-monitoring-text)}.alert-danger{background:var(--badge-ill-bg);border-color:var(--color-danger);color:var(--badge-ill-text)}.photo-uploader{border:2px dashed var(--border-color);border-radius:var(--radius-sm);text-align:center;cursor:pointer;color:var(--text-muted);transition:border-color var(--transition-fast), color var(--transition-fast);background:var(--bg-input);padding:24px}.photo-uploader:hover{border-color:var(--color-primary);color:var(--color-primary)}.photo-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px;display:grid}.photo-preview{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);position:relative;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%}.kanban-counter-track{flex-wrap:wrap;justify-content:space-between;align-items:stretch;gap:10px;margin-top:14px;display:flex}.kanban-stage-card{border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;min-width:110px;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fff;flex:1;padding:14px 12px}.kanban-stage-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.kanban-stage-name{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:7px;font-size:11px;font-weight:700}.kanban-stage-count{font-size:28px;font-weight:800;font-family:var(--font-mono);color:var(--color-primary);letter-spacing:-.02em}.kanban-arrow{color:var(--text-muted);justify-content:center;align-items:center;font-size:18px;display:flex}.login-shell{width:100%;min-height:100vh;display:flex;overflow:hidden}.login-brand-panel{color:oklch(92% .008 80);background:linear-gradient(160deg,oklch(22% .025 235) 0%,oklch(18% .02 240) 55%,oklch(20% .03 180) 100%);border-right:1px solid oklch(30% .02 235/.4);flex-direction:column;flex:0 0 44%;justify-content:space-between;padding:56px 52px;display:flex;position:relative;overflow:hidden}.login-brand-panel:before{content:"";pointer-events:none;background:radial-gradient(circle,oklch(50% .07 195/.2) 0%,#0000 65%);width:480px;height:480px;animation:8s ease-in-out infinite floatGlow;position:absolute;top:-120px;right:-120px}.login-brand-panel:after{content:"";pointer-events:none;background:radial-gradient(circle,oklch(60% .13 150/.13) 0%,#0000 65%);width:360px;height:360px;animation:10s ease-in-out infinite reverse floatGlow;position:absolute;bottom:-100px;left:-80px}.login-brand-body{z-index:1;position:relative}.login-brand-icon{color:#fff;width:64px;height:64px;font-size:26px;font-weight:800;font-family:var(--font-heading);background:oklch(55% .07 195);border-radius:16px;justify-content:center;align-items:center;margin-bottom:28px;display:flex;box-shadow:0 8px 28px oklch(50% .07 195/.4)}.login-brand-panel h1{color:#fff;letter-spacing:-.03em;margin-bottom:8px;font-size:2.1rem;font-weight:800}.login-brand-tagline{color:oklch(75% .01 80);max-width:300px;margin-bottom:44px;font-size:.88rem;line-height:1.55}.login-features{flex-direction:column;gap:14px;display:flex}.login-feature-item{color:oklch(85% .008 80);align-items:center;gap:11px;font-size:.875rem;font-weight:500;display:flex}.login-feature-item svg{color:oklch(60% .13 150);flex-shrink:0}.login-brand-footer{z-index:1;color:oklch(60% .01 80/.7);letter-spacing:.06em;text-transform:uppercase;border-top:1px solid oklch(40% .02 80/.3);align-items:center;gap:8px;padding-top:28px;font-size:.7rem;font-weight:600;display:flex;position:relative}.login-form-panel{background:var(--bg-main);flex:1;justify-content:center;align-items:center;padding:48px 40px;display:flex}.login-form-inner{width:100%;max-width:400px}.login-form-inner h2{letter-spacing:-.02em;color:var(--text-main);margin-bottom:5px;font-size:1.55rem;font-weight:700}.login-form-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:.875rem}.input-icon-wrapper{position:relative}.input-icon-wrapper input{padding-right:44px}.input-toggle-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:11px;transform:translateY(-50%)}.input-toggle-btn:hover{color:var(--text-main)}.dev-hub-section{border-top:1px solid var(--border-color);margin-top:26px;padding-top:18px}.dev-hub-toggle{cursor:pointer;width:100%;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;transition:color var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;padding:4px 0;font-size:.7rem;font-weight:700;display:flex}.dev-hub-toggle:hover{color:var(--color-primary)}.dev-hub-grid{grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;display:grid}.dev-quick-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:#fff;padding:8px 10px;font-size:.72rem;font-weight:600;line-height:1.4}.dev-quick-btn:hover{border-color:var(--color-primary);color:var(--text-main);background:var(--bg-card-hover)}.dev-quick-btn .role-tag{color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-size:.65rem;font-weight:700;display:block}.app-container,.app-container.navbar-only{flex-direction:column;min-height:100vh;display:flex}.app-container.navbar-only .main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.navbar{border-bottom:1px solid var(--border-color);background:var(--bg-header);z-index:100;box-shadow:var(--shadow-sm);align-items:center;gap:16px;padding:14px 28px;display:flex;position:sticky;top:0}.navbar-nav{align-items:center;gap:6px;display:flex}.navbar-tab-item{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast);font-size:14px;font-weight:500;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:7px;padding:8px 14px;display:flex}.navbar-tab-item:hover{color:var(--text-main);background:var(--bg-card-hover)}.navbar-tab-item.active{color:var(--color-primary);background:oklch(95.5% .04 195);font-weight:700}.navbar-user-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.navbar-user-block{border:1px solid var(--border-color);transition:border-color var(--transition-fast);background:#fff;border-radius:999px;align-items:center;gap:9px;padding:5px 11px 5px 5px;display:flex}.navbar-user-block:hover{border-color:var(--color-primary)}.navbar-user-name{color:var(--text-main);white-space:nowrap;font-size:13px;font-weight:600}.navbar-user-role{color:var(--text-muted);font-size:11px;line-height:1}.brand-icon{background:var(--color-primary);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;font-weight:800;display:flex}.page-header-strip{border-bottom:1px solid var(--border-color);background:var(--bg-header);justify-content:space-between;align-items:center;padding:18px 28px;display:flex}.page-header-title{color:var(--text-main);font-size:1.25rem;font-weight:700}.page-header-desc{color:var(--text-muted);margin-top:2px;font-size:12.5px}.main-content{flex-direction:column;flex:1;display:flex}.simulator-panel{border-radius:var(--radius-md);background:oklch(96.5% .025 195);border:1px solid oklch(88% .04 195)}.sim-time-badge{font-family:var(--font-mono);border:1px solid var(--border-color);color:var(--color-primary);background:#fff;border-radius:6px;padding:4px 12px;font-size:1.15rem;font-weight:700}.user-badge{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;align-items:center;gap:7px;padding:4px 10px;font-size:12px;font-weight:500;display:flex}.badge-dot{border-radius:50%;width:8px;height:8px}.custom-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.custom-modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);width:95%;max-width:500px;box-shadow:var(--shadow-lg);color:var(--text-main);max-height:90vh;padding:28px;animation:.2s slideUp;overflow-y:auto}.custom-modal-content-lg{max-width:700px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
