/* ============================================================
   En Garde — design tokens
   Dark mode primary. Cormorant Garamond + JetBrains Mono.
   Ink / cream / gold base; profile-specific accent overrides.
   ============================================================ */

:root {
    --ink:        #0a0a0d;
    --ink-2:      #14141a;
    --ink-3:      #1f1f27;
    --ink-4:      #2a2a35;
    --hairline:   #2c2c36;
    --cream:      #ece5d5;
    --cream-dim:  #a89f8b;
    --cream-mute: #6b6759;
    --gold:       #c9a558;
    --gold-dim:   #8a7141;
    --gold-soft:  rgba(201, 165, 88, 0.12);

    --raedyn:     #a82b2b;
    --raedyn-soft:rgba(168, 43, 43, 0.18);
    --kaylan:     #d4af37;
    --kaylan-soft:rgba(212, 175, 55, 0.18);
    --parent:     #5a7a8c;
    --parent-soft:rgba(90, 122, 140, 0.18);

    --accent:     var(--gold);
    --accent-soft:var(--gold-soft);

    --success:    #6b9a4d;
    --warn:       #c98a3a;
    --danger:     #b54545;

    --serif:      'Cormorant Garamond', Georgia, 'Times New Roman', serif;
    --mono:       'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

    --r-sm: 4px;
    --r-md: 8px;
    --r-lg: 12px;
    --r-xl: 18px;

    --gap-xs: 4px;
    --gap-sm: 8px;
    --gap-md: 16px;
    --gap-lg: 24px;
    --gap-xl: 32px;

    --topbar-h:  60px;
    --bottomnav-h: 64px;
    --tap: 44px;
}

/* per-profile accent override */
body[data-active-role='raedyn'] {
    --accent: var(--raedyn);
    --accent-soft: var(--raedyn-soft);
}
body[data-active-role='kaylan'] {
    --accent: var(--kaylan);
    --accent-soft: var(--kaylan-soft);
}
body[data-active-role='parent'] {
    --accent: var(--parent);
    --accent-soft: var(--parent-soft);
}

/* ============================================================
   reset + base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    background: var(--ink);
    color: var(--cream);
    font-family: var(--serif);
    font-size: 18px;
    line-height: 1.4;
    -webkit-font-smoothing: antialiased;
    text-size-adjust: 100%;
}

body {
    min-height: 100vh;
    min-height: 100dvh;
    padding-top: var(--topbar-h);
    padding-bottom: calc(var(--bottomnav-h) + env(safe-area-inset-bottom, 0px));
    overscroll-behavior-y: contain;
}

button { font: inherit; color: inherit; }
input, textarea, select {
    font: inherit;
    color: inherit;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 {
    font-family: var(--serif);
    font-weight: 500;
    color: var(--cream);
    margin: 0 0 var(--gap-md);
    letter-spacing: 0.01em;
}
h1 { font-size: 2rem; line-height: 1.1; }
h2 { font-size: 1.5rem; line-height: 1.15; }
h3 { font-size: 1.2rem; }
h4 { font-size: 1rem; color: var(--cream-dim); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }

.mono, code, kbd, .data { font-family: var(--mono); font-size: 0.92em; }

/* ============================================================
   topbar
   ============================================================ */
.topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: var(--topbar-h);
    padding: 0 var(--gap-md);
    padding-top: env(safe-area-inset-top, 0px);
    height: calc(var(--topbar-h) + env(safe-area-inset-top, 0px));
    background: linear-gradient(180deg, var(--ink) 0%, rgba(10,10,13,0.92) 100%);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--hairline);
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    z-index: 50;
}
.topbar-left { justify-self: start; }
.topbar-right { justify-self: end; font-family: var(--mono); font-size: 0.78rem; color: var(--cream-dim); }

.brand {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 500;
    font-size: 1.4rem;
    margin: 0;
    color: var(--cream);
    letter-spacing: 0.02em;
}

.profile-switcher {
    display: inline-flex;
    align-items: center;
    gap: var(--gap-sm);
    padding: 6px 10px;
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-radius: var(--r-md);
    cursor: pointer;
    min-height: var(--tap);
    color: var(--cream);
}
.profile-switcher:hover { border-color: var(--accent); }
.profile-mark {
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
    flex: 0 0 auto;
}
.profile-name { font-family: var(--serif); font-weight: 500; font-size: 1rem; }
.caret { font-size: 0.7rem; color: var(--cream-dim); }

.profile-menu {
    position: fixed;
    top: calc(var(--topbar-h) + env(safe-area-inset-top, 0px) + 4px);
    left: var(--gap-md);
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-radius: var(--r-lg);
    box-shadow: 0 8px 30px rgba(0,0,0,0.5);
    z-index: 60;
    min-width: 220px;
    overflow: hidden;
}
.profile-menu button {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    width: 100%;
    padding: 12px 16px;
    background: transparent;
    border: 0;
    text-align: left;
    cursor: pointer;
    border-bottom: 1px solid var(--hairline);
    min-height: var(--tap);
}
.profile-menu button:last-child { border-bottom: 0; }
.profile-menu button:hover { background: var(--ink-3); }
.profile-menu .profile-mark { width: 10px; height: 10px; }
.profile-menu .role-raedyn .profile-mark { background: var(--raedyn); box-shadow: 0 0 0 3px var(--raedyn-soft); }
.profile-menu .role-kaylan .profile-mark { background: var(--kaylan); box-shadow: 0 0 0 3px var(--kaylan-soft); }
.profile-menu .role-parent .profile-mark { background: var(--parent); box-shadow: 0 0 0 3px var(--parent-soft); }

/* ============================================================
   countdown chip
   ============================================================ */
.countdown {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--accent-soft);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
    border-radius: 999px;
    color: var(--cream);
}
.countdown .label { color: var(--cream-dim); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; }
.countdown .num { color: var(--accent); font-weight: 600; }
.countdown.taper { border-color: var(--warn); color: var(--warn); }
.countdown.taper .num { color: var(--warn); }

/* ============================================================
   offline banner
   ============================================================ */
.offline-banner {
    position: fixed;
    top: calc(var(--topbar-h) + env(safe-area-inset-top, 0px));
    left: 0; right: 0;
    background: var(--warn);
    color: var(--ink);
    text-align: center;
    padding: 6px 12px;
    font-family: var(--mono);
    font-size: 0.8rem;
    z-index: 49;
}

/* ============================================================
   bottom nav
   ============================================================ */
.bottom-nav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: var(--bottomnav-h);
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: linear-gradient(180deg, rgba(10,10,13,0.92) 0%, var(--ink) 100%);
    backdrop-filter: blur(8px);
    border-top: 1px solid var(--hairline);
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    z-index: 50;
}
.bottom-nav a {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    color: var(--cream-mute);
    text-decoration: none;
    font-family: var(--serif);
    font-size: 0.7rem;
    transition: color 120ms ease;
}
.bottom-nav a:hover { text-decoration: none; color: var(--cream-dim); }
.bottom-nav a.active { color: var(--accent); }
.bottom-nav .nav-icon { font-size: 1.1rem; line-height: 1; }
.bottom-nav .nav-label { font-size: 0.65rem; letter-spacing: 0.08em; text-transform: uppercase; }

/* ============================================================
   app surface
   ============================================================ */
.app {
    max-width: 760px;
    margin: 0 auto;
    padding: var(--gap-lg) var(--gap-md);
}

@media (min-width: 720px) {
    .app { padding: var(--gap-xl) var(--gap-lg); }
}

.section {
    margin-bottom: var(--gap-xl);
}

.section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: var(--gap-md);
    border-bottom: 1px solid var(--hairline);
    padding-bottom: var(--gap-sm);
}
.section-head h2 { margin: 0; }
.section-head .meta { font-family: var(--mono); font-size: 0.78rem; color: var(--cream-dim); }

/* ============================================================
   cards
   ============================================================ */
.card {
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-radius: var(--r-lg);
    padding: var(--gap-md);
    margin-bottom: var(--gap-md);
}
.card.bordered-accent { border-left: 3px solid var(--accent); }
.card .card-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: var(--gap-sm);
}
.card .card-head h3 { margin: 0; }
.card .card-meta { font-family: var(--mono); font-size: 0.78rem; color: var(--cream-dim); }

.empty {
    text-align: center;
    padding: var(--gap-xl) var(--gap-md);
    color: var(--cream-dim);
    font-style: italic;
}

/* ============================================================
   form controls
   ============================================================ */
.field { margin-bottom: var(--gap-md); }
.field > label, .label {
    display: block;
    font-family: var(--mono);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--cream-dim);
    margin-bottom: 6px;
}
.row { display: flex; gap: var(--gap-sm); flex-wrap: wrap; }
.row > * { flex: 1 1 auto; }
.row.tight { gap: var(--gap-xs); }

input[type=text], input[type=number], input[type=date], input[type=time],
input[type=email], input[type=password], textarea, select {
    width: 100%;
    background: var(--ink-3);
    border: 1px solid var(--hairline);
    border-radius: var(--r-md);
    padding: 12px 14px;
    color: var(--cream);
    font-family: var(--serif);
    font-size: 1rem;
    min-height: var(--tap);
}
input[type=number] { font-family: var(--mono); }
textarea { min-height: 80px; resize: vertical; font-family: var(--serif); }

input:focus, textarea:focus, select:focus {
    outline: 0;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent-soft);
}

input[type=range] {
    width: 100%;
    accent-color: var(--accent);
    height: var(--tap);
}

.score-input {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--gap-sm);
    background: var(--ink-3);
    border: 1px solid var(--hairline);
    border-radius: var(--r-md);
    padding: 10px;
}
.score-input input {
    background: transparent;
    border: 0;
    text-align: center;
    font-family: var(--mono);
    font-size: 1.5rem;
    padding: 0;
}
.score-input .vs { color: var(--cream-mute); font-family: var(--mono); }

/* ============================================================
   buttons
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: var(--tap);
    padding: 10px 18px;
    background: var(--accent);
    color: var(--ink);
    border: 0;
    border-radius: var(--r-md);
    cursor: pointer;
    font-family: var(--serif);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    transition: filter 120ms ease, transform 100ms ease;
}
.btn:hover { filter: brightness(1.08); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-ghost {
    background: transparent;
    color: var(--cream);
    border: 1px solid var(--hairline);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); }

.btn-danger { background: var(--danger); color: white; }
.btn-link { background: transparent; color: var(--accent); padding: 8px 4px; min-height: 0; font-weight: 500; }
.btn-link:hover { background: transparent; text-decoration: underline; }

.btn-row { display: flex; gap: var(--gap-sm); flex-wrap: wrap; }
.btn-row.right { justify-content: flex-end; }

.fab {
    position: fixed;
    right: 18px;
    bottom: calc(var(--bottomnav-h) + env(safe-area-inset-bottom, 0px) + 12px);
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--ink);
    border: 0;
    font-size: 1.6rem;
    cursor: pointer;
    box-shadow: 0 10px 25px rgba(0,0,0,0.4);
    z-index: 40;
    display: grid;
    place-items: center;
}

/* ============================================================
   chips (multi-select tags)
   ============================================================ */
.chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    background: var(--ink-3);
    color: var(--cream-dim);
    border: 1px solid var(--hairline);
    border-radius: 999px;
    cursor: pointer;
    font-family: var(--serif);
    font-size: 0.92rem;
    user-select: none;
    transition: all 120ms ease;
    min-height: 36px;
}
.chip:hover { color: var(--cream); border-color: var(--cream-mute); }
.chip[aria-pressed='true'], .chip.on {
    background: var(--accent-soft);
    color: var(--accent);
    border-color: var(--accent);
}
.chip[data-kind='failure'][aria-pressed='true'],
.chip.failure.on {
    background: rgba(181, 69, 69, 0.15);
    color: #d9897a;
    border-color: var(--danger);
}
.chip-add {
    border-style: dashed;
    color: var(--cream-mute);
}
.chip-add:hover { border-style: solid; color: var(--accent); border-color: var(--accent); }
.chip .x { color: var(--cream-mute); margin-left: 2px; }
.chip.tally {
    cursor: default;
    background: var(--ink-3);
    color: var(--cream);
    border-color: var(--accent);
}
.chip.tally .count { font-family: var(--mono); font-size: 0.8rem; color: var(--cream-dim); margin-left: 4px; }

/* ============================================================
   sliders / mastery bars
   ============================================================ */
.scale {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--gap-sm);
    align-items: center;
}
.scale input { margin: 0; }
.scale-value {
    font-family: var(--mono);
    font-size: 1rem;
    color: var(--accent);
    min-width: 36px;
    text-align: right;
}

.bar {
    position: relative;
    height: 6px;
    background: var(--ink-3);
    border-radius: 3px;
    overflow: hidden;
}
.bar > span {
    display: block;
    height: 100%;
    background: var(--accent);
}

/* ============================================================
   bouts list
   ============================================================ */
.bout-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--gap-md);
    align-items: center;
    padding: 12px 14px;
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-left: 3px solid var(--cream-mute);
    border-radius: var(--r-md);
    margin-bottom: var(--gap-sm);
    cursor: pointer;
}
.bout-row.win { border-left-color: var(--success); }
.bout-row.loss { border-left-color: var(--danger); }
.bout-row.draw { border-left-color: var(--warn); }
.bout-row .bout-date { font-family: var(--mono); font-size: 0.85rem; color: var(--cream-dim); }
.bout-row .bout-opponent { font-family: var(--serif); font-size: 1.1rem; color: var(--cream); }
.bout-row .bout-context { font-family: var(--mono); font-size: 0.7rem; color: var(--cream-mute); text-transform: uppercase; letter-spacing: 0.08em; }
.bout-row .bout-score {
    font-family: var(--mono);
    font-size: 1.05rem;
    color: var(--cream);
    text-align: right;
}
.bout-row .bout-score .you { color: var(--accent); font-weight: 600; }
.bout-row.loss .bout-score .you { color: var(--cream); }

/* ============================================================
   SWOT grid
   ============================================================ */
.swot {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gap-sm);
}
@media (min-width: 560px) {
    .swot { grid-template-columns: 1fr 1fr; }
}
.swot .quadrant {
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-radius: var(--r-md);
    padding: var(--gap-md);
    min-height: 120px;
}
.swot .quadrant h4 {
    margin: 0 0 8px;
    font-family: var(--mono);
    font-size: 0.7rem;
    letter-spacing: 0.14em;
}
.swot .quadrant.s { border-top: 2px solid var(--success); }
.swot .quadrant.s h4 { color: var(--success); }
.swot .quadrant.w { border-top: 2px solid var(--warn); }
.swot .quadrant.w h4 { color: var(--warn); }
.swot .quadrant.o { border-top: 2px solid var(--accent); }
.swot .quadrant.o h4 { color: var(--accent); }
.swot .quadrant.t { border-top: 2px solid var(--danger); }
.swot .quadrant.t h4 { color: var(--danger); }

/* ============================================================
   five-w-two-h
   ============================================================ */
.scout-card {
    background: var(--ink-2);
    border: 1px solid var(--hairline);
    border-radius: var(--r-lg);
    padding: var(--gap-lg);
    position: relative;
}
.scout-card::before {
    content: 'scout card';
    position: absolute;
    top: 12px; right: 16px;
    font-family: var(--mono);
    font-size: 0.65rem;
    color: var(--cream-mute);
    text-transform: uppercase;
    letter-spacing: 0.18em;
}
.scout-card .grid-7 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gap-md);
}
@media (min-width: 560px) {
    .scout-card .grid-7 { grid-template-columns: 1fr 1fr; }
}
.scout-card .field-static {
    border-left: 2px solid var(--accent);
    padding: 4px 0 4px 12px;
}
.scout-card .field-static .key {
    font-family: var(--mono);
    font-size: 0.7rem;
    color: var(--cream-dim);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.scout-card .field-static .val {
    font-family: var(--serif);
    font-size: 1.05rem;
    color: var(--cream);
}

/* ============================================================
   toast
   ============================================================ */
.toast-region {
    position: fixed;
    bottom: calc(var(--bottomnav-h) + 8px + env(safe-area-inset-bottom, 0px));
    left: 50%;
    transform: translateX(-50%);
    z-index: 80;
    pointer-events: none;
}
.toast {
    background: var(--ink-3);
    color: var(--cream);
    border: 1px solid var(--hairline);
    border-left: 3px solid var(--accent);
    padding: 10px 16px;
    border-radius: var(--r-md);
    font-family: var(--serif);
    font-size: 0.95rem;
    margin-top: 8px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.4);
    animation: toast-in 200ms ease;
}
.toast.error { border-left-color: var(--danger); }
.toast.warn { border-left-color: var(--warn); }
@keyframes toast-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   misc
   ============================================================ */
.muted { color: var(--cream-dim); }
.dim   { color: var(--cream-mute); }
.center{ text-align: center; }
.italic{ font-style: italic; }
.kicker{ font-family: var(--mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--cream-dim); }
.divider {
    height: 1px;
    background: var(--hairline);
    margin: var(--gap-lg) 0;
}
.spacer { height: var(--gap-lg); }

.sign-in {
    max-width: 380px;
    margin: 60px auto;
    text-align: center;
    padding: var(--gap-xl) var(--gap-md);
}
.sign-in h1 { font-style: italic; font-size: 2.4rem; }
.sign-in p { color: var(--cream-dim); }
.sign-in .btn { width: 100%; margin-top: var(--gap-md); }

/* advisory nudge banner (taper, knee, etc.) */
.nudge {
    background: rgba(201, 138, 58, 0.10);
    border: 1px solid var(--warn);
    border-left: 3px solid var(--warn);
    border-radius: var(--r-md);
    padding: 12px 14px;
    margin-bottom: var(--gap-md);
    font-size: 0.95rem;
}
.nudge .nudge-head {
    font-family: var(--mono);
    font-size: 0.72rem;
    color: var(--warn);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin-bottom: 4px;
}
.nudge .nudge-fine {
    font-size: 0.82rem;
    color: var(--cream-dim);
    font-style: italic;
    margin-top: 6px;
}

.meter {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--gap-sm);
    align-items: center;
    padding: 10px 12px;
    background: var(--ink-3);
    border-radius: var(--r-md);
    margin-bottom: 6px;
}
.meter .meter-label { font-size: 0.95rem; }
.meter .meter-data { font-family: var(--mono); font-size: 0.88rem; color: var(--accent); }

/* drill checklist row */
.drill-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--gap-sm);
    padding: 10px 12px;
    background: var(--ink-3);
    border-radius: var(--r-md);
    margin-bottom: 6px;
}
.drill-row.done { opacity: 0.85; }
.drill-row .check {
    width: 24px; height: 24px;
    border-radius: 6px;
    border: 2px solid var(--cream-mute);
    cursor: pointer;
    display: grid;
    place-items: center;
    color: var(--accent);
    font-weight: 700;
}
.drill-row.done .check { background: var(--accent-soft); border-color: var(--accent); }
.drill-row .reps {
    width: 64px;
    text-align: center;
    font-family: var(--mono);
    background: var(--ink);
    border: 1px solid var(--hairline);
    border-radius: var(--r-sm);
    padding: 4px;
    color: var(--cream);
}

/* tactic tally row */
.tactic-tally {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--gap-sm);
    align-items: center;
    padding: 10px 12px;
    background: var(--ink-3);
    border-radius: var(--r-md);
    margin-bottom: 6px;
}
.tactic-tally .name { font-family: var(--serif); }
.tactic-tally .pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--ink);
    border: 1px solid var(--hairline);
    font-family: var(--mono);
    font-size: 0.85rem;
    color: var(--cream);
    cursor: pointer;
    user-select: none;
    min-height: 30px;
}
.tactic-tally .pill .delta {
    width: 22px; height: 22px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: var(--ink-3);
    border: 1px solid var(--hairline);
    color: var(--cream-dim);
    cursor: pointer;
}
.tactic-tally .pill .delta:hover { color: var(--accent); border-color: var(--accent); }
.tactic-tally .pill.success { border-color: var(--success); color: #a3c98a; }
.tactic-tally .pill.fail { border-color: var(--danger); color: #d9897a; }
