@import "https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;500;600;700&display=swap";:root{--bg-primary:#f0f2f5;--bg-white:#fff;--bg-sidebar:#fff;--text-primary:#1a1a2e;--text-secondary:#4a4a68;--text-muted:#8c8ca1;--accent:#2c5ea0;--accent-dark:#1e4478;--accent-light:#e8f0fe;--accent-hover:#234b80;--success:#28a745;--warning:#e6a817;--danger:#dc3545;--border:#dde1e7;--border-light:#e8ecf1;--sidebar-width:220px;--header-height:52px;--section-header:#2c5ea0}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:"Source Sans 3",-apple-system,BlinkMacSystemFont,sans-serif}a{color:var(--accent);text-decoration:none}button{cursor:pointer;border:none;font-family:inherit;font-size:.875rem}input,select,textarea{font-family:inherit;font-size:.875rem}.top-header{height:var(--header-height);background:var(--accent-dark);z-index:200;justify-content:space-between;align-items:center;padding:0 1.25rem;display:flex;position:fixed;top:0;left:0;right:0}.top-header-brand{color:#fff;align-items:center;gap:.6rem;display:flex}.top-header-brand-icon{background:#ffffff26;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.top-header-brand h1{letter-spacing:.02em;font-size:1rem;font-weight:700}.top-header-brand span{opacity:.7;font-size:.65rem;font-weight:400;display:block}.top-header-right{color:#fff;align-items:center;gap:1rem;font-size:.85rem;display:flex}.top-header-user{align-items:center;gap:.5rem;display:flex}.top-header-user strong{color:#fbbf24}.top-header-logout{color:#fff;background:#ffffff1f;border-radius:4px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.8rem;transition:background .15s;display:flex}.top-header-logout:hover{background:#ffffff38}.hamburger-btn{color:#fff;background:0 0;padding:.25rem;display:none}.app-layout{padding-top:var(--header-height);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);top:var(--header-height);z-index:100;transition:transform .2s;position:fixed;bottom:0;left:0;overflow-y:auto}.sidebar-nav{padding:.5rem 0}.sidebar-link{color:var(--text-secondary);align-items:center;gap:.6rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;transition:all .12s;display:flex}.sidebar-link:hover{background:var(--accent-light);color:var(--accent-dark)}.sidebar-link.active{background:var(--accent-light);color:var(--accent-dark);font-weight:600}.sidebar-link .icon{width:20px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-link.active .icon{color:var(--accent-dark)}.sidebar-section{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:1rem 1rem .3rem;font-size:.65rem;font-weight:700}.sidebar-section:first-child{padding-top:.5rem}.sidebar-overlay{z-index:99;background:#0000004d;display:none;position:fixed;inset:0}.main-content{margin-left:var(--sidebar-width);min-height:calc(100vh - var(--header-height));flex:1;padding-bottom:3rem}.page-title-bar{padding:1.25rem 1.5rem .75rem}.page-title-bar h2{color:var(--text-primary);font-size:1.5rem;font-weight:700}.page-title-bar p{color:var(--text-muted);margin-top:.15rem;font-size:.85rem}.page-body{padding:0 1.5rem 1.5rem}.section-block{background:var(--bg-white);border:1px solid var(--border);border-radius:6px;margin-bottom:1.25rem;overflow:hidden}.section-header{background:var(--section-header);color:#fff;justify-content:space-between;align-items:center;padding:.6rem 1rem;font-size:.9rem;font-weight:600;display:flex}.section-header .btn{color:#fff;background:#ffffff26;font-size:.78rem}.section-header .btn:hover{background:#ffffff40}.section-body{padding:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.25rem;display:grid}.stat-card{background:var(--bg-white);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem}.stat-card-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.35rem;font-size:.75rem;font-weight:500}.stat-card-value{color:var(--text-primary);font-size:1.75rem;font-weight:700}.stat-card-sub{color:var(--text-muted);margin-top:.15rem;font-size:.75rem}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--border);background:#f8f9fb;padding:.65rem 1rem;font-size:.75rem;font-weight:600}td{border-bottom:1px solid var(--border-light);color:var(--text-secondary);padding:.65rem 1rem;font-size:.85rem}tr:hover td{background:#f8f9fb}.badge{border-radius:4px;align-items:center;gap:.3rem;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-success{color:#1a7431;background:#e6f4ea}.badge-warning{color:#856404;background:#fef3cd}.badge-danger{color:#a71d2a;background:#fde8ea}.badge-muted{color:#6c757d;background:#ebedf0}.badge-info{background:var(--accent-light);color:var(--accent-dark)}.badge-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.badge-success .badge-dot{background:var(--success)}.badge-warning .badge-dot{background:var(--warning)}.badge-danger .badge-dot{background:var(--danger)}.badge-muted .badge-dot{background:#adb5bd}.btn{border-radius:4px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.85rem;font-weight:500;transition:all .12s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{color:var(--text-secondary);background:#e9ecef}.btn-secondary:hover{background:#dee2e6}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#c82333}.btn-sm{padding:.3rem .65rem;font-size:.78rem}.map-container{background:var(--bg-white);border:1px solid var(--border);border-radius:6px;margin-bottom:1.25rem;overflow:hidden}.map-placeholder-inner{height:320px;color:var(--text-muted);background-color:#e8ecf1;background-image:linear-gradient(#2c5ea008 1px,#0000 1px),linear-gradient(90deg,#2c5ea008 1px,#0000 1px);background-position:0 0;background-repeat:repeat;background-size:40px 40px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.map-dot{cursor:pointer;border:2px solid #fff;border-radius:50%;width:14px;height:14px;transition:transform .15s;position:absolute;box-shadow:0 1px 4px #0003}.map-dot:hover{transform:scale(1.4)}.map-dot.green{background:var(--success)}.map-dot.orange{background:var(--warning)}.map-dot.red{background:var(--danger)}.map-dot.gray{background:#adb5bd}.map-legend{border-top:1px solid var(--border);color:var(--text-muted);gap:1.25rem;padding:.6rem 1rem;font-size:.78rem;display:flex}.map-legend-item{align-items:center;gap:.35rem;display:flex}.map-legend-dot{border-radius:50%;width:8px;height:8px}.instruments-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.instrument-card{background:var(--bg-white);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:1rem 1.15rem;transition:all .15s}.instrument-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #2c5ea014}.instrument-card-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.instrument-card-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.instrument-card-type{color:var(--text-muted);font-size:.72rem;font-weight:500}.instrument-card-details{flex-direction:column;gap:.35rem;display:flex}.instrument-card-row{justify-content:space-between;font-size:.8rem;display:flex}.instrument-card-label{color:var(--text-muted)}.instrument-card-value{color:var(--text-secondary);font-weight:500}.notification-list{flex-direction:column;gap:.5rem;display:flex}.notification-item{background:var(--bg-white);border:1px solid var(--border);border-radius:6px;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;display:flex}.notification-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notification-icon.critical{color:var(--danger);background:#fde8ea}.notification-icon.warning{color:#b8860b;background:#fef3cd}.notification-icon.info{background:var(--accent-light);color:var(--accent)}.notification-icon.success{color:var(--success);background:#e6f4ea}.notification-body{flex:1}.notification-title{color:var(--text-primary);margin-bottom:.1rem;font-size:.85rem;font-weight:600}.notification-desc{color:var(--text-muted);font-size:.8rem}.notification-time{color:var(--text-muted);white-space:nowrap;margin-top:.2rem;font-size:.72rem}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:var(--bg-white);border:1px solid var(--border);border-radius:8px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 4px 24px #0000000f}.login-logo{text-align:center;margin-bottom:1.75rem}.login-logo .icon{background:var(--accent);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:.75rem;display:inline-flex}.login-logo h1{color:var(--text-primary);font-size:1.35rem;font-weight:700}.login-logo p{color:var(--text-muted);margin-top:.2rem;font-size:.85rem}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);margin-bottom:.3rem;font-size:.82rem;font-weight:600;display:block}.form-group input{border:1px solid var(--border);width:100%;color:var(--text-primary);background:#fff;border-radius:4px;outline:none;padding:.55rem .75rem;transition:border-color .15s}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2c5ea01f}.login-btn{background:var(--accent);color:#fff;border-radius:4px;width:100%;margin-top:.5rem;padding:.65rem;font-size:.9rem;font-weight:600;transition:background .15s}.login-btn:hover{background:var(--accent-hover)}.login-divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:1.25rem 0;font-size:.78rem;display:flex}.login-divider:before,.login-divider:after{content:"";border-top:1px solid var(--border);flex:1}.passkey-btn{border:1px solid var(--border);width:100%;color:var(--text-secondary);background:#fff;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;padding:.65rem;font-size:.88rem;font-weight:500;transition:all .15s;display:flex}.passkey-btn:hover{border-color:var(--accent);background:var(--accent-light)}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1.25rem;display:flex}.tab{color:var(--text-muted);background:0 0;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;transition:all .12s}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.alert-banner{color:#721c24;background:#fde8ea;border:1px solid #dc354540;border-radius:6px;align-items:center;gap:.6rem;margin-bottom:1rem;padding:.6rem 1rem;font-size:.85rem;display:flex}.alert-banner.warning{color:#856404;background:#fef3cd;border-color:#e6a81740}.confirm-overlay{z-index:500;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{background:#fff;border-radius:8px;width:100%;max-width:420px;padding:1.5rem;box-shadow:0 8px 32px #00000026}.confirm-dialog h3{margin-bottom:.5rem;font-size:1rem;font-weight:700}.confirm-dialog p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.85rem;line-height:1.5}.confirm-dialog-actions{justify-content:flex-end;gap:.5rem;display:flex}.connection-status{border-radius:4px;align-items:center;gap:.4rem;padding:.3rem .7rem;font-size:.8rem;display:inline-flex}.connection-status.connected{color:#1a7431;background:#e6f4ea}.connection-status.disconnected{color:#a71d2a;background:#fde8ea}.connection-status .pulse{border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-anim}.connection-status.connected .pulse{background:var(--success)}.connection-status.disconnected .pulse{background:var(--danger)}@keyframes pulse-anim{0%,to{opacity:1}50%{opacity:.3}}.empty-state{text-align:center;color:var(--text-muted);padding:2.5rem 1rem}.empty-state-icon{color:var(--border);margin-bottom:.75rem}.empty-state-title{color:var(--text-secondary);margin-bottom:.25rem;font-size:.95rem;font-weight:600}.empty-state-desc{max-width:300px;margin:0 auto;font-size:.82rem}.app-footer{color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-white);margin-left:var(--sidebar-width);z-index:50;justify-content:space-between;padding:.5rem 1.5rem;font-size:.72rem;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width<=768px){.hamburger-btn{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 16px #0000001a}.sidebar-overlay.open{display:block}.main-content,.app-footer{margin-left:0}.stats-grid{grid-template-columns:repeat(2,1fr)}.instruments-grid{grid-template-columns:1fr}}
