/* ═══════════════════════════════════════════════════════════
   RESET & ROOT
═══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Clearly blue navy — not gray */
  --navy:      #0D3358;
  --navy2:     #1A4A7A;
  --navy3:     #2A6096;
  --navy-line: rgba(255,255,255,.13);
  --navy-line2:rgba(255,255,255,.08);

  /* Warm orange accent */
  --orange:    #D97A3A;
  --orange2:   #E8904F;
  --orange-bg: rgba(217,122,58,.1);
  --orange-bd: rgba(217,122,58,.3);

  /* Warm cream backgrounds */
  --bg:        #F7F5F2;
  --bg2:       #F0EDE8;
  --white:     #FFFFFF;
  --line:      #EDE9E3;
  --line2:     #DDD8D0;

  /* Text */
  --tx:        #1A2A3A;
  --tx2:       #4A5568;
  --tx3:       #9AA5B4;

  /* Status */
  --red:       #B53A3A;  --red-bg:    #FEF1F1;  --red-bd:    #F5C0C0;
  --ylw:       #C4860A;  --ylw-bg:    #FEF3E8;  --ylw-bd:    #F5CC80;
  --grn:       #3A7A52;  --grn-bg:    #EAF4ED;  --grn-bd:    #9DD4B0;
  --purple:    #6D28D9;  --purple-bg: #F3F0FF;  --purple-bd: #C4B5FD;

  --font:  'Nunito',sans-serif;
  --mono:  'DM Mono',monospace;
  --r:     10px;
  --r2:    14px;
}

html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--tx)}
body{display:flex;flex-direction:column;overflow:hidden}

/* ═══════════════════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════════════════ */
.topbar{
  height:58px;flex-shrink:0;
  background:var(--navy);
  display:flex;align-items:center;
  padding:0 24px;gap:10px;
  border-bottom:3px solid var(--orange);
  z-index:100;
}
.tb-logo{
  font-size:18px;font-weight:700;color:#fff;
  letter-spacing:-.3px;white-space:nowrap;margin-right:4px;
}
.tb-logo span{color:var(--orange2)}
.tb-sub{font-size:11px;color:#7A9AC0;font-family:var(--mono);white-space:nowrap}
.tb-sep{width:1px;height:28px;background:var(--navy-line);flex-shrink:0}
.tb-gap{flex:1}
.tbtn{
  font-family:var(--font);font-size:13px;font-weight:500;
  padding:7px 14px;border-radius:8px;white-space:nowrap;
  cursor:pointer;transition:all .14s;border:1.5px solid;
}
.tbtn-ghost{background:rgba(255,255,255,.07);color:#C8D8EA;border-color:rgba(255,255,255,.14)}
.tbtn-ghost:hover{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28)}
.tbtn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.tbtn-orange:hover{background:var(--orange2);border-color:var(--orange2)}
.tbtn-white{background:#fff;color:var(--navy);border-color:#fff}
.tbtn-white:hover{background:#E8ECF0;border-color:#E8ECF0}

/* ═══════════════════════════════════════════════════════════
   APP LAYOUT — MAIN + SIDEBAR
═══════════════════════════════════════════════════════════ */
.app{
  display:flex;flex:1;
  min-height:0;         /* critical for flex children to scroll */
  overflow:hidden;
}

/* MAIN */
.main{
  flex:1;min-width:0;
  overflow-y:auto;
  padding:20px 20px 80px;
  height:100%;
}

/* SIDEBAR */
.sidebar{
  width:340px;flex-shrink:0;
  background:var(--navy);
  display:flex;flex-direction:column;
  height:100%;
  border-left:2px solid var(--orange-bd);
  overflow:hidden;
  transition:width .2s cubic-bezier(.4,0,.2,1);
}
.sidebar.collapsed{
  width:0!important;
  border-left:none;
  overflow:hidden;
}
@media(max-width:1100px){.sidebar{width:300px}}
@media(max-width:820px){
  .app{flex-direction:column-reverse}
  .sidebar{width:100%;height:260px;border-left:none;border-top:1px solid var(--navy-line)}
  .main{height:calc(100% - 260px)}
}

/* Sidebar tabs */
.s-tabs{display:flex;flex-shrink:0;border-bottom:1px solid var(--navy-line)}
.s-tab{
  flex:1;padding:13px 10px;font-size:13px;font-weight:600;
  color:#6A89A8;background:none;border:none;cursor:pointer;
  border-bottom:2.5px solid transparent;transition:all .15s;font-family:var(--font);
}
.s-tab.on{color:#fff;border-bottom-color:var(--orange)}
.s-tab:hover{color:#C8D8EA;background:rgba(255,255,255,.03)}

/* Sidebar meta */
.s-meta{
  flex-shrink:0;padding:8px 14px 6px;
  font-size:11.5px;color:#6A89A8;font-family:var(--mono);
  border-bottom:1px solid var(--navy-line2);
}
/* Queue legend */
.q-legend{
  flex-shrink:0;display:flex;gap:14px;padding:7px 14px;
  border-bottom:1px solid var(--navy-line2);
  background:var(--navy2);
}
.q-leg{display:flex;align-items:center;gap:5px;font-size:11px;color:#6A89A8;font-family:var(--mono)}
.q-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* Sidebar scroll areas */
.s-panel{
  flex:1;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-height:0;
}
/* The actual scrollable list inside each panel */
#stores-list, #queue-list{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:6px 10px 32px;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.12) transparent;
}
#stores-list::-webkit-scrollbar,
#queue-list::-webkit-scrollbar{width:4px}
#stores-list::-webkit-scrollbar-thumb,
#queue-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

/* ═══════════════════════════════════════════════════════════
   STORE ROWS (Butiker tab)
═══════════════════════════════════════════════════════════ */
.st-sec{
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#4A6580;padding:12px 8px 6px;font-family:var(--mono);
}
.st-sec:first-child{padding-top:4px}
.st-row{
  display:flex;flex-direction:column;gap:9px;
  padding:12px 12px;border-radius:10px;margin-bottom:4px;
  border:1.5px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  transition:background .13s;
  overflow:hidden;
}
.st-row:hover{background:rgba(255,255,255,.08)}
.st-row.paused{opacity:.75;background:rgba(255,255,255,.02)}
.st-top{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}
.st-name{
  flex:1;font-size:15px;font-weight:700;
  color:#EEF2F6;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.st-paused-pill{
  font-size:10px;font-weight:600;font-family:var(--mono);
  background:rgba(255,255,255,.08);color:#6A89A8;
  border-radius:20px;padding:2px 8px;flex-shrink:1;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.st-bot{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.st-iv-lbl{font-size:11px;color:#6A89A8;font-family:var(--mono);white-space:nowrap;flex-shrink:0}
.st-iv-in{
  width:52px;padding:5px 7px;border-radius:6px;text-align:center;
  border:1.5px solid rgba(255,255,255,.16);background:rgba(255,255,255,.07);
  color:#fff;font-family:var(--mono);font-size:13px;font-weight:600;
  outline:none;transition:all .13s;
}
.st-iv-in:focus{border-color:var(--orange);background:rgba(255,255,255,.12)}
.st-iv-unit{font-size:11px;color:#4A6580;font-family:var(--mono)}
.st-gap{flex:1}
.st-btns{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap}
.st-btn{
  display:flex;align-items:center;gap:4px;
  padding:6px 11px;border-radius:7px;font-size:13px;font-weight:500;
  border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);
  color:#B8C8D8;cursor:pointer;transition:all .13s;
  white-space:nowrap;font-family:var(--font);line-height:1;
}
.st-btn:hover{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.25)}
.st-btn.resume{
  background:rgba(14,107,58,.2);color:#4ADE80;border-color:rgba(14,107,58,.35);
  width:100%;justify-content:center;margin-top:2px;
}
.st-btn.resume:hover{background:rgba(14,107,58,.35);color:#86EFAC}
.st-btn.del{background:rgba(196,26,26,.1);color:#F87171;border-color:rgba(196,26,26,.22)}
.st-btn.del:hover{background:rgba(196,26,26,.25);color:#FCA5A5}
.st-btn .lbl{font-size:12px}

/* ═══════════════════════════════════════════════════════════
   QUEUE ROWS (Kö tab)
═══════════════════════════════════════════════════════════ */
.q-sec{
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#4A6580;padding:12px 8px 6px;font-family:var(--mono);
  border-top:1px solid var(--navy-line2);margin-top:4px;
}
.q-sec:first-child{border-top:none;padding-top:4px;margin-top:0}
.qi{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 12px;border-radius:10px;margin-bottom:4px;
  cursor:grab;user-select:none;
  border:1.5px solid transparent;
  transition:background .13s,transform .13s;
}
.qi:hover{transform:translateX(2px)}
.qi.dragging{opacity:.3;transform:none}
.qi.q-over{background:rgba(232,97,10,.15);border-color:rgba(232,97,10,.4)}
.qi.q-soon{background:rgba(196,26,26,.18);border-color:rgba(220,50,50,.35)}
.qi.q-soon:hover{background:rgba(196,26,26,.26)}
.qi.q-warn{background:rgba(160,88,0,.18);border-color:rgba(220,150,40,.35)}
.qi.q-warn:hover{background:rgba(160,88,0,.26)}
.qi.q-ok{background:rgba(10,107,58,.15);border-color:rgba(70,200,110,.3)}
.qi.q-ok:hover{background:rgba(10,107,58,.22)}
.qi.q-later{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08)}
.qi.q-later:hover{background:rgba(255,255,255,.08)}
.qi.q-paused{background:rgba(255,255,255,.025);border-color:rgba(255,255,255,.05);opacity:.6}
.qi-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:5px}
.qi.q-over  .qi-dot,.qi.q-soon  .qi-dot{background:#FF6060;box-shadow:0 0 6px rgba(255,96,96,.5)}
.qi.q-warn  .qi-dot{background:#FFB830;box-shadow:0 0 6px rgba(255,184,48,.4)}
.qi.q-ok    .qi-dot{background:#3FD17A;box-shadow:0 0 6px rgba(63,209,122,.4)}
.qi.q-later .qi-dot{background:#3A5068}
.qi.q-paused .qi-dot{background:#2A3A4A}
.qi-body{flex:1;min-width:0}
.qi-name{
  font-size:14px;font-weight:700;color:#EEF2F6;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  line-height:1.2;margin-bottom:4px;
}
.qi-name .qi-ptag{
  font-size:10px;background:rgba(255,255,255,.08);color:#6A89A8;
  border-radius:3px;padding:1px 6px;margin-left:6px;
  font-family:var(--mono);font-weight:400;vertical-align:middle;
}
.qi-meta{font-size:11.5px;color:#6A89A8;font-family:var(--mono);line-height:1.5}
.qi-pill{
  flex-shrink:0;font-size:11px;font-weight:700;font-family:var(--mono);
  padding:3px 10px;border-radius:20px;white-space:nowrap;letter-spacing:.02em;align-self:flex-start;
}
.qi.q-over  .qi-pill,.qi.q-soon  .qi-pill{background:#C41A1A;color:#fff}
.qi.q-warn  .qi-pill{background:#A05800;color:#FEF9EB}
.qi.q-ok    .qi-pill{background:#0A6B3A;color:#D0FAE8}
.qi.q-later .qi-pill{background:rgba(255,255,255,.1);color:#8896A8}
.qi.q-paused .qi-pill{background:rgba(255,255,255,.06);color:#4A5A6A}

/* ═══════════════════════════════════════════════════════════
   MAIN — WARNINGS, UNDO, STATUS
═══════════════════════════════════════════════════════════ */
.warn-banner{
  display:none;align-items:center;gap:10px;
  padding:11px 16px;border-radius:10px;margin-bottom:14px;
  background:var(--red-bg);color:var(--red);
  border:2px solid var(--red-bd);font-size:14px;font-weight:600;
}
.warn-banner.on{display:flex}
.warn-x{margin-left:auto;cursor:pointer;font-size:18px;opacity:.6;line-height:1}
.warn-x:hover{opacity:1}
.topbar-msg{
  display:none;align-items:center;gap:10px;
  padding:9px 14px;border-radius:9px;margin-bottom:12px;
  font-size:13px;background:var(--bg2);border:1.5px solid var(--line);color:var(--tx2);
  flex-wrap:wrap;
}
.topbar-msg.on{display:flex}
.msg-r{font-size:11px;color:var(--tx3);font-family:var(--mono);margin-left:auto}

/* ═══════════════════════════════════════════════════════════
   WEEK & DAY CARDS
═══════════════════════════════════════════════════════════ */
.weeks{display:flex;flex-direction:column;gap:28px}
.wk{margin-bottom:0;background:var(--white);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 1px 6px rgba(45,58,74,.05)}
.wk-hdr{display:flex;align-items:center;gap:10px;margin-bottom:0;padding:12px 16px 10px;background:var(--bg2);border-bottom:1px solid var(--line);flex-wrap:wrap}
.wk-num{
  font-size:19px;font-weight:700;color:var(--tx);letter-spacing:-.3px;
}
.wk-dates{font-size:13px;color:var(--tx3);font-family:var(--mono)}
.wk-tag{font-size:11px;font-weight:600;border-radius:5px;padding:3px 9px;border:1.5px solid;letter-spacing:.02em}
.t-hist{background:var(--bg2);color:var(--tx3);border-color:var(--line)}
.t-lon{background:var(--ylw-bg);color:var(--ylw);border-color:var(--ylw-bd)}
.t-cfg{background:var(--bg2);color:var(--tx3);border-color:var(--line);cursor:pointer}
.t-cfg:hover{border-color:var(--tx3);color:var(--tx2)}
.wk-acts{display:flex;gap:6px;margin-left:auto}
/* Day grid */
.dgrid{display:grid;grid-template-columns:repeat(var(--dgrid-cols,5),1fr);gap:10px;padding:12px}
@media(max-width:900px){.dgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.dgrid{grid-template-columns:1fr 1fr}}
/* Day card */
.dc{
  background:#FAFBFC;border:1.5px solid var(--line);
  border-radius:12px;display:flex;flex-direction:column;
  transition:border-color .14s,box-shadow .14s;min-width:0;
}
.dc.drag-over{border-color:var(--orange)!important;box-shadow:0 0 0 3px var(--orange-bg);background:#FFFCF9}
.dc.inact{border-style:dashed;background:transparent}
.dc.lon{border-color:var(--ylw-bd)}
/* Day header */
.dc-hdr{
  padding:8px 11px 7px;border-bottom:1.5px solid var(--line);
  display:flex;align-items:flex-start;justify-content:space-between;gap:6px;flex-shrink:0;
  border-radius:10px 10px 0 0;background:var(--navy);
}
.dc-hdr.lon{background:var(--ylw-bg);border-color:var(--ylw-bd)}
.dc-name{
  font-size:13px;font-weight:700;color:#fff;
  outline:none;border:none;background:transparent;cursor:text;font-family:var(--font);
}
.dc-name:focus{text-decoration:underline dotted}
.dc-date{
  font-size:11px;color:rgba(255,255,255,.6);font-family:var(--mono);
  outline:none;border:none;background:transparent;cursor:text;display:block;margin-top:2px;
}
.dc-date:focus{text-decoration:underline dotted;color:#fff}
.dc-cnt{
  font-size:11px;font-family:var(--mono);font-weight:700;
  padding:3px 8px;border-radius:6px;flex-shrink:0;white-space:nowrap;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);
}
.cnt-ok  {background:rgba(255,255,255,.18);color:#fff}
.cnt-warn{background:var(--ylw-bg);color:var(--ylw)}
.cnt-empty{color:rgba(255,255,255,.4);background:transparent}
.dc-hint{font-size:12px;color:var(--tx3);text-align:center;padding:18px 8px;font-style:italic}
/* Stops */
.stops{flex:1;padding:0;min-height:24px}
.stop{
  display:grid;
  grid-template-columns:14px 28px minmax(0,1fr) 16px;
  grid-template-rows:auto auto auto;
  column-gap:4px;row-gap:0;
  padding:5px 5px 4px 5px;
  cursor:grab;user-select:none;
  border-bottom:1px solid var(--bg2);
  transition:background .1s;position:relative;
  overflow:hidden;
  align-items:start;
}
.stop:last-child{border-bottom:none}
.stop:hover{background:var(--bg)}
.stop.dragging{opacity:.3}
/* Left accent bar */
.stop::before{
  content:'';position:absolute;left:0;top:6px;bottom:6px;
  width:3px;border-radius:0 2px 2px 0;background:transparent;
}
.stop.dev-ok::before  {background:var(--grn)}
.stop.dev-warn::before{background:var(--ylw)}
.stop.dev-bad{background:var(--red-bg)}
.stop.dev-bad:hover{background:#FEE2E2}
.stop.dev-bad::before{background:var(--red)}
/* New-start */
.stop.ns{background:linear-gradient(90deg,rgba(109,40,217,.06),transparent)}
.stop.ns:hover{background:linear-gradient(90deg,rgba(109,40,217,.11),transparent)}
.stop.ns::before{background:var(--purple)!important}
.ns-tag{
  font-size:9px;font-weight:700;background:var(--purple);color:#fff;
  border-radius:3px;padding:1px 5px;font-family:var(--mono);white-space:nowrap;
  line-height:1.4;flex-shrink:0;
}
/* Grid placement */
.s-grip{
  grid-column:1;grid-row:1/4;align-self:flex-start;margin-top:4px;
  color:var(--tx3);font-size:10px;cursor:grab;line-height:1;
}
.s-num{
  grid-column:2;grid-row:1;align-self:flex-start;
  font-size:11px;font-family:var(--mono);color:var(--tx3);
  text-align:right;line-height:1.3;
}
/* Row 1: name — full width */
.s-name{
  grid-column:3;grid-row:1;
  font-size:13px;font-weight:600;color:var(--tx);
  outline:none;border:none;background:transparent;cursor:pointer;
  line-height:1.3;font-family:var(--font);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.s-name:focus{outline:none;white-space:normal;overflow:visible}
/* Row 2: senast metadata */
.s-meta-row2{
  grid-column:3;grid-row:2;
  display:flex;align-items:center;gap:4px;margin-top:0;
  min-width:0;
}
.s-stop-meta{
  font-size:10.5px;color:var(--tx3);font-family:var(--mono);flex:1;
  line-height:1.3;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.s-badge{
  grid-column:2;grid-row:2;
  flex-shrink:0;cursor:pointer;justify-self:end;
}
.s-badge:hover{opacity:.75}
.badge{font-size:9px;padding:1px 5px;}
/* Delete btn */
.s-del{
  grid-column:4;grid-row:1/4;align-self:flex-start;margin-top:3px;
  display:none;background:none;border:none;cursor:pointer;
  color:var(--tx3);font-size:15px;line-height:1;
  padding:2px 3px;border-radius:4px;transition:all .1s;
}
.stop:hover .s-del{display:block}
.s-del:hover{color:var(--red);background:var(--red-bg)}
.s-drop{
  border:2px dashed var(--line2);border-radius:6px;
  margin:3px 8px;height:32px;background:var(--bg);display:block;
}
.add-stop{
  display:flex;align-items:center;gap:5px;padding:5px 11px;
  font-size:11px;color:var(--tx3);cursor:pointer;border:none;background:none;
  font-family:var(--font);width:100%;text-align:left;font-weight:500;
  border-top:1px solid var(--line);transition:all .13s;
  border-radius:0 0 var(--r2) var(--r2);
}
.add-stop:hover{color:var(--tx);background:var(--bg)}
.add-day-btn{
  border:2px dashed var(--line2);border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  min-height:60px;cursor:pointer;color:var(--tx3);font-size:13px;
  gap:6px;transition:all .13s;background:none;font-family:var(--font);font-weight:500;
}
.add-day-btn:hover{border-color:var(--navy3);color:var(--navy);background:var(--white)}

/* Badges */
.badge{
  font-size:10px;font-weight:700;font-family:var(--mono);
  padding:2px 6px;border-radius:4px;border:1.5px solid;
  white-space:nowrap;display:inline-block;
}
.b4 {background:#FEF2F2;color:#991B1B;border-color:#FECACA}
.b5 {background:#FFFBEB;color:#92400E;border-color:#FDE68A}
.b6 {background:#FFF7ED;color:#9A3412;border-color:#FED7AA}
.b7 {background:var(--grn-bg);color:#166534;border-color:var(--grn-bd)}
.b8 {background:var(--grn-bg);color:#166534;border-color:var(--grn-bd)}
.b10{background:#EEF3FE;color:#1E40AF;border-color:#93B4F7}
.b12{background:#EEF3FE;color:#1E40AF;border-color:#93B4F7}
.b14{background:#EEF3FE;color:#1E40AF;border-color:#93B4F7}
.bnew{background:var(--purple-bg);color:#5B21B6;border-color:var(--purple-bd)}
/* ── BESÖK / EJ LEVERANS ── */
.stop.nodelivery::before{background:#8B5CF6!important}
.stop.nodelivery{background:rgba(139,92,246,.04)}
.nodelivery-tag{
  font-size:9px;font-weight:700;background:#8B5CF6;color:#fff;
  border-radius:3px;padding:1px 5px;font-family:var(--mono);white-space:nowrap;
  line-height:1.4;flex-shrink:0;
}
.nd-btn{
  font-size:9px;padding:1px 5px;border:1.5px solid #C4B5FD;background:transparent;
  color:#7C3AED;border-radius:3px;cursor:pointer;font-family:var(--mono);
  line-height:1.4;font-weight:600;opacity:0;transition:opacity .1s;
  margin-left:2px;white-space:nowrap;flex-shrink:0;
}
.stop:hover .nd-btn{opacity:1}
.stop.nodelivery .nd-btn{opacity:1;background:#8B5CF6;color:#fff;border-color:#7C3AED}
/* ── FÖLJESEDEL ── */
.fs-tag{
  font-size:9px;font-weight:700;background:#0891B2;color:#fff;
  border-radius:3px;padding:1px 5px;font-family:var(--mono);white-space:nowrap;
  line-height:1.4;flex-shrink:0;
}
/* ── PROVISORISKT STOPP ── */
.stop.temp-stop::before{background:#F59E0B!important}
.temp-tag{
  font-size:9px;font-weight:700;background:#F59E0B;color:#fff;
  border-radius:3px;padding:1px 5px;font-family:var(--mono);white-space:nowrap;
  line-height:1.4;flex-shrink:0;
}
/* ── STÄNGD DAG ── */
.dc.closed{opacity:.7}
.dc.closed .dc-hdr{background:#4A5568}
.dc.closed .stops,.dc.closed .add-stop,.dc.closed .stop-fields{pointer-events:none;opacity:.5}
.day-closed-lbl{font-size:9px;color:#C0CAD4;margin-left:auto;font-style:italic}
/* ── ARKIVERADE VECKOR ── */
.archived-bar{
  background:var(--bg2);border:1.5px solid var(--line);border-radius:10px;
  padding:8px 14px;display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--tx3);margin-bottom:12px;
}
/* ── PAUSA TILL ── */
.pause-until-lbl{font-size:10px;color:var(--ylw);font-family:var(--mono);margin-left:4px}

/* ═══════════════════════════════════════════════════════════
   BUTTONS (main area)
═══════════════════════════════════════════════════════════ */
.btn{
  font-family:var(--font);font-size:13px;font-weight:500;
  padding:8px 16px;border-radius:8px;border:1.5px solid var(--line2);
  background:var(--white);color:var(--tx);cursor:pointer;transition:all .13s;white-space:nowrap;
}
.btn:hover{background:var(--bg2);border-color:var(--navy3)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}.btn-navy:hover{background:var(--navy2)}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}.btn-orange:hover{background:var(--orange2);border-color:var(--orange2)}
.btn-red{background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}.btn-red:hover{background:#FEE2E2}
.btn-grn{background:var(--grn-bg);color:var(--grn);border-color:var(--grn-bd)}.btn-grn:hover{background:#D1FAE5}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px}

/* ═══════════════════════════════════════════════════════════
   MODALS
═══════════════════════════════════════════════════════════ */
.overlay{
  display:none;position:fixed;inset:0;
  background:rgba(8,16,30,.5);z-index:300;
  align-items:flex-start;justify-content:center;
  padding:44px 16px;overflow-y:auto;
  backdrop-filter:blur(4px);
}
.overlay.on{display:flex}
/* Innan inloggning: göm hela app-skalet så schemat aldrig skymtar bakom login */
body.pre-auth .topbar,body.pre-auth .app{display:none}
.modal{
  background:var(--white);border-radius:16px;padding:26px;
  width:100%;max-width:500px;margin:auto;
  box-shadow:0 24px 64px rgba(8,16,30,.25);
}
.modal h3{font-size:20px;font-weight:700;margin-bottom:18px;color:var(--tx);letter-spacing:-.2px}
.f-lbl{
  font-size:13px;font-weight:600;color:var(--tx2);
  display:block;margin-bottom:5px;margin-top:14px;
}
.f-lbl:first-of-type{margin-top:0}
.f-in{
  width:100%;padding:10px 13px;border:1.5px solid var(--line2);
  border-radius:8px;font-size:14px;font-family:var(--font);
  outline:none;background:var(--white);color:var(--tx);transition:border-color .12s;
}
.f-in:focus{border-color:var(--navy3)}
.f-hint{font-size:12px;color:var(--tx3);margin-top:5px;line-height:1.4}
.m-sep{border:none;border-top:1.5px solid var(--line);margin:18px 0}
.m-acts{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap;align-items:center}
.m-acts-l{margin-right:auto;display:flex;gap:6px}

/* ═══════════════════════════════════════════════════════════
   DATE PICKER
═══════════════════════════════════════════════════════════ */
.dp-wrap{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.dp-wrap select{flex:1;min-width:120px;padding:9px 10px;border:1.5px solid var(--line2);border-radius:8px;font-size:13px;font-family:var(--font);outline:none;background:var(--white);color:var(--tx);cursor:pointer;transition:border-color .12s}
.dp-wrap select:focus{border-color:var(--navy3)}
.dp-lbl{font-size:11px;color:var(--tx3);font-family:var(--mono);white-space:nowrap}

/* Week cfg checkboxes */
.day-chks{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}
.day-chk{
  display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;
  cursor:pointer;padding:6px 11px;border:1.5px solid var(--line2);border-radius:7px;
  user-select:none;transition:all .13s;color:var(--tx);
}
.day-chk:has(input:checked){background:var(--navy);color:#fff;border-color:var(--navy)}
.day-chk input{display:none}

/* Timeline */
.tl-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.tl-row:last-child{border-bottom:none}
.tl-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}
.tl-info{flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.tl-date{font-size:14px;font-weight:600;font-family:var(--mono)}
.tl-wk{font-size:12px;color:var(--tx3)}
.tl-dev{font-size:11px;font-family:var(--mono);padding:2px 7px;border-radius:4px;border:1.5px solid}
.td-ok  {background:var(--grn-bg);color:var(--grn);border-color:var(--grn-bd)}
.td-warn{background:var(--ylw-bg);color:var(--ylw);border-color:var(--ylw-bd)}
.td-bad {background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(10px);
  background:var(--navy);color:#fff;font-size:13px;
  padding:10px 20px;border-radius:24px;opacity:0;
  transition:all .25s;pointer-events:none;
  font-family:var(--mono);z-index:500;
  white-space:nowrap;box-shadow:0 4px 20px rgba(8,16,30,.3);
}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}


/* ── SIDEBAR SEARCH ── */
.s-search-wrap{
  flex-shrink:0;padding:8px 10px;
  border-bottom:1px solid var(--navy-line2);
  background:var(--navy);
}
.s-search{
  width:100%;padding:8px 12px 8px 34px;
  border-radius:8px;border:1.5px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.07);color:#EEF2F6;
  font-family:var(--font);font-size:13px;outline:none;
  transition:all .14s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236A89A8' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:10px center;
}
.s-search::placeholder{color:#4A6580}
.s-search:focus{border-color:var(--orange);background-color:rgba(255,255,255,.1)}
.s-no-results{font-size:13px;color:#4A6580;text-align:center;padding:20px 10px;font-style:italic}


/* Standalone toggle tab — sits between main and sidebar inside .app */
.s-toggle-tab{
  width:16px;flex-shrink:0;
  background:var(--navy2);
  border-left:1px solid var(--navy-line);
  border-right:1px solid var(--navy-line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .14s;
  user-select:none;
}
.s-toggle-tab:hover{background:var(--navy3)}
.s-toggle-tab span{
  color:#7A9AC0;font-size:11px;line-height:1;
  transition:color .14s;
}
.s-toggle-tab:hover span{color:#fff}
/* Main area expands smoothly */
.main{
  transition:flex .2s cubic-bezier(.4,0,.2,1);
}


/* ── STOP EXTRA FIELDS (qty + notes) ── */
.stop-fields{
  grid-column:3;grid-row:3;
  display:flex;flex-direction:column;gap:0;
  margin-top:1px;padding-top:1px;
  border-top:1px solid var(--bg2);
}
.stop-field{
  display:flex;align-items:center;gap:4px;min-width:0;
}
.stop-field-lbl{
  font-size:10px;font-weight:600;color:var(--tx3);
  font-family:var(--mono);white-space:nowrap;flex-shrink:0;
  letter-spacing:.02em;
  min-width:50px;opacity:.65;
}
.stop-field-in{
  flex:1;font-size:11.5px;font-family:var(--font);color:var(--tx2);
  border:none;background:transparent;outline:none;
  padding:0 3px;border-radius:3px;
  transition:background .1s;
  min-width:0;line-height:1.25;
}
.stop-field-in::placeholder{color:var(--tx3);font-style:italic}
.stop-field-in:hover{background:var(--bg2);color:var(--tx)}
.stop-field-in:focus{background:var(--bg2);color:var(--tx);outline:1px solid var(--line2)}
/* grid-template-rows already set to auto auto auto in .stop */


/* ── COLLAPSIBLE DAY CARDS ── */
.dc.collapsed .stops,
.dc.collapsed .add-stop{
  display:none;
}
.dc.collapsed .stop-fields{
  display:none;
}
/* Collapse toggle on day header */
.dc-collapse{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.5);font-size:13px;line-height:1;
  padding:2px 5px;border-radius:4px;transition:all .14s;
  flex-shrink:0;margin-left:4px;
}
.dc-collapse:hover{background:rgba(255,255,255,.12);color:#fff}
.dc.collapsed .dc-collapse{color:var(--tx3)}
/* When collapsed, card is just the header */
.dc.collapsed{
  height:auto;
}
/* Add-day button: always full width in grid */
.add-day-btn{
  grid-column:1/-1;
}


.dc-del{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.4);font-size:13px;line-height:1;
  padding:2px 5px;border-radius:4px;transition:all .14s;flex-shrink:0;
}
.dc-del:hover{background:rgba(255,255,255,.12);color:#fff}

/* Misc utilities */
.hidden{display:none!important}

/* Skrivskyddat läge (chaufför): dölj redigeringskontroller */
body.role-readonly .tb-edit{display:none!important}
body.role-readonly .s-grip{display:none!important}
body.role-readonly .stop{cursor:default}
