/* appi.ca console — design system (from Figma: navy + blue professional admin) */
:root{
  --bg:#f5f6f8; --fg:#111827; --card:#fff;
  --primary:#1b3a6b; --primary-fg:#fff;
  --secondary:#eef1f7; --secondary-fg:#1b3a6b;
  --muted:#e8ecf3; --muted-fg:#6b7489;
  --accent:#0e7ec8; --accent-fg:#fff;
  --destructive:#dc2626;
  --border:rgba(17,24,39,.09);
  --ring:#0e7ec8; --radius:8px;
  --sidebar:#1b3a6b; --sidebar-fg:#e8ecf3; --sidebar-muted:#9fb0cc;
  --sidebar-active:#243f72;
  --font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"Iowan Old Style",Georgia,"Times New Roman",serif;
  --font-mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font-sans);background:var(--bg);color:var(--fg);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.ti{font-size:18px;line-height:1;vertical-align:-3px}

/* ---- App shell ---- */
.app{display:flex;min-height:100vh}
.sidebar{width:240px;flex:0 0 240px;background:var(--sidebar);color:var(--sidebar-fg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:18px}
.sidebar .brand .mark{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}
.sidebar .brand .name{font-weight:600;font-size:16px}
.sidebar .brand .sub{font-size:12px;color:var(--sidebar-muted)}
.sidebar .section{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--sidebar-muted);padding:16px 18px 6px}
.nav{display:flex;flex-direction:column;gap:2px;padding:0 10px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:var(--sidebar-fg);font-size:14px;font-weight:500}
.nav a:hover{background:var(--sidebar-active);text-decoration:none}
.nav a.active{background:var(--sidebar-active)}
.nav a.disabled{color:var(--sidebar-muted);opacity:.7;cursor:default}
.nav a .ti{font-size:18px;width:18px;opacity:.9}
.nav .count{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:600;border-radius:999px;padding:1px 7px}
.sidebar .user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:14px 18px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar .user .av{width:32px;height:32px;border-radius:999px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}
.sidebar .user .nm{font-size:13px;font-weight:600}
.sidebar .user .rl{font-size:12px;color:var(--sidebar-muted)}
.sidebar .user form{margin-left:auto}
.sidebar .user button{background:none;border:0;color:var(--sidebar-muted);cursor:pointer;font-size:18px;padding:0}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;background:#fff;border-bottom:1px solid var(--border);padding:13px 28px}
.topbar h1{font-size:18px;font-weight:600;margin:0}
.topbar .sub{font-size:13px;color:var(--muted-fg);margin-top:1px}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:12px}
.page{padding:24px 28px;max-width:1120px;width:100%}

/* ---- Cards ---- */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card+.card{margin-top:16px}

/* ---- Stat cards ---- */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative}
.stat .lab{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted-fg)}
.stat .num{font-size:30px;font-weight:600;margin:6px 0 2px}
.stat .sub{font-size:13px;color:var(--muted-fg)}
.stat .ico{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:8px;background:var(--secondary);display:flex;align-items:center;justify-content:center;color:var(--muted-fg)}
.stat.alert{background:#fef2f2;border-color:#fecaca}
.stat.alert .num{color:var(--destructive)}

/* ---- Tables ---- */
table.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.tbl th{text-align:left;font-size:12px;font-weight:600;color:var(--muted-fg);padding:12px 14px;border-bottom:1px solid var(--border)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr:hover td{background:#fafbfc}
.tbl.bare{border:0;border-radius:0;background:transparent}
.tbl.bare td{padding-left:0;padding-right:0}
.tbl.bare tbody tr:hover td{background:transparent}
.tbl.bare tr:last-child td{border-bottom:0}

/* ---- Badges (status dot) ---- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px}
.badge::before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}
.badge.active{background:#e7f6ee;color:#067a52}
.badge.paused{background:#fdf3e3;color:#a6650a}
.badge.scheduled{background:#f0ebfb;color:#6d34c9}
.badge.broken_target,.badge.expired{background:#fde9e9;color:#c0322f}
.badge.archived,.badge.draft{background:#eef0f3;color:#5b6473}
.badge.pending_approval,.badge.submitted{background:#e7f0fb;color:#1162a8}
.badge.in_review,.badge.needs_information{background:#fdf3e3;color:#a6650a}
.badge.approved,.badge.completed{background:#e7f6ee;color:#067a52}
.badge.rejected,.badge.cancelled{background:#fde9e9;color:#c0322f}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-size:14px;font-weight:600;padding:9px 15px;border-radius:8px;border:1px solid transparent;cursor:pointer;line-height:1}
.btn:hover{text-decoration:none}
.btn .ti{font-size:16px}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:#16315b}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#0b6aa9}
.btn-ghost{background:#fff;color:var(--fg);border-color:var(--border)}
.btn-ghost:hover{background:var(--secondary)}
.btn-danger{background:var(--destructive);color:#fff}
.btn-sm{padding:6px 11px;font-size:13px}

/* ---- Forms ---- */
label{display:block;font-size:13px;font-weight:500;color:var(--fg);margin:14px 0 5px}
.help{font-size:12px;color:var(--muted-fg)}
input[type=text],input[type=url],input[type=email],input[type=password],input[type=datetime-local],select,textarea{
  width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;font-family:inherit;color:var(--fg)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px rgba(14,126,200,.15)}

/* ---- Toolbar / pills / search ---- */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.pills{display:flex;gap:6px;flex-wrap:wrap}
.pill{font-size:13px;font-weight:500;padding:7px 13px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--fg)}
.pill:hover{text-decoration:none;background:var(--secondary)}
.pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ---- misc ---- */
.mono{font-family:var(--font-mono);font-size:13px}
.muted{color:var(--muted-fg)}
.row{display:flex;gap:20px;flex-wrap:wrap}
.flex{display:flex;align-items:center}
h1{font-size:22px;font-weight:600;margin:0 0 16px}
h2{font-size:16px;font-weight:600;margin:24px 0 10px}
.warn-box{background:#fffbeb;border:1px solid #fde68a;color:#92400e;padding:11px 14px;border-radius:8px;font-size:14px}
.err-box{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:11px 14px;border-radius:8px;font-size:14px;margin-bottom:14px}
