/* ================================================================
   Operation Workspace — base styles (command-center theme)
   ================================================================ */
:root{
  --blue:#2563EB; --blue-dark:#1D4ED8; --dark:#0F172A; --slate:#475569;
  --amber:#D97706; --green:#16A34A; --red:#DC2626;
  --bg:#F1F5F9; --card:#FFFFFF; --line:#E2E8F0; --muted:#64748B;
  --nav-w:248px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'IBM Plex Sans Thai','IBM Plex Sans','Segoe UI',system-ui,sans-serif;
  background:var(--bg); color:var(--dark); font-size:14px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue);text-decoration:none}
/* Lucide line icons — consistent sizing/stroke everywhere */
.lucide,svg.lucide,[data-lucide]{width:1em;height:1em;stroke-width:1.9;vertical-align:-0.13em;display:inline-block}
.ow-ic .lucide{width:18px;height:18px}

/* ---- Layout: sidebar + content ---- */
.ow-has-nav{padding-left:var(--nav-w)}
#ow-topbar{display:none}
#ow-sidebar{
  position:fixed; top:0; left:0; bottom:0; width:var(--nav-w);
  background:var(--dark); color:#CBD5E1; padding:14px 12px; overflow-y:auto; z-index:50;
  display:flex; flex-direction:column; gap:2px;
}
.ow-brand{display:flex; align-items:center; gap:10px; padding:6px 8px 14px; color:#fff}
.ow-logo-chip{display:inline-grid; place-items:center; width:34px; height:34px; border-radius:9px;
  background:var(--blue); color:#fff; font-weight:700; font-size:14px}
.ow-logo-img{height:30px}
.ow-brand-text{font-weight:700; font-size:15px; color:#fff; line-height:1.15}
.ow-event{padding:8px; background:rgba(255,255,255,.05); border-radius:10px; margin-bottom:10px}
.ow-event label{display:block; font-size:11px; color:#94A3B8; margin-bottom:4px; text-transform:uppercase; letter-spacing:.04em}
.ow-event select{width:100%; padding:8px; border-radius:8px; border:1px solid #334155;
  background:#1E293B; color:#fff; font-family:inherit; font-size:13px}
.ow-nav-group{font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:#64748B;
  margin:14px 8px 6px; font-weight:600}
.ow-nav-link{display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:9px;
  color:#CBD5E1; font-size:13.5px; font-weight:500}
.ow-nav-link:hover{background:rgba(255,255,255,.07); color:#fff}
.ow-nav-link.active{background:var(--blue); color:#fff}
.ow-nav-link.ext{color:#94A3B8}
.ow-nav-link.disabled{color:#475569; cursor:default}
.ow-ic{width:20px; text-align:center}
.ow-soon{margin-left:auto; font-size:10px; background:#1E293B; color:#64748B; padding:1px 7px; border-radius:99px}
.ow-nav-foot{margin-top:auto; display:flex; align-items:center; gap:9px; padding:12px 6px 4px;
  border-top:1px solid #1E293B}
.ow-avatar{width:32px; height:32px; border-radius:50%; background:var(--blue); color:#fff;
  display:grid; place-items:center; font-weight:700; flex:0 0 auto}
.ow-user{display:flex; flex-direction:column; min-width:0}
.ow-user b{color:#fff; font-size:13px}
.ow-user small{color:#64748B; font-size:10.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:120px}
.ow-badge{background:var(--amber); color:#fff; font-size:9px; padding:1px 6px; border-radius:99px; width:fit-content; margin:2px 0}
.ow-logout{margin-left:auto; color:#64748B; font-size:18px; padding:4px 8px}
.ow-logout:hover{color:#fff}

/* ---- Content ---- */
.ow-main{max-width:none; margin:0; padding:26px 28px 60px}
.ow-page-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap}
.ow-page-head h1{margin:0; font-size:24px}
.ow-page-head .sub{color:var(--muted); font-size:13px; margin-top:3px}
.ow-eventpill{background:#fff; border:1px solid var(--line); border-radius:99px; padding:6px 14px;
  font-weight:600; font-size:13px; color:var(--dark)}
.ow-eventpill b{color:var(--blue)}

/* ---- Cards / grid ---- */
.ow-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:14px}
.ow-card{background:var(--card); border:1px solid var(--line); border-radius:14px; padding:16px}
.ow-card h3{margin:0 0 4px; font-size:15px}
.ow-card .meta{color:var(--muted); font-size:12px}
.ow-sec-no{display:inline-grid; place-items:center; width:26px; height:26px; border-radius:8px;
  background:#EFF6FF; color:var(--blue); font-weight:700; font-size:13px; margin-bottom:8px}
.ow-prog{height:8px; border-radius:99px; background:#E2E8F0; overflow:hidden; margin:10px 0 6px}
.ow-prog > i{display:block; height:100%; background:var(--green)}
.ow-prog-label{font-size:11.5px; color:var(--muted)}

.ow-tiles{display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; margin-top:10px}
.ow-tile{display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:14px; color:var(--dark)}
.ow-tile:hover{border-color:var(--blue); box-shadow:0 2px 10px rgba(37,99,235,.08)}
.ow-tile .emoji{font-size:22px}
.ow-tile b{display:block; font-size:14px}
.ow-tile small{color:var(--muted); font-size:11.5px}

/* ---- Table ---- */
.ow-toolbar{display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:14px}
.ow-toolbar .grow{flex:1}
table.ow-tbl{width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line); border-radius:12px; overflow:hidden}
table.ow-tbl th, table.ow-tbl td{padding:10px 12px; text-align:left; border-bottom:1px solid var(--line); font-size:13px; vertical-align:top}
table.ow-tbl th{background:#F8FAFC; color:var(--slate); font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:.03em}
table.ow-tbl tr:last-child td{border-bottom:none}
table.ow-tbl tr:hover td{background:#FAFBFF}
.ow-secchip{font-size:11px; color:var(--slate); background:#F1F5F9; padding:2px 8px; border-radius:99px; white-space:nowrap}

/* ---- Status pills ---- */
.pill{display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:600; padding:3px 10px; border-radius:99px}
.pill::before{content:""; width:7px; height:7px; border-radius:50%; background:currentColor}
.pill.todo{color:var(--red); background:#FEF2F2}
.pill.doing{color:var(--amber); background:#FFFBEB}
.pill.done{color:var(--green); background:#F0FDF4}

/* ---- Buttons / inputs ---- */
.btn{display:inline-flex; align-items:center; gap:6px; border:1px solid var(--line); background:#fff;
  color:var(--dark); padding:8px 14px; border-radius:9px; font-family:inherit; font-size:13px; font-weight:600; cursor:pointer}
.btn:hover{border-color:var(--blue)}
.btn.primary{background:var(--blue); border-color:var(--blue); color:#fff}
.btn.primary:hover{background:var(--blue-dark)}
.btn.sm{padding:5px 10px; font-size:12px}
.btn.danger{color:var(--red); border-color:#FECACA}
input,select,textarea{font-family:inherit; font-size:13px; padding:9px 11px; border:1px solid var(--line);
  border-radius:9px; background:#fff; color:var(--dark); width:100%}
input:focus,select:focus,textarea:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.field{margin-bottom:12px}
.field label{display:block; font-size:12px; font-weight:600; color:var(--slate); margin-bottom:5px}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}

/* ---- Modal ---- */
.ow-modal-bg{position:fixed; inset:0; background:rgba(15,23,42,.5); z-index:200; display:none; align-items:flex-start; justify-content:center; padding:40px 16px; overflow:auto}
.ow-modal-bg.open{display:flex}
.ow-modal{background:#fff; border-radius:16px; width:100%; max-width:560px; padding:22px; box-shadow:0 24px 60px rgba(0,0,0,.3)}
.ow-modal h2{margin:0 0 16px; font-size:18px}
.ow-modal-actions{display:flex; justify-content:flex-end; gap:10px; margin-top:18px}

.ow-empty{text-align:center; color:var(--muted); padding:50px 20px}
.ow-empty .big{font-size:40px; margin-bottom:8px}

/* ---- Segmented toggle (List / Gantt) ---- */
.ow-seg{display:inline-flex; background:#fff; border:1px solid var(--line); border-radius:9px; overflow:hidden}
.ow-seg button{border:none; background:none; padding:7px 14px; font-family:inherit; font-size:13px; font-weight:600; color:var(--slate); cursor:pointer}
.ow-seg button.active{background:var(--blue); color:#fff}
.pill.tl-toggle{border:none; cursor:pointer; font-family:inherit}

/* ---- Timeline (day groups) ---- */
.tl-day{margin-bottom:22px}
.tl-day-head{font-size:15px; font-weight:700; color:var(--dark); margin:0 0 8px; padding-bottom:6px; border-bottom:2px solid var(--blue); display:inline-flex; align-items:center; gap:6px}
.tl-wb{margin-top:2px}

/* ---- Gantt ---- */
.gantt{background:#fff; border:1px solid var(--line); border-radius:12px; padding:14px 16px 18px}
.gantt-axis{position:relative; height:20px; margin-left:170px; border-bottom:1px solid var(--line); margin-bottom:8px}
.gantt-tick{position:absolute; top:0; bottom:-4px; border-left:1px dashed #E2E8F0}
.gantt-tick span{position:absolute; top:0; left:3px; font-size:10px; color:var(--muted); white-space:nowrap}
.gantt-row{display:flex; align-items:center; gap:0; min-height:30px; cursor:pointer; border-radius:6px}
.gantt-row:hover{background:#FAFBFF}
.gantt-label{width:170px; flex:0 0 170px; font-size:12.5px; font-weight:500; padding-right:10px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.gantt-track{position:relative; flex:1; height:24px}
.gantt-bar{position:absolute; top:3px; height:18px; background:var(--blue); color:#fff; border-radius:5px;
  font-size:10.5px; line-height:18px; padding:0 6px; overflow:hidden; white-space:nowrap; min-width:2px}
.gantt-bar.done{background:var(--green)}
.gantt-ms{position:absolute; top:4px; width:14px; height:14px; background:var(--amber); transform:rotate(45deg) translateX(-7px); border-radius:2px}
.gantt-ms.done{background:var(--green)}
@media (max-width:860px){
  .gantt-axis{margin-left:110px}
  .gantt-label{width:110px; flex-basis:110px; font-size:11px}
}

/* ---- RACI / Org board ---- */
.raci-phase{margin-bottom:24px}
.raci-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; margin-top:10px}
.raci-zone{background:#fff; border:1px solid var(--line); border-radius:12px; padding:12px 14px}
.raci-zone-head{font-size:13.5px; font-weight:700; color:var(--dark); margin-bottom:8px; padding-bottom:7px;
  border-bottom:1px solid var(--line); display:flex; align-items:center; gap:7px}
.raci-row{display:flex; align-items:center; gap:8px; padding:7px 4px; border-radius:8px; cursor:pointer; border-bottom:1px solid #F1F5F9}
.raci-row:last-child{border-bottom:none}
.raci-row:hover{background:#FAFBFF}
.raci-main{flex:1; min-width:0}
.raci-main b{font-size:13px; font-weight:600}
.raci-person{display:flex; flex-wrap:wrap; gap:4px; margin-top:4px}
.chip{font-size:11px; background:#EFF6FF; color:var(--blue-dark); padding:1px 8px; border-radius:99px; font-weight:600}
.raci-time{font-size:11px; color:var(--slate); background:#F1F5F9; padding:2px 8px; border-radius:6px; white-space:nowrap; flex:0 0 auto}
.raci-tag{flex:0 0 auto; width:22px; height:22px; border-radius:6px; display:grid; place-items:center;
  font-size:11px; font-weight:700; color:#fff}
.raci-tag.r-R{background:var(--green)} .raci-tag.r-A{background:var(--blue)}
.raci-tag.r-C{background:var(--amber)} .raci-tag.r-I{background:var(--slate)}
.ow-avatar.sm{width:24px; height:24px; font-size:11px}
.pill.skip{color:var(--slate); background:#F1F5F9}
/* inline-editable org rows */
.raci-zone-head .lucide{width:16px;height:16px;color:var(--blue)}
.raci-addbtn{margin-left:auto; border:none; background:none; color:var(--blue); cursor:pointer; padding:3px 5px; border-radius:6px; line-height:0}
.raci-addbtn:hover{background:#EFF6FF}
.raci-row .raci-sel{flex:0 0 auto; width:48px; text-align:center; font-weight:700; padding:6px 2px}
.raci-sel.r-R{color:var(--green)} .raci-sel.r-A{color:var(--blue)} .raci-sel.r-C{color:var(--amber)} .raci-sel.r-I{color:var(--slate)}
.raci-row .raci-time-in{flex:0 0 auto; width:82px}
.raci-row .raci-main{display:flex; flex-direction:column; flex:1; min-width:0}
.tl-day-head .lucide{width:18px;height:18px;color:var(--blue);vertical-align:-0.18em}

/* ---- E5 Field-Data ---- */
.fd-row{display:flex; align-items:center; gap:8px; padding:7px 4px; border-bottom:1px solid #F1F5F9}
.fd-row:last-child{border-bottom:none}
.fd-label{flex:1; font-size:13px; font-weight:500; min-width:0}
.fd-val{width:96px; flex:0 0 96px; text-align:right; font-weight:700; font-size:14px; padding:6px 8px}
.fd-unit{font-size:11.5px; color:var(--muted); width:38px; flex:0 0 38px}
.fd-edit{border:none; background:none; color:var(--muted); cursor:pointer; font-size:13px; padding:4px 6px; border-radius:6px; flex:0 0 auto}
.fd-edit:hover{background:#F1F5F9; color:var(--blue)}
.fd-sum{margin-left:auto; font-size:12px; font-weight:700; color:var(--blue); background:#EFF6FF; padding:2px 10px; border-radius:99px}

/* ---- E6 Run-of-Show ---- */
.ros{background:#fff; border:1px solid var(--line); border-radius:12px; overflow:hidden}
.ros-row{display:flex; gap:12px; padding:11px 14px; border-bottom:1px solid var(--line); cursor:pointer}
.ros-row:last-child{border-bottom:none}
.ros-row:hover{background:#FAFBFF}
.ros-time{flex:0 0 64px; font-weight:700; color:var(--blue); font-size:13.5px}
.ros-body{flex:1; min-width:0}
.ros-body b{font-size:13.5px}
.ros-mc{font-size:12.5px; color:var(--slate); margin-top:3px; font-style:italic}
.ros-photo{font-size:12px; color:var(--amber); margin-top:3px}

/* ---- E8 Checklist ---- */
.ck-row{display:flex; align-items:center; gap:9px; padding:6px 2px}
.ck-box{flex:0 0 auto; width:22px; height:22px; border-radius:6px; border:2px solid var(--line); background:#fff;
  cursor:pointer; color:#fff; font-size:13px; font-weight:700; display:grid; place-items:center; line-height:1}
.ck-box.on{background:var(--green); border-color:var(--green)}
.ck-item{flex:1; font-size:13px; min-width:0}
.ck-item.done{color:var(--muted); text-decoration:line-through}
.ck-qty{font-size:11.5px; color:var(--slate); background:#F1F5F9; padding:2px 8px; border-radius:6px; white-space:nowrap}

/* ---- E7 Leaflet map ---- */
#ow-map{height:520px; border:1px solid var(--line); border-radius:12px; z-index:0}
.leaflet-container{font-family:inherit}

/* ---- Workboard (Asana-like inline-edit + drag-reorder table) ---- */
.wb-group{margin-bottom:20px}
.wb-group-head{display:flex; align-items:center; gap:8px; font-size:14px; font-weight:700; color:var(--dark); margin:0 0 8px}
.wb-group-head .lucide{color:var(--blue); width:18px; height:18px}
table.wb{width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line); border-radius:12px; overflow:hidden}
table.wb th{background:#F8FAFC; color:var(--slate); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.03em; padding:8px 8px; text-align:left; border-bottom:1px solid var(--line)}
table.wb td{padding:3px 6px; border-bottom:1px solid var(--line); vertical-align:middle}
table.wb tr:last-child td{border-bottom:none}
.wb-row.wb-dragging{opacity:.4}
.wb-row.wb-over td{box-shadow:inset 0 2px 0 var(--blue)}
/* Food Plan category tints: F = main dish (green), D = dessert (pink) */
.wb-row.fd-F td{background:rgba(22,163,74,.07)}
.wb-row.fd-F td:first-child{box-shadow:inset 3px 0 0 var(--green)}
.wb-row.fd-D td{background:rgba(236,72,153,.08)}
.wb-row.fd-D td:first-child{box-shadow:inset 3px 0 0 #EC4899}
.wb-drag{width:26px; color:#CBD5E1; cursor:grab; text-align:center}
.wb-drag:active{cursor:grabbing}
.wb-drag .lucide{width:16px; height:16px}
.wb-del{width:34px; text-align:center}
.wb-delbtn{border:none; background:none; color:#CBD5E1; cursor:pointer; padding:5px; border-radius:6px; line-height:0}
.wb-delbtn:hover{color:var(--red); background:#FEF2F2}
.wb-delbtn .lucide{width:15px; height:15px}
.wb-in{width:100%; border:1px solid transparent; background:transparent; border-radius:7px; padding:7px 8px;
  font-family:inherit; font-size:13px; color:var(--dark)}
.wb-in:hover{background:#F8FAFC}
.wb-in:focus{outline:none; background:#fff; border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.12)}
select.wb-in{cursor:pointer}
textarea.wb-in{resize:vertical; line-height:1.4; vertical-align:top; min-height:32px}
/* Logistics symbol legend (click to insert into focused Detail cell) */
.ow-legend{display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin:0 0 14px}
.ow-legend-lbl{font-size:12px; color:var(--muted)}
.ow-legend button{border:1px solid var(--line); background:#fff; border-radius:99px; padding:5px 12px; font-family:inherit; font-size:13px; cursor:pointer; color:var(--dark)}
.ow-legend button:hover{border-color:var(--blue); background:#F8FAFF}
.ow-legend button .lucide{width:15px; height:15px; vertical-align:-2px}
.ow-legend button .lucide+.lucide{margin-left:-3px}

/* ---- Van Diagram (timeline per vehicle, line icons) ---- */
.vd-card{background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px 16px; margin-top:18px}
.vd-title{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; font-size:14px; font-weight:700; margin-bottom:12px}
.vd-title>span:first-child{display:inline-flex; align-items:center; gap:7px}
.vd-key{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:500; color:var(--slate)}
.vd-dot{width:11px; height:11px; border-radius:3px; display:inline-block; border:1px solid}
.vd-dot.vd-tv{background:#EFF6FF; border-color:#93C5FD} .vd-dot.vd-tb{background:#FFFBEB; border-color:#FCD34D}
.vd-scroll{overflow-x:auto}
.vd-grid{display:flex; flex-direction:column; gap:6px; min-width:680px}
.vd-row{display:grid; grid-template-columns:190px repeat(4,1fr); gap:6px; align-items:stretch}
.vd-head .vd-cell{min-height:0; border:none; background:transparent; font-size:11px; text-transform:uppercase; letter-spacing:.03em; color:var(--slate); font-weight:700; justify-content:center; padding:2px 0}
.vd-van{display:flex; align-items:center; font-size:12.5px; color:var(--dark); padding:6px 6px; position:sticky; left:0; background:#fff; z-index:1}
.vd-van b{margin-right:5px} .vd-van small{display:block; color:var(--muted); font-size:10.5px}
.vd-cell{min-height:48px; border:1px dashed var(--line); border-radius:10px; padding:7px 9px; font-size:11.5px; color:var(--slate); display:flex; flex-direction:column; gap:3px; line-height:1.3}
.vd-cell.vd-on{border-style:solid}
.vd-cell.vd-tv{background:#EFF6FF; border-color:#BFDBFE; color:#1E40AF}
.vd-cell.vd-tb{background:#FFFBEB; border-color:#FDE68A; color:#92400E}
.vd-ic{display:inline-flex; align-items:center; gap:3px} .vd-ic .lucide{width:17px; height:17px}
.vd-tx{font-size:11px; opacity:.85}
.vd-idle{color:#CBD5E1}
.vd-empty{color:var(--muted); font-size:13px; padding:8px}

/* ---- Van Planner ---- */
.vp-card{background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px; margin-bottom:18px}
.vp-head{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:12px}
.vp-head b{font-size:15px; display:inline-flex; align-items:center; gap:7px}
.vp-modes{display:inline-flex; background:#F1F5F9; border-radius:9px; padding:3px; gap:2px}
.vp-mode{border:none; background:transparent; padding:6px 12px; border-radius:7px; font-family:inherit; font-size:12.5px; font-weight:600; color:var(--slate); cursor:pointer}
.vp-mode.active{background:#fff; color:var(--blue); box-shadow:0 1px 4px rgba(0,0,0,.08)}
.vp-cfg{display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:13px; color:var(--slate); margin-bottom:12px}
.vp-hint{font-size:11px; color:var(--muted)}
.vp-in{border:1px solid var(--line); border-radius:7px; padding:6px 8px; font-family:inherit; font-size:13px; text-align:center}
.vp-in:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.vp-tbl{border-collapse:collapse; margin-bottom:6px}
.vp-tbl th{font-size:11px; text-transform:uppercase; letter-spacing:.03em; color:var(--slate); font-weight:600; padding:4px 14px 4px 0; text-align:left}
.vp-tbl td{padding:3px 14px 3px 0; font-size:13px}
.vp-calc{font-weight:700; color:var(--blue); font-size:15px}
.vp-note{background:#F8FAFC; border:1px dashed var(--line); border-radius:9px; padding:9px 12px; font-size:12.5px; color:var(--slate)}
.vp-result{border-top:1px solid var(--line); margin-top:8px; padding-top:12px}
.vp-rline{font-size:13px; color:var(--dark); margin-bottom:6px; display:flex; align-items:center; gap:7px}
.vp-rline i{width:15px;height:15px;color:var(--slate)}
.vp-opts{display:flex; gap:10px; flex-wrap:wrap; margin:10px 0}
.vp-opt{border:1px solid var(--line); border-radius:10px; padding:9px 14px; min-width:180px}
.vp-opt.best{border-color:var(--green); background:#F0FDF4}
.vp-opt .t{font-size:11.5px; color:var(--slate)}
.vp-opt .v{font-size:15px; font-weight:700; margin-top:2px}
.vp-suggest{font-size:13px; color:#15803D; display:flex; align-items:center; gap:7px; margin:4px 0 10px}
.vp-suggest i{width:15px;height:15px}
.vp-total{display:flex; align-items:center; justify-content:space-between; background:#EFF6FF; border-radius:10px; padding:10px 14px; font-size:13px}
.vp-total b{font-size:18px; color:var(--blue)}
/* hide number spinners so digits aren't clipped in dense numeric tables */
.wb-in[type=number]::-webkit-inner-spin-button,.wb-in[type=number]::-webkit-outer-spin-button{-webkit-appearance:none; margin:0}
.wb-in[type=number]{-moz-appearance:textfield}
.wb-in.st-todo,.wb-in.st-pending{color:var(--red); font-weight:600}
.wb-in.st-doing{color:var(--amber); font-weight:600}
.wb-in.st-done{color:var(--green); font-weight:600}
.wb-in.st-skip{color:var(--slate); font-weight:600}
.wb-in.st-R{color:var(--green); font-weight:700} .wb-in.st-A{color:var(--blue); font-weight:700}
.wb-in.st-C{color:var(--amber); font-weight:700} .wb-in.st-I{color:var(--slate); font-weight:700}
.wb-add{margin-top:10px; color:var(--blue); border-style:dashed}
.wb-add .lucide{width:15px; height:15px}
.wb-check{display:grid; place-items:center; width:24px; height:24px; margin:0 auto; border-radius:6px;
  border:2px solid var(--line); background:#fff; color:#fff; cursor:pointer; line-height:0}
.wb-check.on{background:var(--green); border-color:var(--green)}
.wb-check .lucide{width:15px; height:15px}
.wb-url{display:flex; align-items:center; gap:3px}
.wb-url .wb-in{flex:1; min-width:0}
.wb-open{flex:0 0 auto; color:var(--blue); padding:5px; border-radius:6px; line-height:0}
.wb-open:hover{background:#EFF6FF}
.wb-open .lucide{width:15px; height:15px}
/* layered-list group icon (Map) */
.tl-day-head .layer-ic{width:18px;height:18px;vertical-align:-0.18em;margin-right:4px}

/* ---- Mobile ---- */
@media (max-width:860px){
  .ow-has-nav{padding-left:0; padding-top:52px}
  #ow-topbar{display:flex; align-items:center; gap:12px; position:fixed; top:0; left:0; right:0; height:52px;
    background:var(--dark); color:#fff; padding:0 14px; z-index:60}
  #ow-burger{background:none; border:none; color:#fff; font-size:22px; cursor:pointer}
  .ow-topbar-brand{font-weight:700}
  #ow-sidebar{transform:translateX(-100%); transition:transform .2s; top:52px}
  .ow-nav-open #ow-sidebar{transform:translateX(0)}
  #ow-scrim{display:none; position:fixed; inset:52px 0 0 0; background:rgba(0,0,0,.4); z-index:40}
  .ow-nav-open #ow-scrim{display:block}
  .ow-main{padding:18px 16px 60px}
  .row2{grid-template-columns:1fr}
}

/* ============ Operation No — no.raceup red theme overrides ============ */
:root{ --blue:#EE4439; --blue-dark:#D23A30; --red:#EE4439; }
body{ font-family:'Prompt','Segoe UI',system-ui,sans-serif; }
#ow-sidebar{ background:#3F3F46; }
#ow-topbar{ background:#3F3F46; }
.ow-logo-chip{ background:#fff; color:#3F3F46; }
.ow-event{ background:rgba(255,255,255,.12); }
.ow-event select{ background:#52525B; border-color:#3f3f46; }
.ow-nav-group{ color:rgba(255,255,255,.6); }
.ow-nav-link{ color:#E4E4E7; }
.ow-nav-link:hover{ background:rgba(255,255,255,.12); color:#fff; }
.ow-nav-link.active{ background:#fff; color:#3F3F46; }
.ow-nav-link.ext{ color:rgba(255,255,255,.8); }
.ow-nav-foot{ border-top-color:rgba(255,255,255,.18); }
.ow-avatar{ background:#fff; color:#3F3F46; }
.ow-user b{ color:#fff } .ow-user small{ color:rgba(255,255,255,.7) }
.ow-logout{ color:rgba(255,255,255,.8) } .ow-logout:hover{ color:#fff }
.ow-badge{ background:#fff; color:#3F3F46 }

/* ============ Hydration calculator ============ */
.hy-inputs{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:16px}
.hy-inp{background:#fff; border:1px solid var(--line); border-radius:12px; padding:10px 14px; min-width:120px}
.hy-inp label{display:block; font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.03em}
.hy-inp input{border:none; padding:2px 0; font-size:22px; font-weight:700; color:var(--dark); width:100%}
.hy-inp input:focus{outline:none}
.hy-inp .tot{font-size:22px; font-weight:700; color:var(--red)}
table.hy{width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line); border-radius:12px; overflow:hidden; font-size:12.5px}
table.hy th,table.hy td{padding:7px 8px; border-bottom:1px solid var(--line); text-align:center; white-space:nowrap}
table.hy th{background:#FFF1F0; color:var(--red-dark,#D23A30); font-weight:600; font-size:11px; position:sticky; top:0}
table.hy td.l{text-align:left}
table.hy td.calc{background:#F8FAFC; font-weight:600}
table.hy tr.tot td{background:#FFF1F0; font-weight:700; border-top:2px solid var(--red)}
table.hy input{width:54px; text-align:center; border:1px solid transparent; border-radius:6px; padding:4px; font-family:inherit; font-size:12.5px}
table.hy input:hover{background:#F1F5F9} table.hy input:focus{outline:none; border-color:var(--red); background:#fff}
table.hy .chk{cursor:pointer; font-weight:700}
.hy-wrap{overflow-x:auto; border-radius:12px}
.hy-conv{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; margin-top:16px}
.hy-conv .ow-card b{color:var(--red); font-size:20px}
.hy-inp select{border:none; padding:2px 0; font-size:17px; font-weight:700; color:var(--dark); width:100%; background:transparent; cursor:pointer}
.hy-inp select:focus{outline:none}

/* ============ generic module — totals strip (sumCols) ============ */
.ow-note{background:#FFFBEB; border:1px solid #FDE68A; border-radius:10px; padding:9px 13px; margin:0 0 12px; font-size:12.5px; color:#92400E; line-height:1.6}
.ow-note b{color:#78350F}
.ow-sumbar{display:flex; flex-wrap:wrap; gap:8px; margin:12px 2px 2px}
.ow-sumchip{display:inline-flex; align-items:center; gap:6px; background:#F4F4F5; border:1px solid #E4E4E7;
  border-radius:999px; padding:5px 12px; font-size:12.5px; color:#52525B; white-space:nowrap}
.ow-sumchip i{width:14px; height:14px; color:#71717A}
.ow-sumchip b{color:#3F3F46; font-size:14px; font-weight:700}
.wb-calc{display:inline-block; padding:0 8px; font-weight:600; color:#3F3F46; font-size:14px}

/* ============ generic module — team tabs ============ */
.ow-tabs{display:flex; flex-wrap:wrap; gap:4px; margin:2px 0 14px; border-bottom:1px solid #E4E4E7}
.ow-tab{appearance:none; border:none; background:transparent; cursor:pointer; font-family:inherit; font-size:13.5px;
  color:#71717A; padding:8px 14px; display:inline-flex; align-items:center; gap:7px; position:relative; top:1px; border-bottom:2px solid transparent}
.ow-tab:hover{color:#3F3F46}
.ow-tab.active{color:#18181B; font-weight:600; border-bottom-color:#3F3F46}
.ow-tab-n{background:#E4E4E7; color:#52525B; border-radius:999px; font-size:11px; font-weight:600; padding:1px 7px; min-width:18px; text-align:center}
.ow-tab.active .ow-tab-n{background:#3F3F46; color:#fff}

/* top summary stat boxes (hydration-style) for module pages */
.ow-statwrap{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:16px}
.ow-statbox{background:#fff; border:1px solid var(--line); border-radius:12px; padding:10px 14px; min-width:118px}
.ow-statbox .lab{font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.03em; display:flex; align-items:center; gap:5px}
.ow-statbox .lab i{width:13px; height:13px}
.ow-statbox .val{font-size:22px; font-weight:700; color:var(--dark); margin-top:3px}
.ow-statbox .val span{font-size:13px; font-weight:500; color:var(--muted)}
.ow-statbox.accent .val{color:var(--red)}

/* grouped stat boxes (Food Plan custom summary) */
/* groups laid out in ONE row, color-coded */
.ow-statrow{display:flex; flex-wrap:wrap; gap:16px; align-items:stretch; margin-bottom:18px}
.ow-statgroup{margin:0; background:#fff; border:1px solid var(--line); border-top:3px solid var(--line); border-radius:14px; padding:11px 14px 13px}
.ow-statgroup-h{font-size:12.5px; font-weight:700; color:var(--slate); margin:0 0 9px; display:flex; align-items:center; gap:6px}
.ow-statgroup .ow-statwrap{margin-bottom:0}
.ow-statgroup.sg-runner{border-top-color:var(--blue)} .ow-statgroup.sg-runner .ow-statgroup-h{color:var(--blue)}
.ow-statgroup.sg-team{border-top-color:var(--amber)} .ow-statgroup.sg-team .ow-statgroup-h{color:var(--amber)}
/* per-box color tones (match table row colors) */
.ow-statbox.tone-green{background:#F0FDF4; border-color:#BBF7D0} .ow-statbox.tone-green .val{color:var(--green)}
.ow-statbox.tone-pink{background:#FDF2F8; border-color:#FBCFE8} .ow-statbox.tone-pink .val{color:#DB2777}
.ow-statbox.tone-blue{background:#EFF6FF; border-color:#BFDBFE} .ow-statbox.tone-blue .val{color:var(--blue)}

/* Staff Food — table footer totals row */
.wb tr.wb-tot td{background:#FFF1F0; font-weight:700; border-top:2px solid var(--red); color:var(--dark); text-align:center; padding:8px 4px; font-size:13px}
.wb tr.wb-tot td.l{text-align:left; color:var(--slate); padding-left:10px}
