/* ============================================================
   QLARIFY — shared prototype design system (one look, every page)
   Link this from every prototype page: <link rel="stylesheet" href="../shared/tokens.css">
   Accent = #069668 (emerald). Monochrome chrome, content carries colour.
   Font: Plus Jakarta Sans (load via Google Fonts in each page <head>).
   ============================================================ */
:root{
  /* brand */
  --q-accent:#069668; --q-accent-hover:#05805a; --q-accent-deep:#046b4b;
  --q-accent-soft:#e8f5ef; --q-accent-soft-2:#d4ecdf; --q-accent-ring:rgba(6,150,104,.28);
  /* neutrals (ink scale) */
  --q-ink:#0f1714; --q-ink-2:#3a4540; --q-mut:#5c6b64; --q-mut-2:#8a958f; --q-mut-3:#aab4ae;
  --q-line:#e7eae8; --q-line-2:#eef1ef;
  --q-bg:#f7f9f8; --q-surface:#ffffff; --q-surface-2:#fbfcfb; --q-surface-3:#f2f5f3;
  /* semantic */
  --q-ok:#0f9d63; --q-ok-soft:#e6f5ee; --q-warn:#b8761a; --q-warn-soft:#fbf1e1;
  --q-danger:#c4452f; --q-danger-soft:#fbeae6; --q-info:#3a6ea5;
  /* lifecycle / accent-2 palette for chips, pipelines, charts */
  --q-violet:#6366f1; --q-sky:#0ea5e9; --q-amber:#f59e0b; --q-purple:#8b5cf6; --q-teal:#0f766e; --q-rose:#e25563;
  /* shape + depth */
  --q-r-sm:8px; --q-r-md:12px; --q-r-lg:16px; --q-r-xl:22px; --q-r-pill:999px;
  --q-sh-xs:0 1px 2px rgba(15,23,20,.04);
  --q-sh-sm:0 2px 8px -2px rgba(15,23,20,.08);
  --q-sh-md:0 10px 30px -12px rgba(15,23,20,.16);
  --q-sh-lg:0 26px 60px -30px rgba(6,150,104,.28);
  --q-font:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--q-bg);color:var(--q-ink);font-family:var(--q-font);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}
h1,h2,h3,h4{margin:0;letter-spacing:-.02em;font-weight:800;color:var(--q-ink)}
h1{font-size:clamp(24px,3vw,32px)} h2{font-size:20px} h3{font-size:16px}
p{margin:0;color:var(--q-mut)}
a{color:var(--q-accent-deep);text-decoration:none}
.q-muted{color:var(--q-mut)} .q-muted-2{color:var(--q-mut-2)}

/* ---------- App shell: sidebar + main ---------- */
.q-app{display:flex;min-height:100vh}
.q-side{width:248px;flex:none;background:var(--q-surface);border-right:1px solid var(--q-line);display:flex;flex-direction:column;padding:18px 14px;gap:6px}
.q-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}
.q-brand .mark{width:32px;height:32px;border-radius:9px;background:var(--q-accent);display:grid;place-items:center;box-shadow:0 6px 16px -6px var(--q-accent-ring)}
.q-brand .mark svg{width:18px;height:18px;stroke:#fff;stroke-width:2.4;fill:none}
.q-brand .name{font-weight:800;font-size:18px;letter-spacing:-.02em}
.q-nav-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--q-mut-3);padding:14px 10px 6px}
.q-nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--q-r-md);color:var(--q-ink-2);font-weight:600;font-size:14px;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .15s,color .15s}
.q-nav-item svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;opacity:.85}
.q-nav-item:hover{background:var(--q-surface-3)}
.q-nav-item.is-active{background:var(--q-accent-soft);color:var(--q-accent-deep)}
.q-nav-item .count{margin-left:auto;font-size:12px;color:var(--q-mut-2);font-weight:700}
.q-side-foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--q-r-md);cursor:pointer}
.q-side-foot:hover{background:var(--q-surface-3)}
.q-main{flex:1;min-width:0;display:flex;flex-direction:column}
.q-topbar{display:flex;align-items:center;gap:14px;padding:18px 28px;border-bottom:1px solid var(--q-line-2);background:var(--q-surface);position:sticky;top:0;z-index:20}
.q-page{padding:26px 28px 60px;max-width:1240px;width:100%}
.q-page-head{margin-bottom:22px}
.q-page-head .sub{margin-top:4px}

/* ---------- Buttons ---------- */
.q-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 16px;border-radius:var(--q-r-md);font-family:inherit;font-weight:700;font-size:14px;cursor:pointer;border:1px solid transparent;transition:transform .12s,background .15s,box-shadow .15s,border-color .15s;white-space:nowrap}
.q-btn:active{transform:translateY(1px)}
.q-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}
.q-btn-primary{background:var(--q-accent);color:#fff;box-shadow:0 8px 18px -8px var(--q-accent-ring)}
.q-btn-primary:hover{background:var(--q-accent-hover)}
.q-btn-secondary{background:var(--q-surface);color:var(--q-ink);border-color:var(--q-line)}
.q-btn-secondary:hover{border-color:var(--q-accent);color:var(--q-accent-deep)}
.q-btn-ghost{background:transparent;color:var(--q-ink-2)}
.q-btn-ghost:hover{background:var(--q-surface-3)}
.q-btn-sm{padding:6px 11px;font-size:13px}
.q-btn-lg{padding:12px 22px;font-size:15px}

/* ---------- Cards / tiles ---------- */
.q-card{background:var(--q-surface);border:1px solid var(--q-line);border-radius:var(--q-r-lg);box-shadow:var(--q-sh-xs)}
.q-card-pad{padding:22px}
.q-tile{display:flex;flex-direction:column;gap:6px;padding:20px;background:var(--q-surface);border:1px solid var(--q-line);border-radius:var(--q-r-lg);box-shadow:var(--q-sh-xs);cursor:pointer;text-decoration:none;color:inherit;transition:transform .2s cubic-bezier(.2,.7,.2,1),border-color .2s,box-shadow .2s}
.q-tile:hover{transform:translateY(-4px);border-color:var(--q-accent);box-shadow:var(--q-sh-lg)}
.q-tile .ico{width:42px;height:42px;border-radius:var(--q-r-md);background:var(--q-accent-soft);color:var(--q-accent-deep);display:grid;place-items:center;margin-bottom:8px}
.q-tile .ico svg{width:21px;height:21px;stroke:currentColor;stroke-width:1.8;fill:none}
.q-tile.is-soon{opacity:.62;cursor:default}
.q-tile.is-soon:hover{transform:none;border-color:var(--q-line);box-shadow:var(--q-sh-xs)}

/* ---------- Pills / badges / chips ---------- */
.q-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--q-r-pill);font-size:12px;font-weight:700}
.q-pill-accent{background:var(--q-accent-soft);color:var(--q-accent-deep)}
.q-pill-ok{background:var(--q-ok-soft);color:var(--q-ok)}
.q-pill-warn{background:var(--q-warn-soft);color:var(--q-warn)}
.q-pill-soon{background:var(--q-warn-soft);color:var(--q-warn)}
.q-pill-mut{background:var(--q-surface-3);color:var(--q-mut)}
.q-dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.q-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:7px;font-size:12px;font-weight:600;background:var(--q-surface-3);color:var(--q-ink-2);border:1px solid var(--q-line)}

/* ---------- Inputs ---------- */
.q-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.q-label{font-size:13px;font-weight:700;color:var(--q-ink-2)}
.q-input,.q-select,.q-textarea{width:100%;font-family:inherit;font-size:14px;color:var(--q-ink);background:var(--q-surface);border:1px solid var(--q-line);border-radius:var(--q-r-md);padding:10px 12px;outline:none;transition:border-color .15s,box-shadow .15s}
.q-input:focus,.q-select:focus,.q-textarea:focus{border-color:var(--q-accent);box-shadow:0 0 0 3px var(--q-accent-ring)}
.q-textarea{min-height:96px;resize:vertical;line-height:1.55}
.q-input::placeholder,.q-textarea::placeholder{color:var(--q-mut-3)}

/* ---------- Toggle switch ---------- */
.q-switch{position:relative;display:inline-block;width:42px;height:24px;flex:none;cursor:pointer}
.q-switch input{opacity:0;width:0;height:0}
.q-switch .track{position:absolute;inset:0;background:var(--q-mut-3);border-radius:var(--q-r-pill);transition:background .2s}
.q-switch .track:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:var(--q-sh-xs)}
.q-switch input:checked + .track{background:var(--q-accent)}
.q-switch input:checked + .track:before{transform:translateX(18px)}

/* ---------- Segmented control ---------- */
.q-seg{display:inline-flex;background:var(--q-surface-3);border:1px solid var(--q-line);border-radius:var(--q-r-pill);padding:3px}
.q-seg button{border:none;background:none;font-family:inherit;font-weight:700;font-size:13px;color:var(--q-mut);padding:6px 14px;border-radius:var(--q-r-pill);cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.q-seg button.is-active{background:var(--q-ink);color:#fff}

/* ---------- Table ---------- */
.q-table{width:100%;border-collapse:collapse}
.q-table th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--q-mut-2);padding:0 14px 10px}
.q-table td{padding:13px 14px;border-top:1px solid var(--q-line-2);font-size:14px}
.q-table tr:hover td{background:var(--q-surface-2)}

/* ---------- Avatar ---------- */
.q-av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:13px;color:#fff;flex:none}

/* ---------- Helpers ---------- */
.q-row{display:flex;align-items:center;gap:12px}
.q-grid{display:grid;gap:18px}
.q-stat{font-size:30px;font-weight:800;letter-spacing:-.02em}
.q-soft-note{background:var(--q-accent-soft);border-radius:var(--q-r-md);padding:12px 14px;font-size:13px;color:var(--q-accent-deep)}
.q-divider{height:1px;background:var(--q-line-2);border:none;margin:18px 0}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}
