/* v29 */
:root{
  --ink:#131E3A; --canvas:#F5F2EF; --surface:#FFFFFF; --muted:#5F6676; --line:#E8E8EC;
  --accent:#FF5454; --accentInk:#fff; --accentSoft:rgba(255,84,84,.12);
  --mainChipBg:#E8F0FF; --mainChipText:#16315F;
  --wkndChipBg:#FCE7F3; --wkndChipText:#6B214C;
  --shadow:0 1px 2px rgba(19,30,58,.06), 0 6px 24px rgba(19,30,58,.06);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--canvas)}
.container{max-width:1120px;margin:0 auto;padding:0 20px}
.topbar{position:sticky;top:0;background:linear-gradient(180deg,var(--canvas),rgba(245,242,239,.75));backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);z-index:10}
.bar{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:14px 0}
.brand h1{margin:0;font-size:24px}
.month-nav{display:flex;align-items:center;gap:10px}
.iconbtn{inline-size:34px;block-size:34px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;box-shadow:var(--shadow)}
.month-nav h2{margin:0 6px;font-size:18px;font-weight:700}
.mode{font-size:12px;border:1px solid var(--line);background:var(--surface);padding:4px 10px;border-radius:999px;color:var(--muted);box-shadow:var(--shadow)}
.mainpad{padding:16px 0 6px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.legend{display:flex;flex-wrap:wrap;align-items:center;gap:18px;padding:10px 14px;margin-bottom:8px;border-radius:999px}
.legend span{font-size:14px}
.pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px}
.pill.main{background:var(--mainChipBg);color:var(--mainChipText)} .pill.wknd{background:var(--wkndChipBg);color:var(--wkndChipText)}
.weekday-head{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;color:var(--muted);margin:10px 0 8px;padding:0 2px}
.weekday-head>div{text-align:center;font-size:12px}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.day{background:var(--surface);border:1px solid var(--line);border-radius:14px;min-height:84px;padding:10px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow)}
.day header{display:flex;justify-content:space-between;align-items:center;position:relative}
.day h4{margin:0;font-weight:700;font-size:14px} .day small{color:var(--muted)}
.todaypill{border-radius:999px;background:var(--accent);color:var(--accentInk);font-size:10px;padding:3px 10px;font-weight:700;letter-spacing:.2px}
.todaypill.center{position:absolute;left:50%;transform:translateX(-50%);top:0;bottom:0;margin:auto 0}
.day.today{outline:2px solid var(--accent); box-shadow:0 0 0 6px var(--accentSoft), var(--shadow)}
.tags{display:flex;flex-direction:column;gap:6px}
.rowchips{display:flex;flex-direction:column;gap:6px}
.sep{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;padding-top:2px}
.sep:before,.sep:after{content:"";flex:1;border-bottom:1px dashed var(--line)}
.tag{font-size:12px;border:1px solid var(--line);border-radius:999px;padding:4px 8px;white-space:nowrap;align-self:flex-start}
.tag.main{background:var(--mainChipBg);color:var(--mainChipText)} .tag.wknd{background:var(--wkndChipBg);color:var(--wkndChipText)}
.morelink{font-size:12px;color:#0F62FE;cursor:pointer;margin-top:2px;align-self:flex-start}.morelink:hover{text-decoration:underline}
.btn{background:var(--ink);color:#fff;border:1px solid var(--ink);padding:7px 12px;border-radius:12px;cursor:pointer;box-shadow:var(--shadow)}
.btn.ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.day .open{margin-top:auto;align-self:stretch;text-align:center;background:var(--surface);color:var(--ink);border:1px solid var(--line);padding:8px 12px;border-radius:12px;cursor:pointer}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.panel{padding:10px;border-radius:12px;border:1px dashed var(--line);background:#fff}
.row{display:flex;justify-content:space-between;align-items:center;margin:6px 0}.name{font-weight:600}.role{color:var(--muted)}
.dialog{border:0;padding:0;border-radius:16px;max-width:min(700px,94vw);box-shadow:0 10px 40px rgba(19,30,58,.18)}
.dialog::backdrop{background:rgba(19,30,58,.35)}
.moreWrap,.updateWrap{background:var(--surface);border-radius:16px;padding:14px}
.moreHeader,.updateHeader{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.moreList{display:flex;flex-direction:column;gap:8px}
@media (max-width: 1024px){
  .container{padding:0 16px}
  .weekday-head{display:none}
  .calendar{grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap:12px}
  .day{padding:10px; min-height:78px}
  .detail-grid{grid-template-columns:1fr}
}
@media (max-width: 600px){
  .container{padding:0 14px}
  .legend{padding:8px 10px; gap:12px}
  .calendar{grid-template-columns: repeat(2, minmax(0, 1fr)); gap:10px}
  .day{padding:8px; min-height:72px; border-radius:12px}
  .day h4{font-size:13px}
  .tag{font-size:11px; padding:4px 8px}
  .todaypill{font-size:10px; padding:3px 8px}
}

/* v29_2: minor modal header sizing + edit controls */
.updateHeader h3, .moreHeader h3 { font-size: 18px; line-height: 1.2; }
.updateHeader { align-items: center; }
.updateWrap .detail-grid { margin-bottom: 8px; }

/* Action row at bottom of update modal */
.updateActions { display:flex; gap:10px; justify-content:flex-end; border-top:1px dashed var(--line); padding-top:10px; }

/* Remove mode X */
.chip { position: relative; }
.chip .remx { position:absolute; top:-6px; right:-6px; width:18px; height:18px; border-radius:50%; border:1px solid #C62828; background:#fff; color:#C62828; font-size:12px; line-height:16px; text-align:center; display:none; cursor:pointer; }
.chip.removable .remx { display:block; }

/* Add/Remove links below panels */
.panel .panel-actions { display:flex; gap:12px; font-size:12px; color:#0F62FE; }
.panel .panel-actions button { background:none; border:0; padding:0; color:#0F62FE; cursor:pointer; }

/* New dialog forms */
.addForm input[type="text"], .saveForm input[type="password"] { width:100%; padding:10px; border:1px solid var(--line); border-radius:10px; font-size:14px; }
.addForm .row-actions, .saveForm .row-actions { display:flex; justify-content:flex-end; margin-top:10px; }
.saveForm .radios { display:flex; gap:14px; border:0; margin:10px 0; padding:0; }
.saveForm .radios label { font-size:14px; color:var(--ink); }
.error { color:#C62828; font-size:12px; min-height:16px; }

/* Editable chips styling hook */
.editable .rowchips .tag { cursor:grab; }
.editable .rowchips .tag:active { cursor:grabbing; }

/* Update modal footer buttons default hidden */
.updateFooter { display:flex; justify-content:flex-end; gap:10px; }
.updateFooter .btn { display:none; }
.updateFooter .btn.show { display:inline-block; }

/* Accessibility helper */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }


/* v30j — Update modal base (scoped) */
#updateDialog::backdrop { background: rgba(19, 30, 58, 0.35); }
#updateDialog { padding: 0; border: none; border-radius: 18px; max-width: 560px; width: min(560px, 92vw); }
#updateDialog .updateHeader{ display:flex; justify-content:space-between; align-items:center; padding:16px 18px 8px; }
#updateDialog .updateHeader h3{ margin:0; font-size:18px; font-weight:700; color:#131E3A; }
#updateDialog .detail-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:6px; }
#updateDialog .panel{ background:#fff; border:1px dashed #E8E8EC; border-radius:14px; overflow:hidden; }
#updateDialog .panelHeader{ background:#F7F7FA; padding:8px 10px; border-bottom:1px dashed #E8E8EC; }
#updateDialog .panelHeader .panelTitle{ font-weight:700; font-size:14px; line-height:1.2; color:#131E3A; }
#updateDialog .panelHeader .hint{ margin-top:4px; font-size:12px; color:#7A8090; display:flex; gap:.35rem; align-items:center; }
#updateDialog .panelBody{ padding:10px; }
#updateDialog .list{ display:flex; flex-direction:column; gap:6px; }
#updateDialog .chip.editable{ display:flex; align-items:center; justify-content:space-between; border-radius:12px; padding:4px 10px; font-size:13px; line-height:18px; box-shadow:none; }
#updateDialog .chip.editable .label{ font-weight:600; }
#updateDialog .chip.editable .dragHint{ opacity:.55; font-size:12px; }
#updateDialog .chip.editable.main{ background:#E8F0FF; color:#16315F; }
#updateDialog .chip.editable.wknd{ background:#FCE7F3; color:#6B214C; }
#updateDialog .toolbar{ display:flex; align-items:center; gap:10px; margin-top:10px; }
#updateDialog .btn.link{ background:none; border:0; color:#2B6CB0; font-weight:600; padding:2px 4px; border-radius:8px; }
#updateDialog .btn.link:focus{ outline:2px solid #aac7ff; outline-offset:2px; }
#updateDialog .btn.xbtn{ margin-left:8px; background:none; border:0; color:#C62828; font-weight:700; }
#updateDialog .updateFooter{ display:flex; justify-content:center; gap:8px; padding:12px 14px 16px; }
#updateDialog .updateFooter .btn{ border-radius:18px; padding:8px 16px; font-weight:700; border:1px solid transparent; }
#updateDialog .updateFooter .btn.primary{ background:#D4F0D4; border-color:#B9E2B9; }
#updateDialog .updateFooter .btn.ghost.danger{ background:#F5D6D6; border-color:#E6BABA; }
#updateDialog .updateFooter .btn.hidden{ display:none; }
@media (max-width:720px){ #updateDialog{ width:94vw; } #updateDialog .detail-grid{ grid-template-columns:1fr; gap:12px; } }
#addDriverDialog .addWrap, #saveDialog .addWrap{ padding:14px 16px; }
#addDriverDialog .addForm label, #saveDialog .addForm label{ font-weight:600; }
#addDriverDialog .addForm input, #saveDialog .addForm input{ padding:8px 10px; border-radius:10px; border:1px solid #aac7ff; width:100%; }
#addDriverDialog .actions, #saveDialog .actions{ margin-top:12px; }


/* v30k — layout wrapper + center grid */
#updateDialog #updateBody{ display:block !important; padding: 0 18px 10px; }
#updateDialog .updateInner{ display:block; margin:0; }
#updateDialog .detail-grid{ margin: 6px auto 0; width: 100%; max-width: 520px; }
#updateDialog .panel{ min-width: 0; }


/* v30l — tighter modal padding */
#updateDialog{ padding: 8px 10px 10px !important; border-radius:16px; }
#updateDialog .updateHeader{ padding: 10px 12px 6px !important; }
#updateDialog .detail-grid{ gap: 14px !important; margin-top: 4px !important; }
#updateDialog .panelBody{ padding: 8px !important; }
#updateDialog .toolbar{ margin-top: 8px !important; }
#updateDialog .updateFooter{ padding: 8px 10px 10px !important; gap: 6px !important; }


/* v30m — halve padding on dialogs */
#updateDialog{ padding: 6px 8px 8px !important; border-radius: 16px; }
#moreDialog{ padding: 10px 14px !important; border-radius: 18px; max-width: 720px; }
#moreDialog::backdrop{ background: rgba(19,30,58,.35); }
#moreDialog h3{ margin: 0 0 10px 0; font-size: 22px; }
#moreDialog .chip{ margin: 10px 0; }


/* v32 mobile drag */
.updateInner .chip.editable{ touch-action: none; }
.drag-ghost{
  position: fixed; pointer-events: none; opacity:.9; z-index: 9999;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}
.chip.placeholder{
  background: transparent; border: 2px dashed #E8E8EC; color: transparent;
}
