/* Creatvix License Dashboard
   Palette: white background + deep blue accent (#1E3A8A).
   Strict two-color discipline; greys for chrome only. */

:root {
  --bg:        #FFFFFF;
  --surface:   #FFFFFF;
  --surface-2: #F7F8FA;
  --line:      #E5E7EB;
  --line-2:    #D1D5DB;
  --text:      #0F172A;
  --muted:     #6B7280;
  --accent:    #1E3A8A;
  --accent-2:  #1E40AF;
  --accent-soft: #EEF2FF;
  --ok:        #166534;
  --ok-soft:   #DCFCE7;
  --bad:       #991B1B;
  --bad-soft:  #FEE2E2;
  --warn:      #92400E;
  --warn-soft: #FEF3C7;
  --radius:    10px;
  --shadow:    0 1px 2px rgba(15,23,42,.04), 0 1px 1px rgba(15,23,42,.03);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--surface-2);
  color: var(--text);
  font: 14px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
        Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  -webkit-font-smoothing: antialiased;
}
code { font-family: "SF Mono", Menlo, Consolas, monospace; font-size: .92em;
       background: var(--surface-2); padding: 1px 6px; border-radius: 6px;
       border: 1px solid var(--line); }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Layout ----------------------------------------------------------- */
.sidebar {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 220px; background: #fff; border-right: 1px solid var(--line);
  padding: 22px 0; display: flex; flex-direction: column;
}
.sidebar .brand { font-weight: 800; letter-spacing: .14em; padding: 0 22px;
                  color: var(--accent); font-size: 16px; }
.sidebar .sub   { padding: 0 22px 18px; color: var(--muted); font-size: 12px; }
.sidebar nav    { display: flex; flex-direction: column; }
.sidebar nav a  { padding: 9px 22px; color: var(--text); border-left: 3px solid transparent; }
.sidebar nav a:hover { background: var(--surface-2); text-decoration: none; }
.sidebar nav a.on    { background: var(--accent-soft); color: var(--accent);
                       border-left-color: var(--accent); font-weight: 600; }
.sidebar .who { margin-top: auto; padding: 14px 22px; border-top: 1px solid var(--line);
                font-size: 13px; color: var(--muted); display: flex; flex-direction: column; gap: 4px; }
.sidebar .who a { font-size: 12px; }

.main { margin-left: 220px; padding: 28px 32px 60px; max-width: 1200px; }

.page-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.page-head h1 { margin: 0; font-size: 22px; letter-spacing: -.01em; }

/* ---- Cards & sections ------------------------------------------------- */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
        padding: 18px 20px; margin-bottom: 18px; box-shadow: var(--shadow); }
.card h2 { margin: 0 0 12px; font-size: 15px; }

/* ---- Stat grid -------------------------------------------------------- */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 18px; }
.stat { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 16px; }
.stat .n { font-size: 26px; font-weight: 700; color: var(--accent); }
.stat .l { color: var(--muted); font-size: 12px; margin-top: 4px; text-transform: uppercase; letter-spacing: .04em; }
.stat.warn .n { color: var(--bad); }

/* ---- Tables ----------------------------------------------------------- */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th, .tbl td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.tbl th { font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); background: var(--surface-2); }
.tbl tbody tr:hover { background: var(--surface-2); }
.tbl.small th, .tbl.small td { padding: 7px 10px; font-size: 13px; }
.tbl .row-actions { white-space: nowrap; text-align: right; }
.tbl .row-actions form { display: inline; }

/* ---- Pills ------------------------------------------------------------ */
.pill { display: inline-block; padding: 2px 10px; font-size: 11px; font-weight: 600;
        border-radius: 999px; text-transform: uppercase; letter-spacing: .05em;
        background: var(--surface-2); color: var(--muted); border: 1px solid var(--line); }
.pill.ok  { background: var(--ok-soft);  color: var(--ok);  border-color: transparent; }
.pill.bad { background: var(--bad-soft); color: var(--bad); border-color: transparent; }

.warn-text { color: var(--warn); font-weight: 600; }

/* ---- Buttons ---------------------------------------------------------- */
.btn { background: var(--accent); color: #fff; border: 1px solid var(--accent);
       border-radius: 8px; padding: 8px 14px; font: inherit; font-weight: 600; cursor: pointer;
       transition: background .12s; }
.btn:hover { background: var(--accent-2); }
.btn.sm     { padding: 4px 10px; font-size: 12px; }
.btn.ghost  { background: #fff; color: var(--text); border-color: var(--line-2); font-weight: 500; }
.btn.ghost:hover { background: var(--surface-2); }
.btn.danger { background: var(--bad); border-color: var(--bad); }
.btn.danger:hover { background: #7f1d1d; }
.btn[disabled] { opacity: .55; cursor: not-allowed; }
.inline { display: inline; }

/* ---- Forms ------------------------------------------------------------ */
form label { display: block; margin-bottom: 12px; font-size: 13px; color: var(--text); }
form input[type=text], form input[type=password], form input[type=number],
form input:not([type]), form textarea, form select {
  width: 100%; margin-top: 5px; padding: 8px 10px; border: 1px solid var(--line-2);
  border-radius: 8px; background: #fff; font: inherit; color: var(--text);
}
form textarea { resize: vertical; min-height: 60px; }
form input:focus, form select:focus, form textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft);
}
form.narrow { max-width: 380px; }

.actions-row { display: flex; gap: 10px; align-items: center; margin-top: 16px; flex-wrap: wrap; }
.actions-row form { display: inline-flex; gap: 8px; align-items: center; margin: 0; }

/* ---- Filter / chip bar ----------------------------------------------- */
.filter-bar { display: flex; gap: 8px; align-items: center; margin-bottom: 14px; flex-wrap: wrap; }
.filter-bar input { min-width: 280px; padding: 7px 10px; border: 1px solid var(--line-2);
                    border-radius: 8px; font: inherit; }
.chip { display: inline-block; padding: 5px 12px; border-radius: 999px; background: #fff;
        border: 1px solid var(--line); color: var(--text); font-size: 12px; }
.chip.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.chip:hover { text-decoration: none; }

/* ---- Modal ------------------------------------------------------------ */
.modal { border: 1px solid var(--line); border-radius: 12px; padding: 22px 26px;
         max-width: 460px; width: 100%; box-shadow: 0 10px 30px rgba(15,23,42,.12); }
.modal::backdrop { background: rgba(15,23,42,.35); }
.modal h2 { margin: 0 0 14px; font-size: 17px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 8px; }

/* ---- Alerts / flashes ------------------------------------------------ */
.alert { padding: 10px 14px; border-radius: 8px; margin-bottom: 14px; font-weight: 500; }
.alert.ok  { background: var(--ok-soft);  color: var(--ok); }
.alert.err { background: var(--bad-soft); color: var(--bad); }

/* ---- Key reveal box -------------------------------------------------- */
.flash-key { border: 2px solid var(--accent); background: var(--accent-soft); }
.flash-key .key-box { display: flex; gap: 10px; align-items: center; margin: 10px 0 6px; }
.flash-key code { font-size: 16px; padding: 8px 14px; background: #fff; border-color: var(--accent); color: var(--accent); }
.flash-key .meta { color: var(--muted); font-size: 13px; }

/* ---- Key/Value grid -------------------------------------------------- */
.kv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px 28px; }
.kv-grid > div { display: flex; flex-direction: column; gap: 4px; }
.kv-grid .muted { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.notes { margin-top: 14px; padding: 10px 12px; background: var(--surface-2);
         border: 1px solid var(--line); border-radius: 8px; font-size: 13px; }

.muted { color: var(--muted); }

/* ---- Auth pages (no sidebar) ---------------------------------------- */
.auth-page { background: var(--surface-2); min-height: 100vh; display: flex;
             align-items: center; justify-content: center; }
.auth-card { background: #fff; border: 1px solid var(--line); border-radius: 12px;
             padding: 30px 32px; width: 360px; box-shadow: var(--shadow); }
.auth-card .brand { font-weight: 800; letter-spacing: .14em; color: var(--accent);
                    margin-bottom: 4px; font-size: 14px; }
.auth-card h1 { margin: 0 0 4px; font-size: 22px; }
.auth-card .muted { margin-top: 0; }
.auth-card .btn { width: 100%; margin-top: 6px; }
