/* ===== One WASH MIS — shared design system ===== */
:root{
--blue-dark:#0B2545; --blue-primary:#1568B8; --blue-light:#3E8FD8; --blue-50:#EAF2FB; --blue-100:#D6E6F6;
--gold:#F0A62A; --gold-soft:#FBEBD0; --green:#17A34A; --green-soft:#DCF3E4; --red:#E23D3D; --red-soft:#FBE0E0;
--purple:#7A4FD6; --purple-soft:#EDE7FB; --teal:#0E9BA8; --teal-soft:#D6F1F3;
--bg:#F5F8FC; --surface:#FFFFFF; --border:#E6ECF3; --border-strong:#D5DEE9;
--text-dark:#0F2136; --text-mid:#5A6B7C; --text-light:#93A4B5;
--shadow-sm:0 1px 2px rgba(15,40,70,.06),0 1px 3px rgba(15,40,70,.05);
--shadow-md:0 4px 14px rgba(15,40,70,.07);
--shadow-lg:0 14px 40px rgba(15,40,70,.16);
--r:14px; --r-sm:10px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{font-family:'Inter',system-ui,sans-serif;font-size:14px;color:var(--text-dark);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-0.006em;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--text-dark);outline:none;}
input:focus,select:focus,textarea:focus{border-color:var(--blue-light);box-shadow:0 0 0 3px var(--blue-50);}
a{color:var(--blue-primary);text-decoration:none;}
a:hover{text-decoration:underline;}
h1,h2,h3{letter-spacing:-0.02em;}
img{max-width:100%;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:#cdd8e4;border-radius:8px;border:2px solid transparent;background-clip:padding-box;}
::-webkit-scrollbar-thumb:hover{background:#b6c4d3;background-clip:padding-box;}
::-webkit-scrollbar-track{background:transparent;}

/* ---------- Sidebar ---------- */
.sidebar{position:fixed;top:0;left:0;width:248px;height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:40;transition:transform .22s cubic-bezier(.4,0,.2,1);}
.sidebar.collapsed{transform:translateX(-248px);}
.logo-block{height:66px;min-height:66px;display:flex;align-items:center;gap:11px;padding:0 20px;border-bottom:1px solid var(--border);cursor:pointer;}
.logo-block img{height:34px;width:auto;object-fit:contain;}
.logo-block .logo-txt div:first-child{color:var(--text-dark);font-weight:700;font-size:14px;line-height:1.15;letter-spacing:-0.02em;}
.logo-block .logo-txt div:last-child{color:var(--text-light);font-size:10px;font-weight:500;}
.nav{flex:1;overflow-y:auto;padding:10px 12px 16px;}
.nav-band{color:var(--text-light);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:16px 10px 6px;}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;margin:1px 0;color:var(--text-mid);font-size:13.5px;font-weight:500;border-radius:10px;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s;text-decoration:none;}
.nav-item:hover{background:var(--bg);color:var(--text-dark);text-decoration:none;}
.nav-item.active{background:var(--blue-primary);color:#fff;box-shadow:var(--shadow-sm);}
.nav-item.active svg{stroke:#fff;}
.nav-item svg{width:19px;height:19px;flex-shrink:0;stroke:var(--text-light);transition:stroke .12s;}
.nav-item:hover svg{stroke:var(--blue-primary);}
.nav-item .badge-count{margin-left:auto;background:var(--gold);color:#fff;font-size:10px;font-weight:700;border-radius:20px;padding:1px 7px;}
.nav-item.active .badge-count{background:rgba(255,255,255,.25);}
.sidebar-foot{border-top:1px solid var(--border);padding:14px 18px;font-size:10.5px;color:var(--text-light);line-height:1.4;}
.sidebar-foot b{color:var(--text-mid);}

/* ---------- Top bar ---------- */
.topbar{position:fixed;top:0;left:248px;right:0;height:66px;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 26px;z-index:30;transition:left .22s;}
.topbar.full{left:0;}
.hamburger{width:20px;height:20px;stroke:var(--text-mid);flex-shrink:0;cursor:pointer;}
.page-title{font-size:19px;font-weight:700;color:var(--text-dark);white-space:nowrap;}
.topbar-search{margin-left:auto;position:relative;}
.topbar-search input{width:300px;padding:9px 13px 9px 36px;border:1px solid var(--border);border-radius:12px;background:var(--bg);font-size:13px;}
.topbar-search svg{position:absolute;left:12px;top:10px;width:16px;height:16px;stroke:var(--text-light);}
.bell{position:relative;cursor:pointer;width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;transition:background .12s;}
.bell:hover{background:var(--bg);}
.bell svg{width:20px;height:20px;stroke:var(--text-mid);}
.bell .dot{position:absolute;top:4px;right:5px;background:var(--gold);color:#fff;font-size:9px;font-weight:700;border-radius:20px;padding:0 4px;min-width:15px;text-align:center;line-height:15px;height:15px;box-shadow:0 0 0 2px #fff;}
.user-chip{display:flex;align-items:center;gap:10px;cursor:pointer;padding:5px 8px 5px 5px;border-radius:12px;transition:background .12s;}
.user-chip:hover{background:var(--bg);}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue-primary),var(--blue-light));color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.user-meta div:first-child{font-size:13px;font-weight:600;line-height:1.15;}
.user-meta div:last-child{font-size:11px;color:var(--text-light);}
.lang-toggle{font-size:12px;color:var(--text-mid);font-weight:600;padding:6px 10px;border:1px solid var(--border);border-radius:10px;cursor:pointer;}
.lang-toggle b{color:var(--blue-primary);}
.user-menu{position:absolute;top:52px;right:0;width:246px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .16s;z-index:60;}
.user-menu.open{opacity:1;visibility:visible;transform:translateY(0);}
.um-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--text-dark);text-decoration:none;}
.um-item:hover{background:var(--bg);text-decoration:none;}
.um-item svg{width:17px;height:17px;stroke:var(--text-mid);}

/* ---------- Main / layout ---------- */
.main{margin-left:248px;padding:88px 30px 48px;transition:margin-left .22s;}
.main.full{margin-left:0;}
.wrap{max-width:1360px;}
.breadcrumb{font-size:12.5px;color:var(--text-light);margin-bottom:12px;}
.breadcrumb a{color:var(--text-mid);}
.breadcrumb .sep{margin:0 7px;}
.page-head{margin-bottom:20px;}
.page-head h1{font-size:23px;font-weight:700;}
.page-sub{color:var(--text-mid);font-size:14px;margin-top:3px;}

/* ---------- Cards & generic ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-sm);}
.card-title{font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:16px;letter-spacing:-0.01em;}
.grid{display:grid;gap:18px;}
.row{display:flex;gap:18px;}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:8px;white-space:nowrap;line-height:1.5;}
.badge.green{background:var(--green-soft);color:#0f7a37;}
.badge.gold{background:var(--gold-soft);color:#b0740f;}
.badge.red{background:var(--red-soft);color:#c02b2b;}
.badge.blue{background:var(--blue-50);color:var(--blue-primary);}
.badge.purple{background:var(--purple-soft);color:#5b32b0;}
.badge.grey{background:#eef2f7;color:var(--text-mid);}
.pill{display:inline-block;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:2px 8px;font-size:12px;font-family:ui-monospace,'SF Mono',Menlo,monospace;color:var(--text-mid);letter-spacing:-0.02em;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;padding:10px 17px;border-radius:11px;transition:transform .1s,box-shadow .12s,filter .12s;white-space:nowrap;text-decoration:none;}
.btn:hover{filter:brightness(1.03);text-decoration:none;}
.btn:active{transform:translateY(1px);}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 2px 8px rgba(240,166,42,.3);}
.btn-blue{background:var(--blue-primary);color:#fff;box-shadow:0 2px 8px rgba(21,104,184,.28);}
.btn-green{background:var(--green);color:#fff;}
.btn-outline{background:var(--surface);border:1px solid var(--border-strong);color:var(--text-dark);}
.btn-outline:hover{background:var(--bg);}
.btn-outline-red{background:var(--surface);border:1px solid var(--red);color:var(--red);}
.btn-outline-gold{background:var(--surface);border:1px solid var(--gold);color:#b0740f;}
.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:9px;}
.btn-ghost{background:var(--bg);color:var(--text-dark);}

table{width:100%;border-collapse:collapse;font-size:13px;}
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden;}
.table-scroll{overflow-x:auto;}
thead th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg);}
tbody td{padding:13px 14px;border-bottom:1px solid var(--border);color:var(--text-dark);}
tbody tr:last-child td{border-bottom:none;}
tbody tr.clickable{cursor:pointer;transition:background .1s;}
tbody tr.clickable:hover{background:var(--blue-50);}

.tabs{display:flex;gap:4px;background:var(--bg);border:1px solid var(--border);padding:4px;border-radius:12px;margin-bottom:20px;width:fit-content;max-width:100%;overflow-x:auto;}
.tab{padding:8px 16px;font-size:13px;font-weight:600;color:var(--text-mid);border-radius:9px;cursor:pointer;white-space:nowrap;transition:all .12s;}
.tab:hover{color:var(--text-dark);}
.tab.active{color:var(--blue-primary);background:var(--surface);box-shadow:var(--shadow-sm);}

.field label{display:block;font-size:12px;font-weight:600;color:var(--text-mid);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:#fff;}
.input-sm{padding:8px 11px;border:1px solid var(--border-strong);border-radius:9px;background:#fff;font-size:13px;}
.banner{background:var(--gold-soft);border:1px solid #f3ddb5;border-radius:12px;padding:14px 18px;font-size:14px;color:var(--text-dark);}
.banner.blue{background:var(--blue-50);border-color:var(--blue-100);}
.filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:18px;box-shadow:var(--shadow-sm);}
.filter-bar .field{min-width:130px;}

/* ---------- CHART CONTAINERS (fixes overflow) ---------- */
.chart{position:relative;width:100%;}
.chart>canvas{position:absolute;inset:0;width:100%!important;height:100%!important;}
.chart.h140{height:140px;} .chart.h180{height:180px;} .chart.h220{height:220px;}
.chart.h260{height:260px;} .chart.h300{height:300px;} .chart.h340{height:340px;}
.spark{position:relative;height:38px;margin-top:10px;}
.spark>canvas{position:absolute;inset:0;width:100%!important;height:100%!important;}

/* ---------- KPI ---------- */
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s;}
.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.kpi-ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.kpi .lbl{font-size:12.5px;color:var(--text-mid);font-weight:600;}
.kpi .val{font-size:28px;font-weight:700;color:var(--text-dark);margin:3px 0 4px;letter-spacing:-0.03em;}
.kpi .delta{font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px;}

.iswitch{position:relative;width:40px;height:23px;background:#cdd8e4;border-radius:20px;cursor:pointer;transition:background .18s;flex-shrink:0;}
.iswitch.on{background:var(--blue-primary);}
.iswitch::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;background:#fff;border-radius:50%;transition:left .18s;box-shadow:0 1px 3px rgba(0,0,0,.25);}
.iswitch.on::after{left:19px;}
.timeline{position:relative;padding-left:24px;}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--border-strong);}
.tl-item{position:relative;padding:0 0 20px;}
.tl-item::before{content:"";position:absolute;left:-22px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--blue-primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--border-strong);}
.tl-item .d{font-size:12px;color:var(--text-light);}
.tl-item .a{font-weight:600;font-size:13px;}
.hidden{display:none!important;}
.region-poly{stroke:#fff;stroke-width:1.5;cursor:pointer;transition:opacity .15s;}
.region-poly:hover{opacity:.82;}
.map-tooltip{position:fixed;z-index:130;background:var(--blue-dark);color:#fff;font-size:12px;padding:9px 12px;border-radius:9px;pointer-events:none;display:none;box-shadow:var(--shadow-lg);}
.map-tooltip b{display:block;margin-bottom:3px;font-size:13px;}

/* ---------- Toast / Modal ---------- */
#toast-wrap{position:fixed;top:78px;right:26px;z-index:120;display:flex;flex-direction:column;gap:12px;}
.toast{min-width:290px;max-width:410px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:12px;box-shadow:var(--shadow-lg);padding:14px 18px;font-size:13.5px;color:var(--text-dark);animation:slideIn .28s cubic-bezier(.2,.8,.2,1);display:flex;gap:11px;align-items:flex-start;}
.toast.warn{border-left-color:var(--gold);}
.toast svg{width:18px;height:18px;flex-shrink:0;margin-top:1px;}
.toast.fade{animation:fadeOut .4s forwards;}
@keyframes slideIn{from{transform:translateX(30px);opacity:0;}to{transform:translateX(0);opacity:1;}}
@keyframes fadeOut{to{opacity:0;transform:translateX(30px);}}
@keyframes pop{from{transform:scale(.96);opacity:0;}to{transform:scale(1);opacity:1;}}
#overlay{position:fixed;inset:0;background:rgba(11,37,69,.42);backdrop-filter:blur(3px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px;}
#overlay.show{display:flex;}
.modal{background:var(--surface);border-radius:16px;max-width:530px;width:100%;box-shadow:var(--shadow-lg);animation:pop .2s;max-height:90vh;overflow:auto;}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-head h3{font-size:17px;}
.modal-body{padding:24px;}
.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;}
.close-x{width:22px;height:22px;stroke:var(--text-mid);cursor:pointer;}

/* ---------- Home / feature tiles ---------- */
.hero-card{background:linear-gradient(120deg,#0B2545 0%,#144a86 55%,#1568B8 100%);border-radius:20px;padding:34px 36px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-md);}
.hero-card h1{font-size:26px;font-weight:700;}
.feature-tile{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;cursor:pointer;transition:transform .13s,box-shadow .13s,border-color .13s;box-shadow:var(--shadow-sm);display:block;text-decoration:none;color:inherit;}
.feature-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--blue-100);text-decoration:none;}
.feature-ic{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.feature-ic svg{width:22px;height:22px;}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;text-decoration:none;}
.chip:hover{border-color:var(--blue-100);color:var(--blue-primary);text-decoration:none;}

/* ---------- Kanban ---------- */
.kb-col{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:12px;}
.kb-card{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:13px;margin-bottom:10px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .1s,box-shadow .1s;text-decoration:none;color:inherit;display:block;}
.kb-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none;}

@media(max-width:900px){.grid{grid-template-columns:1fr!important;}.row{flex-direction:column;}.main{padding-left:20px;padding-right:20px;}}

/* ===================== Loaders ===================== */
@keyframes spin{to{transform:rotate(360deg);}}
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--border-strong);border-top-color:var(--blue-primary);animation:spin .8s linear infinite;}
.spinner.sm{width:20px;height:20px;border-width:2.5px;}
.spinner.lg{width:46px;height:46px;border-width:4px;}
#page-loader{position:fixed;inset:0;background:rgba(245,248,252,.72);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;z-index:220;flex-direction:column;gap:14px;}
#page-loader.show{display:flex;}
#page-loader .pl-txt{font-size:13px;color:var(--text-mid);font-weight:600;}
#np{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--blue-light));z-index:240;transition:width .3s ease,opacity .3s;box-shadow:0 0 8px rgba(240,166,42,.5);}
.map-loading{position:absolute;inset:0;background:rgba(245,248,252,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:5;font-size:13px;color:var(--text-mid);}
@keyframes shimmer{100%{background-position:-200% 0;}}
.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#e2e9f1 37%,#eef2f7 63%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px;}

/* Google Translate widget — hide chrome */
#google_translate_element{display:none;}
.goog-te-banner-frame,.goog-te-gadget-icon,.goog-logo-link{display:none!important;}
.goog-te-gadget{height:0;overflow:hidden;}
body{top:0!important;}
.skiptranslate>iframe{display:none!important;visibility:hidden!important;}

/* ===================== Status / uptime ===================== */
.uptime-bars{display:flex;gap:2px;align-items:flex-end;height:34px;}
.up-bar{flex:1;height:100%;border-radius:2px;background:var(--green);min-width:2px;}
.up-bar.warn{background:var(--gold);}
.up-bar.down{background:var(--red);}
.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;}
.status-dot.up{background:var(--green);}
.status-dot.deg{background:var(--gold);}
.status-dot.down{background:var(--red);}

/* Sidebar backdrop (mobile) */
#sidebar-backdrop{position:fixed;inset:0;background:rgba(11,37,69,.4);z-index:35;display:none;}
#sidebar-backdrop.show{display:block;}

/* ===================== Responsive ===================== */
@media(max-width:1200px){
  .grid[data-cols4]{grid-template-columns:repeat(2,1fr)!important;}
}
/* Grid stacking only — sidebar stays put at these widths */
@media(max-width:1024px){
  .grid{grid-template-columns:1fr 1fr!important;}
  .row{flex-direction:column;}
  .row>*{flex:1 1 auto!important;width:100%;}
  #kanban{grid-template-columns:repeat(2,1fr)!important;}
}
/* Genuine mobile — sidebar becomes off-canvas (hamburger) */
@media(max-width:820px){
  .sidebar{transform:translateX(-248px);box-shadow:var(--shadow-lg);}
  .sidebar.open{transform:translateX(0);}
  .topbar{left:0!important;}
  .main{margin-left:0!important;}
  .topbar-search{display:none;}
  .login-split{flex-direction:column!important;}
  .login-brand{display:none!important;}
}
@media(max-width:680px){
  .main{padding:80px 16px 40px;}
  .grid{grid-template-columns:1fr!important;}
  #kanban{grid-template-columns:1fr!important;}
  .tabs{width:100%;}
  .page-head h1{font-size:20px;}
  .user-meta{display:none;}
  .lang-toggle{display:none;}
  .hero-card{padding:24px 20px;}
  .hero-card h1{font-size:22px;}
  .modal{max-width:100%;}
  .filter-bar .field{min-width:calc(50% - 6px);}
  table{font-size:12px;}
  thead th,tbody td{padding:10px 9px;}
}
@media(max-width:680px){.pheroh1{font-size:26px!important;} .status-dot{min-width:10px;}}
