/* Cafe Rooster - Dark premium-ish (v2) */
:root{
  --bg: #0b0f16;
  --panel: rgba(255,255,255,.06);
  --stroke: rgba(255,255,255,.10);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);
  --danger: #ff4d6d;
  --ok: #38b000;
  --warn: #ffb703;
  --accent: #4cc9f0;
  --shadow: 0 12px 30px rgba(0,0,0,.35);
  --radius: 18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  /* Keep it clean & readable (less "kleurvlekken" op de achtergrond) */
  background:
    radial-gradient(900px 520px at 50% -15%, rgba(255,255,255,.05), transparent 70%),
    var(--bg);
  color:var(--text);
}

/* Better tap UX */
button, .btn, .chip{touch-action: manipulation}
a{color:inherit}
.container{width:min(1100px, 92vw);margin: 18px auto 60px auto;}
.topbar{
  position: sticky;top:0;z-index:10;
  backdrop-filter: blur(10px);
  background: rgba(11,15,22,.72);
  border-bottom:1px solid var(--stroke);
  display:flex;align-items:center;justify-content:space-between;
  padding: 12px 18px;
}
.brand{display:flex; align-items:center; gap:12px}
.logo{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid var(--stroke);
  box-shadow: var(--shadow);
  font-size:20px;
}
.brandtext .app{font-weight:800; letter-spacing:.2px}
.brandtext .sub{color:var(--muted); font-size:12px; margin-top:2px}
.nav{display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.navlink{color:var(--muted); text-decoration:none;padding: 8px 10px; border-radius: 12px;}
.navlink:hover{background:rgba(255,255,255,.06); color:var(--text)}
.navsep{width:1px; height:22px; background:var(--stroke); margin:0 6px}
.navuser{color:var(--muted); font-size:13px}
.footer{width:min(1100px, 92vw);margin: 0 auto 20px auto;color: var(--muted);font-size: 12px;opacity: .85;}
.card{
  background: linear-gradient(180deg, var(--panel), rgba(255,255,255,.03));
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card.pad{padding:18px}
.grid{display:grid;gap:14px;}
.grid.cols2{grid-template-columns: 1.2fr .8fr}
@media (max-width: 920px){.grid.cols2{grid-template-columns: 1fr}}
.h1{font-size:28px; font-weight:900; margin:0 0 8px 0}
.h2{font-size:18px; font-weight:900; margin:0 0 8px 0}
.p{color:var(--muted); margin:0 0 14px 0; line-height:1.4}
.row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.spacer{flex:1}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 10px 12px; border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color:var(--text); text-decoration:none; cursor:pointer; font-weight:700;
}
.btn:hover{background: rgba(255,255,255,.10)}
.btn.primary{border-color: rgba(76,201,240,.35);background: rgba(76,201,240,.16);}
.btn.danger{border-color: rgba(255,77,109,.35);background: rgba(255,77,109,.14);}
.btn.ghost{border-color: rgba(255,255,255,.10);background: transparent;}
.flash{
  padding: 12px 14px; border-radius: 14px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.06);
  margin-bottom: 14px;
}
.flash.ok{border-color: rgba(56,176,0,.35); background: rgba(56,176,0,.12)}
.flash.err{border-color: rgba(255,77,109,.35); background: rgba(255,77,109,.12)}
.flash.warn{border-color: rgba(255,183,3,.35); background: rgba(255,183,3,.10)}
label{display:block; font-size:12px; color:var(--muted); margin-bottom:6px}
input, select, textarea{
  width:100%;
  padding: 10px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  outline:none;
}

/* ===== Mobile navigation + spacing ===== */
.mobileNav{display:none}
@media (max-width: 780px){
  .container{width:min(1100px, 94vw); margin: 12px auto 92px auto;}
  .footer{margin-bottom:92px;}
  /* Keep header compact */
  .topbar{padding: 10px 12px;}
  .logo{width:38px;height:38px;border-radius:12px; font-size:18px}
  .brandtext .sub{display:none}
  /* Hide complex menu on small screens (use bottom nav instead) */
  .nav .navlink, .nav .navsep, .nav .navuser{display:none}
  .nav{gap:8px}
  .btn{padding: 12px 14px; border-radius:16px}
  input, select, textarea{font-size:16px} /* prevent iOS zoom */

  .mobileNav{
    display:flex;
    position:fixed;
    left:0; right:0; bottom:0;
    z-index:50;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
    gap:8px;
    backdrop-filter: blur(10px);
    background: rgba(11,15,22,.76);
    border-top:1px solid rgba(255,255,255,.10);
  }
  .mobileNav a{
    flex:1 1 0;
    text-decoration:none;
    color: rgba(255,255,255,.86);
    border:1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.05);
    border-radius: 16px;
    padding: 10px 8px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:6px;
    min-height: 56px;
  }
  .mobileNav a .mi{font-size:18px; line-height:1}
  .mobileNav a .ml{font-size:12px; font-weight:800; line-height:1; opacity:.92}
  .mobileNav a.is-active{
    border-color: rgba(76,201,240,.55);
    background: rgba(76,201,240,.14);
  }

  /* Make button rows easier on phone */
  .row.wrap .btn{flex:1 1 100%}
}

.mobileOnly{display:none}
@media (max-width: 780px){
  .mobileOnly{display:block}
}
textarea{min-height:90px; resize:vertical}
input:focus, select:focus, textarea:focus{border-color: rgba(76,201,240,.38)}
.formgrid{display:grid;grid-template-columns: 1fr 1fr;gap: 12px;}
.formgrid.one{grid-template-columns:1fr}
@media (max-width: 700px){.formgrid{grid-template-columns: 1fr}}
.weekbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;}
.badge{
  display:inline-flex;gap:8px;align-items:center;
  padding: 6px 10px;border-radius: 999px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.06);
  color: var(--muted);font-size: 12px;
}
.chip{
  display:inline-flex;gap:8px;align-items:center;
  padding: 6px 10px;border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--text);font-size: 12px;
  cursor: default;
  user-select: none;
}
button.chip{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  cursor: pointer;
}
button.chip:hover{border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.07)}
button.chip.is-selected{border-color: rgba(76,201,240,.55); background: rgba(76,201,240,.14)}
button.chip:focus{outline:2px solid rgba(76,201,240,.35); outline-offset:2px}
.chip.ok{border-color: rgba(56,176,0,.30); background: rgba(56,176,0,.12)}
.chip.warn{border-color: rgba(255,183,3,.30); background: rgba(255,183,3,.10)}
.chip.danger{border-color: rgba(255,77,109,.30); background: rgba(255,77,109,.10)}
.days{display:grid;grid-template-columns: repeat(7, 1fr);gap: 12px;}
@media (max-width: 980px){.days{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 560px){.days{grid-template-columns: 1fr}}
.day{padding: 14px;}
.dayhead{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px;}
.daytitle{font-weight:900}
.daydate{color:var(--muted); font-size:12px}
.shift{
  padding: 10px 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  margin-bottom:10px;
}
.shift.mine{border-color: rgba(76,201,240,.35); background: rgba(76,201,240,.10)}
.shift.cancelled{opacity:.55; filter: grayscale(.25)}
.shift .top{display:flex; justify-content:space-between; gap:10px; align-items:center}
.shift .time{font-weight:900}
.shift .pos{color:var(--muted); font-size:12px; margin-top:4px}
.shift .who{color:var(--muted); font-size:12px}
.shift .note{color:var(--muted); font-size:12px; margin-top:8px; line-height:1.35}
.table{width:100%;border-collapse: collapse;}
.table th, .table td{padding: 10px 10px;border-bottom: 1px solid rgba(255,255,255,.08);vertical-align: top;}
.table th{color:var(--muted); font-size:12px; text-align:left; font-weight:700}
.actions{display:flex; gap:8px; flex-wrap:wrap}
.small{font-size:12px; color:var(--muted)}
hr.sep{border:none;border-top:1px solid rgba(255,255,255,.08); margin:14px 0}
code{color: rgba(255,255,255,.88)}

/* ===== Mobile roster view (swipe days) ===== */
@media (max-width: 900px){
  .weekgrid.days{
    display:flex;
    gap:12px;
    overflow-x:auto;
    padding-bottom:10px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .weekgrid.days .day{
    min-width: 86vw;
    scroll-snap-align:start;
  }
}
@media (max-width: 520px){
  .weekgrid.days .day{ min-width: 92vw; }
}


/* ===== Cafe Rooster Custom Select (remove white native dropdown) ===== */
.cr-select{position:relative;width:100%}
.cr-select-native{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
.cr-select-btn{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px; border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
  cursor:pointer;
}
.cr-select-btn:focus{outline:none;border-color:rgba(76,201,240,.38)}
.cr-select-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cr-select-caret{opacity:.8}
.cr-select-menu{
  position:absolute; left:0; right:0; top:calc(100% + 8px);
  background:rgba(12,16,24,.96);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.55);
  padding:6px;
  max-height:280px;
  overflow:auto;
  display:none;
  z-index:9999;
}
.cr-select.open .cr-select-menu{display:block}
.cr-select-item{
  width:100%;
  text-align:left;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  color:rgba(255,255,255,.92);
  cursor:pointer;
}
.cr-select-item:hover{background:rgba(255,255,255,.06)}
.cr-select-item.is-active{
  background:rgba(76,201,240,.14);
  border-color:rgba(76,201,240,.22);
}
.cr-select-item:disabled{opacity:.4;cursor:not-allowed}


/* ===== Availability UI ===== */
.avail-switch { display:flex; gap:12px; flex-wrap:wrap; margin:16px 0; }
.avail-switch .btn { cursor:pointer; border:1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); color:#fff; padding:12px 14px; border-radius:12px; font-weight:700; }
.avail-switch .btn.active { outline:2px solid rgba(0,255,140,.35); background: rgba(0,255,140,.12); }

@media (max-width: 560px){
  .avail-switch .btn{flex:1 1 0}
  .month-cal{gap:8px}
  .day-tile{min-height:74px; padding:9px}
  .day-meta{font-size:11px}
}

.avail-panel { display:none; }
.avail-panel.active { display:block; }

.month-toolbar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin:10px 0 14px; }
.month-toolbar input[type="month"]{ background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); color:#fff; padding:10px 12px; border-radius:12px; }
.month-cal { display:grid; grid-template-columns: repeat(7, 1fr); gap:10px; }
.month-cal .dow { opacity:.7; font-weight:700; text-align:center; padding:8px 0; }
.day-tile { position:relative; min-height:84px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.05); padding:10px; cursor:pointer; }
.day-tile:hover { background: rgba(255,255,255,.08); }
.day-tile.muted { opacity:.35; cursor:default; }
.day-num { font-weight:800; font-size:16px; }
.day-meta { margin-top:8px; font-size:12px; opacity:.85; line-height:1.25; }
.badge { display:inline-block; padding:4px 8px; border-radius:999px; font-size:11px; font-weight:800; border:1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); }
.badge.ok { background: rgba(0,255,140,.14); outline:1px solid rgba(0,255,140,.22); }
.badge.no { background: rgba(255,60,60,.14); outline:1px solid rgba(255,60,60,.22); }

.modal-overlay{ position:fixed; inset:0; background: rgba(0,0,0,.55); display:none; align-items:center; justify-content:center; padding:18px; z-index:9999; }
.modal-overlay.show{ display:flex; }
.modal{ width:min(560px, 100%); background: rgba(20,20,26,.96); border:1px solid rgba(255,255,255,.14); border-radius:18px; padding:16px; box-shadow: 0 20px 70px rgba(0,0,0,.55); }
.modal h3{ margin:4px 0 12px; }
.modal .row{ display:flex; gap:10px; flex-wrap:wrap; }
.modal label{ display:block; font-size:12px; opacity:.8; margin:8px 0 6px; }
.modal input[type="time"], .modal select, .modal input[type="text"]{
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); color:#fff;
  padding:10px 12px; border-radius:12px;
}
.modal .actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:14px; flex-wrap:wrap; }
.modal .actions .btn{ padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); color:#fff; cursor:pointer; font-weight:800; }
.modal .actions .btn.primary{ background: rgba(0,255,140,.16); outline:1px solid rgba(0,255,140,.25); }
.hint{ font-size:12px; opacity:.75; margin-top:6px; }


/* --- Simple wizard (planner) --- */
.wizardSteps{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 12px 0}
.wStep{
  appearance:none;-webkit-appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:8px 10px;
  border-radius: 999px;
  font-weight:800;
  cursor:pointer;
}
.wStep.is-active{
  border-color: rgba(76,201,240,.55);
  background: rgba(76,201,240,.14);
}
.wPanel{padding-top:2px}

/* --- Simple list blocks (dashboard) --- */
.list{display:flex;flex-direction:column;gap:10px}
.listItem{
  display:flex;gap:12px;align-items:flex-start;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 16px;
  padding:10px 12px;
}


/* ===== Force mobile preview on desktop (add ?mobile=1) ===== */
body.force-mobile .container{width:min(420px, 94vw); margin: 12px auto 92px auto;}
body.force-mobile .footer{margin-bottom:92px;}
body.force-mobile .topbar{padding: 10px 12px;}
body.force-mobile .logo{width:38px;height:38px;border-radius:12px; font-size:18px}
body.force-mobile .brandtext .sub{display:none}
body.force-mobile .nav .navlink,
body.force-mobile .nav .navsep,
body.force-mobile .nav .navuser{display:none}
body.force-mobile .nav{gap:8px}
body.force-mobile .btn{padding: 12px 14px; border-radius:16px}
body.force-mobile input,
body.force-mobile select,
body.force-mobile textarea{font-size:16px}

/* Bottom nav always on in forced mode */
body.force-mobile .mobileNav{
  display:flex;
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:50;
  padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
  gap:8px;
  backdrop-filter: blur(10px);
  background: rgba(11,15,22,.76);
  border-top:1px solid rgba(255,255,255,.10);
}
body.force-mobile .mobileNav a{
  flex:1 1 0;
  text-decoration:none;
  color: rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  border-radius: 16px;
  padding: 10px 8px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height: 56px;
}
body.force-mobile .mobileNav a .mi{font-size:18px; line-height:1}
body.force-mobile .mobileNav a .ml{font-size:12px; font-weight:800; line-height:1; opacity:.92}
body.force-mobile .mobileNav a.is-active{
  border-color: rgba(76,201,240,.55);
  background: rgba(76,201,240,.14);
}

/* Show mobile-only helper text */
body.force-mobile .mobileOnly{display:block}

/* Swipe-style week view in forced mode */
body.force-mobile .weekgrid.days{
  display:flex;
  gap:12px;
  overflow-x:auto;
  padding-bottom:10px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
body.force-mobile .weekgrid.days .day{
  min-width: 390px;
  max-width: 94vw;
  scroll-snap-align:start;
}

/* Bottom-nav icons */
.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.bottom-nav .nav-ic{font-size:18px;line-height:1}
.bottom-nav .nav-tx{font-size:12px;line-height:1.1}

/* ===== Maand beschikbaarheid (cleaner) ===== */
#monthCal .badge{display:none !important;} /* in case old markup is cached */
#monthCal .dot{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  flex:0 0 auto;
}
#monthCal .dot.ok{ background: rgba(0,255,140,.55); border-color: rgba(0,255,140,.35); }
#monthCal .dot.no{ background: rgba(255,60,60,.55); border-color: rgba(255,60,60,.35); }
#monthCal .dot.add{ background: rgba(255,255,255,.20); border-color: rgba(255,255,255,.18); }

#monthCal .day-meta{
  display:flex;
  align-items:center;
  gap:8px;
}
#monthCal .day-meta .time{opacity:.85}

@media (max-width: 560px){
  .month-cal{gap:8px}
  .month-cal .dow{font-size:12px; padding:6px 0}
  .day-tile{min-height:64px; padding:8px}
  .day-num{font-size:14px}
  #monthCal .day-meta{font-size:11px}
  /* allow horizontal scroll if tiles get too small */
  #monthCal{overflow-x:auto; -webkit-overflow-scrolling:touch}
  #monthCal.month-cal{grid-template-columns: repeat(7, minmax(46px, 1fr));}
}


/* ===== Availability Month Calendar – chips + equal tile height ===== */
.month-cal{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:clamp(6px, 1.8vw, 10px);
}

.month-cal .dow{
  opacity:.7;
  font-weight:800;
  text-align:center;
  padding:clamp(6px, 1.2vw, 10px) 0;
  font-size:clamp(11px, 2.2vw, 14px);
}

.day-tile{
  position:relative;
  border-radius:clamp(12px, 2vw, 16px);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  padding:clamp(6px, 1.6vw, 10px);
  height:clamp(72px, 11.5vw, 96px); /* keeps all days equal height */
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.day-tile:hover{ background:rgba(255,255,255,.08); }
.day-tile.muted{ opacity:.35; cursor:default; }
.day-tile.empty{ opacity:.9; }

.day-num{
  font-weight:900;
  font-size:clamp(12px, 2.6vw, 16px);
  line-height:1;
}

.chips{
  margin-top:auto; /* push chips to bottom */
  display:flex;
  gap:6px;
  align-items:center;
  overflow:hidden;
  white-space:nowrap;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 8px;
  border-radius:999px;
  font-size:clamp(9px, 2.0vw, 12px);
  line-height:1;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}

.chip-dot{
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.65);
  flex:0 0 auto;
}

.chip.ok{ border-color:rgba(40, 255, 150, .30); }
.chip.ok .chip-dot{ background:rgba(40, 255, 150, .85); }

.chip.no{ border-color:rgba(255, 90, 90, .30); }
.chip.no .chip-dot{ background:rgba(255, 90, 90, .9); }

.chip.add{
  border-style:dashed;
  opacity:.85;
  padding:5px 10px;
}

.chip.more{
  opacity:.75;
  padding:5px 10px;
}

/* on very narrow phones, tighten spacing a bit */
@media (max-width: 420px){
  .month-cal{ gap:6px; }
  .chip{ padding:4px 7px; }
}


/* ===== Calendar edge padding fix (v15) ===== */
.month-cal{
  padding-left:10px;
  padding-right:10px;
  width:100%;
  box-sizing:border-box;
}

.month-cal .dow{
  text-align:center;
  font-weight:700;
  font-size:13px;
  opacity:.8;
}


/* ===== Calendar hard override (v16) ===== */
.month-cal-wrap{
  padding-left:12px;
  padding-right:12px;
  box-sizing:border-box;
  overflow-x:hidden; /* prevent hidden left-clipping from min-width rules */
}

.month-cal{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  margin:0 auto !important;
  box-sizing:border-box !important;
  padding:0 !important; /* padding handled by wrap */
  grid-template-columns:repeat(7, minmax(0,1fr)) !important;
}

@media (max-width: 520px){
  .month-cal{ gap:6px !important; }
  .day-tile{ height:clamp(68px, 12vw, 90px) !important; }
}

/* if any old rule sets min-width on small screens, kill it */
@media (max-width: 420px){
  .month-cal{ min-width:0 !important; }
}


/* ===== Calendar fit-to-phone tweak (v17) ===== */
html, body{
  max-width:100%;
  overflow-x:hidden;
}

@media (max-width: 420px){
  .month-cal-wrap{ padding-left:8px !important; padding-right:8px !important; }
  .month-cal{ gap:4px !important; }
  .day-tile{
    padding:4px !important;
    border-radius:12px !important;
    height:clamp(64px, 12vw, 86px) !important;
  }
  .day-num{ font-size:clamp(12px, 3.0vw, 15px) !important; }
  .chip{ padding:3px 6px !important; font-size:clamp(9px, 2.2vw, 11px) !important; }
  .chips{ gap:4px !important; }
}


/* ===== Dot-only chips (v18) ===== */
.chips{ justify-content:flex-start; }
.chip{
  padding:0 !important;
  width:18px;
  height:18px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0 !important;
  max-width:none;
}
.chip .chip-dot{
  width:10px;
  height:10px;
}
.chip.add{
  border-style:dashed;
  opacity:.7;
}
.chip.more{
  opacity:.6;
}
@media (max-width: 420px){
  .chip{ width:16px; height:16px; }
  .chip .chip-dot{ width:9px; height:9px; }
}


/* ===== Rooster week header – mobile polish (v20) ===== */
.weekbar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.weekbar .week-range{
  white-space:nowrap;
}

.actions-row{
  gap:12px;
  flex-wrap:wrap;
}

@media (max-width: 520px){
  .weekbar{
    gap:8px;
  }
  .weekbar .btn.ghost{
    padding:10px 12px;
    border-radius:16px;
    flex:1 1 auto;
    text-align:center;
  }
  .weekbar .week-range{
    flex:1 1 100%;
    order:10;
    justify-self:center;
    text-align:center;
    padding:10px 12px;
  }
  .actions-row .btn{
    flex:1 1 calc(50% - 6px);
    text-align:center;
    padding:14px 12px;
    border-radius:18px;
    font-weight:800;
  }
}

@media (max-width: 380px){
  .actions-row .btn{
    flex:1 1 100%;
  }
}


/* ===== Weekstrip overzicht (v21) ===== */
.weekstrip{
  display:flex;
  gap:10px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:10px 2px;
  margin-top:6px;
  scroll-snap-type:x mandatory;
}
.weekstrip::-webkit-scrollbar{ display:none; }

.wday{
  flex:0 0 auto;
  width:66px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  padding:10px 10px;
  text-decoration:none;
  color:inherit;
  scroll-snap-align:start;
}
.wday:active{ transform:scale(.98); }

.wday.today{
  border-color:rgba(0, 220, 140, .35);
  box-shadow:0 0 0 2px rgba(0,220,140,.10) inset;
}

.wtop{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.wlbl{ font-weight:800; opacity:.85; font-size:13px; }
.wdate{ font-weight:900; font-size:18px; line-height:1; }

.wbot{ margin-top:10px; display:flex; align-items:center; justify-content:space-between; gap:8px; }
.wdot{ width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.25); }
.wday.hasmine .wdot{ background:rgba(40,255,150,.9); }
.wday.hasopen .wdot{ background:rgba(255,200,60,.9); }

.wcnt{
  font-size:12px;
  font-weight:900;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
}

@media (max-width: 420px){
  .wday{ width:62px; padding:9px 9px; border-radius:16px; }
  .wdate{ font-size:17px; }
}


/* ===== Shift staff picker popup (v24) ===== */
.segbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.segbtn{
  flex:1 1 180px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.segbtn:active{ transform:scale(.99); }
.segcount{
  font-size:12px;
  font-weight:900;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  opacity:.9;
}


/* ===== Rooster view toggle + Maand kalender (v30) ===== */
.viewtoggle{
  display:inline-flex;
  gap:6px;
  padding:6px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
}
.viewtoggle .vt{
  text-decoration:none;
  color:#fff;
  font-weight:900;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
}
.viewtoggle .vt.is-active{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.10);
}

.calwrap{
  margin-top:12px;
}
.calhead{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:8px;
  margin-bottom:8px;
}
.calh{
  text-align:center;
  font-weight:900;
  opacity:.8;
  font-size:12px;
}

.calgrid{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:8px;
}

.calday{
  text-align:left;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  padding:10px;
  min-height:92px;
  cursor:pointer;
}
.calday:active{ transform:scale(.99); }
.calday.other{ opacity:.45; }
.calday.today{
  border-color:rgba(0, 220, 140, .35);
  box-shadow:0 0 0 2px rgba(0,220,140,.10) inset;
}

.caldate{ display:flex; justify-content:flex-start; }
.caldate .num{ font-weight:900; font-size:14px; }

.chips{ margin-top:8px; display:flex; flex-direction:column; gap:6px; }
.chip{
  font-size:12px;
  font-weight:900;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.chip.mine{ border-color: rgba(76,201,240,.35); background: rgba(76,201,240,.10); }
.chip.open{ border-color: rgba(255,200,60,.35); background: rgba(255,200,60,.10); }
.chip.more{ opacity:.85; }

.calmodal{
  border:none;
  background:transparent;
  padding:0;
  max-width:min(720px, 92vw);
  width:92vw;
}
.calmodal::backdrop{ background:rgba(0,0,0,.55); }
.calmodal-inner{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(11,15,26,.96);
  padding:14px;
}
.calmodal-top{ display:flex; gap:10px; align-items:flex-start; }

.mitem{
  margin-top:10px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  padding:12px;
}
.mitem.mine{ border-color: rgba(76,201,240,.35); background: rgba(76,201,240,.08); }
.mitem.open{ border-color: rgba(255,200,60,.35); background: rgba(255,200,60,.08); }
.mrow{ display:flex; justify-content:space-between; gap:10px; align-items:center; }
.mtime{ font-weight:900; }
.mwho,.mpos,.mnote{ color:var(--muted); font-size:12px; margin-top:6px; line-height:1.35; }

@media (max-width: 520px){
  .calgrid{ gap:6px; }
  .calday{ padding:8px; min-height:78px; border-radius:16px; }
  .chip{ padding:5px 8px; font-size:11px; }
}

/* chips in modal */
.chip.chip-ok{ border-color:rgba(40,255,150,.25); }
.chip.chip-unk{ border-color:rgba(255,255,255,.16); opacity:.92; }
.chip.chip-no{ border-color:rgba(255,90,90,.25); }

.modal #availModalList .chip{
  padding:10px 12px;
  border-radius:14px;
}
@media (max-width: 520px){
  .segbtn{ flex:1 1 100%; }
}


/* ===== Avail modal list layout (v25) ===== */
#availModalList{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  align-items:stretch !important;
}
#availModalList .chip{
  width:100% !important;
  justify-content:flex-start !important;
  padding:12px 14px !important;
  border-radius:16px !important;
  font-weight:900;
}
#availModalList .chip::after{
  content:'';
  margin-left:auto;
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
}
#availModalList .chip.is-selected::after{
  background:rgba(0, 220, 140, .9);
}


/* ===== Selection highlight clarity (v26) ===== */
#availModalList .chip.is-selected{
  border-color: rgba(60, 170, 255, .55) !important;
  box-shadow: 0 0 0 2px rgba(60, 170, 255, .18) inset !important;
}
#availModalList .chip.is-selected::after{
  background: rgba(60, 170, 255, .95) !important; /* blue dot */
}

/* picked people chips (top) – make clearer */
#pickedList .chip{
  border-color: rgba(60, 170, 255, .45) !important;
  background: rgba(60, 170, 255, .10) !important;
}
#pickedList .chip.is-selected{
  box-shadow: 0 0 0 2px rgba(60, 170, 255, .18) inset !important;
}
#pickedList .chip::before{
  content:'';
  width:10px; height:10px; border-radius:50%;
  background: rgba(60, 170, 255, .95);
  display:inline-block;
  margin-right:8px;
}


/* ===== Dashboard Quick Check polish (v29) ===== */
#qcModalList{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:stretch;
}
#qcModalList .qc-row{
  width:100%;
  justify-content:flex-start;
  padding:12px 14px;
  border-radius:16px;
  font-weight:900;
  cursor:pointer;
}
#qcModalList .qc-row::after{
  content:'';
  margin-left:auto;
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(60,170,255,.95); /* blue dot to show "plan" */
  opacity:.75;
}

/* ===== Rooster nav (mobiel netjes 3 knoppen + label) ===== */
.navwrap{ display:flex; flex-direction:column; gap:10px; align-items:stretch; }
.navrow{ display:flex; gap:10px; flex-wrap:nowrap; }
.navrow .btn{ flex:1 1 0; }
.navlabel{ text-align:center; }

@media (max-width: 560px){
  .navrow{ gap:8px; }
  .navrow .btn{ padding:10px 10px; }
}


/* ===== Staff roster cleanup fix (2026-03-06) ===== */
.desktopOnly{display:block}
.staff-quicklinks{display:flex;gap:10px;flex-wrap:wrap}
.roster-toolbar{align-items:center;gap:12px}
.staff-footer{padding-bottom:110px}

@media (max-width: 780px){
  .desktopOnly{display:none !important}
  .staff-footer{display:none}
  .role-staff .card.pad{padding:18px}
  .role-staff .h1{font-size:24px;margin-bottom:4px}
  .role-staff .p{font-size:16px;margin-bottom:0}
  .role-staff .actions-row{align-items:flex-start}
  .role-staff .weekbar{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;margin-bottom:0}
  .role-staff .weekbar .btn.ghost{margin:0;min-width:0;width:100%;justify-content:center}
  .role-staff .weekbar .week-range{grid-column:1 / -1;order:3;justify-content:center;text-align:center;padding:12px 14px}
  .role-staff .roster-toolbar{margin-top:14px}
  .role-staff .viewtoggle{width:100%;justify-content:flex-start}
  .role-staff .viewtoggle .vt{flex:1 1 0;text-align:center}
  .role-staff .weekstrip{margin-top:4px;padding-top:2px}
}

@media (max-width: 520px){
  .role-staff .container{width:min(1100px, calc(100vw - 22px));}
  .role-staff .topbar{padding:10px 10px}
  .role-staff .brand{gap:10px}
  .role-staff .btn.ghost{padding:10px 12px}
}


/* ===== Global polish pass ===== */
.navlink.is-active{
  background: rgba(76,201,240,.14);
  color: var(--text);
  border:1px solid rgba(76,201,240,.28);
}
.wizard{display:grid;gap:14px}
.wizardSteps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.wStep{
  width:100%;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);color:var(--muted);font-weight:800;cursor:pointer;
}
.wStep.is-active{
  color:var(--text);border-color:rgba(76,201,240,.45);background:rgba(76,201,240,.12);
  box-shadow:0 8px 20px rgba(0,0,0,.18);
}
.wPanel{border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;background:rgba(255,255,255,.03)}
.segbar{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.segbtn{
  display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:var(--text);font-weight:800;cursor:pointer;
}
.segbtn:hover{background:rgba(255,255,255,.08)}
.segcount{display:inline-flex;min-width:28px;justify-content:center;padding:4px 8px;border-radius:999px;background:rgba(0,0,0,.24)}
.list{display:grid;gap:10px}
.listItem{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04)}
.notifList{display:grid;gap:12px}
.notifItem{padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04)}
.notifItem.unread{border-color:rgba(76,201,240,.35);background:rgba(76,201,240,.08)}
.notifTop{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.notifTitle{font-weight:900}
.notifMeta{font-size:12px;color:var(--muted)}
.notifBody{margin-top:8px;color:var(--text);opacity:.92;line-height:1.45}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.56);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:18px;z-index:100}
.modal-overlay.show{display:flex}
.modal{width:min(720px, 100%);max-height:min(82vh, 900px);overflow:auto;border-radius:22px;padding:16px;border:1px solid rgba(255,255,255,.12);background:#0e1420;box-shadow:0 24px 60px rgba(0,0,0,.45)}
#pickedList .chip{cursor:pointer;padding:10px 12px;font-weight:800}
#pickedList .chip.is-selected{background:rgba(76,201,240,.16);border-color:rgba(76,201,240,.46)}
.chip-ok{border-color:rgba(56,176,0,.30);background:rgba(56,176,0,.12)}
.chip-unk{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.06)}
.chip-no{border-color:rgba(255,77,109,.30);background:rgba(255,77,109,.12)}
.shiftcard{overflow:hidden}
.avail-switch{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.avail-switch .btn.active{border-color:rgba(76,201,240,.45);background:rgba(76,201,240,.14)}
.avail-panel{display:none}
.avail-panel.active{display:block}
@media (max-width:780px){
  .wizardSteps,.segbar{grid-template-columns:1fr}
  .notifTop,.listItem{flex-direction:column;align-items:flex-start}
  .modal{padding:14px;border-radius:18px}
}


/* ===== Round 2 polish ===== */
.navlink.is-active{
  background: rgba(76,201,240,.14);
  color: var(--text);
  border:1px solid rgba(76,201,240,.28);
}

.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
@media (max-width:860px){.kpi-grid{grid-template-columns:1fr}}
.kpi-card{padding:14px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05)}
.kpi-label{font-size:12px;color:var(--muted);margin-bottom:6px}
.kpi-value{font-size:30px;font-weight:900;line-height:1}
.kpi-sub{font-size:12px;color:var(--muted);margin-top:6px}

.panel-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.panel-title .actions-inline{display:flex;gap:8px;flex-wrap:wrap}
.muted-box{border:1px dashed rgba(255,255,255,.12);background:rgba(255,255,255,.03);border-radius:16px;padding:12px}

.staff-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
@media (max-width:760px){.staff-grid{grid-template-columns:1fr}}
.staff-tile{
  display:flex;align-items:center;gap:16px;
  padding:16px 18px;border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  cursor:pointer;transition:.15s ease;
}
.staff-tile:hover{background:rgba(255,255,255,.08);transform:translateY(-1px)}
.staff-tile.is-selected{border-color:rgba(76,201,240,.55);background:rgba(76,201,240,.14);box-shadow:0 0 0 2px rgba(76,201,240,.16) inset}
.staff-avatar{
  width:52px;height:52px;border-radius:16px;display:grid;place-items:center;
  font-weight:900;font-size:22px;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);flex:0 0 auto;
}
.staff-main{min-width:0;flex:1}
.staff-name{font-weight:900;font-size:28px;line-height:1.05;color:#fff;letter-spacing:.01em}
.staff-meta{font-size:17px;color:rgba(255,255,255,.88);margin-top:6px;line-height:1.2}
.staff-check{font-size:30px;font-weight:900;color:#fff;opacity:.9;line-height:1}
.staff-tile.is-selected .staff-check{opacity:1}

.staff-tile.is-selected .staff-check{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:999px;
  background:rgba(76,201,240,.22);
  border:1px solid rgba(76,201,240,.45);
  box-shadow:0 0 0 2px rgba(76,201,240,.10) inset;
}
@media (max-width: 700px){
  .staff-tile{padding:14px 16px;gap:14px}
  .staff-avatar{width:46px;height:46px;font-size:20px}
  .staff-name{font-size:22px}
  .staff-meta{font-size:15px}
  .staff-check{font-size:26px}
}
.picked-pills{display:flex;flex-wrap:wrap;gap:8px}
.picked-pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(76,201,240,.32);background:rgba(76,201,240,.12);font-size:13px;font-weight:700;
}
.picked-pill button{all:unset;cursor:pointer;opacity:.85}
.picked-pill button:hover{opacity:1}

.quick-groups{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}
@media (max-width:860px){.quick-groups{grid-template-columns:1fr}}
.quick-group{
  border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);border-radius:18px;padding:12px;
}
.quick-group .qhead{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.quick-group .qtitle{font-weight:900}
.quick-list{display:flex;flex-wrap:wrap;gap:8px}
.quick-empty{font-size:12px;color:var(--muted)}
.qc-row{padding:10px 12px !important;cursor:pointer}

.calendar-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.calendar-hero .legend{display:flex;gap:8px;flex-wrap:wrap}
.calendar-hero .legend .pill{background:rgba(255,255,255,.05)}
.av-day-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-top:12px}
@media (max-width:980px){.av-day-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:560px){.av-day-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.av-day-tile{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);border-radius:18px;padding:12px;text-decoration:none;color:inherit}
.av-day-tile.is-selected{border-color:rgba(76,201,240,.45);background:rgba(76,201,240,.10)}
.av-day-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.av-day-num{font-size:20px;font-weight:900}
.av-day-count{font-size:12px;color:var(--muted);margin-top:8px}
.av-day-names{font-size:12px;color:var(--text);opacity:.88;margin-top:8px;line-height:1.3;min-height:30px}
.av-detail-row{display:flex;gap:10px;align-items:flex-start;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.av-detail-avatar{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;font-weight:900;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}
.av-detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.av-detail-tag{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04)}

#availModal .modal{width:min(780px, 100%)}
#availModal h3{font-size:42px;line-height:1.05;font-weight:900;color:#fff;margin:0}
#availModal .small{font-size:18px;color:rgba(255,255,255,.88)!important;line-height:1.35}
#availModalClose{font-size:18px;font-weight:900}
@media (max-width: 700px){
  #availModal h3{font-size:30px}
  #availModal .small{font-size:16px}
}


/* ===== Personeel kalender duidelijker ===== */
.legendbtn{ white-space:nowrap; }
.legend-inline{
  display:flex;
  flex-wrap:wrap;
  gap:10px 14px;
  align-items:center;
  color:rgba(255,255,255,.92);
  font-weight:700;
}
.legend-list{ display:flex; flex-direction:column; gap:12px; margin-top:14px; }
.legend-row{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border-radius:16px;
  border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04);
}
.legend-pill{
  width:18px; height:18px; border-radius:999px; display:inline-block;
  border:1px solid rgba(255,255,255,.18); flex:0 0 18px;
  background:rgba(255,255,255,.18);
}
.legend-pill.mine{ background:rgba(76,201,240,.9); border-color:rgba(76,201,240,.65); }
.legend-pill.open{ background:rgba(0,220,140,.9); border-color:rgba(0,220,140,.65); }
.legend-pill.free{ background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.2); }
.legend-pill.today{ background:transparent; border:2px solid rgba(0,220,140,.85); box-shadow:0 0 0 3px rgba(0,220,140,.16); }
.legendmodal-inner{ max-width:560px; }

.calday{
  min-height:118px;
  padding:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
}
.calday.other{ opacity:.35; }
.calday .caldate{ align-items:center; justify-content:space-between; gap:8px; }
.caldate .num{ font-size:17px; color:#fff; }
.todaytag{
  font-size:11px; font-weight:900; color:#cffff0;
  padding:4px 8px; border-radius:999px;
  background:rgba(0,220,140,.12); border:1px solid rgba(0,220,140,.28);
}
.daystate{
  margin-top:8px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#fff;
  opacity:.95;
}
.daystate.mine{ color:#8edfff; }
.daystate.open{ color:#7cf3ba; }
.daystate.free{ color:rgba(255,255,255,.72); }
.chips{ margin-top:8px; gap:7px; }
.chip{
  font-size:12px;
  padding:7px 10px;
  border-radius:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chip.mine{
  background:rgba(76,201,240,.14);
  border-color:rgba(76,201,240,.45);
  color:#eefaff;
}
.chip.open{
  background:rgba(0,220,140,.12);
  border-color:rgba(0,220,140,.36);
  color:#effff7;
}
.calempty{
  margin-top:18px;
  font-size:12px;
  color:rgba(255,255,255,.55);
  font-weight:700;
}

@media (max-width: 520px){
  .roster-toolbar{ align-items:stretch; }
  .legendbtn{ width:100%; justify-content:center; }
  .calhead{ gap:6px; }
  .calh{ font-size:14px; opacity:.95; }
  .calgrid{ gap:8px; }
  .calday{
    min-height:150px;
    border-radius:22px;
    padding:10px 8px;
  }
  .caldate .num{ font-size:20px; }
  .todaytag{ font-size:10px; padding:3px 6px; }
  .daystate{ font-size:11px; margin-top:10px; }
  .chip{
    font-size:12px;
    padding:8px 8px;
    border-radius:12px;
  }
  .calempty{ margin-top:20px; font-size:12px; }
}


/* ===== Staff month calendar cleanup v6 ===== */
.role-staff .calwrap{overflow:hidden}
.role-staff .calhead{margin-bottom:8px}
.role-staff .calgrid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.role-staff .calday{
  min-height:128px;
  padding:10px 8px;
  border-radius:20px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  overflow:hidden;
}
.role-staff .caldate{width:100%;display:flex;align-items:center;justify-content:space-between;gap:6px}
.role-staff .caldate .num{font-size:18px;font-weight:900;color:#fff}
.role-staff .todaytag{font-size:10px;padding:3px 7px}
.role-staff .daystate{
  margin-top:12px;
  font-size:12px;
  line-height:1.1;
  text-transform:none;
  letter-spacing:0;
  font-weight:900;
}
.role-staff .daystate.free{color:rgba(255,255,255,.88)}
.role-staff .chips{margin-top:10px;display:flex;flex-direction:column;gap:6px;width:100%}
.role-staff .chip{
  width:100%;
  max-width:100%;
  font-size:11px;
  line-height:1.2;
  padding:7px 8px;
  border-radius:10px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  box-sizing:border-box;
}
.role-staff .chip.more{opacity:.9;color:rgba(255,255,255,.82)}
.role-staff .calempty{display:none}

@media (max-width: 520px){
  .role-staff .calgrid{gap:6px}
  .role-staff .calh{font-size:13px;font-weight:800;opacity:.9}
  .role-staff .calday{min-height:116px;padding:8px 7px;border-radius:18px}
  .role-staff .caldate .num{font-size:17px}
  .role-staff .daystate{margin-top:10px;font-size:11px}
  .role-staff .chip{font-size:10px;padding:6px 7px;border-radius:9px}
  .role-staff .legendbtn{font-size:14px;padding:12px 14px}
}


/* ===== Legend modal readability hotfix v7 ===== */
#legendModal,
#legendModal *{
  color:#f4f7fb;
}
#legendModal .calmodal-inner{
  background:linear-gradient(180deg, rgba(10,16,29,.985), rgba(14,22,38,.985));
  box-shadow:0 28px 70px rgba(0,0,0,.58);
}
#legendModal .calmodal-top{
  align-items:flex-start;
  justify-content:space-between;
}
#legendModal .h2,
#legendModal strong{
  color:#ffffff !important;
  font-weight:900;
  letter-spacing:.01em;
}
#legendModal .h2{
  font-size:34px;
  line-height:1.05;
  margin:0 0 6px;
  text-shadow:0 2px 12px rgba(0,0,0,.35);
}
#legendModal .small{
  color:rgba(255,255,255,.92) !important;
  font-size:20px;
  line-height:1.4;
}
#legendModal .legend-list{
  gap:14px;
  margin-top:18px;
}
#legendModal .legend-row{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.16);
  padding:16px 18px;
  gap:16px;
}
#legendModal .legend-row strong{
  display:block;
  font-size:22px;
  line-height:1.15;
  margin-bottom:4px;
}
#legendModal .legend-pill{
  width:34px;
  height:34px;
  flex:0 0 34px;
}
#legendModalClose{
  color:#fff !important;
  font-size:20px;
  font-weight:900;
  padding:14px 18px;
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
}
@media (max-width: 520px){
  #legendModal .calmodal{width:94vw;max-width:94vw;}
  #legendModal .calmodal-inner{padding:16px;}
  #legendModal .h2{font-size:28px;}
  #legendModal .small{font-size:18px;}
  #legendModal .legend-row{padding:14px 14px;}
  #legendModal .legend-row strong{font-size:20px;}
  #legendModal .legend-pill{width:30px;height:30px;flex-basis:30px;}
  #legendModalClose{font-size:18px;padding:12px 16px;}
}


/* ===== Staff roster perfection pass v8 ===== */
.staff-roster-head{overflow:hidden}
.staff-roster-summary{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:12px;margin-top:14px}
.summary-tile{
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:18px;
  padding:14px 16px;
}
.summary-tile.has-shift{border-color:rgba(76,201,240,.28);background:linear-gradient(180deg, rgba(76,201,240,.12), rgba(255,255,255,.04));}
.summary-label{font-size:12px;font-weight:800;color:rgba(255,255,255,.72);text-transform:uppercase;letter-spacing:.05em}
.summary-value{margin-top:8px;font-size:26px;line-height:1.05;font-weight:900;color:#fff}
.summary-sub{margin-top:6px;font-size:14px;color:rgba(255,255,255,.82)}
.legend-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.legend-strip > span{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);font-size:13px;font-weight:800;color:#eef3fb}
.legend-strip .legendbtn{margin-left:2px}
.legend-strip .legend-pill{width:14px;height:14px;flex-basis:14px}

.role-staff .calgrid{gap:7px}
.role-staff .calday{
  min-height:104px;
  padding:9px 8px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
}
.role-staff .calday.today{box-shadow:inset 0 0 0 1px rgba(0,220,140,.35), 0 0 0 1px rgba(0,220,140,.18)}
.role-staff .calday.other{opacity:.22}
.role-staff .caldate .num{font-size:17px}
.role-staff .daystate{margin-top:10px;font-size:11px;line-height:1.08}
.role-staff .chips{margin-top:8px;gap:5px}
.role-staff .chip{
  font-size:10px;
  line-height:1.1;
  padding:6px 7px;
  border-radius:10px;
  white-space:normal;
  word-break:break-word;
  overflow:visible;
  text-overflow:clip;
}
.role-staff .chip.more{padding:4px 2px;background:transparent;border:none;color:rgba(255,255,255,.74)}
.role-staff .daystate.free{color:rgba(255,255,255,.92)}
.role-staff .daystate.mine{color:#8edfff}
.role-staff .daystate.open{color:#70efc1}

#calModal, #calModal *{color:#f5f8fc}
#calModal .calmodal-inner{
  background:linear-gradient(180deg, rgba(10,16,29,.985), rgba(14,22,38,.985));
  box-shadow:0 28px 70px rgba(0,0,0,.58);
}
#calModal .h2{font-size:30px;line-height:1.08;color:#fff !important}
#calModal .small{font-size:17px;line-height:1.35;color:rgba(255,255,255,.84) !important}
#calModal .mitem{padding:16px 16px 14px;border-radius:18px;border-color:rgba(255,255,255,.14);background:rgba(255,255,255,.055)}
#calModal .mitem.mine{border-color:rgba(76,201,240,.36);background:rgba(76,201,240,.10)}
#calModal .mitem.open{border-color:rgba(0,220,140,.34);background:rgba(0,220,140,.10)}
#calModal .mrow{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
#calModal .mbadge{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:13px;font-weight:900;color:#fff}
#calModal .mtime{font-size:30px;line-height:1.05;font-weight:900;color:#fff;letter-spacing:-.02em}
#calModal .mmeta{display:flex;flex-direction:column;gap:2px;margin-top:8px}
#calModal .mlabel{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.62)}
#calModal .mvalue{font-size:18px;line-height:1.28;color:#fff;font-weight:700}
#calModalClose{color:#fff !important;font-size:18px;font-weight:900;padding:12px 16px}

@media (max-width: 760px){
  .staff-roster-summary{grid-template-columns:1fr;gap:10px}
  .summary-value{font-size:22px}
}
@media (max-width: 520px){
  .staff-roster-summary{margin-top:12px}
  .summary-tile{padding:12px 14px;border-radius:16px}
  .summary-label{font-size:11px}
  .summary-value{font-size:20px}
  .summary-sub{font-size:13px}
  .legend-strip{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .legend-strip > span{justify-content:flex-start;padding:9px 10px;font-size:12px}
  .legend-strip .legendbtn{grid-column:1 / -1;width:100%;justify-content:center;margin:0}
  .role-staff .calhead{margin-bottom:6px}
  .role-staff .calh{font-size:12px;font-weight:900}
  .role-staff .calgrid{gap:5px}
  .role-staff .calday{min-height:96px;padding:8px 6px;border-radius:16px}
  .role-staff .caldate .num{font-size:15px}
  .role-staff .todaytag{font-size:9px;padding:2px 6px}
  .role-staff .daystate{margin-top:8px;font-size:10px}
  .role-staff .chip{font-size:9px;padding:5px 6px;border-radius:9px}
  #calModal .calmodal-inner{padding:16px}
  #calModal .h2{font-size:24px}
  #calModal .small{font-size:15px}
  #calModal .mrow{flex-direction:column;gap:8px;margin-bottom:8px}
  #calModal .mbadge{font-size:12px;padding:6px 9px}
  #calModal .mtime{font-size:24px}
  #calModal .mvalue{font-size:17px}
}


/* ===== Staff roster final polish ===== */
.staff-roster-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.summary-tile{padding:10px 12px;border-radius:16px;min-height:0}
.summary-label{font-size:11px}
.summary-value{margin-top:6px;font-size:18px;line-height:1.05}
.summary-sub{margin-top:4px;font-size:12px}
.legend-strip{gap:8px}
.legend-strip > span{padding:7px 10px;font-size:12px}
.legend-strip .legendbtn{padding:9px 12px}
.role-staff .calday{min-height:110px;padding:8px 6px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;overflow:hidden}
.role-staff .caldate{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:6px}
.role-staff .caldate .num{font-size:18px;line-height:1;font-weight:900;color:#fff}
.role-staff .todaytag{flex:0 0 auto;max-width:54px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px;padding:3px 7px;border-radius:999px}
.role-staff .daystate{margin-top:8px;font-size:12px;line-height:1.05;font-weight:900;min-height:24px}
.role-staff .chips{margin-top:6px;width:100%;display:flex;flex-direction:column;align-items:stretch;gap:5px}
.role-staff .chip{display:block;width:100%;font-size:12px;line-height:1.1;padding:6px 8px;border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
.role-staff .chip.more{padding:0;font-size:11px;text-align:left}
#calModal .h2{font-size:24px;color:#fff !important}
#calModal .small{font-size:15px;color:rgba(255,255,255,.86) !important}
#calModal .mtime{font-size:24px}
#calModal .mvalue{font-size:17px}
@media (max-width: 760px){
  .staff-roster-summary{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .summary-tile{padding:9px 10px}
  .summary-value{font-size:16px}
  .summary-sub{font-size:11px}
}
@media (max-width: 520px){
  .staff-roster-summary{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .summary-tile{padding:10px 10px;border-radius:14px}
  .summary-label{font-size:10px}
  .summary-value{font-size:15px}
  .summary-sub{font-size:11px;line-height:1.2}
  .legend-strip{display:flex;flex-wrap:wrap;gap:6px}
  .legend-strip > span{padding:6px 8px;font-size:11px}
  .legend-strip .legendbtn{width:auto;flex:1 1 100%;justify-content:center}
  .role-staff .calgrid{gap:6px}
  .role-staff .calday{min-height:104px;padding:7px 5px;border-radius:16px}
  .role-staff .caldate .num{font-size:16px}
  .role-staff .todaytag{max-width:44px;font-size:9px;padding:2px 6px}
  .role-staff .daystate{font-size:11px;min-height:22px}
  .role-staff .chip{font-size:11px;padding:5px 7px}
}


.license-pill{display:inline-flex; align-items:center; padding:10px 14px; border-radius:999px; font-size:13px; font-weight:800; border:1px solid var(--line); background:rgba(255,255,255,.04); color:#eef3ff}
.license-pill.ok{border-color:rgba(82,196,126,.35); background:rgba(82,196,126,.10); color:#d9ffe6}
.license-pill.warn{border-color:rgba(255,196,77,.35); background:rgba(255,196,77,.12); color:#ffe7ad}
.license-pill.expired{border-color:rgba(255,99,132,.35); background:rgba(255,99,132,.12); color:#ffd3dc}
.license-inline-card{display:none; margin:0 0 12px; padding:12px 14px; border-radius:16px; font-weight:800; border:1px solid var(--line); background:rgba(255,255,255,.03)}
.license-inline-card.ok{border-color:rgba(82,196,126,.35); background:rgba(82,196,126,.08); color:#d9ffe6}
.license-inline-card.warn{border-color:rgba(255,196,77,.35); background:rgba(255,196,77,.10); color:#ffe7ad}
.license-inline-card.expired{border-color:rgba(255,99,132,.35); background:rgba(255,99,132,.10); color:#ffd3dc}
.mobile-license-pill{display:none; width:100%; margin:0 0 10px; padding:10px 12px; border-radius:14px; font-size:12px; font-weight:800; text-align:center; border:1px solid var(--line); background:rgba(255,255,255,.03)}
.mobile-license-pill.ok{border-color:rgba(82,196,126,.35); background:rgba(82,196,126,.08); color:#d9ffe6}
.mobile-license-pill.warn{border-color:rgba(255,196,77,.35); background:rgba(255,196,77,.10); color:#ffe7ad}
.mobile-license-pill.expired{border-color:rgba(255,99,132,.35); background:rgba(255,99,132,.10); color:#ffd3dc}

@media (max-width: 980px){
  .license-pill{display:none}
  .license-inline-card{display:block}
  .mobile-license-pill{display:block}
}


.license-feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
}
.license-feature-item{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:48px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:#eef3ff;
  font-weight:800;
  line-height:1.25;
  cursor:pointer;
}
.license-feature-item:hover{
  border-color:rgba(76,201,240,.28);
  background:rgba(76,201,240,.08);
}
.license-feature-item input[type=checkbox]{
  width:18px !important;
  height:18px !important;
  min-width:18px;
  margin:0;
  accent-color:#4cc9f0;
  flex:0 0 18px;
}
.license-feature-item span{
  display:block;
  white-space:normal;
  overflow:visible;
  text-overflow:unset;
}
@media (max-width: 700px){
  .license-feature-grid{grid-template-columns:1fr;}
  .license-feature-item{padding:11px 12px; border-radius:14px;}
}


/* Login flow */
.login-flow-wrap{display:flex;justify-content:center;padding:24px 0 10px}
.login-flow-card{width:min(100%,760px);background:#fff;color:#17212f;border-radius:28px;padding:34px 32px 30px;box-shadow:0 30px 80px rgba(0,0,0,.22)}
.login-flow-greeting{font-size:clamp(2rem,4.6vw,3rem);font-weight:900;line-height:1.05;color:#0d63bf;margin:0 0 18px}
.login-flow-sub{font-size:clamp(1.05rem,2vw,1.5rem);color:#202938;margin-bottom:22px}
.login-field-label{display:block;font-weight:800;color:#253044;margin-bottom:10px}
.login-field{display:flex;align-items:center;gap:14px;border:2px solid #2d8cff;border-radius:16px;background:#fff;padding:0 18px;min-height:74px;box-shadow:0 0 0 4px rgba(45,140,255,.12)}
.login-field-icon{font-size:1.5rem;line-height:1;flex:0 0 auto}
.login-input{border:0 !important;box-shadow:none !important;background:transparent !important;color:#1d2737 !important;padding:0 !important;height:auto !important;font-size:1.35rem !important;width:100% !important}
.login-input::placeholder{color:#6d7787}
.login-suggestions{margin-top:10px;display:grid;gap:8px}
.login-suggestion-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 16px;border-radius:14px;border:1px solid rgba(13,99,191,.18);background:#f8fbff;color:#1d2737;font:inherit;cursor:pointer;text-align:left}
.login-suggestion-item strong{font-size:1rem}
.login-suggestion-item span{color:#5f6b7c;font-size:.94rem}
.login-suggestion-item:hover{background:#eef6ff;border-color:#2d8cff}
.login-suggestion-empty{padding:12px 4px;color:#6d7787}
.chosen-company-row{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#eef2f7;border:1px solid #d9e1ec;border-radius:14px;padding:14px 16px;margin-bottom:18px}
.chosen-company-row--stack{align-items:flex-start;justify-content:flex-start;gap:24px;flex-wrap:wrap}
.chosen-company-label{font-size:.84rem;font-weight:800;color:#6a7384;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.chosen-company-name{font-size:1.08rem;font-weight:800;color:#1d2737}
.chosen-company-change{border:0;background:none;color:#0d63bf;font-weight:900;font-size:1rem;cursor:pointer}
.login-primary-btn{display:inline-flex;align-items:center;justify-content:center;min-height:58px;width:100%;border:0;border-radius:14px;background:#0d63bf;color:#fff;font-weight:900;font-size:1.2rem;cursor:pointer;margin-top:18px}
.login-primary-btn:disabled{opacity:.5;cursor:not-allowed}
.login-step-message{margin-top:10px;min-height:24px;color:#627184;font-weight:700}
.login-step-message.ok{color:#107a3d}
.login-step-message.err{color:#b42318}
@media (max-width: 720px){.login-flow-card{padding:24px 20px 22px;border-radius:22px}.login-field{min-height:66px;padding:0 14px}.login-input{font-size:1.12rem !important}.chosen-company-row{padding:12px 14px}}

/* ===== Login flow refresh ===== */
body.page-login .container{width:min(1240px,94vw);margin:34px auto 60px auto}
body.page-login .footer{width:min(1240px,94vw)}
body.page-login{
  background:
    radial-gradient(820px 440px at 14% 10%, rgba(76,201,240,.10), transparent 70%),
    radial-gradient(760px 380px at 86% 18%, rgba(13,99,191,.14), transparent 68%),
    linear-gradient(180deg, #07111f 0%, #091322 48%, #08101d 100%);
}
body.page-login .topbar{background:rgba(5,11,20,.78)}
.login-shell{display:grid;grid-template-columns:minmax(280px,430px) minmax(340px,640px);gap:28px;align-items:stretch}
.login-hero,.login-flow-card{border:1px solid rgba(255,255,255,.10);border-radius:30px;box-shadow:0 30px 80px rgba(0,0,0,.34)}
.login-hero{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  padding:30px 28px;display:flex;flex-direction:column;justify-content:space-between;
}
.login-hero-badge{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;padding:10px 14px;border-radius:999px;background:rgba(76,201,240,.13);border:1px solid rgba(76,201,240,.22);font-weight:800;color:#dff7ff}
.login-hero-title{font-size:clamp(1.9rem,3.2vw,2.8rem);font-weight:900;line-height:1.02;margin-top:16px}
.login-hero-text{margin-top:14px;color:rgba(255,255,255,.76);font-size:1.02rem;line-height:1.55;max-width:32ch}
.login-hero-points{display:grid;gap:12px;margin-top:24px}
.login-hero-point{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.9)}
.login-hero-point span:first-child{color:#7be0ff;font-weight:900}
.login-flow-card{
  background:linear-gradient(180deg, rgba(15,22,34,.96), rgba(12,18,30,.96));
  color:#edf4ff;padding:28px 28px 26px;position:relative;overflow:hidden;
}
.login-flow-card::before{content:"";position:absolute;inset:auto -80px -100px auto;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle at center, rgba(76,201,240,.18), transparent 70%);pointer-events:none}
.login-stepper{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.login-step-chip{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:rgba(255,255,255,.72);font-weight:800;font-size:.95rem}
.login-step-chip.is-active{background:rgba(76,201,240,.16);border-color:rgba(76,201,240,.34);color:#fff}
.login-step-chip.is-done{background:rgba(56,176,0,.15);border-color:rgba(56,176,0,.28);color:#ecffef}
.login-flow-greeting{font-size:clamp(2rem,4vw,3.1rem);font-weight:900;line-height:1.04;color:#ffffff;margin:0 0 10px}
.login-flow-sub{font-size:clamp(1.08rem,1.8vw,1.4rem);color:rgba(255,255,255,.80);margin-bottom:24px;max-width:30ch;line-height:1.35}
.login-field-label{display:block;font-weight:800;color:rgba(255,255,255,.78);margin-bottom:10px;font-size:.96rem}
.login-field{display:flex;align-items:center;gap:14px;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:rgba(255,255,255,.05);padding:0 18px;min-height:72px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.02)}
.login-field:focus-within{border-color:rgba(76,201,240,.45);box-shadow:0 0 0 4px rgba(76,201,240,.10)}
.login-field-icon{font-size:1.35rem;line-height:1;flex:0 0 auto;filter:grayscale(.05)}
.login-input{border:0 !important;box-shadow:none !important;background:transparent !important;color:#f5f9ff !important;padding:0 !important;height:auto !important;font-size:1.18rem !important;width:100% !important}
.login-input::placeholder{color:rgba(255,255,255,.42)}
.login-help{margin-top:11px;color:rgba(255,255,255,.52);font-size:.95rem;line-height:1.4}
.login-suggestions{margin-top:12px;display:grid;gap:10px}
.login-suggestion-item{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:14px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:#f5f9ff;font:inherit;cursor:pointer;text-align:left}
.login-suggestion-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.login-suggestion-main strong{font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.login-suggestion-main small{font-size:.85rem;color:rgba(255,255,255,.50)}
.login-suggestion-meta{padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.06);font-size:.84rem;color:rgba(255,255,255,.76);white-space:nowrap}
.login-suggestion-item:hover{background:rgba(76,201,240,.11);border-color:rgba(76,201,240,.30)}
.login-suggestion-empty{padding:12px 4px;color:rgba(255,255,255,.55)}
.chosen-company-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:18px;border-radius:20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);margin-bottom:18px}
.chosen-company-row--stack{display:grid;grid-template-columns:1fr 1fr}
.chosen-company-label{font-size:.78rem;font-weight:800;color:rgba(255,255,255,.52);text-transform:uppercase;letter-spacing:.06em}
.chosen-company-name{font-size:1.05rem;font-weight:800;color:#fff;margin-top:4px;word-break:break-word}
.chosen-company-change{border:0;background:transparent;color:#7ddaff;font-weight:900;cursor:pointer;font-size:1rem}
.login-primary-btn{display:inline-flex;align-items:center;justify-content:center;min-height:60px;width:100%;border:0;border-radius:18px;background:linear-gradient(180deg, #1e8cff, #0d63bf);color:#fff;font-weight:900;font-size:1.14rem;cursor:pointer;margin-top:18px;box-shadow:0 16px 34px rgba(13,99,191,.25)}
.login-primary-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.login-step-message{margin-top:12px;min-height:24px;color:rgba(255,255,255,.62);font-weight:700}
.login-step-message.ok{color:#7ff4a2}
.login-step-message.err{color:#ff8c9d}
body.page-login .btn.ghost{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
@media (max-width: 980px){
  .login-shell{grid-template-columns:1fr}
  .login-hero{order:2;padding:22px}
  .login-flow-card{order:1}
}
@media (max-width: 720px){
  body.page-login .container{width:min(100%,94vw);margin:18px auto 60px auto}
  .login-flow-card,.login-hero{border-radius:24px}
  .login-flow-card{padding:22px 18px 20px}
  .login-stepper{gap:8px;margin-bottom:18px}
  .login-step-chip{font-size:.84rem;padding:9px 11px}
  .login-flow-greeting{font-size:2.2rem}
  .login-flow-sub{font-size:1.05rem;margin-bottom:18px}
  .login-field{min-height:64px;padding:0 14px}
  .login-input{font-size:1.06rem !important}
  .chosen-company-row{padding:14px}
  .chosen-company-row--stack{grid-template-columns:1fr}
}

/* Magister-style login */
body.page-login{
  background:linear-gradient(180deg,#b8d7e9 0%,#dcecf6 100%);
  color:#1e2b36;
}
body.page-login .topbar{
  background:transparent;
  border-bottom:0;
  padding:20px 28px 0;
}
body.page-login .brand .logo{
  background:#fff;
  color:#0d63bf;
  box-shadow:0 10px 24px rgba(13,99,191,.12);
}
body.page-login .brand .app{color:#16324a}
body.page-login .brand .sub{color:#5f7488}
body.page-login .nav .btn{background:#fff;border:1px solid rgba(13,99,191,.15);color:#0d63bf;box-shadow:0 8px 20px rgba(13,99,191,.08)}
body.page-login .container{max-width:none;padding:18px 24px 32px;display:flex;justify-content:center}
body.page-login .footer{background:transparent;border-top:0;color:#5c7388;padding:18px 28px 28px}
body.page-login .mobileNav{display:none !important}
.mag-login-wrap{width:100%;min-height:calc(100dvh - 168px);display:flex;align-items:center;justify-content:center;padding:18px 0 36px}
.mag-login-shell{width:min(640px,100%);margin:0 auto;display:block}
.mag-login-card{position:relative;width:100%;background:#fff;border:1px solid rgba(13,99,191,.12);border-radius:28px;box-shadow:0 24px 60px rgba(16,58,94,.18);padding:38px 34px 30px;overflow:hidden}
.mag-login-card::after{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle at center, rgba(13,99,191,.09), transparent 70%);pointer-events:none}
.mag-stepper{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.mag-step{padding:10px 14px;border-radius:999px;background:#eef4f9;border:1px solid #d6e2ec;color:#688095;font-weight:800;font-size:.95rem}
.mag-step.is-active{background:#e7f2ff;border-color:#8fc0ff;color:#0d63bf}
.mag-step.is-done{background:#ebfaf0;border-color:#9ed8af;color:#1f7a39}
.mag-greeting{font-size:clamp(2.25rem,4.2vw,3.2rem);line-height:1.02;margin:0 0 10px;color:#0d63bf;font-weight:900}
.mag-subtitle{font-size:clamp(1.15rem,1.8vw,1.55rem);line-height:1.35;color:#213244;margin-bottom:26px}
.mag-label{display:block;margin-bottom:10px;font-weight:800;color:#32495c}
.mag-input-wrap{display:flex;align-items:center;gap:14px;min-height:68px;background:#fff;border:1.5px solid #8bbcf0;border-radius:16px;padding:0 18px;box-shadow:0 0 0 4px rgba(13,99,191,.08);transition:border-color .15s, box-shadow .15s}
.mag-input-wrap:focus-within{border-color:#0d63bf;box-shadow:0 0 0 4px rgba(13,99,191,.14)}
.mag-input-icon{font-size:1.35rem;line-height:1;flex:0 0 auto}
.mag-input{width:100%;border:0 !important;outline:0 !important;background:transparent !important;box-shadow:none !important;padding:0 !important;height:auto !important;font-size:1.18rem !important;color:#1e2b36 !important}
.mag-input::placeholder{color:#7c8ea0}
.mag-inline-help{margin-top:12px;color:#698094;font-size:.96rem;line-height:1.45}
.mag-search-results{position:relative;margin-top:10px;display:grid;gap:8px;min-height:0}
.mag-result-item{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;padding:14px 16px;border-radius:16px;border:1px solid #d5e3ef;background:#fff;color:#1e2b36;font:inherit;text-align:left;cursor:pointer;box-shadow:0 8px 18px rgba(13,99,191,.05)}
.mag-result-item:hover{background:#f4f9ff;border-color:#9ac5f7}
.mag-result-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.mag-result-main strong{font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mag-result-main small{color:#72869a;font-size:.84rem}
.mag-result-meta{padding:7px 10px;border-radius:999px;background:#eef5fb;color:#5e7387;font-size:.82rem;white-space:nowrap}
.mag-no-results{padding:14px 4px;color:#718598}
.mag-selected-box{display:flex;align-items:center;gap:14px;background:#f2f6f9;border:1px solid #d8e3ec;border-radius:16px;padding:14px 16px;margin-bottom:18px}
.mag-selected-box.compact{margin-bottom:0}
.mag-selected-box-icon{font-size:1.35rem;line-height:1;flex:0 0 auto;color:#0d63bf}
.mag-selected-box-body{min-width:0;flex:1}
.mag-selected-box-label{font-size:.82rem;font-weight:800;color:#6b8296;text-transform:uppercase;letter-spacing:.04em}
.mag-selected-box-value{font-size:1.06rem;font-weight:800;color:#203243;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mag-link-btn{border:0;background:transparent;color:#0d63bf;font-weight:800;cursor:pointer;padding:8px 10px;border-radius:12px}
.mag-link-btn:hover{background:#e7f2ff}
.mag-step-message{margin-top:12px;min-height:24px;font-weight:700;color:#678094}
.mag-step-message.ok{color:#17743a}
.mag-step-message.err{color:#b42318}
.mag-primary-btn,.mag-secondary-btn{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:58px;border-radius:14px;font-weight:900;font-size:1.12rem;cursor:pointer;transition:transform .06s ease, box-shadow .12s ease}
.mag-primary-btn{margin-top:18px;border:0;background:#0d63bf;color:#fff;box-shadow:0 14px 30px rgba(13,99,191,.22)}
.mag-primary-btn:hover{transform:translateY(-1px)}
.mag-primary-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.mag-actions{display:grid;gap:12px;margin-top:18px}
.mag-secondary-btn{border:1px solid #cad9e5;background:#fff;color:#2a4053}
.mag-selected-stack{display:grid;gap:10px;margin-bottom:18px}
.mag-super-link{display:inline-block;margin-top:16px;color:#0d63bf;font-weight:800}
@media (min-width: 1100px){
  .mag-login-shell{width:min(700px,100%)}
  .mag-login-card{padding:42px 40px 34px}
  .mag-greeting{font-size:3.35rem}
}
@media (max-width: 900px){
  .mag-login-shell{max-width:720px}
}
@media (max-width: 640px){
  body.page-login .topbar{padding:16px 14px 0}
  body.page-login .container{padding:12px 12px 24px}
  body.page-login .footer{padding:14px 16px 24px}
  .mag-login-wrap{min-height:auto;padding:0 0 18px}
  .mag-login-card{padding:22px 18px 20px;border-radius:22px}
  .mag-step{font-size:.84rem;padding:9px 11px}
  .mag-subtitle{font-size:1.08rem;margin-bottom:18px}
  .mag-input-wrap{min-height:62px;padding:0 14px}
  .mag-input{font-size:1.05rem !important}
}

/* ===== Own login layout ===== */
body.page-login{background:linear-gradient(180deg,#dcecf8 0%,#cfe3f2 100%)}
body.page-login .container{max-width:1200px}
.bk-login-page{width:100%;min-height:calc(100dvh - 172px);display:flex;align-items:center;justify-content:center;padding:24px 0 40px}
.bk-login-shell{width:min(1120px,100%);display:grid;grid-template-columns:minmax(320px,430px) minmax(420px,620px);gap:30px;align-items:stretch}
.bk-login-side,.bk-login-card{border-radius:32px;box-shadow:0 22px 60px rgba(27,61,94,.16)}
.bk-login-side{position:relative;overflow:hidden;padding:34px 30px;background:linear-gradient(165deg,#0f58aa 0%,#0c4a95 56%,#0a366d 100%);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:620px}
.bk-login-side::after{content:"";position:absolute;right:-70px;bottom:-70px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 70%)}
.bk-login-side-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);font-weight:800;align-self:flex-start}
.bk-login-side-title{font-size:clamp(2.3rem,3.6vw,3.5rem);line-height:.98;font-weight:900;color:#fff;margin:18px 0 0}
.bk-login-side-text{margin:18px 0 0;color:rgba(255,255,255,.88);font-size:1.08rem;line-height:1.6;max-width:30ch}
.bk-login-side-points{display:grid;gap:14px;margin-top:28px}
.bk-login-side-point{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);font-weight:700;color:#f3f8ff}
.bk-login-side-point span{font-size:1.4rem;line-height:1;color:#a9dcff}
.bk-login-card{position:relative;background:#fff;border:1px solid rgba(13,99,191,.12);padding:34px 34px 28px;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.bk-login-card::before{content:"";position:absolute;left:-80px;top:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle at center,rgba(13,99,191,.08),transparent 70%);pointer-events:none}
.bk-stepper{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.bk-step{padding:11px 16px;border-radius:999px;background:#eef4fa;border:1px solid #d6e3ef;color:#688099;font-weight:800}
.bk-step.is-active{background:#e8f2ff;border-color:#91bfff;color:#0d63bf}
.bk-step.is-done{background:#edf8f1;border-color:#b3e2c1;color:#157347}
.bk-greeting{position:relative;font-size:clamp(2.5rem,4vw,4rem);line-height:.98;font-weight:900;color:#0d63bf;margin:10px 0 10px}
.bk-subtitle{font-size:clamp(1.15rem,1.8vw,1.55rem);line-height:1.35;color:#243549;max-width:26ch;margin-bottom:22px}
.bk-step-panel{position:relative;z-index:1}
.bk-label{display:block;font-weight:800;color:#223348;margin-bottom:10px;font-size:.98rem}
.bk-input-wrap{display:flex;align-items:center;gap:12px;min-height:74px;padding:0 18px;background:#fff;border:2px solid #b8d4f2;border-radius:18px;box-shadow:0 0 0 4px rgba(45,140,255,.08);transition:border-color .18s ease, box-shadow .18s ease}
.bk-input-wrap:focus-within{border-color:#2d8cff;box-shadow:0 0 0 4px rgba(45,140,255,.14)}
.bk-input-icon{font-size:1.35rem;line-height:1;flex:0 0 auto}
.bk-input{border:0 !important;box-shadow:none !important;background:transparent !important;color:#1c2736 !important;padding:0 !important;height:auto !important;font-size:1.22rem !important;width:100% !important}
.bk-input::placeholder{color:#7a8796}
.bk-inline-help{margin-top:12px;color:#6a7a8d;font-size:1rem;line-height:1.45}
.bk-search-results{margin-top:12px;display:grid;gap:10px}
.bk-result-item{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:15px 16px;border-radius:18px;border:1px solid #d7e4f0;background:#f7fbff;color:#1d2a39;font:inherit;cursor:pointer;text-align:left}
.bk-result-main{display:flex;flex-direction:column;gap:2px;min-width:0}.bk-result-main strong{font-size:1rem}.bk-result-main small{color:#6d7e91}
.bk-result-meta{padding:7px 10px;border-radius:999px;background:#ebf4ff;color:#0d63bf;font-size:.84rem;white-space:nowrap}
.bk-result-item:hover{background:#eef6ff;border-color:#8fc0ff}
.bk-no-results{padding:12px 2px;color:#6a7a8d}
.bk-selected-box{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:20px;background:#f3f7fb;border:1px solid #dbe6ef;margin-bottom:18px}
.bk-selected-box.compact{margin-bottom:0}
.bk-selected-box-icon{width:42px;height:42px;border-radius:14px;background:#e8f2ff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex:0 0 42px}
.bk-selected-box-body{min-width:0}.bk-selected-box-label{font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:#6b7d90;font-weight:800}.bk-selected-box-value{font-size:1.04rem;color:#203244;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-link-btn{margin-left:auto;border:0;background:transparent;color:#0d63bf;font-weight:900;font-size:1rem;cursor:pointer}
.bk-step-message{margin-top:12px;min-height:24px;color:#66798c;font-weight:700}.bk-step-message.ok{color:#157347}.bk-step-message.err{color:#b42318}
.bk-primary-btn,.bk-secondary-btn{display:inline-flex;align-items:center;justify-content:center;min-height:60px;border-radius:18px;font-weight:900;font-size:1.08rem;cursor:pointer}
.bk-primary-btn{width:100%;margin-top:18px;border:0;background:linear-gradient(180deg,#1f7de4,#0d63bf);color:#fff;box-shadow:0 16px 32px rgba(13,99,191,.18)}
.bk-primary-btn:disabled{opacity:.48;box-shadow:none;cursor:not-allowed}
.bk-actions{display:grid;gap:12px;margin-top:18px}.bk-secondary-btn{width:100%;border:1px solid #d2dee9;background:#fff;color:#28415a}
.bk-selected-stack{display:grid;gap:12px;margin-bottom:16px}
.bk-super-link{display:inline-block;margin-top:14px;color:#0d63bf;font-weight:800;text-decoration:none}
.bk-super-link:hover{text-decoration:underline}
@media (min-width: 901px){
  .bk-login-card{min-height:620px}
}
@media (max-width: 900px){
  .bk-login-page{min-height:auto;padding:8px 0 24px}
  .bk-login-shell{grid-template-columns:1fr;gap:18px;width:min(720px,100%)}
  .bk-login-side{min-height:auto;padding:24px 20px;border-radius:24px}
  .bk-login-side-title{font-size:2.2rem}
  .bk-login-card{padding:24px 20px 22px;border-radius:24px}
}
@media (max-width: 640px){
  .bk-login-side{display:none}
  .bk-login-page{padding:0 0 18px}
  .bk-login-shell{width:min(100%,720px)}
  .bk-login-card{padding:22px 18px 20px;border-radius:22px}
  .bk-step{padding:10px 13px;font-size:.95rem}
  .bk-greeting{font-size:2.6rem}
  .bk-subtitle{font-size:1.18rem;margin-bottom:18px}
  .bk-input-wrap{min-height:66px;padding:0 14px;border-radius:16px}
  .bk-input{font-size:1.06rem !important}
  .bk-inline-help{font-size:.95rem}
}

.bk-remember-card{margin-top:18px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:16px 18px;border:2px solid #b8d4f2;border-radius:20px;background:linear-gradient(180deg,#f8fbff 0%,#eef6ff 100%);box-shadow:0 10px 22px rgba(13,99,191,.08);cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.bk-remember-card:hover{border-color:#7ab3ff;box-shadow:0 14px 30px rgba(13,99,191,.12)}
.bk-remember-card.is-on{border-color:#0d63bf;box-shadow:0 0 0 5px rgba(13,99,191,.12),0 14px 30px rgba(13,99,191,.14)}
.bk-remember-check{width:26px !important;height:26px;margin:0;accent-color:#0d63bf;cursor:pointer;flex:0 0 auto}
.bk-remember-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.bk-remember-title{font-size:1.05rem;font-weight:900;color:#18324d;line-height:1.2}
.bk-remember-help{font-size:.92rem;line-height:1.45;color:#5f7286}
.bk-remember-tag{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#e8f2ff;color:#0d63bf;font-size:.82rem;font-weight:900;white-space:nowrap}
@media (max-width: 640px){
  .bk-remember-card{grid-template-columns:auto 1fr;gap:12px;padding:14px 14px 15px}
  .bk-remember-tag{grid-column:2;justify-self:start;margin-top:2px}
  .bk-remember-title{font-size:1rem}
  .bk-remember-help{font-size:.9rem}
}
