/* Aletra — HTML/htmx component layer.
   Plain CSS classes built on the design-system tokens (no React).
   Port these straight into Askama templates; htmx swaps fragments into [data-region].
   Link order in a page:  styles.css  →  app.css  */

/* ---------- reset / base ---------- */
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--al-font-text);
  color: var(--al-text);
  background: var(--al-chiaro);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }
h1, h2, h3, h4 { font-family: var(--al-font-display); font-weight: 500; margin: 0; color: var(--al-ink); }

/* ---------- layout: app shell ---------- */
.app { display: flex; height: 100vh; overflow: hidden; }
.sidebar {
  width: 248px; flex: none; background: var(--al-ink);
  display: flex; flex-direction: column; padding: 20px 14px;
  border-right: 1px solid var(--al-border-dark);
}
.sidebar__brand { padding: 6px 8px 22px; }
.sidebar__nav { display: flex; flex-direction: column; gap: 2px; }
.sidebar__section { font-family: var(--al-font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--al-on-dark-mut); padding: 16px 12px 6px; }
.navlink {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  border-radius: var(--al-radius-md); border: none; cursor: pointer; text-align: left;
  font-family: var(--al-font-text); font-size: 14px; font-weight: 500; text-decoration: none;
  background: transparent; color: var(--al-on-dark-mut);
  transition: background var(--al-dur) var(--al-ease), color var(--al-dur) var(--al-ease);
}
.navlink:hover { background: rgba(255,255,255,.04); color: var(--al-chiaro); }
.navlink.is-active { background: var(--al-ink-surface); color: var(--al-chiaro); }
.navlink .ico { color: currentColor; opacity: .85; }
.navlink.is-active .ico { color: var(--al-amber); opacity: 1; }

.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.topbar { display: flex; align-items: center; gap: 20px; padding: 16px 28px; border-bottom: 1px solid var(--al-border-soft); background: var(--al-white); }
.topbar__title { flex: 1; }
.topbar__title h1 { font-size: 22px; }
.topbar__title p { margin: 2px 0 0; font-size: 13px; color: var(--al-text-muted); }
.content { flex: 1; overflow-y: auto; padding: 28px; }
.content--narrow { max-width: 1080px; margin: 0 auto; width: 100%; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--al-font-text); font-weight: 500; font-size: 15px; line-height: 1.2;
  padding: 11px 20px; border-radius: var(--al-radius-md); border: 1px solid transparent;
  cursor: pointer; white-space: nowrap;
  transition: background var(--al-dur) var(--al-ease), border-color var(--al-dur) var(--al-ease), transform var(--al-dur-fast) var(--al-ease);
}
.btn:active { transform: translateY(1px); }
.btn--sm { padding: 7px 14px; font-size: 14px; border-radius: var(--al-radius-sm); }
.btn--lg { padding: 14px 26px; font-size: 16px; }
.btn--primary { background: var(--al-amber); color: var(--al-ink); border-color: var(--al-amber); }
.btn--primary:hover { background: var(--al-glow); border-color: var(--al-glow); }
.btn--dark { background: var(--al-ink); color: var(--al-chiaro); border-color: var(--al-ink); }
.btn--dark:hover { background: var(--al-ink-surface); }
.btn--secondary { background: transparent; color: var(--al-ink); border-color: var(--al-border); }
.btn--secondary:hover { background: var(--al-cloud-50); }
.btn--ghost { background: transparent; color: var(--al-ink); }
.btn--ghost:hover { background: var(--al-cloud); }
.btn[disabled] { opacity: .5; cursor: not-allowed; }
.btn--block { width: 100%; }

.iconbtn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; padding: 0; border-radius: var(--al-radius-md);
  border: 1px solid transparent; background: transparent; color: var(--al-text); cursor: pointer;
  transition: background var(--al-dur) var(--al-ease);
}
.iconbtn:hover { background: var(--al-cloud); }
.iconbtn--outline { border-color: var(--al-border); background: var(--al-white); }

/* ---------- cards / panels ---------- */
.card { background: var(--al-white); border: 1px solid var(--al-border-soft); border-radius: var(--al-radius-lg); box-shadow: var(--al-shadow-sm); }
.card--pad { padding: 22px; }
.card--sunken { background: var(--al-cloud-50); box-shadow: none; }
.card--dark { background: var(--al-ink-surface); border-color: var(--al-border-dark); color: var(--al-on-dark); box-shadow: none; }
.card--dark h1, .card--dark h2, .card--dark h3 { color: var(--al-chiaro); }
.panel-head { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--al-border-soft); }
.panel-head h2 { font-size: 18px; flex: 1; }
.eyebrow { font-family: var(--al-font-text); font-size: 12px; font-weight: 600; letter-spacing: var(--al-tracking-eyebrow); text-transform: uppercase; color: var(--al-amber-deep); }

/* ---------- stat tiles ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat { background: var(--al-white); border: 1px solid var(--al-border-soft); border-radius: var(--al-radius-lg); padding: 18px; box-shadow: var(--al-shadow-sm); }
.stat__label { display: flex; align-items: center; gap: 8px; color: var(--al-text-muted); font-size: 13px; margin-bottom: 12px; }
.stat__value { font-family: var(--al-font-display); font-weight: 500; font-size: 30px; color: var(--al-ink); }

/* ---------- badges / tags ---------- */
.badge { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; line-height: 1.4; padding: 4px 10px; border-radius: var(--al-radius-pill); white-space: nowrap; }
.badge--glow { background: var(--al-glow); color: var(--al-amber-deep); }
.badge--neutral { background: var(--al-cloud); color: var(--al-text-muted); }
.badge--ink { background: var(--al-ink); color: var(--al-chiaro); }
.badge--success { background: var(--al-success-bg); color: var(--al-success); }
.badge--warning { background: var(--al-warning-bg); color: var(--al-warning); }
.badge--error { background: var(--al-error-bg); color: var(--al-error); }
.badge--info { background: var(--al-info-bg); color: var(--al-info); }
.tag { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 500; line-height: 1.3; padding: 5px 10px; border-radius: var(--al-radius-sm); border: 1px solid var(--al-border); background: var(--al-white); color: var(--al-text); }
.tag--on { border-color: var(--al-amber-deep); background: var(--al-glow); color: var(--al-amber-deep); }

/* ---------- forms ---------- */
.field { display: block; }
.field > label { display: block; font-size: 14px; font-weight: 500; color: var(--al-text); margin-bottom: 6px; }
.field .hint { font-size: 13px; color: var(--al-text-muted); margin-top: 6px; }
.field .err { font-size: 13px; color: var(--al-error); margin-top: 6px; }
.input, .select, .textarea {
  width: 100%; font-family: var(--al-font-text); font-size: 15px; color: var(--al-text);
  background: var(--al-white); border: 1px solid var(--al-border); border-radius: var(--al-radius-md);
  padding: 10px 12px; transition: border-color var(--al-dur) var(--al-ease), box-shadow var(--al-dur) var(--al-ease);
}
.input:focus, .select:focus, .textarea:focus { outline: none; border-color: var(--al-amber-deep); box-shadow: 0 0 0 3px var(--focus-ring); }
.textarea { resize: vertical; min-height: 90px; line-height: 1.6; }
.select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235A6675' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }

/* ---------- table ---------- */
.table { width: 100%; border-collapse: collapse; font-family: var(--al-font-text); }
.table thead th { text-align: left; font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--al-text-muted); padding: 12px 16px; }
.table tbody td { padding: 14px 16px; border-top: 1px solid var(--al-border-soft); font-size: 14px; }
.table tbody tr.is-clickable { cursor: pointer; }
.table tbody tr.is-clickable:hover { background: var(--al-cloud-50); }
.mono { font-family: var(--al-font-mono); }
.muted { color: var(--al-text-muted); }

/* ---------- avatar ---------- */
.avatar { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; flex: none; overflow: hidden; font-weight: 600; font-size: 14px; background: var(--al-ink-surface); color: var(--al-amber); }

/* ---------- tabs ---------- */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--al-border-soft); }
.tab { position: relative; border: none; background: transparent; font-family: var(--al-font-text); font-size: 15px; font-weight: 500; color: var(--al-text-muted); padding: 10px 14px; cursor: pointer; }
.tab.is-active { color: var(--al-ink); }
.tab.is-active::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: -1px; height: 2px; border-radius: 2px; background: var(--al-amber); }

/* ---------- progress ---------- */
.progress { height: 8px; border-radius: 4px; background: var(--al-cloud); overflow: hidden; }
.progress > span { display: block; height: 100%; border-radius: 4px; background: var(--al-amber); }
.progress--ondark { background: var(--al-ink-surface); }

/* ---------- icons (Lucide stroke defaults) ---------- */
.ico { display: inline-flex; }
.ico svg { width: 18px; height: 18px; stroke-width: 1.75; }

/* htmx: subtle fade on swapped content */
.htmx-swapping { opacity: 0; }
[data-region] { transition: opacity var(--al-dur) var(--al-ease); }
.htmx-settling [data-region], .htmx-added { opacity: 1; }
