/* ── font-display override (fallback = 100ms block, no visible swap on cached loads) ── */
@font-face {
  font-family: "Stabil Grotesk";
  src: url('/gruenhorn/fonts/StabilGrotesk-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: fallback;
}
@font-face {
  font-family: "Stabil Grotesk";
  src: url('/gruenhorn/fonts/StabilGrotesk-Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: fallback;
}
@font-face {
  font-family: "Stabil Grotesk";
  src: url('/gruenhorn/fonts/StabilGrotesk-Light.otf') format('opentype');
  font-weight: 300; font-style: normal; font-display: fallback;
}
@font-face {
  font-family: "Attila Sans Classic";
  src: url('/gruenhorn/fonts/AttilaSansClassic-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: fallback;
}
@font-face {
  font-family: "Attila Sans Classic";
  src: url('/gruenhorn/fonts/AttilaSansClassic-Semibold.otf') format('opentype');
  font-weight: 600; font-style: normal; font-display: fallback;
}

/* ── Fonts & base ─────────────────────────────────────── */
body.gh-body {
  background: var(--gh-creme-smoke);
  font-family: var(--gh-font-ui);
  color: var(--gh-text);
  font-size: 14px;
}

/* ── Sidebar ──────────────────────────────────────────── */
.sidebar {
  background: var(--gh-kush) !important;
  border-right: none;
}
.sidebar-brand {
  color: var(--gh-creme-smoke);
  font-family: var(--gh-font-display);
  font-size: 16px;
  font-weight: 600;
  padding: 16px 20px 20px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.sidebar-brand img {
  height: 26px;
  width: auto;
  flex-shrink: 0;
}
.sidebar-brand small {
  display: block;
  font-family: var(--gh-font-ui);
  font-size: 11px;
  font-weight: 400;
  color: rgba(245,245,245,0.5);
  margin-top: 2px;
}
.sidebar .nav-link {
  color: rgba(245,245,245,0.65) !important;
  padding: 8px 14px;
  font-family: var(--gh-font-ui);
  font-size: 13px;
  font-weight: 500;
  border-left: none !important;
  border-radius: 6px;
  margin: 1px 8px;
}
.sidebar .nav-link:hover {
  color: var(--gh-creme-smoke) !important;
  background: rgba(255,255,255,0.08) !important;
}
.sidebar .nav-link.active {
  color: #fff !important;
  background: rgba(255,255,255,0.14) !important;
}
.sidebar .nav-link i {
  opacity: 0.75;
}
.sidebar .nav-link.active i {
  opacity: 1;
}
.sidebar-footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 12px 16px;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.sidebar-footer .text-muted {
  color: rgba(245,245,245,0.5) !important;
}
.sidebar-footer a {
  color: rgba(245,245,245,0.5) !important;
  font-size: 12px;
  text-decoration: none;
}
.sidebar-footer a:hover {
  color: var(--gh-creme-smoke) !important;
}

/* ── Top bar ──────────────────────────────────────────── */
.top-bar {
  background: var(--gh-white) !important;
  border-bottom: 1px solid var(--gh-grey-border) !important;
}

/* ── Main content ─────────────────────────────────────── */
.main-content {
  min-height: calc(100vh - 57px);
}

/* ── Headings ─────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--gh-font-ui);
  color: var(--gh-kush);
}

/* ── Links ────────────────────────────────────────────── */
a { color: var(--gh-kush); }
a:hover { color: var(--gh-matt-olive); }
.text-decoration-none:hover { color: var(--gh-kush); }

/* ── Bootstrap color utilities → GH tokens ───────────── */
.text-muted { color: var(--gh-grey-text) !important; }
.text-danger { color: var(--gh-danger) !important; }
.text-warning { color: var(--gh-warning) !important; }
.text-primary { color: var(--gh-kush) !important; }
.text-success { color: var(--gh-success-ink) !important; }

.bg-light { background: var(--gh-creme-smoke) !important; }
.bg-secondary { background: var(--gh-grey-quiet) !important; }
.bg-info.bg-opacity-10 { background: rgba(25,50,200,0.08) !important; }
.bg-warning.bg-opacity-10 { background: rgba(247,158,27,0.10) !important; }
.bg-success.bg-opacity-10 { background: rgba(54,151,93,0.10) !important; }
.bg-danger.bg-opacity-10 { background: rgba(235,0,27,0.08) !important; }

pre.bg-dark { background: #0D1F1C !important; }
.bg-dark.text-light:not(.badge) { background: #0D1F1C !important; }

/* ── Cards ────────────────────────────────────────────── */
.card {
  border-color: var(--gh-grey-border) !important;
  border-radius: var(--gh-radius-sm) !important;
  box-shadow: var(--gh-shadow-xs) !important;
  background: var(--gh-white) !important;
}
.card-header {
  background: transparent !important;
  border-bottom: 1px solid var(--gh-grey-border) !important;
  padding: 11px 16px !important;
  font-family: var(--gh-font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--gh-kush);
}
.card-body {
  font-family: var(--gh-font-ui);
  font-size: 13px;
  color: var(--gh-text);
}

/* Stat card left-border accents */
.stat-card.border-danger  { border-left: 4px solid var(--gh-danger) !important; }
.stat-card.border-warning { border-left: 4px solid var(--gh-warning) !important; }
.stat-card.border-primary { border-left: 4px solid var(--gh-kush) !important; }
.stat-card.border-success { border-left: 4px solid var(--gh-success-ink) !important; }
.stat-card .text-danger   { color: var(--gh-danger) !important; }
.stat-card .text-warning  { color: var(--gh-warning) !important; }
.stat-card .text-primary  { color: var(--gh-kush) !important; }
.stat-card .text-success  { color: var(--gh-success-ink) !important; }

/* Card semantic border colors */
.card.border-info    { border-color: rgba(25,50,200,0.25) !important; }
.card.border-warning { border-color: rgba(247,158,27,0.35) !important; }
.card.border-primary { border-color: rgba(18,40,36,0.30) !important; }
.card.border-success { border-color: rgba(54,151,93,0.30) !important; }

/* ── Buttons ──────────────────────────────────────────── */
.btn {
  border-radius: 999px !important;
  font-family: var(--gh-font-ui) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 6px 18px !important;
  transition: background 120ms, border-color 120ms !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
}
.btn-sm { font-size: 12px !important; padding: 4px 14px !important; }
.btn-lg { font-size: 14px !important; padding: 9px 22px !important; }

.btn-primary {
  background-color: var(--gh-kush) !important;
  border-color: var(--gh-kush) !important;
  color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--gh-matt-olive) !important;
  border-color: var(--gh-matt-olive) !important;
  color: #fff !important;
}

.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-info,
.btn-outline-warning {
  background: var(--gh-creme-smoke) !important;
  border-color: var(--gh-grey-border) !important;
  color: var(--gh-kush) !important;
}
.btn-outline-primary:hover,
.btn-outline-secondary:hover,
.btn-outline-info:hover,
.btn-outline-warning:hover {
  background: var(--gh-grey-hover) !important;
  border-color: var(--gh-kush) !important;
  color: var(--gh-kush) !important;
}

.btn-outline-success, .btn-success {
  background: var(--gh-success-ink) !important;
  border-color: var(--gh-success-ink) !important;
  color: #fff !important;
}
.btn-outline-success:hover, .btn-success:hover {
  background: #2a7a4a !important;
  border-color: #2a7a4a !important;
  color: #fff !important;
}

.btn-outline-danger, .btn-danger {
  background: var(--gh-danger) !important;
  border-color: var(--gh-danger) !important;
  color: #fff !important;
}
.btn-outline-danger:hover, .btn-danger:hover {
  background: #c00015 !important;
  border-color: #c00015 !important;
  color: #fff !important;
}

.btn:focus-visible { box-shadow: var(--gh-focus-ring) !important; outline: none !important; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* ── Badges ───────────────────────────────────────────── */
.badge {
  border-radius: 4px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 8px !important;
}
.badge.bg-danger  { background: rgba(235,0,27,0.10)   !important; color: #EB001B !important; }
.badge.bg-warning { background: rgba(247,158,27,0.14) !important; color: #9B6200 !important; }
.badge.bg-success { background: rgba(54,151,93,0.12)  !important; color: #36975D !important; }
.badge.bg-secondary { background: #ECECEC !important; color: #6A6A6A !important; }
.badge.bg-info    { background: rgba(25,50,200,0.10)  !important; color: #1932C8 !important; }
.badge.bg-dark    { background: #ECECEC !important; color: #6A6A6A !important; }
.badge.bg-primary { background: rgba(18,40,36,0.10)   !important; color: var(--gh-kush) !important; }
.badge.bg-light   { background: #ECECEC !important; color: #6A6A6A !important; }

/* ── Form controls ────────────────────────────────────── */
.form-control, .form-control-sm, .form-control-lg {
  background: var(--gh-creme-smoke) !important;
  border-color: var(--gh-grey-border) !important;
  border-radius: var(--gh-radius-sm) !important;
  color: var(--gh-kush) !important;
  font-family: var(--gh-font-ui) !important;
  font-size: 13px !important;
  padding: 7px 12px !important;
}
.form-control::placeholder { color: var(--gh-grey-muted) !important; }
.form-control:focus {
  background: var(--gh-creme-smoke) !important;
  border-color: var(--gh-kush) !important;
  box-shadow: var(--gh-focus-ring) !important;
  color: var(--gh-kush) !important;
}
.form-select {
  background-color: var(--gh-creme-smoke) !important;
  border-color: var(--gh-grey-border) !important;
  border-radius: var(--gh-radius-sm) !important;
  color: var(--gh-kush) !important;
  font-family: var(--gh-font-ui) !important;
  font-size: 13px !important;
  padding: 7px 12px !important;
}
.form-select:focus {
  border-color: var(--gh-kush) !important;
  box-shadow: var(--gh-focus-ring) !important;
}
.form-label {
  font-family: var(--gh-font-ui);
  font-size: 12px;
  font-weight: 500;
  color: var(--gh-grey-text);
}
.input-group-text {
  background: var(--gh-creme-smoke);
  border-color: var(--gh-grey-border);
  color: var(--gh-grey-text);
  font-size: 13px;
  font-family: var(--gh-font-ui);
}

/* ── Tables ───────────────────────────────────────────── */
.table {
  font-size: 13px;
  color: var(--gh-text);
  font-family: var(--gh-font-ui);
  --bs-table-hover-bg: var(--gh-grey-hover);
}
.table > thead > tr > th {
  background: var(--gh-grey-quiet) !important;
  color: var(--gh-grey-text);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--gh-grey-border) !important;
  padding: 8px 12px;
}
.table > tbody > tr > td {
  border-color: var(--gh-grey-border);
  vertical-align: middle;
}
.table-hover > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > th {
  --bs-table-color-state: var(--gh-text);
  background-color: var(--gh-grey-hover);
}

/* ── Alerts ───────────────────────────────────────────── */
.alert {
  border-radius: var(--gh-radius-sm) !important;
  font-size: 13px;
  font-family: var(--gh-font-ui);
}
.alert-warning {
  background: rgba(247,158,27,0.10) !important;
  border-color: rgba(247,158,27,0.35) !important;
  color: #7A4A00 !important;
}
.alert-success {
  background: rgba(54,151,93,0.10) !important;
  border-color: rgba(54,151,93,0.30) !important;
  color: var(--gh-success-ink) !important;
}
.alert-danger {
  background: rgba(235,0,27,0.08) !important;
  border-color: rgba(235,0,27,0.25) !important;
  color: var(--gh-danger) !important;
}
.alert-info {
  background: rgba(25,50,200,0.08) !important;
  border-color: rgba(25,50,200,0.20) !important;
  color: #1932C8 !important;
}

/* ── List groups ──────────────────────────────────────── */
.list-group-item {
  border-color: var(--gh-grey-border) !important;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--gh-text);
  font-family: var(--gh-font-ui);
}
.list-group-item-action:hover,
.list-group-item-action:focus {
  background: var(--gh-grey-hover) !important;
  color: var(--gh-text) !important;
}
.list-group-item.active {
  background: var(--gh-kush) !important;
  border-color: var(--gh-kush) !important;
  color: #fff !important;
}

/* ── Pagination ───────────────────────────────────────── */
.page-link {
  color: var(--gh-kush);
  border-color: var(--gh-grey-border);
  font-size: 13px;
  font-family: var(--gh-font-ui);
  border-radius: 6px !important;
  margin: 0 2px;
}
.page-link:hover {
  background: var(--gh-grey-hover) !important;
  color: var(--gh-kush) !important;
  border-color: var(--gh-grey-border) !important;
}
.page-item.active .page-link {
  background: var(--gh-kush) !important;
  border-color: var(--gh-kush) !important;
  color: #fff !important;
}
.page-item.disabled .page-link {
  color: var(--gh-grey-muted) !important;
}

/* ── Code ─────────────────────────────────────────────── */
code:not(pre code) {
  color: var(--gh-kush);
  background: var(--gh-grey-quiet);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--gh-font-mono);
  font-size: 12px;
}
pre {
  border-radius: var(--gh-radius-sm);
  font-family: var(--gh-font-mono);
  font-size: 12px;
}

/* ── Collapse toggle ──────────────────────────────────── */
[data-bs-toggle="collapse"] {
  color: var(--gh-kush);
  font-size: 13px;
  font-weight: 500;
}

/* ── Timeline (order detail) ──────────────────────────── */
.timeline-step:not(:last-child)::before { background: var(--gh-grey-border) !important; }
.step-dot.done    { background: var(--gh-success-ink) !important; }
.step-dot.error   { background: var(--gh-danger) !important; }
.step-dot.pending { background: var(--gh-grey-border) !important; color: var(--gh-grey-text) !important; }

/* ── Article content ──────────────────────────────────── */
.article-content {
  font-size: 14px;
  line-height: 1.7;
  color: var(--gh-text);
  font-family: var(--gh-font-ui);
}
.article-content h1, .article-content h2, .article-content h3,
.article-content h4, .article-content h5, .article-content h6 {
  font-family: var(--gh-font-ui);
  color: var(--gh-kush);
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}
.article-content p { margin-bottom: 1rem; }
.article-content ul, .article-content ol { margin-bottom: 1rem; padding-left: 1.5rem; }
.article-content pre { background: #0D1F1C; color: var(--gh-creme-smoke); padding: 1rem; }
.article-content code:not(pre code) { color: var(--gh-kush); background: var(--gh-grey-quiet); padding: 1px 5px; border-radius: 3px; }
.article-content a { color: var(--gh-kush); }
.article-content a:hover { color: var(--gh-matt-olive); }

/* ── Login page ───────────────────────────────────────── */
.login-wrap {
  min-height: 100vh;
  background: var(--gh-kush);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.login-card {
  background: var(--gh-white);
  border-radius: var(--gh-radius-md);
  padding: 2.5rem;
  width: 100%;
  max-width: 400px;
  box-shadow: var(--gh-shadow-md);
}
.login-card .login-logo {
  height: 36px;
  margin-bottom: 1.25rem;
}
.login-card h2 {
  font-family: var(--gh-font-display);
  color: var(--gh-kush);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 4px;
}
.login-card .login-subtitle {
  color: var(--gh-grey-text);
  font-size: 13px;
  margin-bottom: 1.75rem;
}

/* ── Copy button ──────────────────────────────────────── */
.copy-btn { cursor: pointer; color: var(--gh-grey-text); transition: color 120ms; }
.copy-btn:hover { color: var(--gh-kush); }
