/* ── Dashboard: VALTHR mobile hero card ─────────────────────────────────── */
.dash-hero{
  display:none; /* desktop: hidden */
  background:#0b0b12;
  border-radius:var(--rl);
  border:1px solid rgba(255,255,255,.09);
  padding:20px 20px;
  align-items:center;
  gap:0;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.4);
}

/* Show only on mobile/tablet */
@media(max-width:900px){
  .dash-hero{ display:flex }
}

.dash-hero-logo{
  font-size:30px;
  font-weight:900;
  letter-spacing:.02em;
  flex-shrink:0;
  /* Metallic silver gradient matching valthr.com */
  background:linear-gradient(160deg,#ffffff 0%,#a0a0b8 45%,#ffffff 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  padding-right:20px;
}

/* Vertical divider */
.dash-hero-sep{
  width:1px;
  align-self:stretch;
  background:rgba(255,255,255,.12);
  margin-right:20px;
  flex-shrink:0;
}

/* Contact rows container */
.dash-hero-info{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:9px;
  min-width:0;
}

.dash-hero-row{
  display:flex;
  align-items:center;
  gap:9px;
  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.72);
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-family:inherit;
}
a.dash-hero-row:hover{ color:#fff }

.dash-hero-ic{
  font-size:14px;
  flex-shrink:0;
  opacity:.7;
  width:20px;
  text-align:center;
}

/* ── VALTHR landing page (Login.js first screen) ────────────────────────── */
.vl-wrap{
  min-height:100vh;
  background:#0a0b0f;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  position:relative;
  overflow:hidden;
}
.vl-glow{
  position:absolute;
  left:28%; top:50%;
  transform:translate(-50%,-50%);
  width:600px; height:400px;
  background:radial-gradient(ellipse,rgba(91,91,214,.07) 0%,transparent 70%);
  pointer-events:none;
}
.vl-lock{
  position:absolute;
  top:24px; right:24px;
  width:40px; height:40px;
  border-radius:10px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s;
  color:rgba(255,255,255,.3);
}
.vl-lock:hover{background:rgba(255,255,255,.09);color:rgba(255,255,255,.7)}
.vl-card{
  display:flex;
  align-items:center;
  padding:0 40px;
}
.vl-logo-wrap{ padding-right:64px; user-select:none }
.vl-logo{
  font-size:clamp(48px,8vw,80px);
  font-weight:900;
  letter-spacing:.04em;
  line-height:1;
  background:linear-gradient(175deg,#fff 0%,#c8cdd8 35%,#8892a4 65%,#5a6170 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  font-family:'Arial Black','Arial Bold',Arial,sans-serif;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,.6));
}
.vl-divider{
  width:1px; height:130px; flex-shrink:0;
  background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.18) 25%,rgba(255,255,255,.18) 75%,transparent 100%);
}
.vl-contacts{
  padding-left:64px;
  display:flex; flex-direction:column; gap:24px;
}
.vl-row{ display:flex; align-items:center; gap:18px }
.vl-icon{ color:rgba(255,255,255,.35); flex-shrink:0; display:flex }
.vl-txt{ font-size:15px; color:rgba(255,255,255,.7); font-weight:400; letter-spacing:.01em }

/* Mobile: stack VALTHR on top, contacts below */
@media(max-width:600px){
  .vl-card{
    flex-direction:column;
    align-items:center;
    text-align:center;
    padding:48px 24px;
    gap:36px;
  }
  .vl-logo-wrap{ padding-right:0 }
  .vl-logo{ font-size:clamp(56px,18vw,80px) }
  .vl-divider{ display:none }
  .vl-contacts{ padding-left:0; gap:22px; align-items:center }
  .vl-glow{ left:50%; top:30% }
  .vl-lock{ top:16px; right:16px }
}

/* ── Login page ──────────────────────────────────────────────────────────── */
.lwrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:linear-gradient(135deg,rgba(91,91,214,.08) 0%,var(--bg) 55%);
}
:root.dark .lwrap{
  background:linear-gradient(135deg,rgba(91,91,214,.12) 0%,var(--bg) 60%);
}
.lcard{
  width:100%;
  max-width:400px;
  padding:44px 40px;
  box-shadow:var(--shl);
}
.llogo{
  width:52px;
  height:52px;
  background:var(--ac);
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 22px;
  font-size:22px;
  box-shadow:0 8px 20px rgba(91,91,214,.30);
}

/* ── Calendar ────────────────────────────────────────────────────────────── */
.cal-hd{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:3px;
  margin-bottom:4px;
}
.cal-hdc{
  text-align:center;
  font-size:10px;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.07em;
  padding:6px 0;
}
.cal-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:4px;
}
.cal-cell{
  background:var(--sf2);
  border-radius:8px;
  min-height:80px;
  padding:7px;
  cursor:default;
  border:1.5px solid transparent;
  transition:border-color .15s,background .15s;
}
.cal-cell:hover{border-color:var(--bd2)}
.cal-cell.ctoday{
  border-color:var(--ac)!important;
  background:var(--acl);
}
.cal-cell.cother{opacity:.3}

.cal-day{
  font-size:12px;
  font-weight:600;
  color:var(--tx2);
  margin-bottom:5px;
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:6px;
}
.cal-cell.ctoday .cal-day{
  background:var(--ac);
  color:#fff;
}
.cal-dot{
  font-size:10px;
  font-weight:500;
  padding:1px 6px;
  border-radius:4px;
  margin-bottom:2px;
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.cd-work{background:var(--gr-bg);color:var(--gr)}
.cd-sick{background:var(--re-bg);color:var(--re)}
.cd-leave{background:var(--pu-bg);color:var(--pu)}
.cd-holiday{background:#fef3c7;color:#92400e}
.cd-pubhol {background:#ffe4e6;color:#be123c}
:root.dark .cd-holiday{background:rgba(251,191,36,.15);color:#fbbf24}
:root.dark .cd-pubhol {background:rgba(244,63,94,.18);color:#fb7185}
/* Closed-day cell tint */
.cal-cell.cclosed{background:#fff5f5}
:root.dark .cal-cell.cclosed{background:rgba(244,63,94,.06)}

/* Calendar navigation buttons */
.cnav-btn{
  background:var(--sf);
  border:1.5px solid var(--bd);
  border-radius:var(--r);
  color:var(--tx2);
  padding:6px 18px;
  cursor:pointer;
  font-size:20px;
  line-height:1;
  transition:all .15s;
  box-shadow:var(--sh);
  font-family:inherit;
}
.cnav-btn:hover{
  border-color:var(--bd2);
  color:var(--tx);
  background:var(--sf2);
}

/* ── Calendar: horizontal scroll on phone ────────────────────────────────── */
@media(max-width:600px){
  /* Wrap in scrollable container */
  .cal-hd, .cal-grid{
    min-width:500px;
  }
  /* Make the card/parent scrollable */
  .card:has(.cal-grid){
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  /* Smaller cells on phone */
  .cal-cell{
    min-height:64px;
    padding:5px;
  }
  .cal-dot{
    font-size:9px;
    padding:0 4px;
  }
}

/* ── Toast — top-right on desktop, top-center on mobile ─────────────────── */
.toast{
  position:fixed;
  top:20px;
  right:24px;
  bottom:auto;
  left:auto;
  transform:translateY(-6px);
  background:var(--tx);
  color:var(--sf);
  padding:9px 18px;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  z-index:300;
  opacity:0;
  transition:opacity .2s,transform .2s;
  pointer-events:none;
  box-shadow:var(--shm);
  white-space:nowrap;
  letter-spacing:.01em;
}
.toast.show{
  opacity:1;
  transform:translateY(0);
}
@media(max-width:600px){
  .toast{
    right:auto;
    left:50%;
    transform:translateX(-50%) translateY(-6px);
  }
  .toast.show{
    transform:translateX(-50%) translateY(0);
  }
}

/* ── Pulse dot (sick / overtime warnings) ──────────────────────────────── */
@keyframes pulse-dot{
  0%,100%{opacity:1;}
  50%{opacity:.35;}
}
.pulse-dot{
  display:inline-block;
  width:7px;height:7px;
  border-radius:50%;
  background:var(--am);
  animation:pulse-dot 1.8s ease-in-out infinite;
  vertical-align:middle;
  margin-left:5px;
}
.pulse-dot.red{background:var(--re);}

/* ── Timelog responsive table / card toggle ──────────────────────────────── */
.tl-desktop{display:none}
.tl-mobile {display:block}
@media(min-width:640px){
  .tl-desktop{display:block}
  .tl-mobile {display:none}
}
/* Early-start row */
.tl-early td{background:var(--early-bg)!important}
.tl-early td:first-child{box-shadow:inset 3px 0 0 var(--early)}
.tl-early:hover td{background:rgba(8,145,178,0.16)!important}
