/* CWS Recipes — theme aligned with cwscode.com (indigo / slate, light, modern) */
:root {
  --indigo-50: #eef2ff;
  --indigo-100: #e0e7ff;
  --indigo-400: #818cf8;
  --indigo-500: #6366f1;
  --indigo-600: #4f46e5;
  --indigo-700: #4338ca;
  --slate-900: #0f172a;
  --slate-800: #1e293b;
  --slate-700: #334155;
  --slate-600: #475569;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #f1f5f9;
  --slate-50: #f8fafc;
  --white: #ffffff;
  --green-600: #16a34a;
  --green-50: #f0fdf4;
  --red-600: #dc2626;
  --red-50: #fef2f2;
  --amber-600: #d97706;
  --amber-50: #fffbeb;
  --radius: 10px;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);
  --shadow: 0 4px 16px rgba(15, 23, 42, .08);
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  color: var(--slate-800);
  background: var(--slate-50);
  font-size: 14px;
  line-height: 1.55;
}
a { color: var(--indigo-600); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { color: var(--slate-900); line-height: 1.25; }
h1 { font-size: 1.5rem; margin: 0 0 .25rem; }
h2 { font-size: 1.15rem; margin: 1.5rem 0 .75rem; }
h3 { font-size: 1rem; margin: 1rem 0 .5rem; }
code, .mono { font-family: var(--mono); }

/* ── top bar ───────────────────────────────────────────── */
.topbar {
  background: var(--slate-900);
  color: var(--white);
  border-bottom: 3px solid var(--indigo-600);
}
.topbar-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 1.25rem;
  display: flex; align-items: center; gap: 1.5rem; height: 56px;
}
.brand { display: flex; align-items: center; gap: .6rem; font-weight: 700; color: var(--white); font-size: 1.05rem; }
.brand:hover { text-decoration: none; }
.brand .logo {
  width: 30px; height: 30px; border-radius: 7px;
  background: linear-gradient(135deg, var(--indigo-500), var(--indigo-700));
  display: grid; place-items: center; color: #fff; font-weight: 800; font-size: .85rem;
}
.brand .sub { color: var(--slate-400); font-weight: 400; font-size: .8rem; }
.nav { display: flex; gap: .25rem; margin-left: 1rem; }
.nav a {
  color: var(--slate-300); padding: .45rem .8rem; border-radius: 7px; font-weight: 500;
}
.nav a:hover { color: #fff; background: rgba(255,255,255,.08); text-decoration: none; }
.nav a.active { color: #fff; background: var(--indigo-600); }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: .75rem; }
.lang { display: flex; gap: .15rem; }
.lang a { color: var(--slate-400); padding: .2rem .45rem; border-radius: 6px; font-size: .8rem; text-transform: uppercase; }
.lang a.active { color: #fff; background: rgba(255,255,255,.12); }
.usermenu { display: flex; align-items: center; gap: .6rem; color: var(--slate-300); font-size: .85rem; }
.usermenu .avatar {
  width: 28px; height: 28px; border-radius: 50%; background: var(--indigo-600);
  display: grid; place-items: center; color: #fff; font-weight: 700; font-size: .8rem;
}

/* ── layout ────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 1.5rem auto; padding: 0 1.25rem; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.muted { color: var(--slate-500); }
.small { font-size: .8rem; }

/* ── cards ─────────────────────────────────────────────── */
.card { background: var(--white); border: 1px solid var(--slate-200); border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.card .card-body { padding: 1.1rem 1.25rem; }
.card .card-head { padding: .85rem 1.25rem; border-bottom: 1px solid var(--slate-200); font-weight: 600; color: var(--slate-900); display:flex; align-items:center; justify-content:space-between; gap:.5rem;}
.grid { display: grid; gap: 1rem; }
.grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 800px) { .grid.cols-3, .grid.cols-4, .grid.cols-2 { grid-template-columns: 1fr; } }

.stat { padding: 1.1rem 1.25rem; }
.stat .n { font-size: 1.9rem; font-weight: 700; color: var(--slate-900); }
.stat .l { color: var(--slate-500); font-size: .85rem; }

/* ── tables ────────────────────────────────────────────── */
table.data { width: 100%; border-collapse: collapse; font-size: .85rem; }
table.data th, table.data td { text-align: left; padding: .55rem .7rem; border-bottom: 1px solid var(--slate-200); }
table.data th { color: var(--slate-500); font-weight: 600; text-transform: uppercase; font-size: .72rem; letter-spacing: .03em; background: var(--slate-50); }
table.data tr:hover td { background: var(--indigo-50); }
table.data td.num, table.data th.num { text-align: right; font-variant-numeric: tabular-nums; }
.table-wrap { overflow-x: auto; }

/* ── badges ────────────────────────────────────────────── */
.badge { display: inline-block; padding: .15rem .55rem; border-radius: 999px; font-size: .72rem; font-weight: 600; border: 1px solid transparent; }
.badge.gray { background: var(--slate-100); color: var(--slate-600); border-color: var(--slate-200); }
.badge.indigo { background: var(--indigo-50); color: var(--indigo-700); border-color: var(--indigo-100); }
.badge.green { background: var(--green-50); color: var(--green-600); }
.badge.red { background: var(--red-50); color: var(--red-600); }
.badge.amber { background: var(--amber-50); color: var(--amber-600); }

/* ── forms ─────────────────────────────────────────────── */
.field { margin-bottom: .9rem; }
.field label { display: block; font-weight: 600; color: var(--slate-700); margin-bottom: .3rem; font-size: .85rem; }
input[type=text], input[type=password], input[type=email], input[type=number], input[type=search], select, textarea {
  width: 100%; padding: .55rem .7rem; border: 1px solid var(--slate-300); border-radius: 8px;
  font-family: inherit; font-size: .9rem; color: var(--slate-800); background: #fff;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--indigo-500); box-shadow: 0 0 0 3px var(--indigo-100); }
.checkbox { display: flex; align-items: center; gap: .5rem; }
.checkbox input { width: auto; }
.form-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.form-row > * { flex: 1; min-width: 200px; }

/* ── buttons ───────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem; cursor: pointer;
  padding: .5rem .9rem; border-radius: 8px; font-weight: 600; font-size: .85rem;
  border: 1px solid var(--slate-300); background: #fff; color: var(--slate-700);
}
.btn:hover { background: var(--slate-50); text-decoration: none; }
.btn.primary { background: var(--indigo-600); border-color: var(--indigo-600); color: #fff; }
.btn.primary:hover { background: var(--indigo-700); }
.btn.danger { background: #fff; border-color: var(--red-600); color: var(--red-600); }
.btn.danger:hover { background: var(--red-50); }
.btn.sm { padding: .3rem .6rem; font-size: .78rem; }
.btn-group { display: flex; gap: .5rem; flex-wrap: wrap; }

/* ── filter bar ────────────────────────────────────────── */
.filterbar { display: flex; gap: .6rem; align-items: end; flex-wrap: wrap; margin-bottom: 1rem; }
.filterbar .field { margin: 0; }
.filterbar .grow { flex: 1; min-width: 200px; }

/* ── tabs ──────────────────────────────────────────────── */
.tabs { display: flex; gap: .25rem; border-bottom: 1px solid var(--slate-200); margin-bottom: 1rem; flex-wrap: wrap; }
.tabs a { padding: .55rem .9rem; color: var(--slate-600); font-weight: 600; border-bottom: 2px solid transparent; }
.tabs a:hover { color: var(--slate-900); text-decoration: none; }
.tabs a.active { color: var(--indigo-700); border-bottom-color: var(--indigo-600); }

/* ── definition list ───────────────────────────────────── */
dl.props { display: grid; grid-template-columns: max-content 1fr; gap: .4rem 1.2rem; margin: 0; }
dl.props dt { color: var(--slate-500); font-size: .85rem; }
dl.props dd { margin: 0; font-weight: 600; color: var(--slate-800); }

/* ── flash / alerts ────────────────────────────────────── */
.flash { padding: .7rem 1rem; border-radius: 8px; margin-bottom: 1rem; font-weight: 500; border: 1px solid; }
.flash.success { background: var(--green-50); color: var(--green-600); border-color: #bbf7d0; }
.flash.error { background: var(--red-50); color: var(--red-600); border-color: #fecaca; }
.flash.info { background: var(--indigo-50); color: var(--indigo-700); border-color: var(--indigo-100); }

/* ── pagination ────────────────────────────────────────── */
.pager { display: flex; gap: .5rem; align-items: center; margin-top: 1rem; }
.pager .info { color: var(--slate-500); font-size: .85rem; }

/* ── auth pages ────────────────────────────────────────── */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; background: linear-gradient(160deg, var(--slate-900), #1b2543 70%, var(--indigo-700)); padding: 1rem; }
.auth-card { background: #fff; width: 100%; max-width: 400px; border-radius: 14px; box-shadow: 0 20px 50px rgba(0,0,0,.3); padding: 2rem; }
.auth-card .brand { color: var(--slate-900); justify-content: center; margin-bottom: .25rem; font-size: 1.2rem; }
.auth-card .tagline { text-align: center; color: var(--slate-500); margin-bottom: 1.5rem; font-size: .85rem; }
.auth-card .btn.primary { width: 100%; justify-content: center; padding: .65rem; }

/* ── footer ────────────────────────────────────────────── */
footer.site { max-width: 1200px; margin: 2rem auto 1.5rem; padding: 1rem 1.25rem 0; border-top: 1px solid var(--slate-200); color: var(--slate-400); font-size: .8rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }

/* ── misc ──────────────────────────────────────────────── */
.qr { display: grid; place-items: center; padding: 1rem; background: #fff; border: 1px solid var(--slate-200); border-radius: 10px; }
.codes { display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem; font-family: var(--mono); }
.codes div { background: var(--slate-50); border: 1px solid var(--slate-200); padding: .5rem .7rem; border-radius: 6px; letter-spacing: .05em; }
.key-box { font-family: var(--mono); background: var(--slate-50); border: 1px dashed var(--slate-300); padding: .6rem .8rem; border-radius: 8px; word-break: break-all; }
.color-dot { display:inline-block; width:.8rem; height:.8rem; border-radius:50%; border:1px solid var(--slate-300); vertical-align:middle; margin-right:.35rem; }
.inline-form { display: inline; }

/* ── bar charts (dependency-free) ──────────────────────── */
.bar-row { display: grid; grid-template-columns: 150px 1fr 64px; align-items: center; gap: .6rem; margin: .4rem 0; font-size: .82rem; }
.bar-row .lbl { color: var(--slate-600); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bar-track { background: var(--slate-100); border-radius: 6px; height: 16px; overflow: hidden; }
.bar-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--indigo-400), var(--indigo-600)); border-radius: 6px; min-width: 2px; }
.bar-val { text-align: right; font-variant-numeric: tabular-nums; color: var(--slate-700); font-weight: 600; }

/* ── composition bar ───────────────────────────────────── */
.composition { display: flex; height: 26px; border-radius: 7px; overflow: hidden; border: 1px solid var(--slate-200); background: var(--slate-100); }
.composition span { display: block; height: 100%; }
.legend { display: flex; flex-wrap: wrap; gap: .4rem 1.1rem; margin-top: .7rem; font-size: .8rem; color: var(--slate-600); }
.legend .item i { display: inline-block; width: .75rem; height: .75rem; border-radius: 3px; margin-right: .4rem; vertical-align: middle; }
