@import url('../../../assets/fonts/fonts.css');

:root {
    --bg:          #dff3e5;
    --bg-white:    rgba(246, 255, 250, 0.66);
    --bg-card:     rgba(255, 255, 255, 0.22);
    --bg-soft:     rgba(255, 255, 255, 0.16);
    --bg-hover:    rgba(255, 255, 255, 0.3);
    --bg-sidebar:  linear-gradient(180deg, rgba(26, 42, 35, 0.48) 0%, rgba(18, 33, 27, 0.54) 100%);
    --border:      rgba(255, 255, 255, 0.34);
    --border-h:    rgba(255, 255, 255, 0.5);
    --shadow-xs:   0 10px 18px rgba(8, 31, 26, 0.11);
    --shadow-sm:   0 14px 30px rgba(7, 22, 32, 0.14);
    --shadow-md:   0 20px 46px rgba(5, 16, 26, 0.2);
    --shadow-lg:   0 28px 64px rgba(5, 16, 26, 0.26);
    --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:        #111111;
    --txt3:        #1f2937;
    --txt4:        #374151;
    --glass-blur: 24px;
    --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;font-size:17px}
body::after{
    content:'';
    position:fixed;
    inset:0;
    pointer-events:none;
    background:
        radial-gradient(circle at 12% 18%, rgba(255,255,255,0.32), transparent 36%),
        radial-gradient(circle at 82% 10%, rgba(34,197,94,0.16), transparent 28%),
        radial-gradient(circle at 72% 78%, rgba(6,182,212,0.14), transparent 30%),
        linear-gradient(180deg, rgba(236,252,243,0.06), rgba(16,185,129,0.08));
    z-index:-1;
}
.main{
    position:relative;
}
.main::before{
    content:'';
    position:absolute;
    inset:10px 10px 10px 0;
    border-radius:24px;
    border:1px solid rgba(255,255,255,0.24);
    background:linear-gradient(180deg, rgba(255,255,255,0.16), rgba(255,255,255,0.05));
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.4), inset 0 -1px 0 rgba(255,255,255,0.08);
    pointer-events:none;
    z-index:0;
}

/* ══════ 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;border-right:1px solid rgba(255,255,255,0.18);backdrop-filter:saturate(160%) blur(calc(var(--glass-blur) + 6px));-webkit-backdrop-filter:saturate(160%) blur(calc(var(--glass-blur) + 6px));box-shadow:0 24px 48px rgba(2,10,20,0.2), inset 0 1px 0 rgba(255,255,255,0.18), inset 0 -1px 0 rgba(255,255,255,0.06);position:relative}

.sidebar::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.16), rgba(0,0,0,0.24));
    pointer-events:none;
    z-index:0;
}
.sidebar > *{
    position:relative;
    z-index:1;
}
.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.72rem;color:var(--txt3);font-weight:700;letter-spacing:0.12em;text-transform:uppercase}
.nl{font-size:0.75rem;font-weight:800;color:rgba(231,245,238,0.8);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:600;font-size:1rem;color:rgba(235,248,241,0.86);position:relative;margin-bottom:2px;font-style: normal;}
.ni:hover{background:rgba(255,255,255,0.12);color:#f1faf5;box-shadow:inset 0 1px 0 rgba(255,255,255,0.14)}
.ni.active{background:linear-gradient(90deg, rgba(16,185,129,0.36), rgba(34,211,238,0.24));color:#f8fff9;font-weight:700;box-shadow:0 8px 26px rgba(8,64,44,0.35), inset 0 1px 0 rgba(255,255,255,0.22)}
.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;font-style: normal;}
.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.08);border-radius:var(--r-sm);margin-bottom:0.5rem;border:1px solid rgba(255,255,255,0.12);backdrop-filter:saturate(140%) blur(calc(var(--glass-blur) - 6px));-webkit-backdrop-filter:saturate(140%) blur(calc(var(--glass-blur) - 6px))}
.s-stat-l{font-size:0.68rem;color:#ffffff;font-weight:800;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:#ffffff}
.s-stat-v span{font-size:0.82rem;color:#ffffff}
.s-user{display:flex;align-items:center;gap:0.6rem;padding:0.6rem;border-radius:var(--r-sm);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);backdrop-filter:saturate(140%) blur(calc(var(--glass-blur) - 6px));-webkit-backdrop-filter:saturate(140%) blur(calc(var(--glass-blur) - 6px))}
.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.96rem;font-weight:700;color:#ffffff}
.s-user-r{font-size:0.8rem;color:#ffffff}

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

header{height:60px;min-height:60px;background:var(--bg-white);border:1px solid var(--border);padding:0 1.75rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-xs), inset 0 1px 0 rgba(255,255,255,0.5);backdrop-filter:saturate(160%) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(160%) blur(var(--glass-blur));margin:10px 12px 0;border-radius:16px}
.h-left h1{font-family:'Plus Jakarta Sans';font-size:1.5rem;font-weight:800;letter-spacing:-0.02em}
.h-sub{font-size:0.86rem;color:var(--txt2);font-family:'JetBrains Mono';font-weight:600}
.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:rgba(209,250,229,0.42);border:1px solid rgba(16,185,129,0.28);font-size:0.75rem;font-weight:600;color:var(--green);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.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.95rem;font-weight:600;cursor:pointer;outline:none;font-family:'Inter',sans-serif;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.lang-t{display:flex;gap:1px;padding:2px;background:var(--bg-soft);border-radius:7px;border:1px solid var(--border);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.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.05rem 1.5rem 1.25rem}

/* ══════ 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);backdrop-filter:saturate(150%) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(150%) blur(var(--glass-blur));overflow:hidden}
.card::before{
    content:'';
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:46%;
    background:linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0));
    pointer-events:none;
}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-h);background:rgba(255,255,255,0.36)}
.ch{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.75rem}
.ct{font-size:0.82rem;font-weight:800;color:var(--txt2);text-transform:uppercase;letter-spacing:0.08em}
.ca{font-size:0.82rem;color:var(--green);cursor:pointer;font-weight:700}

/* ══════ 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), inset 0 1px 0 rgba(255,255,255,0.45);cursor:default;backdrop-filter:saturate(150%) blur(calc(var(--glass-blur) - 2px));-webkit-backdrop-filter:saturate(150%) blur(calc(var(--glass-blur) - 2px))}
.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);background:rgba(255,255,255,0.38)}
.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.85rem;color:var(--txt2);font-weight:700;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;backdrop-filter:saturate(150%) blur(calc(var(--glass-blur) - 2px));-webkit-backdrop-filter:saturate(150%) blur(calc(var(--glass-blur) - 2px));box-shadow:inset 0 1px 0 rgba(255,255,255,0.38)}
.sc:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);background:rgba(255,255,255,0.36)}
.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.82rem;font-weight:600;color:var(--txt2)}
.sc-l{font-size:0.8rem;color:var(--txt2);margin-top:0.2rem;font-weight:600}
.sc-t{font-size:0.74rem;font-weight:700;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;backdrop-filter:saturate(150%) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(150%) blur(var(--glass-blur))}
.map-svg{width:100%;height:100%;display:block}
.map-wrap-tall{height:calc(100vh - 185px);min-height:520px;overflow:hidden}
.map-wrap-tall .map-svg{height:100%;width:100%;display:block}
.sensor-list-panel{max-height:calc(100vh - 235px);overflow-y:auto}
.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:rgba(255,255,255,0.42);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;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.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.78rem;color:var(--txt2);padding:0.6rem 0.75rem;border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:0.08em;font-weight:800}
td{padding:0.65rem 0.75rem;border-bottom:1px solid rgba(255,255,255,0.3);font-size:0.95rem;font-weight:600}
tr:hover td{background:rgba(255,255,255,0.18)}
.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);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.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',sans-serif}
.btn-p{background:linear-gradient(135deg,#10B981,#059669);color:white;box-shadow:0 3px 10px rgba(16,185,129,0.2), inset 0 1px 0 rgba(255,255,255,0.24)}
.btn-p:hover{box-shadow:0 6px 20px rgba(16,185,129,0.3);transform:translateY(-1px)}
.btn-o{background:rgba(255,255,255,0.38);color:var(--txt2);border:1px solid var(--border);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.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.8rem;color:var(--txt2);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;border:1px solid rgba(255,255,255,0.26);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.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);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.sched-t{font-size:0.95rem;font-weight:700}
.sched-s{font-size:0.8rem;color:var(--txt2)}

/* ══════ WEATHER ══════ */
.wx{display:flex;align-items:center;gap:0.75rem;padding:0.75rem;background:linear-gradient(135deg,rgba(219,234,254,0.45),rgba(209,250,229,0.38));border-radius:var(--r-md);border:1px solid var(--border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.wx-ic{font-size:2rem}
.wx-t{font-family:'Plus Jakarta Sans';font-size:1.35rem;font-weight:800}
.wx-d{font-size:0.82rem;color:var(--txt2)}
.wx-det{display:flex;gap:0.75rem;margin-top:0.25rem;font-size:0.76rem;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.75rem;color:var(--txt2);font-weight:700}

/* ══════ 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);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.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.9rem;color:var(--txt2);font-weight:600}
.mr-v{font-family:'JetBrains Mono';font-weight:700;font-size:1rem}
.mr-s{font-size:0.7rem;color:var(--txt2)}

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.75rem}.fs-sm{font-size:0.85rem}.fs-md{font-size:0.95rem}

/* Brand link + typography refresh */
.sl-link {
    text-decoration: none;
    cursor: pointer;
    border-radius: var(--r-md);
    transition: var(--tr);
}
.sl-link:hover {
    background: rgba(255,255,255,0.12);
}
.sl-link:focus-visible {
    outline: 2px solid #34D399;
    outline-offset: 2px;
}
.sl-ic {
    width: 46px;
    height: 46px;
    font-size: 1.45rem;
}
.sl-t {
    font-size: 1.25rem;
    letter-spacing: 0.01em;
}
.sl-s {
    font-size: 0.72rem;
}
.ni {
    font-size: 0.96rem;
}
.h-left h1 {
    font-size: 1.38rem;
}
.h-sub {
    font-size: 0.8rem;
}
.kpi-val {
    font-size: 1.9rem;
}
.sc-v {
    font-size: 1.55rem;
}
.wx-t {
    font-size: 1.6rem;
}
.wx-d,
.wx-det {
    font-size: 0.8rem;
}

@media (max-width: 1200px) {
    .sidebar {
        width: 244px;
    }
    .kpi-strip {
        grid-template-columns: repeat(2, 1fr);
    }
    .sensor-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 760px) {
    body {
        height: auto;
        min-height: 100vh;
        overflow: auto;
        flex-direction: column;
    }
    .sidebar {
        width: 100%;
        height: auto;
        max-height: none;
    }
    .main {
        width: 100%;
    }
    header {
        height: auto;
        min-height: 58px;
        padding: 0.75rem 1rem;
        align-items: flex-start;
        gap: 0.75rem;
        flex-wrap: wrap;
        margin: 0.65rem 0.85rem 0;
    }
    .content {
        padding: 0.85rem;
    }
    .kpi-strip,
    .sensor-grid {
        grid-template-columns: 1fr;
    }
    .h-right {
        width: 100%;
        flex-wrap: wrap;
    }
    .h-sel {
        flex: 1;
        min-width: 180px;
    }
    .map-wrap-tall {
        height: 430px;
        min-height: 430px;
    }
    .map-wrap-tall .map-svg {
        height: auto;
    }
    .sensor-list-panel {
        max-height: 360px;
    }
}
