:root{font-family:Montserrat,Noto Sans TC,sans-serif;--bg: #0b1623;--bg-elevated: #111f30;--bg-panel: rgba(17, 31, 48, .85);--border: rgba(255, 255, 255, .08);--text: #f4f7fb;--text-subtle: #c3cad7;--primary: #58c6ff;--warning: #ffb347;--danger: #ff6b6b;--success: #3dd598;--caution: #ffd166;--sidebar-width: 280px;--sidebar-collapsed-width: 72px}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 20%,rgba(88,198,255,.12),transparent 55%),radial-gradient(circle at 80% 0%,rgba(255,107,107,.16),transparent 55%),linear-gradient(160deg,#080d15,#0f1c2d 60%,#07101c);color:var(--text)}.layout{display:flex;height:100vh;overflow:hidden}.layout--sidebar-mobile-open{overflow:hidden}.sidebar{width:var(--sidebar-width);background:#060c14eb;border-right:1px solid rgba(255,255,255,.05);padding:28px 22px 32px;display:flex;flex-direction:column;gap:24px;transition:width .2s ease,padding .2s ease}.sidebar--collapsed{width:var(--sidebar-collapsed-width);padding:24px 14px;align-items:center;gap:20px}.sidebar__brand{display:flex;align-items:center;gap:14px;width:100%;justify-content:space-between}.sidebar__brand-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.sidebar__brand-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.sidebar--collapsed .sidebar__brand{gap:12px}.sidebar--collapsed .sidebar__brand-info{justify-content:center}.sidebar__logo{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#58c6ffe6,#ff6b6be6);font-weight:700}.sidebar__title{margin:0;font-weight:600;letter-spacing:.5px}.sidebar__subtitle{margin:4px 0 0;color:var(--text-subtle);font-size:.8rem}.sidebar__toggle{background:#060c14b3;color:var(--text);border:1px solid rgba(255,255,255,.18);border-radius:8px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:background .2s ease}.sidebar__close{display:none;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#060c14cc;color:var(--text);font-size:1.2rem;cursor:pointer}.sidebar__toggle{margin-left:auto;background:#060c14b3;color:var(--text);border:1px solid rgba(255,255,255,.18);border-radius:8px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:background .2s ease}.sidebar__toggle:hover{background:#58c6ff2e}.sidebar--collapsed .sidebar__toggle{margin-left:0}.sidebar__nav{display:grid;gap:8px}.sidebar__nav-label{margin:0 0 6px;color:var(--text-subtle);font-size:.75rem;text-transform:uppercase;letter-spacing:1.2px}.sidebar__nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;text-decoration:none;color:var(--text-subtle);font-weight:500;background:transparent;border:none;cursor:pointer;width:100%;text-align:left;transition:background .2s ease,color .2s ease}.sidebar__nav-item:hover,.sidebar__nav-item--active{background:#58c6ff29;color:var(--text)}.sidebar__nav-icon{font-size:1.2rem;display:inline-flex;width:24px;justify-content:center}.sidebar__nav-icon svg{width:20px;height:20px}.sidebar__nav-text{flex:1;text-align:left}.sidebar__nav-item:disabled{cursor:not-allowed;opacity:.6}.sidebar__nav-badge{display:none;font-size:.65rem;padding:2px 6px;border-radius:999px;background:#ffffff1f;color:var(--text-subtle)}.sidebar__nav-item--disabled .sidebar__nav-badge{display:inline-flex}.sidebar__projects{margin-top:auto;display:grid;gap:12px}.sidebar__project-card{padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#0e1a2799}.sidebar__project-name{margin:0 0 6px;font-weight:600}.sidebar__project-meta{margin:3px 0;color:var(--text-subtle);font-size:.85rem}.sidebar--collapsed .sidebar__title,.sidebar--collapsed .sidebar__subtitle,.sidebar--collapsed .sidebar__nav-label,.sidebar--collapsed .sidebar__nav-text,.sidebar--collapsed .sidebar__nav-badge,.sidebar--collapsed .sidebar__projects{display:none}.sidebar--collapsed .sidebar__nav-item{justify-content:center;padding:10px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#03070c8c;z-index:900}.hamburger{position:fixed;top:18px;left:18px;width:44px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#060c14d9;color:var(--text);display:none;align-items:center;justify-content:center;flex-direction:column;gap:6px;cursor:pointer;z-index:800}.hamburger span{display:block;width:20px;height:2px;border-radius:2px;background:var(--text)}.main{flex:1;padding:32px 40px 48px;display:flex;flex-direction:column;gap:28px;overflow-y:auto}.main--map{padding:0;gap:0;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.header__title{margin:0;font-size:1.8rem}.header__subtitle{margin:8px 0 0;color:var(--text-subtle)}.stats-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{padding:18px;border-radius:16px;background:var(--bg-panel);border:1px solid var(--border);display:grid;gap:8px}.stat-card__label{margin:0;color:var(--text-subtle);font-size:.9rem}.stat-card__value{margin:0;font-size:1.8rem;font-weight:700}.stat-card__change{margin:0;font-size:.85rem;color:var(--text-subtle)}.stat-card--primary{border-color:#58c6ff73}.stat-card--warning{border-color:#ffb34773}.stat-card--danger{border-color:#ff6b6b73}.stat-card--success{border-color:#3dd59873}.main-grid{display:grid;grid-template-columns:2fr 1.3fr;gap:22px}.main-grid__left,.main-grid__right{display:grid;gap:22px}.panel{background:var(--bg-panel);border-radius:20px;border:1px solid var(--border);padding:20px 24px;display:flex;flex-direction:column;gap:18px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.panel--map{min-height:320px}.panel__header{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.panel__header h3{margin:0}.panel__meta{color:var(--text-subtle);font-size:.85rem}.panel__action{color:var(--primary);text-decoration:none;font-size:.85rem}.alert-list{display:grid;gap:12px}.alert-item{padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#0b162399}.alert-item__header{display:flex;justify-content:space-between;align-items:center}.alert-item__title{margin:10px 0 4px}.alert-item__message,.alert-item__owner,.alert-item__time{margin:0;color:var(--text-subtle);font-size:.85rem}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.6px}.badge--danger{background:#ff6b6b33;color:var(--danger)}.badge--warning{background:#ffb34733;color:var(--warning)}.badge--caution{background:#ffd16633;color:var(--caution)}.badge--success{background:#3dd59833;color:var(--success)}.badge--normal{background:#58c6ff33;color:var(--primary)}.sensor-health{display:grid;gap:14px}.sensor-health__segment{display:grid;gap:6px}.sensor-health__bar{width:100%;height:8px;border-radius:999px;background:#ffffff14}.sensor-health__fill{height:100%;border-radius:999px}.sensor-health__fill--success{background:linear-gradient(90deg,#3dd598e6,#58c6ffb3)}.sensor-health__fill--warning{background:linear-gradient(90deg,#ffd16699,#ffb347b3)}.sensor-health__fill--danger{background:linear-gradient(90deg,#ff6b6bcc,#ff3d3dcc)}.sensor-health__label{display:flex;justify-content:space-between;color:var(--text-subtle);font-size:.85rem}.footer-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.roadmap-list{margin:0;padding-left:18px;display:grid;gap:8px;color:var(--text-subtle)}.map-placeholder{position:relative;flex:1;min-height:260px;border-radius:16px;background:radial-gradient(circle at 30% 30%,rgba(88,198,255,.35),transparent 60%),radial-gradient(circle at 70% 60%,rgba(255,107,107,.28),transparent 62%),linear-gradient(140deg,#081523e6,#0a1c2ce6);overflow:hidden;border:1px solid rgba(255,255,255,.08)}.map-marker{position:absolute;transform:translate(-50%,-50%);padding:6px 10px;border-radius:12px;font-size:.7rem;font-weight:700;letter-spacing:.5px}.map-marker--critical{background:#ff6b6bd9}.map-marker--warning{background:#ffb347d9}.map-marker--normal{background:#3dd598d9}.map-legend{position:absolute;bottom:14px;right:16px;display:flex;gap:12px;padding:6px 10px;border-radius:999px;background:#00000059;font-size:.75rem}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.dot--critical{background:var(--danger)}.dot--warning{background:var(--warning)}.dot--normal{background:var(--success)}.map-wrapper{position:relative;width:100%;min-height:100vh;height:100vh;flex:1}.map-container{width:100%;height:100%;overflow:hidden;position:relative}.map-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center;padding:32px;background:#08101aeb;color:var(--text);z-index:10}.map-empty h3{margin-bottom:12px}.map-overlay{position:absolute;z-index:5;background:#060c14d1;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text)}.map-overlay--layers{top:20px;left:20px;width:min(260px,90vw)}.map-overlay--layers h3{margin:0}.map-overlay--layers ul{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:10px}.map-overlay--layers li{background:#0b1623a6;border-radius:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.08);display:grid;gap:6px}.map-overlay--layers li.is-active{border-color:#58c6ff73}.map-overlay--legend{top:20px;right:20px;display:flex;gap:12px;align-items:center}.map-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.map-marker{width:16px;height:16px;border-radius:50%;position:relative;box-shadow:0 0 0 4px #ffffff26}.map-marker span{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:currentColor}.map-marker--danger{color:#ff6b6b}.map-marker--warning{color:#ffb347}.map-marker--normal{color:#3dd598}@media (max-width: 768px){.map-overlay--layers{top:auto;bottom:20px;left:20px}.map-overlay--legend{top:20px;right:20px;flex-direction:column;gap:8px}}.module-card--danger{border-color:#ff6b6b73}.module-card--warning{border-color:#ffb34773}.module-card--caution{border-color:#ffd16673}.table--alerts .table__head,.table--alerts .table__row,.table--reports .table__head,.table--reports .table__row,.table--admin .table__head,.table--admin .table__row{grid-template-columns:1.5fr .6fr 1.4fr 1fr 1fr .9fr}.table__head--alerts span:nth-child(2),.table__head--alerts span:nth-child(4){text-align:center}.table__row--alerts span:nth-child(2),.table__row--alerts span:nth-child(4){justify-items:center}.table--reports .table__row span:nth-child(6),.table--admin .table__row span:nth-child(6){display:flex;gap:8px;align-items:center}.chip--danger{background:#ff6b6b2e;color:var(--danger)}.chip--warning{background:#ffb3472e;color:var(--warning)}.chip--caution{background:#ffd1662e;color:var(--caution)}.chip--success{background:#3dd5982e;color:var(--success)}.link-button{background:none;border:none;color:var(--primary);font-size:.85rem;cursor:pointer;padding:0}.link-button:hover{text-decoration:underline}.assistant{display:flex;justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 120px);padding:32px 0}.assistant--active{align-items:flex-start;padding-top:0}.assistant__container{width:min(880px,100%);display:flex;flex-direction:column;gap:24px}.assistant__header{text-align:center;display:grid;gap:12px}.assistant__header h2{margin:0;font-size:clamp(1.8rem,2.6vw,2.4rem)}.assistant__header p{margin:0;color:var(--text-subtle)}.assistant__conversation{background:var(--bg-panel);border-radius:22px;border:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:18px;max-height:600px;overflow-y:auto}.assistant__bubble{padding:16px;border-radius:16px;background:#0b162399;border:1px solid rgba(255,255,255,.08);display:grid;gap:8px}.assistant__bubble--user{margin-left:auto;background:#58c6ff1f;border-color:#58c6ff47}.assistant__bubble--assistant{margin-right:auto}.assistant__bubble.is-thinking{opacity:.75;font-style:italic}.assistant__meta{display:flex;justify-content:space-between;color:var(--text-subtle);font-size:.8rem}.assistant__bubble p{margin:0;line-height:1.55}.assistant__composer{padding:18px 20px;border-radius:18px;background:#0a1421b8;border:1px solid rgba(255,255,255,.08)}.assistant__composer{padding:18px 20px;border-radius:18px;background:#0a1421b8;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:12px}.assistant__composer-field{display:flex;gap:12px;align-items:center}.assistant__composer input{flex:1;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#060c14e6;color:var(--text)}.assistant__composer button{padding:12px 22px;border-radius:12px;border:none;background:linear-gradient(135deg,#58c6ffd9,#3595ffd9);color:#041321;font-weight:600;cursor:pointer}.assistant__composer button:disabled{cursor:not-allowed;opacity:.6}.assistant__footer{display:flex;justify-content:space-between;align-items:center}.assistant__actions{display:flex;align-items:center;gap:12px}.assistant__upload{display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;color:var(--text);cursor:pointer;position:relative}.assistant__upload input{display:none}.assistant__upload-icon{font-size:1.4rem;line-height:1}.assistant__upload-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#060c14eb;border-radius:8px;padding:6px 10px;font-size:.75rem;color:var(--text);border:1px solid rgba(255,255,255,.12);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease}.assistant__upload:hover .assistant__upload-tooltip{opacity:1}.assistant__pending{display:flex;flex-wrap:wrap;gap:8px}.assistant__pending-item{padding:6px 10px;border-radius:8px;background:#58c6ff29;color:var(--text);font-size:.8rem}.assistant__attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.assistant__attachment{display:inline-flex;flex-direction:column;padding:8px 10px;border-radius:10px;background:#060c1499;border:1px solid rgba(255,255,255,.08);color:var(--text);text-decoration:none;font-size:.8rem}.assistant__attachment:hover{border-color:#58c6ff59}.assistant__attachment-name{font-weight:600}.assistant__attachment-size{color:var(--text-subtle)}.assistant__input-large{padding:16px 20px;font-size:1.05rem}@media (max-width: 768px){.assistant{padding:24px 0}.assistant__container{width:100%;padding:0 16px}.assistant__conversation{max-height:unset}.assistant__footer{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 768px){.header{flex-direction:column;align-items:flex-start}.header__meta{text-align:left}.layout{flex-direction:column;height:auto}.main{padding:80px 16px 32px;overflow-y:visible}.sidebar{height:100vh}}.module{display:flex;flex-direction:column;gap:26px}.module__header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.module__header h2{margin:0 0 8px}.module__header p{margin:0;color:var(--text-subtle)}.module__summary-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.module-card{background:var(--bg-panel);border-radius:16px;border:1px solid var(--border);padding:20px;display:grid;gap:8px}.module-card__label{margin:0;color:var(--text-subtle)}.module-card__value{margin:0;font-size:1.6rem;font-weight:700}.module-card__meta{margin:0;color:var(--text-subtle);font-size:.85rem}.module__table-block{background:var(--bg-panel);border-radius:20px;border:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:18px}.module__table-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.module__filters{display:flex;gap:12px}.module__select{padding:8px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#050c15cc;color:var(--text)}.table{display:grid;gap:12px}.table__head,.table__row{display:grid;grid-template-columns:1.6fr 1.3fr 1fr 1fr 1.2fr;gap:12px;align-items:flex-start}.table__head{color:var(--text-subtle);font-size:.85rem}.table__row{padding:16px;border-radius:16px;background:#0b162399;border:1px solid rgba(255,255,255,.08)}.table__row span{display:grid;gap:6px}.table__row strong{font-size:1rem}.table__row small{color:var(--text-subtle);font-size:.8rem}.table__head-cell{display:inline-flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none;transition:color .2s ease,opacity .2s ease}.table__head-cell-label{display:inline-flex;align-items:center;gap:4px}.table__head-cell--sortable{cursor:pointer}.table__head-cell--sortable:hover .table__head-cell-label,.table__head-cell--sortable:focus-visible .table__head-cell-label{color:var(--text)}.table__head-cell:focus-visible{outline:2px solid rgba(88,198,255,.38);outline-offset:4px;border-radius:6px}.table__sort-icon{font-size:.75rem;opacity:.6;color:var(--text-subtle)}.table__head-cell--sortable:hover .table__sort-icon,.table__head-cell--sortable:focus-visible .table__sort-icon{opacity:1;color:var(--primary)}.table--compact .table__head,.table--compact .table__row{grid-template-columns:1.3fr 1.3fr 1fr 1fr 1fr .8fr}.table__head--compact{font-size:.8rem}.table__row--compact{padding:14px}.module__pagination{margin-top:16px;padding-top:18px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}.module__pagination-controls,.module__pagination-status,.module__pagination-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.module__pagination-controls{gap:8px}.module__pagination-button{min-width:44px;padding:8px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#060c14c7;color:var(--text);font-weight:600;letter-spacing:.5px;transition:background .2s ease,border-color .2s ease,color .2s ease;cursor:pointer}.module__pagination-button:not(:disabled):hover{background:#58c6ff2e;border-color:#58c6ff73;color:var(--text)}.module__pagination-button:disabled{cursor:not-allowed;opacity:.4}.module__pagination-status span:first-child,.module__pagination-total{color:var(--text-subtle);font-size:.85rem}.module__pagination-jump{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-subtle)}.module__pagination-input{width:72px;padding:6px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#050c15e0;color:var(--text);font-size:.9rem;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.module__pagination-input:focus{outline:2px solid rgba(88,198,255,.38);outline-offset:2px}.module__pagination-input::-webkit-outer-spin-button,.module__pagination-input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none}.module__pagination-size{min-width:140px}@media (max-width: 1200px){.main{padding:28px 24px 40px}.main-grid,.main-grid__left,.main-grid__right{grid-template-columns:1fr}.sidebar__projects{display:none}}.chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:#58c6ff33;color:var(--primary);font-size:.75rem;font-weight:600}@media (max-width: 992px){.table__head,.table__row,.table--compact .table__head,.table--compact .table__row{grid-template-columns:repeat(2,minmax(0,1fr))}.table__row{padding:16px 12px}.module__map-block{grid-template-columns:1fr}.module__pagination{flex-direction:column;align-items:flex-start;gap:12px}.module__pagination-controls,.module__pagination-status,.module__pagination-meta{width:100%}.module__pagination-controls{justify-content:space-between}.module__pagination-status,.module__pagination-meta{justify-content:flex-start}}@media (max-width: 768px){.module__header{flex-direction:column;align-items:flex-start}.module__filters{flex-wrap:wrap}}@media (max-width: 768px){.sidebar{position:fixed;inset:0 auto 0 0;height:100vh;transform:translate(-100%);width:var(--sidebar-width);padding:28px 22px 32px;box-shadow:0 0 24px #0006;z-index:1000;transition:transform .25s ease;align-items:stretch}.sidebar--collapsed{width:var(--sidebar-width);padding:28px 22px 32px;align-items:stretch;gap:24px}.sidebar--mobile-open{transform:translate(0)}.sidebar__brand{flex-direction:column;align-items:flex-start;gap:16px}.sidebar__brand-info{width:100%;gap:12px}.sidebar__brand-actions{width:100%;justify-content:space-between}.sidebar__toggle{display:none}.sidebar__close{display:inline-flex}.sidebar__nav{margin-top:12px;width:100%}.sidebar__title{font-size:1.05rem}.sidebar__subtitle{font-size:.75rem}.hamburger{display:flex}.layout--sidebar-mobile-open .hamburger{display:none}}@media (max-width: 768px){.sidebar__brand{flex-direction:column;align-items:flex-start;gap:16px}.sidebar__brand-info{width:100%;gap:12px}.sidebar__brand-actions{width:100%;justify-content:space-between}.sidebar__title{font-size:1.05rem}.sidebar__subtitle{font-size:.75rem}.sidebar{position:fixed;inset:0 auto 0 0;height:100vh;transform:translate(-100%);width:var(--sidebar-width);padding:28px 22px 32px;box-shadow:0 0 24px #0006;z-index:1000;transition:transform .25s ease}.sidebar--collapsed{width:var(--sidebar-width);padding:28px 22px 32px;align-items:flex-start;gap:24px}.sidebar--mobile-open{transform:translate(0)}.sidebar__toggle{display:none}.sidebar__close{display:inline-flex}.sidebar__nav{margin-top:12px}.hamburger{display:flex}.layout--sidebar-mobile-open .hamburger{display:none}}@media (min-width: 769px){.sidebar{position:relative;transform:none}.sidebar-backdrop,.sidebar__close,.hamburger{display:none}}
