:root {
  --bg: #080c16;
  --surface: #0f1624;
  --surface2: #141e2f;
  --surface3: #1a2540;
  --orange: #f97316;
  --orange-dim: rgba(249,115,22,0.12);
  --teal: #14b8a6;
  --teal-dim: rgba(20,184,166,0.1);
  --yellow: #fbbf24;
  --green: #22c55e;
  --red: #ef4444;
  --blue: #3b82f6;
  --purple: #a78bfa;
  --text: #e2e8f0;
  /* --text-muted: #4a5568; */
  --text-muted: #94a3b8;
  --text-dim: #94a3b8;
  --border: rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.1);
  --sidebar-w: 260px;
  --sidebar-collapsed: 60px;
  --header-h: 90px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Barlow',sans-serif;
  min-height:100vh;
  overflow:auto;
  display:flex;
  flex-direction:column;
}

.app-body{
  display:flex;
  flex:1;
  min-height:0;
  overflow:auto;
}

.main-content{
  flex:1;
  overflow:auto;
  display:flex;
  flex-direction:column;
  min-height:0;
}

.page{
  display:none;
  flex:1;
  overflow:auto;
  min-height:0;
}

.page.active{
  display:flex;
  flex-direction:column;
  overflow:auto;
  min-height:0;
}
/* ─── HEADER ─────────────────────────────── */
.app-header {
  /* height: var(--header-h); */
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 20px 0 0;
  gap: 0;
  flex-shrink: 0;
  position: relative;
  z-index: 2000;
}
.header-brand {
  width: var(--sidebar-w);
  flex: 1;   /* ยืดเต็มพื้นที่ */
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 18px;
  /* border-right: 1px solid var(--border); */
  height: 100%;
}
.brand-icon {
  width: 32px; height: 32px;
  background: var(--orange);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.brand-text {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text);
}
.brand-sub { font-size: 10px; font-weight: 400; color: var(--text-muted); letter-spacing: 1px; }

.header-goal {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 24px;
  border-right: 1px solid var(--border);
  height: 100%;
}
.goal-item { text-align: center; padding: 0 20px; }
.goal-lbl { font-size: 9px; letter-spacing: 2px; color: var(--text-muted); text-transform: uppercase; }
.goal-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px; font-weight: 800;
  color: var(--orange);
  text-shadow: 0 0 20px rgba(249,115,22,0.5);
  line-height: 1;
}
.goal-unit { font-size: 9px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
.goal-sep { width: 1px; height: 36px; background: var(--border); margin: 0 4px; }

.header-stats {
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 0 24px;
  flex: 1;
}
.hstat { text-align: center; }
.hstat-lbl { font-size: 9px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
.hstat-val { font-family:'Barlow Condensed',sans-serif; font-size:18px; font-weight:700; color:var(--teal); }
.hstat-unit { font-size:10px; color:var(--text-muted); }

.header-right { display: flex; align-items: center; gap: 12px; margin-left: auto; }
.live-pill {
  display: flex; align-items: center; gap: 6px;
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.25);
  border-radius: 20px; padding: 4px 12px;
  font-size: 10px; font-weight: 700; color: var(--green); letter-spacing: 1px;
}
.live-dot { width:6px;height:6px;background:var(--green);border-radius:50%;animation:blink 1.5s infinite; }
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.clock-badge {
  font-family:'Barlow Condensed',sans-serif;
  font-size:20px;font-weight:700;color:var(--text-dim);
  padding: 0 8px;
}

/* ─── BODY LAYOUT ─────────────────────────── */
.app-body { display:flex; flex:1; overflow:hidden; }

/* ─── SIDEBAR ─────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: width 0.3s ease;
}
.sidebar.collapsed { width: var(--sidebar-collapsed); }

.nav-section-label {
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text-muted);
  text-transform: uppercase;
  padding: 16px 18px 6px;
  white-space: nowrap;
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.2s;
}
.sidebar.collapsed .nav-section-label { opacity: 0; }

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 18px;
  cursor: pointer;
  border-radius: 0;
  transition: all 0.2s;
  position: relative;
  white-space: nowrap;
  overflow: hidden;
  border-left: 3px solid transparent;

  text-decoration: none;
  color: inherit;
}
.nav-item:hover { background: var(--surface2); }
.nav-item.active {
  background: var(--orange-dim);
  border-left-color: var(--orange);
  text-decoration: none;
  color: inherit;
}
.nav-item.active .nav-icon { color: var(--orange); }
.nav-item.active .nav-label { color: var(--text); font-weight: 600; }

.nav-icon { font-size: 16px; flex-shrink: 0; width: 20px; text-align: center; }
.nav-label { font-size: 13px; color: var(--text-dim); transition: opacity 0.2s; }
.sidebar.collapsed .nav-label { opacity: 0; pointer-events: none; }

.nav-badge {
  margin-left: auto;
  background: var(--orange);
  color: white;
  font-size: 9px;
  font-weight: 700;
  border-radius: 10px;
  padding: 1px 6px;
  transition: opacity 0.2s;
}
.sidebar.collapsed .nav-badge { opacity: 0; }

.sidebar-footer {
  margin-top: auto;
  border-top: 1px solid var(--border);
  padding: 12px 0;
}
.collapse-btn {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px; cursor: pointer;
  color: var(--text-muted); font-size: 13px;
  transition: all 0.2s; white-space: nowrap; overflow: hidden;
}
.collapse-btn:hover { color: var(--text); background: var(--surface2); }
.collapse-icon { font-size:16px; width:20px; text-align:center; flex-shrink:0; transition: transform 0.3s; }
.sidebar.collapsed .collapse-icon { transform: rotate(180deg); }
.sidebar.collapsed .collapse-label { opacity:0; }
.collapse-label { transition: opacity 0.2s; }

.account-wrapper {
    position: relative;
}

.account-btn {
    background: var(--surface2);  
    color: var(--text-dim);       
    padding: 6px 12px;
    border-radius: 8px;
    cursor: pointer;

    font-family: 'Barlow', sans-serif;  
    font-size: 11px;                    
    font-weight: 600;
    letter-spacing: 0.5px;

    display: flex;
    align-items: center;
    gap: 6px;

    border: 1px solid var(--border);
    transition: all 0.2s;
}

.account-btn:hover {
    color: var(--text);
    background: var(--surface3);
    border-color: var(--border2);
}

/* ✅ เพิ่มตัวนี้ */
.account-menu {
    position: absolute;
    right: 0;
    top: 110%;
    background: var(--surface);
    border-radius: 10px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.4);
    display: none;
    min-width: 150px;
    overflow: hidden;
    border: 1px solid var(--border);
}

.account-menu a {
    display: block;
    padding: 10px;
    text-decoration: none;
    color: var(--text-dim);
    font-size: 12px;
}

.account-menu a:hover {
    background: var(--surface2);
    color: var(--text);
}



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

/* PAGE: hidden/visible */
.page { display: none; flex: 1; overflow: hidden; }
.page.active { display: flex; flex-direction: column; overflow: hidden; }

/* ─── PAGE: OVERVIEW ─────────────────────────── */
.overview-layout {
  display: grid;
  grid-template-columns: 260px 1fr 280px;
  flex: 1;
  overflow: hidden;
}

.left-panel {
  background: var(--surface);
  border-right: 1px solid var(--border);
  padding: 14px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 10px;
}
.panel-title {
  font-size: 9px; letter-spacing: 2px; color: var(--text-muted);
  text-transform: uppercase; padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.ov-row { display: flex; gap: 8px; }
.ov-card {
  flex:1; background:var(--surface2); border-radius:8px;
  border:1px solid var(--border); padding:10px; text-align:center;
}
.ov-lbl { font-size:9px; color:var(--text-muted); margin-bottom:2px; }
.ov-val { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:700; color:var(--orange); text-shadow:0 0 16px rgba(249,115,22,0.4); }
.ov-unit { font-size:9px; color:var(--text-muted); }

.flow-box { background:var(--surface2); border-radius:8px; border:1px solid var(--border); padding:12px; }
.flow-nodes { display:flex; align-items:center; justify-content:space-around; margin-bottom:10px; }
.fnode { text-align:center; }
.ficon { width:40px;height:40px;border-radius:50%;margin:0 auto 4px;display:flex;align-items:center;justify-content:center;font-size:17px;border:2px solid; }
.ficon.sol{background:rgba(251,191,36,0.1);border-color:var(--yellow);}
.ficon.grd{background:rgba(59,130,246,0.1);border-color:var(--blue);}
.ficon.ld{background:rgba(249,115,22,0.1);border-color:var(--orange);}
.fnum{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--text);}
.flbl{font-size:9px;color:var(--text-muted);}
.farrow{font-size:20px;color:var(--orange);opacity:0.5;animation:arrowFade 2s infinite;}
@keyframes arrowFade{0%,100%{opacity:0.3}50%{opacity:0.9}}

.pbar-row{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted);margin-bottom:3px;}
.pbar-track{height:4px;background:rgba(255,255,255,0.05);border-radius:2px;overflow:hidden;}
.pbar-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--yellow));border-radius:2px;}

.stat-row{background:var(--surface2);border-radius:8px;border:1px solid var(--border);padding:9px 12px;display:flex;align-items:center;gap:10px;}
.sicon{width:30px;height:30px;background:var(--orange-dim);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}


.sinfo{flex:1;}
.sname{font-size:10px;color:var(--text-dim);}
.sval{font-family:'Barlow Condensed',sans-serif;font-size:19px;font-weight:700;color:var(--text);}
.ssuf{font-size:10px;color:var(--text-muted);margin-left:2px;}

/* Center map */
.map-area {
  position:relative;background:var(--surface2);overflow:hidden;
}
.map-bg {
  width:100%;height:100%;
  background:radial-gradient(ellipse at 35% 45%,rgba(20,184,166,0.05) 0%,transparent 55%),
             radial-gradient(ellipse at 65% 55%,rgba(249,115,22,0.04) 0%,transparent 50%),
             linear-gradient(180deg,#0c1828 0%,#080e1a 100%);
  position:relative;display:flex;align-items:center;justify-content:center;
}
.grid-svg{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0.03;pointer-events:none;}

.site-node {
  position:absolute;background:rgba(8,12,22,0.88);border:1px solid var(--teal);
  border-radius:8px;padding:7px 11px;font-size:11px;backdrop-filter:blur(8px);
  cursor:pointer;transition:all 0.2s;min-width:130px;
}
.site-node:hover{border-color:var(--orange);transform:translateY(-2px);background:rgba(15,22,36,0.95);}
.node-name{color:var(--teal);font-weight:600;font-size:11px;}
.node-kw{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--text);}
.node-cap{font-size:9px;color:var(--text-muted);}
.ndot{width:8px;height:8px;background:var(--teal);border-radius:50%;box-shadow:0 0 10px var(--teal);position:absolute;top:-4px;left:-4px;}
.n-ho1{bottom:24%;right:10%;}
.n-ho2{top:20%;right:16%;}
.n-cp{bottom:18%;left:12%;}

.weather-strip {
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(8,12,22,0.92);border-top:1px solid var(--border);
  padding:8px 20px;display:flex;align-items:center;gap:20px;backdrop-filter:blur(8px);
}
.wclock{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:var(--teal);}
.witem{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim);}
.wval{font-weight:600;color:var(--text);}
.wlast{margin-left:auto;font-size:9px;color:var(--text-muted);}


/* ลบพื้นหลังทั้งหมด */
.leaflet-popup-content-wrapper {
  background: transparent !important;
  box-shadow: none !important;
}

.leaflet-popup-tip {
  display: none;
}

.leaflet-popup-content {
  margin: 0;
}

.leaflet-control-attribution {
    display: none !important;
}

/* 🔥 card style */
.site-node {
  background: #0f172a;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid;
  min-width: 140px;
  position: relative;
  box-shadow: 0 10px 25px rgba(0,0,0,0.4);
}

.site-node .ndot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  position: absolute;
  top: 10px;
  right: 10px;
}

.node-name {
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 4px;
}

.node-kw {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
}

.node-cap {
  font-size: 11px;
  color: #94a3b8;
}
.panel-title {
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 6px;
}

.info-icon {
    position: relative;
    cursor: pointer;
    color: #3b82f6;
    font-size: 0.9em;
}

.tooltip {
    display: none;
    position: absolute;
    top: 120%; /* ข้างล่างไอคอน */
    left: 5px;   /* เริ่มจากซ้ายไอคอน */
    transform: translateX(-60%); /* เลื่อนครึ่งหนึ่งไปทางซ้าย */
    background: #333;
    color: #fff;
    padding: 8px;
    border-radius: 6px;
    font-size: 1em;
    line-height: 1.8; 
    white-space: normal;
    z-index: 10;
    min-width: 200px;
}

.info-icon:hover .tooltip {
    display: block;
}

/* Right panel */
.right-panel{background:var(--surface);border-left:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;}
.gauge-row{display:flex;gap:8px;}
.gcrd{flex:1;background:var(--surface2);border-radius:8px;border:1px solid var(--border);padding:10px 6px;text-align:center;}
.glbl{font-size:9px;color:var(--text-muted);margin-bottom:3px;}
.gval{font-family:'Barlow Condensed',sans-serif;font-size:21px;font-weight:700;}
.gval.or{color:var(--orange);text-shadow:0 0 14px rgba(249,115,22,0.4);}
.gval.te{color:var(--teal);text-shadow:0 0 14px rgba(20,184,166,0.4);}
.gval.ye{color:var(--yellow);}
.gunit{font-size:9px;color:var(--text-muted);}
/* .chart-box{background:var(--surface2);border-radius:8px;border:1px solid var(--border);padding:12px;flex:1;min-height:0;} */
.chart-box{
    background:var(--surface2);
    border-radius:8px;
    border:1px solid var(--border);
    padding:12px;
    /* flex:1; ❌ เอาออก */
    min-height:0;
}
.ctitle{font-size:9px;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;}
.chart-wrap{position:relative;}

.sites-tbl{width:100%;border-collapse:collapse;font-size:11px;}
.sites-tbl th{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;text-align:left;padding:3px 6px;border-bottom:1px solid var(--border);}
.sites-tbl td{padding:6px 6px;border-bottom:1px solid rgba(255,255,255,0.025);color:var(--text-dim);}
.sites-tbl td.v{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--text);}
.sites-tbl td.ok{color:var(--green);}
/* .sdot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--green);margin-right:4px;box-shadow:0 0 5px var(--green);} */

.ok { 
  color: #22c55e; 
}

.bad { 
  color: #ef4444; 
}

.sdot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor; /* ใช้สีเดียวกับ text */
  margin-right: 6px;
  box-shadow: 0 0 5px currentColor; /* glow ตามสี */
}

/* ─── PAGE: ANALYTICS ──────────────────────── */
.analytics-layout {
  flex:1;overflow-y:auto;padding:20px;
  display:flex;flex-direction:column;gap:16px;
}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;}
.page-title{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--text);}
.page-sub{font-size:12px;color:var(--text-muted);}
.tab-row{display:flex;gap:4px;background:var(--surface);border-radius:8px;padding:4px;border:1px solid var(--border);width:fit-content;}
.tab-btn{padding:5px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-dim);transition:all 0.2s;border:none;background:none;}
.tab-btn.active{background:var(--surface2);color:var(--orange);border:1px solid rgba(249,115,22,0.3);}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.kpi-card{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:16px 18px;position:relative;overflow:hidden;}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.kpi-card.or::before{background:var(--orange);}
.kpi-card.te::before{background:var(--teal);}
.kpi-card.gn::before{background:var(--green);}
.kpi-card.bl::before{background:var(--blue);}
.kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.kpi-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;}
.kpi-trend{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;}
.kpi-trend.up{background:rgba(34,197,94,0.1);color:var(--green);}
.kpi-trend.dn{background:rgba(239,68,68,0.1);color:var(--red);}
.kpi-lbl{font-size:10px;color:var(--text-muted);margin-bottom:3px;}
.kpi-num{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:var(--text);}
.kpi-unit{font-size:11px;color:var(--text-muted);margin-left:4px;}

.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:16px;}
.chart-card{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:16px;}
.ccard-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px;}
.ccard-sub{font-size:10px;color:var(--text-muted);margin-bottom:14px;}
.chart-h{position:relative;height:200px;}


/* ─── PAGE: SITES ──────────────────────────── */
.sites-layout{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;}
.sites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.site-card{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:16px;position:relative;overflow:hidden;cursor:pointer;transition:all 0.25s;}
.site-card:hover{border-color:var(--teal);transform:translateY(-2px);}
.site-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--teal);}
.sc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;}
.sc-name{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--text);}
.sc-status{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:600;color:var(--green);}
.sc-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);}
.sc-kw{font-family:'Barlow Condensed',sans-serif;font-size:36px;font-weight:800;color:var(--orange);line-height:1;text-shadow:0 0 20px rgba(249,115,22,0.3);}
.sc-kwlbl{font-size:11px;color:var(--text-muted);margin-bottom:12px;}
.sc-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.sc-stat{background:var(--surface2);border-radius:6px;padding:8px;}
.sc-slbl{font-size:9px;text-transform:uppercase;letter-spacing:1px;}
.sc-sval{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--text);}
.sc-pbar{margin-top:12px;}
.sc-prow{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);margin-bottom:4px;}
.sc-track{height:4px;background:rgba(255,255,255,0.05);border-radius:2px;overflow:hidden;}
.sc-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--blue));}
.edit-btn {
  text-decoration: none;  /* ❌ เอาขีดใต้ออก */
  color: inherit;         /* ✅ ใช้สีตาม parent (ไม่เป็นฟ้า) */
}

/* ─── PAGE: ALERTS ──────────────────────────── */
.alerts-layout{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;}
.alert-filters{display:flex;gap:8px;flex-wrap:wrap;}
.filter-btn{padding:5px 14px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);transition:all 0.2s;}
.filter-btn.active{background:var(--orange-dim);border-color:var(--orange);color:var(--orange);}
.alert-list{display:flex;flex-direction:column;gap:8px;}
.alert-item{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:14px 16px;display:flex;align-items:flex-start;gap:14px;transition:all 0.2s;}
.alert-item:hover{border-color:var(--border2);}
.alert-item.warn{border-left:3px solid var(--yellow);}
.alert-item.info{border-left:3px solid var(--blue);}
.alert-item.ok{border-left:3px solid var(--green);}
.alert-item.err{border-left:3px solid var(--red);}
.aicon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.aicon.warn{background:rgba(251,191,36,0.1);}
.aicon.info{background:rgba(59,130,246,0.1);}
.aicon.ok{background:rgba(34,197,94,0.1);}
.aicon.err{background:rgba(239,68,68,0.1);}
.ainfo{flex:1;}
.atitle{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;}
.adesc{font-size:11px;color:var(--text-dim);}
.ameta{text-align:right;flex-shrink:0;}
.atime{font-size:10px;color:var(--text-muted);}
.abadge{display:inline-block;font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:4px;}
.abadge.warn{background:rgba(251,191,36,0.1);color:var(--yellow);}
.abadge.info{background:rgba(59,130,246,0.1);color:var(--blue);}
.abadge.ok{background:rgba(34,197,94,0.1);color:var(--green);}
.abadge.err{background:rgba(239,68,68,0.1);color:var(--red);}

/* ═══════════ PAGE: BILLING ═══════════ */
.bill-top-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.bill-card{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:16px 18px;position:relative;overflow:hidden;}
.bill-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.bill-card.or::before{background:var(--orange);}
.bill-card.gn::before{background:var(--green);}
.bill-card.te::before{background:var(--teal);}
.bill-card.pu::before{background:var(--purple);}
.bill-lbl{font-size:10px;color:var(--text-muted);margin-bottom:6px;}
.bill-amt{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:800;color:var(--text);}
.bill-currency{font-size:14px;color:var(--text-dim);}
.bill-sub{font-size:10px;color:var(--text-muted);margin-top:4px;}
.bill-trend{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;margin-top:6px;}
.bill-trend.save{background:rgba(34,197,94,.1);color:var(--green);}
.bill-trend.pay{background:rgba(249,115,22,.1);color:var(--orange);}

.bill-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px;}

/* Invoice card */
.invoice-section{background:var(--surface);border-radius:12px;border:1px solid var(--border);overflow:hidden;}
.inv-header{background:var(--surface2);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);}
.inv-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--text);}
.inv-badge{font-size:9px;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:1px;text-transform:uppercase;}
.inv-badge.paid{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.2);}
.inv-badge.due{background:rgba(249,115,22,.1);color:var(--orange);border:1px solid rgba(249,115,22,.2);}
.inv-badge.pending{background:rgba(251,191,36,.1);color:var(--yellow);border:1px solid rgba(251,191,36,.2);}

.inv-body{padding:20px;}
.inv-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border);}
.inv-meta-item .iml{font-size:10px;color:var(--text-muted);margin-bottom:2px;}
.inv-meta-item .imv{font-size:13px;font-weight:600;color:var(--text);}

.inv-table{width:100%;border-collapse:collapse;margin-bottom:16px;}
.inv-table th{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;text-align:left;padding:6px 10px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02);}
.inv-table td{padding:10px;border-bottom:1px solid rgba(255,255,255,.03);font-size:12px;color:var(--text-dim);}
.inv-table td.r{text-align:right;}
.inv-table td.bold{font-weight:600;color:var(--text);}
.inv-table td.green{color:var(--green);}
.inv-table td.orange{color:var(--orange);}
.inv-table tr.subtotal td{background:rgba(255,255,255,.02);font-weight:600;color:var(--text);}
.inv-table tr.total-row td{background:var(--orange-dim);font-weight:700;font-size:14px;border-top:1px solid rgba(249,115,22,.2);}
.inv-table tr.total-row td.orange{font-size:16px;font-family:'Barlow Condensed',sans-serif;}

.inv-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--surface2);border-top:1px solid var(--border);}
.inv-note{font-size:11px;color:var(--text-muted);}
.inv-actions{display:flex;gap:8px;}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--text-dim);padding:6px 14px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Barlow',sans-serif;}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange);}
.btn-primary{background:var(--orange);border:none;color:white;padding:6px 16px;border-radius:7px;font-size:11px;font-weight:700;cursor:pointer;transition:opacity .2s;font-family:'Barlow',sans-serif;}
.btn-primary:hover{opacity:.85;}

/* Bill history */
.bill-history{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:10px;}
.bh-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;}
.bh-item{background:var(--surface2);border-radius:8px;border:1px solid var(--border);padding:12px 14px;cursor:pointer;transition:all .2s;}
.bh-item:hover{border-color:var(--border2);}
.bh-item.active-month{border-color:rgba(249,115,22,.35);background:var(--orange-dim);}
.bh-row{display:flex;align-items:center;justify-content:space-between;}
.bh-month{font-size:13px;font-weight:600;color:var(--text);}
.bh-amt{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;}
.bh-sub{font-size:10px;color:var(--text-muted);margin-top:2px;}
.bh-status{font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;}
.bh-status.paid{background:rgba(34,197,94,.1);color:var(--green);}
.bh-status.due{background:rgba(249,115,22,.1);color:var(--orange);}

/* Tariff mini table */
.tariff-box{background:var(--surface2);border-radius:8px;border:1px solid var(--border);padding:12px;}
.tariff-title{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;}
.tariff-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:11px;}
.tariff-row:last-child{border-bottom:none;}
.tariff-name{color:var(--text-dim);}
.tariff-val{font-weight:600;color:var(--text);}
.tariff-val.save{color:var(--green);}

/* ─── PAGE: SETTINGS ──────────────────────────── */
.settings-layout{flex:1;overflow-y:auto;padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:20px;align-content:start;}
.set-section{background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:20px;}
.set-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;}
.set-sub{font-size:11px;color:var(--text-muted);margin-bottom:16px;}
.set-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);}
.set-row:last-child{border-bottom:none;}
.set-lbl{font-size:13px;color:var(--text-dim);}
.set-lbl span{font-size:10px;color:var(--text-muted);display:block;}
.toggle{width:40px;height:22px;background:var(--surface3);border-radius:11px;position:relative;cursor:pointer;transition:background 0.2s;flex-shrink:0;border:1px solid var(--border);}
.toggle.on{background:rgba(249,115,22,0.3);border-color:var(--orange);}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:all 0.2s;}
.toggle.on::after{left:21px;background:var(--orange);}
.set-inp{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:12px;color:var(--text);width:120px;font-family:'Barlow',sans-serif;}
.set-inp[readonly]{
    background:#2a3447;
    color:#94a3b8;
    border:1px solid #3b475e;
    cursor:not-allowed;
}

.set-inp[readonly]:focus{
    border:1px solid #3b475e;
    outline:none;
}
.set-inp:focus{outline:none;border-color:var(--orange);}
.set-select{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:12px;color:var(--text);font-family:'Barlow',sans-serif;cursor:pointer;}
.set-select:focus{outline:none;border-color:var(--orange);}
.set-select:disabled{
    background:#2a3447;
    color:#94a3b8;
    border:1px solid #3b475e;
    cursor:not-allowed;
    opacity:1; /* ป้องกัน browser ทำสีจางเอง */
}

.set-select:disabled:focus{
    border:1px solid #3b475e;
    outline:none;
}
.save-btn{margin-top:0px;background:var(--orange);color:white;border:none;padding:8px 20px;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;transition:opacity 0.2s;}
.save-btn:hover{opacity:0.85;}

.back-btn{
    margin-top:0px;
    background:rgba(255,255,255,0.07);
    color:white;
    border:none;
    padding:8px 20px;
    border-radius:7px;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    transition:opacity 0.2s;
    text-decoration:none; /* เอาเส้นใต้ออก */
    display:inline-block;
}

.back-btn:hover{
    opacity:0.85;
    text-decoration:none;
}

.delete-btn{
  margin-top:0px;
  background:#ef4444; /* red */
  color:white;
  border:none;
  padding:8px 20px;
  border-radius:7px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  transition:all 0.2s;
}

.delete-btn:hover{
  opacity:0.9;
  background:#dc2626; /* เข้มขึ้นตอน hover */
}

.delete-btn:active{
  /* transform:scale(0.96); /* กดแล้วเด้งนิดๆ */
}

.add-btn{
  background: var(--blue);
  color: white;
  border: none;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 12px;
  cursor: pointer;
  transition: 0.2s;
}

.add-btn:hover{
  filter: brightness(1.15);
  box-shadow: 0 0 10px rgba(59,130,246,0.4);
}

.add-btn:active {
    /* transform: scale(0.96); */
}

::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:2px;}

.site-link{
    color:inherit;
    text-decoration:none;
}

.site-link:hover{
    opacity:.85;
}

/* ─── PAGE: LOGIN ──────────────────────────── */
/* 🔥 เพิ่มเฉพาะ login */
/* .login-container {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
} */

/* .login-box {
    width: 340px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 28px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.5);
} */

 .container {
            display: flex;
            width: 100%;
            height: 100%;
        }

        
.login-box {
    width: 100%;
}

.login-title {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 6px;
}

.login-sub {
    font-size: 12px;
    color: var(--text-muted);
    margin-bottom: 20px;
}

.login-input {
    width: 100%;
    margin-bottom: 12px;
    padding: 10px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--surface2);
    color: var(--text);
    font-size: 13px;
}

.login-input:focus {
    outline: none;
    border-color: var(--orange);
}

.login-btn {
    width: 100%;
    padding: 10px;
    border-radius: 6px;
    border: none;
    background: var(--orange);
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    margin-top: 6px;
}

.login-btn:hover {
    opacity: 0.85;
}

.login-error {
    color: var(--red);
    font-size: 12px;
    margin-bottom: 10px;
}








/* ================= MOBILE RESPONSIVE FIX ================= */
@media (max-width: 768px) {

  body {
    height: auto;
    min-height: 100vh;
    overflow: auto;
  }

  .app-header {
    height: auto !important;
    min-height: 64px;
    padding: 10px 12px !important;
    align-items: flex-start !important;
    gap: 10px;
  }

  .header-brand {
    width: auto;
    flex: 1;
    padding: 0 !important;
  }

  .brand-text {
    font-size: 18px !important;
    line-height: 1.05 !important;
  }

  .brand-sub {
    font-size: 10px !important;
  }

  .header-right {
    gap: 6px;
    align-items: center;
  }

  .live-pill {
    padding: 4px 8px;
    font-size: 9px;
  }

  .clock-badge {
    display: none;
  }

  .account-btn {
    padding: 6px 8px;
    font-size: 10px;
  }

  .app-body {
    display: block;
    overflow: visible;
  }

  .sidebar {
    width: 100%;
    height: auto;
    border-right: none;
    border-bottom: 1px solid var(--border);
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .sidebar .nav-section-label,
  .sidebar-footer {
    display: none;
  }

  .nav-item {
    display: inline-flex;
    width: auto;
    padding: 12px 14px;
    border-left: none;
    border-bottom: 3px solid transparent;
  }

  .nav-item.active {
    border-left: none;
    border-bottom-color: var(--orange);
  }

  .nav-label {
    font-size: 12px;
  }

  #analyticsContent {
    position: fixed;
    left: 10px;
    right: 10px;
    top: 120px;
    z-index: 3000;
    border-radius: 12px;
    border: 1px solid var(--border);
    max-height: 60vh;
    overflow: auto;
  }

  .main-content,
  .page,
  .page.active {
    overflow: visible;
    display: block;
  }

  .overview-layout {
    display: flex;
    flex-direction: column;
    height: auto;
    overflow: visible;
  }

  .left-panel,
  .right-panel {
    width: 100% !important;
    position: static !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border-left: none;
    padding: 12px;
  }

  .map-area,
  .map-wrap,
  #map {
    height: 420px !important;
    min-height: 420px;
    position: relative;
  }

  .map-view-toggle {
    top: 10px !important;
    left: 10px !important;
    right: auto !important;
  }

  .gauge-row,
  .ov-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .stat-row {
    padding: 12px;
  }

  .sval {
    font-size: 22px;
  }

  .weather-strip {
    position: static;
    flex-wrap: wrap;
    padding: 10px 12px;
    gap: 10px;
  }

  .wlast {
    margin-left: 0;
  }
}

/* ================= MOBILE: HIDE MENU TEXT ================= */
@media (max-width: 768px) {

  /* ซ่อนชื่อเมนูทั้งหมด */
  /* .nav-label {
    display: none !important;
  } */

  /* ทำให้เมนูเป็น icon ล้วน */
  .nav-item {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 60px;
    padding: 10px 8px !important;
  }

  /* ไอคอนใหญ่ขึ้น */
  .nav-icon {
    font-size: 20px;
    width: auto;
  }

}

@media (max-width: 768px) {

  .nav-item:active::after {
    content: attr(data-label);
    position: absolute;
    bottom: -18px;
    font-size: 10px;
    color: var(--text-muted);
  }

}

/* ================= MOBILE MAP FIX ================= */
@media (max-width: 768px) {

  .map-area {
    width: 100% !important;
    height: 520px !important;
    min-height: 520px !important;
    margin: 0 !important;
    border-radius: 0 !important;
    position: relative !important;
    overflow: hidden !important;
  }

  #map {
    width: 100% !important;
    height: 520px !important;
    min-height: 520px !important;
    border-radius: 0 !important;
    position: absolute !important;
    inset: 0 !important;
  }

  .map-view-toggle {
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
    z-index: 20 !important;
  }

  .map-area > div[style*="position:absolute"] {
    top: 62px !important;
    left: 12px !important;
    width: calc(100% - 24px) !important;
    z-index: 20 !important;
  }

  .maplibregl-popup {
    max-width: 260px !important;
  }

  .maplibregl-popup-content {
    max-width: 260px !important;
  }
}

/* ================= MOBILE SEARCH MOVE RIGHT ================= */
@media (max-width: 768px) {

  .maplibregl-ctrl-top-left,
  .leaflet-top.leaflet-left {
    left: 16px !important;
    right: auto !important;
  }

  .maplibregl-ctrl-geocoder,
  .leaflet-control-geocoder {
    margin-left: 70px !important;
    width: calc(100vw - 120px) !important;
    max-width: 260px;
  }

}
