/* ─── Brand palette (from horizontal logo) ─────────────────────────────────
   Primary navy:       #1F4F74 (the monogram + "Law" wordmark)
   Primary navy soft:  #2C6691 (hover states, subtle accents)
   Brand gray:         #8C8B89 ("Meredith Office" wordmark)
   Brand gray dark:    #5C5B59 (body text on light backgrounds)
   Brand cream:        #FAF8F4 (off-white background)
   Brand line:         #E4E2DD (warm divider)
   Brand panel tint:   #EAF1F7 (very light blue tint for callout cards)
   ────────────────────────────────────────────────────────────────────────── */

:root {
  --navy:        #1F4F74;
  --navy-soft:   #2C6691;
  --navy-deep:   #163C58;
  --gray:        #8C8B89;
  --gray-dark:   #5C5B59;
  --ink:         #2A2A28;
  --cream:       #FAF8F4;
  --paper:       #FFFFFF;
  --line:        #E4E2DD;
  --tint:        #EAF1F7;
  --ok:          #1F6D4A;
  --ok-bg:       #E7F4EC;
  --warn:        #8A5A0F;
  --warn-bg:     #FBF1DD;
  --err:         #8C2A2A;
  --err-bg:      #FBECEC;

  --serif:       Georgia, "Cormorant Garamond", "Times New Roman", serif;
  --sans:        -apple-system, "Segoe UI", system-ui, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  background: var(--cream);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.55;
}

a { color: var(--navy); }
a:hover { color: var(--navy-soft); }

/* ─── Header ─────────────────────────────────────────────────────────────── */

.topbar {
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  padding: 14px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.topbar .logo {
  height: 38px;
  display: block;
}
.topbar nav a {
  margin-left: 18px;
  text-decoration: none;
  font-size: 14px;
  color: var(--gray-dark);
}
.topbar nav a:hover { color: var(--navy); }

/* ─── Layout ─────────────────────────────────────────────────────────────── */

.container {
  max-width: 980px;
  margin: 28px auto;
  padding: 0 24px 80px;
}

h1, h2, h3, h4 {
  font-family: var(--serif);
  color: var(--navy-deep);
  font-weight: 500;
  letter-spacing: -0.01em;
}
h1 { font-size: 28px; margin-top: 0; line-height: 1.2; }
h2 { font-size: 20px; margin-top: 32px; }
h3 { font-size: 13px; color: var(--gray); text-transform: uppercase;
     letter-spacing: 0.08em; font-family: var(--sans); font-weight: 600; }
h4 { font-size: 15px; }

p, li, td { color: var(--ink); }
.muted { color: var(--gray); }
hr { border: none; border-top: 1px solid var(--line); margin: 28px 0; }

/* ─── Forms ──────────────────────────────────────────────────────────────── */

input, select, textarea, button {
  font: inherit;
  padding: 10px 12px;
  border-radius: 4px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink);
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--navy-soft);
  box-shadow: 0 0 0 3px rgba(44, 102, 145, 0.12);
}
textarea { width: 100%; min-height: 90px; resize: vertical; }
input[type="text"], input[type="email"], input[type="tel"],
input[type="date"], input[type="password"], select { width: 100%; }

button, .btn {
  background: var(--navy);
  color: var(--paper);
  border: 1px solid var(--navy);
  padding: 10px 20px;
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: background-color 0.15s;
}
button:hover, .btn:hover { background: var(--navy-soft); border-color: var(--navy-soft); }
button.secondary, .btn.secondary {
  background: var(--paper);
  color: var(--navy);
}
button.secondary:hover, .btn.secondary:hover {
  background: var(--tint);
  color: var(--navy-deep);
}
button:disabled { opacity: 0.5; cursor: not-allowed; }

form .row { margin-bottom: 16px; }
form label {
  font-weight: 600;
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
  color: var(--gray-dark);
  letter-spacing: 0.02em;
}
fieldset { border: 1px solid var(--line); border-radius: 6px; padding: 14px 16px; margin: 12px 0; }
fieldset legend { padding: 0 8px; color: var(--gray); font-size: 12px; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }

/* ─── Cards & flashes ────────────────────────────────────────────────────── */

.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 22px 26px;
  margin: 18px 0;
  box-shadow: 0 1px 2px rgba(31, 79, 116, 0.04);
}
.card.tint { background: var(--tint); border-color: var(--tint); }

.flash {
  padding: 12px 16px;
  border-radius: 4px;
  margin: 10px 0;
  border-left: 4px solid;
}
.flash-success { background: var(--ok-bg); color: var(--ok); border-left-color: var(--ok); }
.flash-info    { background: var(--tint); color: var(--navy-deep); border-left-color: var(--navy); }
.flash-error   { background: var(--err-bg); color: var(--err); border-left-color: var(--err); }
.flash-warning { background: var(--warn-bg); color: var(--warn); border-left-color: var(--warn); }

.intro {
  background: var(--tint);
  padding: 18px 22px;
  border-radius: 8px;
  white-space: pre-wrap;
  border-left: 3px solid var(--navy);
  font-size: 14.5px;
  line-height: 1.65;
}

/* ─── Tables ─────────────────────────────────────────────────────────────── */

table { width: 100%; border-collapse: collapse; }
th, td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}
th {
  font-size: 11px;
  color: var(--gray);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}

.tag {
  display: inline-block;
  font-size: 11px;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--tint);
  color: var(--navy-deep);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 600;
}
.tag.warn { background: var(--warn-bg); color: var(--warn); }
.tag.ok   { background: var(--ok-bg);   color: var(--ok); }

/* ─── Slot picker ────────────────────────────────────────────────────────── */

.slot-day { margin: 22px 0; }
.slot-day h4 { margin: 0 0 8px; color: var(--navy); font-family: var(--serif); font-size: 16px; }

.slot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}
.slot-btn {
  border: 1.5px solid var(--navy);
  background: var(--paper);
  color: var(--navy);
  padding: 10px 4px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  transition: all 0.12s;
}
.slot-btn:hover { background: var(--tint); }
.slot-btn.warn  { border-color: var(--warn); color: var(--warn); background: var(--warn-bg); }
.slot-btn.warn:hover { background: #F6E5BD; }
.slot-btn.selected { background: var(--navy); color: var(--paper); }

/* ─── Save-to-calendar ───────────────────────────────────────────────────── */

.cal-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 14px 0;
}
.cal-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper);
  color: var(--gray-dark);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: all 0.12s;
}
.cal-btn:hover { border-color: var(--navy); color: var(--navy); background: var(--tint); }
.cal-btn .ico {
  font-size: 18px;
  display: inline-block;
  width: 20px;
  text-align: center;
}

/* ─── Footer ─────────────────────────────────────────────────────────────── */

footer {
  text-align: center;
  padding: 28px 20px;
  color: var(--gray);
  font-size: 13px;
  border-top: 1px solid var(--line);
  background: var(--paper);
}
footer .firm-name { font-family: var(--serif); color: var(--navy); font-size: 14px; }

@media (max-width: 700px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .topbar { flex-direction: column; gap: 10px; align-items: flex-start; padding: 14px 18px; }
  .topbar nav a { margin-left: 0; margin-right: 14px; }
  .container { padding: 0 16px 60px; }
  h1 { font-size: 24px; }
}
