/* =============================================================================
   SEVRIC setup — platform admin console.
   Editorial design system shared with portal/recon/battery/forms/shipping.
   Cooled neutral off-white + cobalt accent. Crimson Pro display, Inter UI,
   Caveat (tilted) accent only.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Crimson+Pro:wght@200;300;400;500;600;700&family=Inter:wght@300;400;500;600&family=Caveat:wght@400;500;600;700&display=swap');

:root {
  --bg:           #F6F6F3;
  --bg-deep:      #ECECE8;
  --bg-elev:      #FBFBF9;
  --panel:        #FFFFFF;
  --line:         rgba(18,20,22,0.07);
  --line-2:       rgba(18,20,22,0.12);
  --line-strong:  rgba(46,86,148,0.30);

  --text:         #14161A;
  --text-muted:   #4A4D54;
  --text-dim:     #6A6D74;
  --text-faint:   #8E9098;

  --brand-cobalt-deep: #1E3E72;
  --brand-cobalt:      #2E5694;
  --brand-cobalt-soft: #6A8DC4;

  --accent:       #2E5694;
  --accent-deep:  #1E3E72;
  --accent-soft:  rgba(46,86,148,0.10);
  --accent-line:  rgba(46,86,148,0.28);

  --gold:         #946A12;
  --ok:           #2A6D38;
  --ok-soft:      rgba(42,109,56,0.10);
  --amber:        #B05E13;
  --warn:         #B05E13;
  --warn-soft:    rgba(176,94,19,0.10);
  --over:         #7C2935;
  --over-soft:    rgba(124,41,53,0.08);
  --danger:       #7C2935;

  --ink-soft:     rgba(18,20,22,0.04);
  --inverse:      #FBFBF9;
  --dock-bg:      rgba(252,252,250,0.78);
  --dock-border:  rgba(18,20,22,0.10);

  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 22px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100vh; }
body {
  font: 400 14.5px/1.55 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  background: var(--bg); color: var(--text);
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(60% 50% at 22% 18%, rgba(46,86,148,0.05), transparent 60%),
    radial-gradient(55% 50% at 78% 82%, rgba(46,86,148,0.04), transparent 65%);
  mix-blend-mode: multiply; opacity: 0.78;
}
a { color: inherit; text-decoration: none; }
em { font-style: normal; color: var(--accent); font-weight: inherit; }

/* Splash kept on bg so it doesn't flash a different color. */
#sevric-splash { background: var(--bg) !important; }
#sevric-splash svg polygon { stroke: var(--accent); fill: transparent; }
#sevric-splash svg polygon:last-child { fill: var(--accent); }
#sevric-splash > div { border-top-color: var(--accent) !important; border-color: var(--accent-soft) !important; }

/* Floating dock */
.dock-wrap { position: sticky; top: 18px; z-index: 50; display: flex; justify-content: center; padding: 0 24px; pointer-events: none; }
.dock { pointer-events: auto; display: inline-flex; align-items: center; gap: 4px; padding: 6px 8px 6px 16px; background: var(--dock-bg); backdrop-filter: blur(28px) saturate(150%); -webkit-backdrop-filter: blur(28px) saturate(150%); border: 1px solid var(--dock-border); border-radius: 999px; box-shadow: 0 20px 44px -16px rgba(40,42,46,0.18), 0 1px 0 rgba(255,255,255,0.5) inset; }
.dock-brand { display: inline-flex; align-items: center; gap: 10px; padding-right: 14px; margin-right: 4px; border-right: 1px solid var(--dock-border); }
.dock-brand svg { width: 24px; height: 24px; color: var(--accent); flex-shrink: 0; }
.lockup { display: inline-flex; flex-direction: column; line-height: 1; }
.lockup .top { font-size: 11px; font-weight: 600; letter-spacing: 0.22em; color: var(--text); }
.lockup .bot { font-family: 'Caveat', cursive; font-weight: 700; font-size: 16px; color: var(--accent); transform: rotate(-1.5deg); transform-origin: 0 50%; margin-top: 1px; }
.dock-link { padding: 9px 14px; border-radius: 999px; color: var(--text-muted); font-size: 12.5px; font-weight: 500; cursor: pointer; transition: all 0.3s var(--ease-out); }
.dock-link:hover { color: var(--text); background: var(--ink-soft); }
.dock-link.active { color: var(--inverse); background: var(--accent); }
.dock-sep { width: 1px; height: 22px; background: var(--dock-border); margin: 0 6px; }
.dock-avi { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-deep)); color: var(--inverse); display: inline-flex; align-items: center; justify-content: center; font-weight: 600; font-size: 12px; }
.dock-signout { background: transparent; border: 0; padding: 6px 12px; border-radius: 999px; font: 500 12px 'Inter', sans-serif; color: var(--text-muted); cursor: pointer; letter-spacing: 0.04em; }
.dock-signout:hover { color: var(--text); background: var(--ink-soft); }

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

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.20em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: 14px;
}
.eyebrow::before { content: ""; width: 26px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent-line)); }
.serif { font-family: 'Caveat', cursive; font-weight: 700; color: var(--accent); display: inline-block; transform: rotate(-1.5deg); }

/* Hero */
.setup-hero { padding: 48px 0 16px; }
.setup-hero h1 { font-family: 'Crimson Pro', serif; font-weight: 200; font-size: 78px; line-height: 0.96; letter-spacing: -0.045em; margin: 0; max-width: 16ch; }
.setup-hero h1 em { color: var(--accent); font-weight: 300; }
.setup-hero h1 .serif { font-size: 0.88em; }
.setup-hero .tag { font-family: 'Caveat', cursive; font-weight: 700; font-size: 40px; color: var(--accent); line-height: 1; margin: 8px 0 18px; display: inline-block; transform: rotate(-1.5deg); }
.setup-hero .sub { font-family: 'Crimson Pro', serif; font-weight: 300; font-size: 19px; line-height: 1.45; color: var(--text-muted); margin: 0; max-width: 60ch; }
.setup-hero .sub b { color: var(--text); font-weight: 500; }

/* Stats */
.setup-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin: 32px 0; }
.setup-kpi { padding: 24px 26px; border-left: 1px solid var(--line); }
.setup-kpi:first-child { border-left: 0; }
.setup-kpi .label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 8px; }
.setup-kpi .value { font-family: 'Crimson Pro', serif; font-weight: 200; font-size: 48px; line-height: 0.95; letter-spacing: -0.04em; color: var(--text); font-variant-numeric: tabular-nums; }
.setup-kpi.lead .value em, .setup-kpi .value em { color: var(--accent); font-weight: 300; font-style: normal; }
.setup-kpi .hint { font-size: 12px; color: var(--text-muted); margin-top: 6px; }

/* Section head */
.tn-head { display: flex; align-items: baseline; justify-content: space-between; margin: 48px 0 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line); gap: 16px; flex-wrap: wrap; }
.tn-head .cap { font-size: 11px; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: var(--gold); }
.tn-head h2 { font-family: 'Crimson Pro', serif; font-weight: 300; font-size: 32px; letter-spacing: -0.025em; margin: 4px 0 0; }
.tn-head h2 em { color: var(--accent); font-style: normal; font-weight: 300; }
.tn-head .right { font-size: 12.5px; color: var(--text-dim); display: inline-flex; align-items: center; gap: 12px; }
.tn-head .right .hint { color: var(--text-muted); }

/* Two-column */
.tn-two { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: start; }
@media (max-width: 880px) { .tn-two { grid-template-columns: 1fr; } }

/* Panel + table */
.tn-panel-body { background: var(--panel); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; }
table.tn-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13.5px; }
table.tn-table thead th { text-align: left; font-size: 11px; font-weight: 600; letter-spacing: 0.10em; text-transform: uppercase; color: var(--text-dim); padding: 13px 18px; border-bottom: 1px solid var(--line); background: var(--bg-elev); }
table.tn-table tbody td { padding: 14px 18px; border-bottom: 1px solid var(--line); vertical-align: middle; }
table.tn-table tbody tr:hover { background: var(--bg-elev); cursor: pointer; }
table.tn-table tbody tr:last-child td { border-bottom: 0; }
table.tn-table td b { color: var(--text); font-weight: 500; }
.mono { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-variant-numeric: tabular-nums; font-size: 12.5px; color: var(--text-muted); }

.pill { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; }
.pill.ok    { color: var(--ok);    background: var(--ok-soft); }
.pill.warn  { color: var(--amber); background: var(--warn-soft); }
.pill.over  { color: var(--over);  background: var(--over-soft); }
.pill.muted { color: var(--text-muted); background: var(--ink-soft); }

.apps-cell { display: inline-flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.app-pip { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 999px; font-size: 10.5px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; background: var(--accent-soft); color: var(--accent); }
.app-pip.off { background: var(--ink-soft); color: var(--text-faint); }

/* Create card */
.tn-create { background: var(--panel); border: 1px solid var(--line); border-radius: 16px; padding: 24px 26px; }
.tn-create h3 { margin: 0 0 6px; font-family: 'Crimson Pro', serif; font-weight: 300; font-size: 22px; letter-spacing: -0.02em; }
.tn-create h3 em { color: var(--accent); font-style: normal; font-weight: 300; }
.tn-create .sub { font-size: 13px; color: var(--text-muted); margin: 0 0 16px; }

.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.field label { font-size: 11px; font-weight: 600; letter-spacing: 0.10em; text-transform: uppercase; color: var(--text-dim); }
.field input, .field select { padding: 10px 12px; background: var(--bg-elev); border: 1px solid var(--line-2); border-radius: 8px; color: var(--text); font: inherit; font-size: 14px; }
.field input:focus, .field select:focus { outline: none; border-color: var(--accent); }
.field .hint { font-size: 11.5px; color: var(--text-dim); margin-top: 2px; }

.tn-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 18px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--panel); color: var(--text); font: 600 13px 'Inter', sans-serif; cursor: pointer; transition: all 0.2s var(--ease-out); width: 100%; }
.tn-btn:hover { border-color: var(--accent-line); }
.tn-btn.primary { background: var(--accent); color: var(--inverse); border-color: transparent; }
.tn-btn.primary:hover { background: var(--accent-deep); }
.tn-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.tn-btn.danger { color: var(--over); border-color: rgba(124,41,53,0.32); background: var(--over-soft); }

.tn-create-toggle { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--panel); color: var(--text); font: 600 12.5px 'Inter', sans-serif; cursor: pointer; }
.tn-create-toggle:hover { border-color: var(--accent-line); }

/* Rooftop cards */
.rt-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 16px; }
@media (max-width: 880px) { .rt-list { grid-template-columns: 1fr; } }
.rt { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; display: grid; grid-template-rows: auto auto auto; gap: 10px; transition: border-color 0.2s var(--ease-out), transform 0.15s var(--ease-out); cursor: pointer; }
.rt:hover { border-color: var(--accent-line); transform: translateY(-1px); }
.rt .h { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.rt .name { font-family: 'Crimson Pro', serif; font-weight: 400; font-size: 22px; letter-spacing: -0.02em; color: var(--text); }
.rt .id { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 11px; color: var(--text-dim); letter-spacing: 0.04em; }
.rt .meta { font-size: 12.5px; color: var(--text-muted); display: flex; gap: 12px; flex-wrap: wrap; }
.rt .apps-row { display: flex; gap: 6px; flex-wrap: wrap; padding-top: 8px; border-top: 1px solid var(--line); }

/* Admins list */
.admin-row { display: grid; grid-template-columns: 38px 1fr auto auto; gap: 14px; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--line); background: var(--panel); }
.admin-row:last-child { border-bottom: 0; }
.admin-row .av { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-deep)); color: var(--inverse); font-weight: 600; font-size: 13px; display: inline-flex; align-items: center; justify-content: center; }
.admin-row .who { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.admin-row .email { font-size: 13.5px; color: var(--text); font-weight: 500; word-break: break-all; }
.admin-row .uid { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 11px; color: var(--text-dim); letter-spacing: 0.04em; }
.admin-role { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; background: var(--accent-soft); color: var(--accent); }
.admin-role.owner { background: var(--ok-soft); color: var(--ok); }
.admin-remove { background: transparent; border: 0; padding: 6px 10px; border-radius: 8px; color: var(--text-dim); font-size: 12px; cursor: pointer; transition: all 0.15s ease; }
.admin-remove:hover { color: var(--over); background: var(--over-soft); }
.admin-remove:disabled { opacity: 0.3; cursor: not-allowed; }

.foot { margin-top: 60px; padding: 22px 0; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size: 12.5px; color: var(--text-dim); }
.foot .cv-tail { font-family: 'Caveat', cursive; font-weight: 700; font-size: 18px; color: var(--accent); transform: rotate(-1.5deg); display: inline-block; }

/* Toast */
#rtToast { position: fixed; right: 22px; bottom: 22px; z-index: 100; background: var(--panel); color: var(--text); border: 1px solid var(--line-2); border-radius: 12px; padding: 10px 14px; font-size: 13px; box-shadow: 0 12px 32px rgba(40,42,46,0.16); display: none; }
#rtToast.show { display: block; animation: toastIn 0.25s var(--ease-out); }
@keyframes toastIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
#rtToast.ok   { border-color: rgba(42,109,56,0.32); color: var(--ok); }
#rtToast.over { border-color: rgba(124,41,53,0.32); color: var(--over); }

@media (max-width: 880px) {
  .setup-hero h1 { font-size: 52px; }
  .setup-hero .tag { font-size: 32px; }
  .setup-kpis { grid-template-columns: repeat(2, 1fr); }
  .setup-kpi:nth-child(3) { border-left: 0; border-top: 1px solid var(--line); }
  .setup-kpi:nth-child(4) { border-top: 1px solid var(--line); }
}

/* Tenant row (rendered by tenants.js) */
.tn-row {
  display: grid; grid-template-columns: 1fr auto 28px;
  gap: 18px; align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
}
.tn-row:last-child { border-bottom: 0; }
.tn-row .name {
  font-family: 'Crimson Pro', serif; font-weight: 400;
  font-size: 20px; letter-spacing: -0.02em; color: var(--text);
  margin-bottom: 4px;
}
.tn-row .meta { font-size: 12.5px; color: var(--text-muted); }
.tn-row .stat { text-align: right; }
.tn-row .stat .v {
  font-family: 'Crimson Pro', serif; font-weight: 200;
  font-size: 30px; line-height: 1; color: var(--accent);
  letter-spacing: -0.03em;
}
.tn-row .stat .l {
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--text-dim); margin-top: 2px;
}
.tn-row .open {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ink-soft); color: var(--text-muted);
  transition: all 0.15s var(--ease-out);
}
.tn-row:hover .open { background: var(--accent); color: var(--inverse); transform: translateX(2px); }
.tn-empty {
  padding: 40px 24px; text-align: center;
  color: var(--text-dim); font-size: 13px;
}
.tn-empty .mark { color: var(--accent-line); display: block; margin: 0 auto 12px; }

/* Rooftop card empty state */
.rt-empty {
  padding: 40px 24px; text-align: center;
  color: var(--text-dim); font-size: 13px;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 14px;
}

/* Create panel toggle (rooftops.html) */
.rt-create { background: var(--panel); border: 1px solid var(--line); border-radius: 16px; padding: 24px 26px; margin-top: 28px; }
.rt-create .head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.rt-create .head h3 { margin: 0; font-family: 'Crimson Pro', serif; font-weight: 300; font-size: 22px; letter-spacing: -0.02em; }
.rt-create.open form { display: block; }
.rt-create form { display: none; margin-top: 14px; }
.rt-create-toggle { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--panel); color: var(--text); font: 600 12px 'Inter', sans-serif; cursor: pointer; }
.rt-create-toggle:hover { border-color: var(--accent-line); }

.rt-btn { display: inline-flex; align-items: center; justify-content: center; padding: 11px 18px; border-radius: 999px; background: var(--accent); color: var(--inverse); border: 0; font: 600 13px 'Inter', sans-serif; cursor: pointer; transition: background 0.2s ease; }
.rt-btn:hover { background: var(--accent-deep); }
.rt-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Per-rooftop delete button — sits in the rt-card-head */
.rt-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.rt-delete {
  flex-shrink: 0;
  width: 30px; height: 30px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--line); color: var(--text-dim);
  cursor: pointer; transition: all 0.15s var(--ease-out);
}
.rt-delete:hover { color: var(--over); border-color: rgba(124,41,53,0.32); background: var(--over-soft); }
.rt-delete:disabled { opacity: 0.4; cursor: not-allowed; }
