/* =================== DoseClock.online — site.css (v8) =================== */
/* ---------- Design tokens ---------- */
:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#6b7280;
  --border:#e5e7eb;
  --panel:#ffffff;
  --primary:#1e3a8a;       /* dark blue */
  --primary-weak:#93c5fd;  /* light blue */
  --danger:#dc2626;
  --success:#16a34a;
  --warning:#d97706;

  --radius-sm:8px;
  --radius-lg:12px;
  --space-1:6px; --space-2:10px; --space-3:14px; --space-4:18px; --space-5:24px;
  --fs-1:.95rem; --fs-2:1rem; --fs-3:1.25rem; --fs-4:1.5rem;

  --shadow-1:0 1px 2px rgba(0,0,0,.06);
  --shadow-2:0 6px 16px rgba(0,0,0,.12);
}

@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1020;
    --text:#e5e7eb;
    --muted:#9ca3af;
    --border:#1f2937;
    --panel:#0f172a;
    --shadow-1:0 1px 2px rgba(0,0,0,.3);
    --shadow-2:0 6px 16px rgba(0,0,0,.35);
  }
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

/* ---------- Header (compact, global) ---------- */
header{
  position:sticky; top:0; z-index:1000;
  display:flex; align-items:center; gap:8px;
  background:#003d80; color:#fff;
  padding:6px 12px; height:50px;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
header a{display:flex; align-items:center; gap:8px; color:inherit; text-decoration:none}
header img{height:36px; width:auto}
header span{font-size:1.2em; font-weight:700}

/* ---------- Layout ---------- */
.container{max-width:980px; margin:30px auto; padding:0 var(--space-3)}
.container--wide{max-width:1200px}
.section{margin:var(--space-5) 0}
.section-title{font-size:var(--fs-3); margin:var(--space-2) 0}
.section-title--light{color:var(--primary-weak); text-align:center}

/* Optional dark hero section */
.hero{background:var(--primary); padding:30px 20px; text-align:center; color:#fff}
.hero .section-title{color:#fff}

/* ---------- Grid ---------- */
.grid{display:grid; gap:var(--space-3)}
.grid--auto{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media (max-width: 900px){ .grid--3{grid-template-columns:1fr 1fr} }
@media (max-width: 680px){ .grid--2,.grid--3{grid-template-columns:1fr} }

/* ---------- Cards & Tiles ---------- */
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--space-3);
  box-shadow:var(--shadow-1);
  color:inherit;
}
.card--link{display:block}
.card:hover{box-shadow:var(--shadow-2)}

/* Dark blue tiles for welcome */
.card--primary{
  background:var(--primary);
  color:#fff;
  text-align:center;
  font-weight:600;
}
.card--primary:hover{background:#0d2a60; text-decoration:none}

/* Optional: keep tiles from getting too large */
.grid--auto .card--primary{max-width:220px; margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:.5rem .9rem; border-radius:8px; border:0; cursor:pointer;
  font-weight:600; line-height:1;
}
.btn:focus{outline:2px solid var(--primary-weak); outline-offset:2px}
.btn--primary{background:var(--primary); color:#fff}
.btn--ghost{background:transparent; border:1px solid var(--border); color:var(--text)}
.btn--danger{background:var(--danger); color:#fff}
.btn--success{background:var(--success); color:#fff}
.btn--sm{padding:.35rem .6rem; font-size:.9rem}
.btn--block{width:100%}

/* ---------- Forms ---------- */
.input,
input[type="text"], input[type="number"], input[type="time"], input[type="date"],
input[type="search"], input[type="email"], input[type="password"],
textarea, select{
  width:100%; padding:.55rem .7rem;
  border:1px solid var(--border); border-radius:8px;
  background:var(--panel); color:var(--text);
}
label{display:block; margin:6px 0 4px; font-weight:600}
.form-row{display:grid; gap:10px; margin-bottom:12px}
.form-row--2{grid-template-columns:1fr 1fr}
.form-row--3{grid-template-columns:1fr 1fr 1fr}
@media (max-width: 800px){
  .form-row--2,.form-row--3{grid-template-columns:1fr}
}
.help{color:var(--muted); font-size:.9rem}
.inline-form{display:inline; margin:0; padding:0}

/* ---------- Tables ---------- */
.table{width:100%; border-collapse:collapse}
.table th,.table td{
  padding:10px; border-bottom:1px solid var(--border);
  text-align:left; vertical-align:middle;
}
.table th{font-weight:700; color:var(--text); background:#f9fafb}
.table--compact th,.table--compact td{padding:6px 8px}

/* Schedule table variants */
.table--schedule th:first-child,.table--schedule td:first-child{width:45%}
.table--schedule th:last-child,.table--schedule td:last-child{
  width:1%; white-space:nowrap; text-align:right;
}

/* Zebra & hover */
.table--zebra tbody tr:nth-child(odd){background:#ffffff}
.table--zebra tbody tr:nth-child(even){background:#f8fafc}
.table--hover tbody tr:hover{background:#f1f5f9}

/* Wrap for responsive scroll + panel look */
.table-wrap{
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow-1);
  padding:0; /* table provides padding */
}

/* Optional sticky header (match header height if sticky header used) */
/*
.table--sticky thead th{ position:sticky; top:50px; z-index:5; }
*/

/* Align helpers for tables */
.t-center{text-align:center}
.t-right{text-align:right}
.nowrap{white-space:nowrap}

/* ---------- Lists with row actions ---------- */
.list{list-style:none; margin:0; padding:0}
.list--rows .row{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:8px 0; border-bottom:1px dashed var(--border);
}
.list--rows .row:last-child{border-bottom:0}
.row__title{margin:0; font-weight:600; line-height:1.2}
.row__meta{color:var(--muted); font-size:.9rem; margin:0}
.row__actions{display:flex; align-items:center; gap:8px}
.row__actions form{margin:0}

/* ---------- Alerts ---------- */
.alert{padding:.8rem 1rem; border-radius:8px; border:1px solid}
.alert--info{background:rgba(14,165,233,.08); border-color:#38bdf8}
.alert--success{background:rgba(22,163,74,.08); border-color:#34d399}
.alert--warning{background:rgba(217,119,6,.08); border-color:#fbbf24}
.alert--danger{background:rgba(220,38,38,.08); border-color:#fca5a5}

/* ---------- Badges ---------- */
.badge{
  display:inline-block; padding:.2rem .45rem;
  border-radius:999px; border:1px solid var(--border); font-size:.85rem;
}
.badge--primary{background:rgba(30,58,138,.08); border-color:var(--primary); color:var(--primary)}
.badge--muted{color:var(--muted)}
/* High-contrast badge for dark tiles */
.badge--inverse{background:rgba(255,255,255,.2); border-color:#fff; color:#fff}

/* ---------- Tabs / Nav ---------- */
.nav{display:flex; gap:10px; flex-wrap:wrap}
.nav a{padding:.45rem .7rem; border-radius:8px; border:1px solid var(--border); color:inherit; text-decoration:none}
.nav a.is-active{background:var(--primary); color:#fff; border-color:var(--primary)}

/* ---------- Utilities ---------- */
.center{display:flex; align-items:center; justify-content:center}
.right{display:flex; justify-content:flex-end}
.m-0{margin:0}
.mt-1{margin-top:6px} .mt-2{margin-top:10px} .mt-3{margin-top:14px} .mt-4{margin-top:18px} .mt-5{margin-top:24px}
.mb-1{margin-bottom:6px} .mb-2{margin-bottom:10px} .mb-3{margin-bottom:14px} .mb-4{margin-bottom:18px} .mb-5{margin-bottom:24px}
.p-1{padding:6px} .p-2{padding:10px} .p-3{padding:14px} .p-4{padding:18px} .p-5{padding:24px}
.text-center{text-align:center}
.text-cap{text-transform:capitalize}

/* ---------- Responsive tweaks ---------- */
@media (max-width:640px){
  .hide-sm{display:none!important}
  .btn--block{width:100%}
}

/* === Welcome spacing & sizing patch === */

/* 1) Make each tile wider by default and add more gap between tiles */
.grid--auto {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); /* was 180px */
  gap: 20px;                                                  /* was ~14px */
}

/* 2) Remove/override the small hard cap on tile width */
.grid--auto .card--primary {
  max-width: none;   /* override any earlier 220px cap */
  padding: 18px 16px;
  font-size: 1.05rem;
  line-height: 1.25;
}

/* 3) Slightly roomier cards globally */
.card { padding: 18px; }

/* 4) Give the page title a bit more space below it */
.section-title { margin-bottom: 20px; }

/* 5) A touch more side padding on narrow screens */
.container { padding: 0 20px; }

/* Optional: on very wide screens, softly cap how huge tiles get */
@media (min-width: 1200px) {
  .grid--auto {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  }
}

/* Section titles - dark blue */
.section-title {
  text-align: center;
  font-size: var(--fs-3);
  margin: var(--space-3) 0;
  font-weight: 700;
  color: #1e3a8a; /* Dark blue */
}


