@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
    --bg:          #F5F7FA;
    --bg-white:    #FFFFFF;
    --bg-card:     #FFFFFF;
    --bg-soft:     #F8FAFB;
    --bg-hover:    #F0F5F4;
    --bg-sidebar:  linear-gradient(180deg, #0C1B2A 0%, #162D44 50%, #0E2236 100%);
    --border:      #E8ECF1;
    --border-h:    #D0D9E3;
    --shadow-xs:   0 1px 2px rgba(0,0,0,0.04);
    --shadow-sm:   0 2px 6px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.02);
    --shadow-md:   0 4px 16px rgba(0,0,0,0.06), 0 1px 4px rgba(0,0,0,0.03);
    --shadow-lg:   0 12px 40px rgba(0,0,0,0.08);
    --shadow-glow: 0 0 50px rgba(16,185,129,0.08);
    --green:       #10B981;
    --green-d:     #059669;
    --green-l:     #D1FAE5;
    --green-50:    rgba(16,185,129,0.06);
    --cyan:        #06B6D4;
    --cyan-l:      #CFFAFE;
    --amber:       #F59E0B;
    --amber-l:     #FEF3C7;
    --red:         #EF4444;
    --red-l:       #FEE2E2;
    --blue:        #3B82F6;
    --blue-l:      #DBEAFE;
    --violet:      #8B5CF6;
    --violet-l:    #EDE9FE;
    --txt:         #111827;
    --txt2:        #4B5563;
    --txt3:        #9CA3AF;
    --txt4:        #D1D5DB;
    --r-sm:  8px;
    --r-md:  12px;
    --r-lg:  16px;
    --r-xl:  20px;
    --tr:    all 0.25s cubic-bezier(0.4,0,0.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--txt);display:flex;height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased}

/* ══════ SIDEBAR ══════ */
.sidebar{width:260px;background:var(--bg-sidebar);display:flex;flex-direction:column;padding:1.2rem 0.75rem;flex-shrink:0;z-index:500;overflow-y:auto}
.sidebar::-webkit-scrollbar{width:0}
.sl{display:flex;align-items:center;gap:0.75rem;padding:0.7rem 0.6rem;margin-bottom:1.5rem}
.sl-ic{width:42px;height:42px;background:linear-gradient(135deg,#10B981,#06B6D4);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 4px 15px rgba(16,185,129,0.4)}
.sl-t{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.1rem;background:linear-gradient(135deg,#34D399,#22D3EE);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sl-s{font-size:0.65rem;color:#64748B;font-weight:600;letter-spacing:0.12em;text-transform:uppercase}
.nl{font-size:0.65rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:0.14em;padding:0 0.7rem;margin:1rem 0 0.35rem}
.ni{display:flex;align-items:center;gap:0.65rem;padding:0.6rem 0.75rem;border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);font-weight:500;font-size:0.9rem;color:#94A3B8;position:relative;margin-bottom:2px}
.ni:hover{background:rgba(255,255,255,0.06);color:#E2E8F0}
.ni.active{background:rgba(16,185,129,0.12);color:#34D399;font-weight:600}
.ni.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#10B981;border-radius:0 3px 3px 0}
.ni i{font-size:1rem;width:22px;text-align:center}
.ni .badge{margin-left:auto;background:#EF4444;color:white;font-size:0.6rem;font-weight:700;padding:2px 7px;border-radius:8px;line-height:1.4}
.s-foot{margin-top:auto}
.s-stat{padding:0.7rem;background:rgba(255,255,255,0.04);border-radius:var(--r-sm);margin-bottom:0.5rem;border:1px solid rgba(255,255,255,0.06)}
.s-stat-l{font-size:0.6rem;color:#64748B;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.2rem}
.s-stat-v{font-family:'JetBrains Mono';font-weight:600;font-size:1.3rem;color:#34D399}
.s-stat-v span{font-size:0.75rem;color:#475569}
.s-user{display:flex;align-items:center;gap:0.6rem;padding:0.6rem;border-radius:var(--r-sm);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06)}
.s-user-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#10B981,#06B6D4);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;color:white}
.s-user-n{font-size:0.85rem;font-weight:600;color:#E2E8F0}
.s-user-r{font-size:0.7rem;color:#34D399}

/* ══════ MAIN ══════ */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}

header{height:60px;min-height:60px;background:var(--bg-white);border-bottom:1px solid var(--border);padding:0 1.75rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-xs)}
.h-left h1{font-family:'Plus Jakarta Sans';font-size:1.25rem;font-weight:700;letter-spacing:-0.02em}
.h-sub{font-size:0.75rem;color:var(--txt3);font-family:'JetBrains Mono';font-weight:500}
.h-right{display:flex;align-items:center;gap:0.75rem}
.h-live{display:flex;align-items:center;gap:0.4rem;padding:5px 14px;border-radius:20px;background:var(--green-l);border:1px solid rgba(16,185,129,0.15);font-size:0.75rem;font-weight:600;color:var(--green)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.h-sel{padding:6px 14px;border-radius:var(--r-sm);background:var(--bg-soft);border:1px solid var(--border);color:var(--txt);font-size:0.85rem;font-weight:500;cursor:pointer;outline:none;font-family:'Inter'}
.lang-t{display:flex;gap:1px;padding:2px;background:var(--bg-soft);border-radius:7px;border:1px solid var(--border)}
.lang-b{background:transparent;border:none;padding:4px 10px;border-radius:5px;font-weight:600;font-size:0.75rem;color:var(--txt3);cursor:pointer;transition:var(--tr)}
.lang-b.active{background:var(--green);color:white;box-shadow:0 2px 6px rgba(16,185,129,0.3)}
.h-bell{position:relative;cursor:pointer;font-size:1.1rem;color:var(--txt2)}
.bell-b{position:absolute;top:-3px;right:-3px;width:14px;height:14px;background:var(--red);border-radius:50%;font-size:0.5rem;color:white;display:flex;align-items:center;justify-content:center;font-weight:700;border:1.5px solid white}

.content{flex:1;overflow-y:auto;padding:1.25rem 1.5rem}

/* ══════ PAGES ══════ */
.pg{display:none}
.pg.active{display:block;animation:pageIn 0.45s ease-out}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ══════ GRID ══════ */
.g{display:grid;grid-template-columns:repeat(12,1fr);gap:0.9rem}
.c12{grid-column:span 12}.c9{grid-column:span 9}.c8{grid-column:span 8}.c7{grid-column:span 7}
.c6{grid-column:span 6}.c5{grid-column:span 5}.c4{grid-column:span 4}.c3{grid-column:span 3}.c2{grid-column:span 2}

/* ══════ CARD ══════ */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.15rem;transition:var(--tr);position:relative;box-shadow:var(--shadow-sm)}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-h)}
.ch{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.75rem}
.ct{font-size:0.72rem;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:0.08em}
.ca{font-size:0.72rem;color:var(--green);cursor:pointer;font-weight:600}

/* ══════ KPI STRIP ══════ */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0.9rem;margin-bottom:0.9rem}
.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:1rem 1.1rem;display:flex;align-items:center;gap:0.85rem;transition:var(--tr);box-shadow:var(--shadow-xs);cursor:default}
.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.kpi-ic{width:50px;height:50px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.kpi-ic.t{background:linear-gradient(135deg,#FEE2E2,#FECACA)}
.kpi-ic.h{background:linear-gradient(135deg,#DBEAFE,#BFDBFE)}
.kpi-ic.c{background:linear-gradient(135deg,#FEF3C7,#FDE68A)}
.kpi-ic.s{background:linear-gradient(135deg,#D1FAE5,#A7F3D0)}
.kpi-body{flex:1;min-width:0}
.kpi-lbl{font-size:0.75rem;color:var(--txt3);font-weight:600;margin-bottom:0.2rem}
.kpi-val{font-family:'Plus Jakarta Sans';font-size:1.65rem;font-weight:800;letter-spacing:-0.03em;line-height:1}
.kpi-sub{display:flex;align-items:center;gap:0.3rem;font-size:0.7rem;font-weight:600;margin-top:0.2rem}
.kpi-sub.up{color:var(--green)}.kpi-sub.dn{color:var(--red)}.kpi-sub.eq{color:var(--txt3)}
.kpi-spark{width:70px;height:34px;flex-shrink:0}
.kpi-pill{position:absolute;top:10px;right:10px;font-size:0.6rem;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:0.04em}
.pill-ok{background:var(--green-l);color:var(--green)}.pill-warn{background:var(--amber-l);color:var(--amber)}.pill-err{background:var(--red-l);color:var(--red)}.pill-info{background:var(--cyan-l);color:var(--cyan)}.pill-off{background:#F3F4F6;color:var(--txt3)}

/* ══════ SENSOR GRID ══════ */
.sensor-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0.75rem;margin-bottom:0.9rem}
.sc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:0.85rem;transition:var(--tr);cursor:default;position:relative;overflow:hidden}
.sc:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.sc-ic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;margin-bottom:0.4rem}
.sc-v{font-family:'Plus Jakarta Sans';font-size:1.4rem;font-weight:800;letter-spacing:-0.02em;line-height:1}
.sc-u{font-size:0.75rem;font-weight:500;color:var(--txt2)}
.sc-l{font-size:0.72rem;color:var(--txt3);margin-top:0.2rem;font-weight:500}
.sc-t{font-size:0.65rem;font-weight:600;margin-top:0.3rem}
.sc-bar{position:absolute;bottom:0;left:0;right:0;height:4px}
.sc-bar-fill{height:100%;transition:width 0.8s}

/* ══════ GAUGE ══════ */
.gauge-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}
.gauge-svg{position:relative}
.gauge-svg svg{transform:rotate(-90deg)}
.gauge-bg{fill:none;stroke:#F3F4F6;stroke-width:10}
.gauge-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(0.4,0,0.2,1)}
.gauge-c{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.gauge-v{font-family:'Plus Jakarta Sans';font-size:1.8rem;font-weight:900;color:var(--green)}
.gauge-lbl{font-size:0.5rem;color:var(--txt3);font-weight:700;text-transform:uppercase}

/* ══════ MAP ══════ */
.map-wrap{position:relative;background:var(--bg-soft);border-radius:var(--r-md);border:1px solid var(--border);overflow:hidden}
.map-svg{width:100%;height:auto;display:block}
.map-dot{position:absolute;width:14px;height:14px;border-radius:50%;cursor:pointer;transition:var(--tr);z-index:10}
.map-dot::after{content:'';position:absolute;top:-5px;left:-5px;right:-5px;bottom:-5px;border-radius:50%;border:2px solid currentColor;opacity:0;animation:rip 2.5s infinite}
.map-dot:hover{transform:scale(1.8);z-index:50}
.map-dot:hover::after{display:none}
@keyframes rip{0%{transform:scale(1);opacity:0.5}100%{transform:scale(2.5);opacity:0}}
.tip{display:none;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translateX(-50%);background:var(--bg-card);border-radius:var(--r-sm);padding:0.65rem 0.8rem;box-shadow:var(--shadow-lg);white-space:nowrap;font-size:0.8rem;border:1px solid var(--border);z-index:100;min-width:140px}
.tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--bg-card)}
.map-dot:hover .tip{display:block;animation:pageIn 0.15s ease-out}

/* ══════ LIVE ══════ */
.live-box{position:relative;border-radius:var(--r-lg);overflow:hidden;background:#0a141e;aspect-ratio:16/9}
.live-box canvas{width:100%;height:100%;display:block}
.live-badge{position:absolute;top:14px;left:14px;display:flex;align-items:center;gap:6px;background:rgba(239,68,68,0.9);color:white;padding:5px 14px;border-radius:20px;font-size:0.75rem;font-weight:700;z-index:5;backdrop-filter:blur(8px)}
.live-badge .ld{width:7px;height:7px;background:white;border-radius:50%;animation:pulse 1s infinite}
.live-ts{position:absolute;bottom:14px;right:14px;color:rgba(255,255,255,0.8);font-family:'JetBrains Mono';font-size:0.8rem;background:rgba(0,0,0,0.5);padding:5px 12px;border-radius:6px;z-index:5;backdrop-filter:blur(4px)}
.live-ov{position:absolute;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-radius:var(--r-sm);padding:8px 12px;box-shadow:var(--shadow-md);font-size:0.8rem;z-index:5;border:1px solid rgba(255,255,255,0.5)}
.live-ov-big{font-family:'JetBrains Mono';font-weight:700;font-size:0.95rem}
.live-scanline{position:absolute;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,rgba(16,185,129,0.5),transparent);animation:scanLine 3s linear infinite;pointer-events:none;z-index:4}
@keyframes scanLine{0%{top:0;opacity:0.6}100%{top:100%;opacity:0}}

/* ══════ TABLE ══════ */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:0.68rem;color:var(--txt3);padding:0.6rem 0.75rem;border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:0.08em;font-weight:700}
td{padding:0.65rem 0.75rem;border-bottom:1px solid #F3F4F6;font-size:0.85rem;font-weight:500}
tr:hover td{background:var(--bg-soft)}
.mono{font-family:'JetBrains Mono';font-size:0.8rem}

/* ══════ HEATMAP ══════ */
.heatmap{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;padding:0.4rem;border-radius:var(--r-md);background:var(--bg-soft)}
.hc{aspect-ratio:1;border-radius:3px;transition:0.2s;cursor:pointer}
.hc:hover{transform:scale(1.2);z-index:2;box-shadow:var(--shadow-md)}

/* ══════ TOGGLE ══════ */
.tog{width:38px;height:20px;background:#E5E7EB;border-radius:10px;cursor:pointer;position:relative;transition:var(--tr);flex-shrink:0}
.tog.on{background:var(--green);box-shadow:0 2px 8px rgba(16,185,129,0.3)}
.tog::after{content:'';position:absolute;left:2px;top:2px;width:16px;height:16px;background:white;border-radius:50%;transition:var(--tr);box-shadow:0 1px 3px rgba(0,0,0,0.15)}
.tog.on::after{left:18px}

/* ══════ BTN ══════ */
.btn{padding:0.5rem 1rem;border:none;border-radius:var(--r-sm);font-weight:600;font-size:0.8rem;cursor:pointer;transition:var(--tr);font-family:'Inter'}
.btn-p{background:linear-gradient(135deg,#10B981,#059669);color:white;box-shadow:0 3px 10px rgba(16,185,129,0.2)}
.btn-p:hover{box-shadow:0 6px 20px rgba(16,185,129,0.3);transform:translateY(-1px)}
.btn-o{background:white;color:var(--txt2);border:1px solid var(--border)}
.btn-o:hover{border-color:var(--green);color:var(--green)}

/* ══════ GH CARD ══════ */
.gh-c{padding:0;overflow:hidden;cursor:pointer}
.gh-c-h{padding:0.85rem 1.1rem 0.6rem;display:flex;justify-content:space-between;align-items:flex-start}
.gh-c-b{padding:0 1.1rem 1rem}
.gh-c-n{font-family:'Plus Jakarta Sans';font-size:1rem;font-weight:700}
.gh-c-m{font-size:0.72rem;color:var(--txt3);margin-top:2px}
.gh-c-g{display:grid;grid-template-columns:repeat(3,1fr);gap:0.35rem;margin:0.5rem 0}
.gh-ms{display:flex;align-items:center;gap:0.3rem;padding:0.3rem 0.45rem;border-radius:6px;background:var(--bg-soft);font-size:0.72rem}
.gh-msv{font-family:'JetBrains Mono';font-weight:600;font-size:0.72rem}
.gh-bar{height:3px;background:#F3F4F6;border-radius:2px;overflow:hidden}
.gh-bar-f{height:100%;border-radius:2px;transition:width 0.8s}

/* ══════ SCHEDULE ══════ */
.sched{display:flex;justify-content:space-between;align-items:center;padding:0.65rem 0.8rem;background:var(--bg-soft);border-radius:var(--r-sm);margin-bottom:0.4rem;border:1px solid var(--border)}
.sched-t{font-size:0.85rem;font-weight:600}
.sched-s{font-size:0.72rem;color:var(--txt3)}

/* ══════ WEATHER ══════ */
.wx{display:flex;align-items:center;gap:0.75rem;padding:0.75rem;background:linear-gradient(135deg,#EFF6FF,#ECFDF5);border-radius:var(--r-md);border:1px solid var(--border)}
.wx-ic{font-size:2rem}
.wx-t{font-family:'Plus Jakarta Sans';font-size:1.35rem;font-weight:800}
.wx-d{font-size:0.72rem;color:var(--txt3)}
.wx-det{display:flex;gap:0.75rem;margin-top:0.25rem;font-size:0.65rem;color:var(--txt2)}

/* ══════ TIMELINE ══════ */
.tl{display:flex;align-items:center;padding:0.6rem 0}
.tl-s{flex:1;text-align:center;position:relative}
.tl-s::before{content:'';position:absolute;top:15px;left:0;right:0;height:2px;background:#F3F4F6;z-index:0}
.tl-s:first-child::before{left:50%}.tl-s:last-child::before{right:50%}
.tl-d{width:30px;height:30px;border-radius:50%;background:#F3F4F6;border:2px solid #E5E7EB;display:flex;align-items:center;justify-content:center;margin:0 auto 0.35rem;position:relative;z-index:1;font-size:0.85rem}
.tl-s.done .tl-d{background:var(--green);border-color:var(--green);box-shadow:0 2px 6px rgba(16,185,129,0.3)}
.tl-s.done::before{background:var(--green)}
.tl-s.cur .tl-d{border-color:var(--green);background:var(--green-l);animation:glowP 2s infinite}
@keyframes glowP{0%,100%{box-shadow:0 0 4px rgba(16,185,129,0.2)}50%{box-shadow:0 0 16px rgba(16,185,129,0.4)}}
.tl-l{font-size:0.65rem;color:var(--txt3);font-weight:600}

/* ══════ METRIC ROW ══════ */
.mr{display:flex;align-items:center;gap:0.6rem;padding:0.55rem 0.7rem;background:var(--bg-soft);border-radius:var(--r-sm);margin-bottom:0.35rem;border:1px solid var(--border)}
.mr:hover{border-color:var(--border-h)}
.mr-ic{font-size:0.95rem;width:20px;text-align:center}
.mr-n{flex:1;font-size:0.8rem;color:var(--txt2);font-weight:500}
.mr-v{font-family:'JetBrains Mono';font-weight:700;font-size:0.9rem}
.mr-s{font-size:0.6rem;color:var(--txt3)}

input[type="range"]{width:100%;height:3px;-webkit-appearance:none;background:#E5E7EB;border-radius:2px;outline:none}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--green);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px rgba(16,185,129,0.3)}

::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:10px}

.fx{display:flex}.fxc{display:flex;align-items:center}.fxb{display:flex;justify-content:space-between;align-items:center}
.mt-xs{margin-top:0.3rem}.mt-sm{margin-top:0.5rem}.mt-md{margin-top:0.75rem}.mb-xs{margin-bottom:0.3rem}.mb-sm{margin-bottom:0.5rem}
.gap-xs{gap:0.3rem}.gap-sm{gap:0.5rem}.gap-md{gap:0.75rem}
.txt-g{color:var(--green)}.txt-r{color:var(--red)}.txt-a{color:var(--amber)}.txt-b{color:var(--blue)}.txt-v{color:var(--violet)}.txt-c{color:var(--cyan)}.txt-m{color:var(--txt3)}
.fw-b{font-weight:700}.fw-xb{font-weight:800}.fs-xs{font-size:0.65rem}.fs-sm{font-size:0.75rem}.fs-md{font-size:0.85rem}
