/* Copeland Weaver Practice Manager — brand styling.
   Source Serif 4 (headings) + Manrope (UI), navy/sky palette to match copelandweaver.com. */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,400;8..60,600;8..60,700&display=swap');

:root {
  --navy: #13294b;
  --navy-700: #1b3a66;
  --petrol: #072028;     /* exact background color of the on-dark logo PNG — keep in sync */
  --sky: #3b82c4;
  --sky-100: #e8f1fa;
  --gold: #b9933f;       /* brand accent — from the CW logo / letterhead */
  --gold-soft: #d8b86a;
  --ink: #1d2733;
  --muted: #5b6776;
  --line: #dde3ea;
  --bg: #f6f8fb;
  --card: #ffffff;
  --good: #1f8a4c;
  --warn: #b06a00;
  --warn-bg: #fff5e6;
  --bad: #b3261e;
  --radius: 8px;
  --serif: 'Source Serif 4', Georgia, serif;
  --sans: 'Manrope', -apple-system, Segoe UI, Roboto, sans-serif;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: var(--sans); color: var(--ink); background: var(--bg); font-size: 15px; line-height: 1.5; }
a { color: var(--sky); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { font-family: var(--serif); color: var(--navy); margin: 0 0 .4em; font-weight: 600; }
h1 { font-size: 1.7rem; } h2 { font-size: 1.3rem; } h3 { font-size: 1.05rem; }

/* Top bar */
/* petrol background matches the on-dark logo PNG exactly, so the logo blends in
   (no visible box). Gold hairline ties to the letterhead accent. */
.topbar { display: flex; align-items: center; gap: 1.25rem; background: var(--petrol); color: #fff; padding: .4rem 1.25rem; min-height: 56px; border-bottom: 3px solid var(--gold); }
.topbar a { color: #cfe0f2; }
.topbar .brand { display: flex; align-items: center; gap: .55rem; flex: 0 0 auto; }
.topbar .brand a { display: flex; align-items: center; }
.topbar .brand-logo { height: 32px; width: auto; max-width: 190px; display: block; }
.topbar .brand span { color: var(--gold-soft); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; }
/* nav links wrap to a second line on narrower windows instead of overflowing
   off-screen — every page stays reachable no matter the window width. */
.topbar nav { display: flex; flex-wrap: wrap; column-gap: 1rem; row-gap: .15rem; flex: 1 1 auto; }
.topbar nav a { padding: .2rem 0; font-weight: 500; white-space: nowrap; }
.topbar nav a:hover { color: #fff; text-decoration: none; }
.userbox { display: flex; align-items: center; gap: 1rem; flex: 0 0 auto; font-size: .85rem; color: #9db8d6; white-space: nowrap; }

.content { max-width: 1100px; margin: 2rem auto; padding: 0 1.5rem; }
.content.wide { max-width: 96vw; padding: 0 1rem; }   /* dashboard: use nearly the full window width */

/* Cards */
.card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.25rem 1.5rem; margin-bottom: 1.25rem; }
.card h2 { margin-top: 0; }
.grid { display: grid; gap: 1rem; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: 1fr 1fr; }

/* Stat tiles */
.stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem 1.25rem; }
.stat .n { font-family: var(--serif); font-size: 2rem; color: var(--navy); font-weight: 700; }
.stat .l { color: var(--muted); font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }
.stat.warn .n { color: var(--warn); }

/* Tables */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: .55rem .6rem; border-bottom: 1px solid var(--line); }
th { font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); font-weight: 600; }
tbody tr:hover { background: var(--sky-100); }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Forms */
label { display: block; font-size: .82rem; color: var(--muted); font-weight: 600; margin-bottom: .25rem; }
input, select, textarea { width: 100%; padding: .5rem .6rem; border: 1px solid var(--line); border-radius: 6px; font: inherit; background: #fff; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--sky); box-shadow: 0 0 0 3px var(--sky-100); }
.field { margin-bottom: 1rem; }
.row { display: flex; gap: 1rem; } .row > * { flex: 1; }

/* Buttons */
.btn { display: inline-block; background: var(--sky); color: #fff; border: none; padding: .55rem 1.1rem; border-radius: 6px; font: inherit; font-weight: 600; cursor: pointer; }
.btn:hover { background: #2f6fab; text-decoration: none; }
.btn.secondary { background: #fff; color: var(--navy); border: 1px solid var(--line); }
.btn.danger { background: var(--bad); }
.btn-link { background: none; border: none; color: inherit; cursor: pointer; text-decoration: underline; padding: 0; font: inherit; }

/* Badges / pills */
.pill { display: inline-block; padding: .1rem .55rem; border-radius: 999px; font-size: .75rem; font-weight: 600; }
.pill.review { background: var(--warn-bg); color: var(--warn); }
.pill.off { background: #eef; color: #44569b; }
.pill.muted { background: #eef1f5; color: var(--muted); }
.pill.good { background: #e6f4ec; color: var(--good); }
.pill.bad { background: #fbeae9; color: var(--bad); }

/* Alerts */
.alert { padding: .75rem 1rem; border-radius: 6px; margin-bottom: 1rem; }
.alert.error { background: #fbeae9; color: var(--bad); border: 1px solid #f0c7c4; }
.alert.warn { background: var(--warn-bg); color: var(--warn); border: 1px solid #f0dcb5; }
.alert.info { background: var(--sky-100); color: var(--navy-700); border: 1px solid #cfe0f2; }
.alert.success { background: #e6f4ec; color: var(--good); border: 1px solid #bfe3cc; }

.muted { color: var(--muted); }
.small { font-size: .85rem; }
.right { text-align: right; }
.mono { font-variant-numeric: tabular-nums; }
.toolbar { display: flex; gap: .75rem; align-items: center; flex-wrap: wrap; margin-bottom: 1rem; }
.toolbar form { display: flex; gap: .5rem; align-items: center; }
.spacer { flex: 1; }
.login-wrap { max-width: 380px; margin: 9vh auto; }
.login-wrap .brand { text-align: center; margin-bottom: 1.5rem; }
.login-wrap .brand-logo { height: auto; width: 100%; max-width: 280px; margin: 0 auto; }
