/* ============================================================
   LeamonHQ — Soft Slate theme
   A gentler take on the Neon theme: warm dark-slate surfaces,
   muted teal / rose / sage / amber accents, no glow effects,
   rounded corners, readable sans-serif body text.
   Switch back to Neon by copying style.neon.css over style.css.
   Classic light theme remains in style.classic.css.
   ============================================================ */

:root {
  /* Tell the browser this is a dark UI so its built-in widgets (date
     pickers, dropdowns, scrollbars) render in matching light-on-dark. */
  color-scheme: dark;

  /* surface */
  --bg:         #2e3447;
  --bg-card:    #373e54;
  --bg-deep:    #262c3e;
  --line:       #485070;
  --line-2:     #404764;

  /* text */
  --ink:        #d6dae6;
  --ink-bright: #f2f4f9;
  --muted:      #8e96aa;
  --muted-2:    #677083;

  /* softened accent palette (same variable names as Neon) */
  --cyan:       #6fc3d4;   /* soft teal */
  --magenta:    #d488a6;   /* dusty rose */
  --lime:       #93c489;   /* sage green */
  --yellow:     #d9b878;   /* warm amber */
  --purple:     #a995cf;   /* lavender */
  --orange:     #cfa177;   /* soft clay */

  /* glows retired — kept as variables so nothing breaks */
  --glow-c:     none;
  --glow-m:     none;
  --glow-l:     none;
  --glow-y:     none;

  /* compatibility aliases for legacy var references */
  --brand:      var(--cyan);
  --brand-ink:  #10131b;
  --ok-bg:      rgba(147,196,137,0.08);
  --ok-line:    var(--lime);
  --err-bg:     rgba(212,136,166,0.08);
  --err-line:   var(--magenta);
  --warn-bg:    rgba(217,184,120,0.08);
  --warn-line:  var(--yellow);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font: 14px/1.6 'Segoe UI', system-ui, -apple-system, 'Helvetica Neue', sans-serif;
  color: var(--ink);
  background: var(--bg);
  background-image:
    radial-gradient(circle at 50% -10%, rgba(111,195,212,0.04) 0%, transparent 55%),
    radial-gradient(circle at 95% 100%, rgba(212,136,166,0.03) 0%, transparent 45%);
  min-height: 100vh;
}

::selection { background: var(--cyan); color: #10131b; }

a { color: var(--cyan); text-decoration: none; }
a:hover { color: var(--ink-bright); }

/* ---------- top chrome ---------- */
.dev-banner {
  background: rgba(217,184,120,0.08);
  border-bottom: 1px solid var(--yellow);
  color: var(--yellow);
  padding: 6px 16px;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

.topbar {
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 13px 24px;
  background: var(--bg-deep);
  border-bottom: 1px solid var(--line);
}
.topbar .brand {
  font-weight: 700;
  font-size: 17px;
  letter-spacing: 0.04em;
  color: var(--ink-bright);
}
.topbar .brand:hover { color: var(--ink-bright); text-decoration: none; }
.topbar .brand .brand-mk {
  margin-left: 2px;
  color: var(--cyan);
}
.topbar nav { display: flex; gap: 4px; flex: 1; }
.topbar nav a {
  padding: 7px 12px;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--muted);
  border: 1px solid transparent;
  border-radius: 7px;
}
.topbar nav a:hover {
  color: var(--cyan);
  background: rgba(111,195,212,0.08);
}
.topbar .who {
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.02em;
}
.topbar .who a { color: var(--magenta); }

/* ---------- container ---------- */
.container { max-width: 1040px; margin: 24px auto; padding: 0 24px 40px; }
.container.narrow { max-width: 560px; }

/* ---------- headings ---------- */
h1, h2, h3 {
  color: var(--ink-bright);
  letter-spacing: 0.01em;
  font-weight: 650;
}
h1 {
  font-size: 23px;
  margin: 0 0 18px;
}
h2 {
  font-size: 13px;
  margin: 0 0 14px;
  color: var(--yellow);
  letter-spacing: 0.09em;
  text-transform: uppercase;
  font-weight: 650;
}
h3 {
  font-size: 12px;
  margin: 20px 0 8px;
  color: var(--cyan);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ---------- card ---------- */
.card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px 20px 20px;
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--cyan);
  opacity: 0.7;
}
/* gentle accent rotation so a page with several cards gets visual rhythm */
.container > .card:nth-of-type(3n+2)::before { background: var(--magenta); }
.container > .card:nth-of-type(3n+3)::before { background: var(--yellow); }
/* explicit accent classes */
.card.card-ok::before   { background: var(--lime); }
.card.card-warn::before { background: var(--yellow); }
.card.card-err::before  { background: var(--magenta); }

/* layout helpers */
.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 760px) { .cols { grid-template-columns: 1fr; } }

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid .actions { grid-column: 1 / -1; padding-top: 4px; }
.grid label.wide { grid-column: 1 / -1; }

/* ---------- inputs / buttons ---------- */
label {
  display: flex; flex-direction: column;
  font-size: 11px; color: var(--muted);
  letter-spacing: 0.06em; text-transform: uppercase;
  gap: 4px;
}
input, select, textarea {
  font: 13.5px/1.4 'Segoe UI', system-ui, sans-serif;
  color: var(--ink-bright);
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg-deep);
  width: 100%;
  outline: none;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 0 3px rgba(111,195,212,0.15);
}
textarea { min-height: 100px; }

/* Make the little calendar button on date fields bright and clickable-looking */
input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.85) sepia(0.2) saturate(2) hue-rotate(150deg);
  opacity: 0.9;
  cursor: pointer;
  width: 18px;
  height: 18px;
}
input[type="date"]::-webkit-calendar-picker-indicator:hover { opacity: 1; }

button {
  font: 600 12px/1 'Segoe UI', system-ui, sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: var(--cyan);
  color: #10131b;
  border: 1px solid var(--cyan);
  border-radius: 8px;
  padding: 10px 18px;
  cursor: pointer;
  transition: background 0.12s, transform 0.05s;
}
button:hover { background: #8ed3e2; border-color: #8ed3e2; }
button:active { transform: translateY(1px); }
button.small { padding: 5px 11px; font-size: 11px; }

button.ghost {
  background: transparent;
  color: var(--magenta);
  border: 1px solid var(--magenta);
}
button.ghost:hover {
  background: rgba(212,136,166,0.12);
  color: var(--ink-bright);
  border-color: var(--magenta);
}

form.inline { display: inline-flex; gap: 6px; align-items: center; margin: 0; }
form.inline input, form.inline select { width: auto; }

/* ---------- tables ---------- */
table { width: 100%; border-collapse: collapse; font-variant-numeric: tabular-nums; }
th, td {
  text-align: left;
  padding: 9px 10px;
  border-bottom: 1px solid var(--line-2);
  font-size: 13px;
}
th {
  color: var(--muted);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line);
}
td.r, th.r { text-align: right; }
tfoot th, tfoot td {
  border-top: 1px solid var(--cyan);
  border-bottom: 0;
  color: var(--ink-bright);
  font-weight: 700;
  font-size: 13.5px;
  padding-top: 12px;
}
tfoot th.r, tfoot td.r { color: var(--ink-bright); }

tr.overdue td { background: rgba(212,136,166,0.1); color: var(--magenta); }
tr.retired td { color: var(--muted-2); }

/* ---------- pill / muted / note ---------- */
.muted { color: var(--muted); }
.pill {
  background: rgba(169,149,207,0.1);
  border: 1px solid var(--purple);
  color: var(--purple);
  border-radius: 999px;
  padding: 2px 11px;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.note {
  border-left: 2px solid var(--cyan);
  padding: 6px 0 6px 14px;
  margin-bottom: 12px;
  background: linear-gradient(90deg, rgba(111,195,212,0.05) 0%, transparent 60%);
  border-radius: 0 6px 6px 0;
}
.note-meta { font-size: 11px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; }
.note-body { font-size: 13.5px; color: var(--ink); margin-top: 4px; }

/* ---------- alerts ---------- */
.ok {
  background: rgba(147,196,137,0.08);
  border: 1px solid var(--lime);
  color: var(--lime);
  padding: 12px 14px;
  border-radius: 8px;
  font-size: 13px;
  letter-spacing: 0.01em;
}
.error {
  background: rgba(212,136,166,0.08);
  border: 1px solid var(--magenta);
  color: var(--magenta);
  padding: 12px 14px;
  border-radius: 8px;
  font-size: 13px;
  letter-spacing: 0.01em;
}
pre { white-space: pre-wrap; word-break: break-word; font-size: 12px; color: var(--cyan); font-family: 'JetBrains Mono', ui-monospace, Consolas, monospace; }

/* ---------- tabs ---------- */
.tabs { display: flex; gap: 4px; margin: 0 0 16px; flex-wrap: wrap; }
.tabs a {
  padding: 8px 14px;
  border: 1px solid var(--line);
  background: var(--bg-card);
  color: var(--muted);
  border-radius: 8px;
  font-size: 12px;
  letter-spacing: 0.04em;
}
.tabs a:hover {
  color: var(--cyan);
  border-color: var(--cyan);
  background: rgba(111,195,212,0.06);
}
.tabs a.on {
  background: rgba(111,195,212,0.1);
  color: var(--cyan);
  border-color: var(--cyan);
}

/* ---------- detail / head / details ---------- */
.detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.head-actions { padding-top: 4px; }

details.card > summary,
details.subtle > summary {
  cursor: pointer;
  font-weight: 650;
  color: var(--cyan);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 12px;
}
details.subtle {
  margin: 10px 0;
  font-size: 13px;
  color: var(--muted);
  border-left: 2px solid var(--line);
  padding-left: 14px;
}
details.subtle > summary { font-weight: 600; color: var(--muted); }
details.subtle[open] > summary { color: var(--cyan); }

/* ---------- microsoft sign-in button ---------- */
.msbtn {
  display: inline-block;
  background: var(--magenta);
  color: #10131b;
  padding: 12px 22px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--magenta);
}
.msbtn:hover { background: #e0a2bb; border-color: #e0a2bb; color: #10131b; text-decoration: none; }

/* ---------- big numbers / btnlink / neg ---------- */
.big {
  font-size: 30px;
  font-weight: 700;
  margin: 6px 0 2px;
  color: var(--cyan);
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
}
/* if a .big is inside the rose-accented (A/P) card, recolor it to match */
.container > .card:nth-of-type(3n+2) .big { color: var(--magenta); }
.container > .card:nth-of-type(3n+3) .big { color: var(--yellow); }

a.btnlink {
  display: inline-block;
  background: var(--cyan);
  color: #10131b;
  padding: 9px 16px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: 1px solid var(--cyan);
  border-radius: 8px;
}
a.btnlink:hover { background: #8ed3e2; border-color: #8ed3e2; color: #10131b; text-decoration: none; }

.neg { color: var(--magenta); }

/* ---------- responsive ---------- */
@media (max-width: 760px) {
  .topbar { flex-wrap: wrap; gap: 10px; padding: 10px 16px; }
  .topbar nav { flex-wrap: wrap; }
  .grid { grid-template-columns: 1fr; }
  .container { padding: 0 14px 30px; }
}

/* ---------- print ---------- */
/* Reports and to-do lists need to print cleanly on paper. Override the dark
   theme to black-on-white, strip all glow/shadow, hide chrome (topbar,
   tabs, forms, action buttons, buttons-as-links). */
@media print {
  body {
    background: #fff !important;
    background-image: none !important;
    color: #000 !important;
    font: 11pt/1.45 'Georgia', 'Times New Roman', serif !important;
  }
  a { color: #000 !important; text-shadow: none !important; }
  a[href]::after { content: ""; }

  .topbar, .tabs, .head-actions, .no-print,
  form, button, .msbtn, a.btnlink,
  .dev-banner, details, .detail-head .head-actions {
    display: none !important;
  }
  .print-only { display: block !important; }

  .container { max-width: 100% !important; margin: 0 !important; padding: 0 !important; }
  .card {
    background: #fff !important;
    border: 1px solid #888 !important;
    box-shadow: none !important;
    padding: 8pt 0 !important;
    margin: 0 0 10pt !important;
    page-break-inside: avoid;
  }
  .card::before { display: none !important; }

  h1, h2, h3 {
    color: #000 !important;
    text-shadow: none !important;
    font-family: 'Georgia', serif !important;
  }
  h1 { font-size: 18pt !important; }
  h1::before { content: "" !important; }
  h2 { font-size: 13pt !important; color: #000 !important; }
  h2::before { content: "" !important; }
  h3 { font-size: 11pt !important; color: #000 !important; }

  .big { color: #000 !important; text-shadow: none !important; font-size: 14pt !important; }
  .muted { color: #555 !important; }
  .pill {
    color: #000 !important; border-color: #000 !important;
    text-shadow: none !important; background: #f3f3f3 !important;
  }
  .pill::before, .pill::after { content: ""; padding: 0 !important; }

  table { font-size: 10pt !important; page-break-inside: auto; }
  thead { display: table-header-group; }  /* repeat header on each page */
  tr { page-break-inside: avoid; page-break-after: auto; }
  th, td {
    border-bottom: 1px solid #ccc !important;
    color: #000 !important;
    text-shadow: none !important;
    padding: 4pt 6pt !important;
    font-size: 10pt !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
  }
  th {
    background: #f0f0f0 !important;
    color: #000 !important;
    font-weight: 700 !important;
  }
  tfoot th, tfoot td {
    border-top: 2px solid #000 !important;
    color: #000 !important;
    font-weight: 700 !important;
  }
  tr.overdue td { background: #fdecec !important; color: #000 !important; }
  .neg { color: #000 !important; }
}
