/* ==========================================================================
   pygab.dev — Bootstrap 5 theme layer (hi-fi)
   Loads AFTER bootstrap.min.css and overrides it.
   Aesthetic: light, airy, cool neutrals + single indigo accent.
   Type: Hanken Grotesk (body) + JetBrains Mono (display / labels / dev touch).
   Only adds classes that DON'T collide with Bootstrap, and themes the rest
   through Bootstrap CSS variables so it stays idiomatic in templates.
   ========================================================================== */

:root{
  /* --- palette --- */
  --bg:#eef1f6; --bg-2:#e7ebf3;
  --surface:#ffffff; --surface-2:#f6f8fc;
  --ink:#1b1e27; --ink-2:#545a68; --ink-3:#98a0b0;
  --border:#e3e7ef; --border-strong:#d4dae5;
  --accent:#4b57d6; --accent-600:#3d49c2; --accent-700:#333dac;
  --accent-soft:#ebedfb; --accent-ink:#ffffff;

  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, monospace;
  --sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;

  --r-sm:10px; --r-md:14px; --r-lg:22px; --r-xl:30px; --r-pill:999px;
  --sh-sm:0 1px 2px rgba(20,26,45,.04), 0 2px 6px rgba(20,26,45,.05);
  --sh-md:0 4px 10px rgba(20,26,45,.05), 0 16px 36px rgba(20,26,45,.07);
  --sh-lg:0 10px 24px rgba(20,26,45,.08), 0 30px 60px rgba(20,26,45,.10);
  --sh-nav:0 6px 24px rgba(27,30,45,.10);

  /* --- map Bootstrap variables to our system --- */
  --bs-body-font-family:var(--sans);
  --bs-body-color:var(--ink-2);
  --bs-body-bg:var(--bg);
  --bs-body-font-size:1.0625rem;   /* 17px */
  --bs-body-line-height:1.6;
  --bs-emphasis-color:var(--ink);
  --bs-primary:var(--accent);
  --bs-primary-rgb:75,87,214;
  --bs-link-color:var(--accent);
  --bs-link-color-rgb:75,87,214;
  --bs-link-hover-color:var(--accent-700);
  --bs-border-color:var(--border);
  --bs-border-radius:var(--r-md);
  --bs-border-radius-lg:var(--r-lg);
}

::selection{ background:var(--accent); color:#fff; }
html{ scroll-behavior:smooth; }
body{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; min-height:100vh; display:flex; flex-direction:column; }
main{ flex:1 0 auto; }
img{ max-width:100%; height:auto; }
a{ text-decoration:none; }

/* wider, Zorin-ish container */
@media (min-width:1200px){ .container,.container-lg,.container-xl,.container-xxl{ max-width:1180px; } }

/* ---------- typography ---------- */
h1,h2,h3,h4,h5{ color:var(--ink); font-weight:800; line-height:1.1; letter-spacing:-.01em; }
.section{ padding:84px 0; }
.section-sm{ padding:56px 0; }
.band{ background:var(--bg-2); }

.eyebrow{
  font-family:var(--mono); font-size:12.5px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--accent);
  margin:0 0 18px; display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{ content:""; width:24px; height:2px; background:var(--accent); border-radius:2px; }
.eyebrow.bare::before{ display:none; }

.display{ font-family:var(--mono); font-weight:800; letter-spacing:-.03em; line-height:1.02; color:var(--ink); }
.display .muted{ color:var(--ink-3); }
.h-hero{ font-size:clamp(40px,6vw,70px); }
.h-page{ font-size:clamp(36px,5vw,58px); }
.h-sec{ font-family:var(--mono); font-weight:800; font-size:clamp(24px,3vw,34px); letter-spacing:-.02em; color:var(--ink); }
.h-sec-sm{ font-size:24px; }
.h-sec-xs{ font-size:22px; }
.h-sec-2xs{ font-size:20px; }
.lead{ font-size:clamp(17px,1.4vw,20px); color:var(--ink-2); line-height:1.6; }
.kicker{ font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.mono{ font-family:var(--mono); }

/* ---------- floating pill navbar (Bootstrap navbar themed) ---------- */
.site-nav{ position:sticky; top:0; z-index:1030; padding:18px 0; background:transparent; }
.site-nav .container{ display:block; }
.site-nav-inner{
  display:flex; align-items:center; gap:14px; width:100%;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(140%) blur(14px);
  border:1px solid var(--border); border-radius:var(--r-pill);
  box-shadow:var(--sh-nav); padding:10px 12px 10px 18px;
}
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--mono); font-weight:800; font-size:15px; color:var(--ink); letter-spacing:-.01em; padding:0; }
.brand .mark{ width:34px; height:34px; border-radius:10px; background:var(--accent); color:#fff; display:grid; place-items:center; font-family:var(--mono); font-weight:800; font-size:14px; box-shadow:0 4px 10px rgba(75,87,214,.35); }
.site-nav .navbar-nav{ gap:4px; align-items:center; }
.site-nav .nav-link{ font-family:var(--mono); font-size:13.5px; font-weight:500; color:var(--ink-2); white-space:nowrap; padding:9px 14px; border-radius:var(--r-pill); transition:background .15s,color .15s; }
.site-nav .nav-link:hover,.site-nav .nav-link:focus{ color:var(--ink); background:var(--surface-2); }
.site-nav .nav-link.active{ color:var(--ink); background:var(--surface-2); font-weight:700; }
.site-nav .nav-cta{ margin-left:6px; color:#fff; }
.navbar-toggler{ border:1px solid var(--border); padding:8px 10px; border-radius:var(--r-pill); }
.navbar-toggler:focus{ box-shadow:0 0 0 3px var(--accent-soft); }

/* nav search + admin dropdown */
.nav-search{ position:relative; }
.nav-search .form-control{ font-family:var(--mono); font-size:13px; padding:8px 14px 8px 34px; border-radius:var(--r-pill); background:var(--surface-2); border:1px solid var(--border); min-height:0; }
.nav-search .nav-search-ic{ position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--ink-3); pointer-events:none; }
.site-nav .dropdown-menu{ font-family:var(--mono); font-size:13.5px; border:1px solid var(--border); border-radius:var(--r-md); box-shadow:var(--sh-md); padding:6px; }
.site-nav .dropdown-item{ border-radius:var(--r-sm); padding:8px 12px; color:var(--ink-2); }
.site-nav .dropdown-item:hover,.site-nav .dropdown-item:focus{ background:var(--surface-2); color:var(--ink); }

@media (max-width:991.98px){
  .site-nav-inner{ flex-wrap:wrap; }
  .site-nav .navbar-collapse{ width:100%; }
  .site-nav .navbar-nav{ align-items:stretch; padding-top:10px; gap:2px; }
  .site-nav .nav-cta{ margin-left:0; margin-top:6px; text-align:center; }
  .nav-search{ margin-top:8px; }
  .nav-search .form-control{ width:100%; }
}

/* ---------- buttons (theme Bootstrap .btn) ---------- */
.btn{ font-family:var(--mono); font-weight:600; font-size:14px; padding:13px 22px; border-radius:var(--r-pill); border:1px solid transparent; display:inline-flex; align-items:center; justify-content:center; gap:9px; white-space:nowrap; transition:transform .12s,box-shadow .15s,background .15s,color .15s,border-color .15s; }
.btn:active{ transform:translateY(1px); }
.btn-sm{ padding:9px 16px; font-size:13px; }
.btn-lg{ padding:16px 28px; font-size:15px; }
.btn-primary{ --bs-btn-bg:var(--accent); --bs-btn-border-color:var(--accent); --bs-btn-hover-bg:var(--accent-600); --bs-btn-hover-border-color:var(--accent-600); --bs-btn-active-bg:var(--accent-700); --bs-btn-color:#fff; --bs-btn-hover-color:#fff; box-shadow:0 6px 16px rgba(75,87,214,.30); }
.btn-primary:hover{ box-shadow:0 8px 22px rgba(75,87,214,.38); }
.btn-ghost{ background:var(--surface); color:var(--ink); border-color:var(--border-strong); }
.btn-ghost:hover{ background:var(--surface-2); border-color:var(--ink-3); color:var(--ink); }
.btn-danger{ --bs-btn-bg:#d6453b; --bs-btn-border-color:#d6453b; --bs-btn-hover-bg:#c13a31; --bs-btn-hover-border-color:#c13a31; --bs-btn-color:#fff; --bs-btn-hover-color:#fff; }
.btn-text{ padding:0; background:none; color:var(--accent); font-weight:700; border:none; }
.btn-text:hover{ color:var(--accent-700); }
.btn .arr{ transition:transform .15s; }
.btn:hover .arr{ transform:translateX(3px); }

/* ---------- tags / meta ---------- */
.tags{ display:flex; flex-wrap:wrap; gap:8px; }
.tag{ font-family:var(--mono); font-size:12px; font-weight:500; color:var(--ink-2); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-pill); padding:6px 12px; }
.tag.solid{ background:var(--accent); color:#fff; border-color:var(--accent); }
.tag.soft{ background:var(--accent-soft); color:var(--accent-700); border-color:transparent; }
.meta{ display:flex; align-items:center; gap:12px; font-family:var(--mono); font-size:12.5px; color:var(--ink-3); }
.meta .sepdot{ width:4px; height:4px; border-radius:50%; background:var(--ink-3); }
.meta .author{ color:var(--ink-2); }

/* ---------- image placeholder ---------- */
.ph{ position:relative; overflow:hidden; background:repeating-linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, var(--surface-2)) 0 11px, var(--surface-2) 11px 22px); border:1px solid var(--border); border-radius:var(--r-lg); display:grid; place-items:center; }
.ph::after{ content:attr(data-label); font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); background:var(--surface); border:1px solid var(--border); padding:5px 11px; border-radius:var(--r-pill); }
.ph.round{ border-radius:50%; }

/* media that replaces a placeholder fills the same box */
.thumb img,.hero-portrait img,.fc-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- cards (theme Bootstrap .card) ---------- */
.card{ --bs-card-border-color:var(--border); --bs-card-border-radius:var(--r-lg); --bs-card-inner-border-radius:var(--r-lg); --bs-card-bg:var(--surface); --bs-card-spacer-y:22px; --bs-card-spacer-x:22px; box-shadow:var(--sh-sm); transition:transform .18s,box-shadow .18s,border-color .18s; overflow:hidden; }
.card-hover:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--border-strong); }
.card .thumb{ aspect-ratio:16/10; border:none; border-radius:0; overflow:hidden; }
.card .thumb-compact{ aspect-ratio:16/9; background:var(--surface-2); border-bottom:1px solid var(--border); }
.card-title{ font-size:21px; line-height:1.2; letter-spacing:-.01em; color:var(--ink); margin:0; }
.card-title a{ color:inherit; }
.card-title a:hover{ color:var(--accent); }
.card-text{ color:var(--ink-2); font-size:15px; }
.card-sm{ --bs-card-spacer-y:16px; --bs-card-spacer-x:18px; }
.card-sm .card-title{ font-size:18px; }
.card-sm .card-text{ font-size:14px; }

/* ---------- horizontal scroller (NOT Bootstrap .carousel) ---------- */
.scroller-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:28px; }
.scroller-track{ display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 2px 18px; margin:0 -2px; scrollbar-width:none; }
.scroller-track::-webkit-scrollbar{ display:none; }
.scroller-track > *{ scroll-snap-align:start; flex:0 0 360px; max-width:82vw; }
.scroller-btns{ display:flex; gap:10px; }
.scroll-btn{ width:46px; height:46px; border-radius:50%; background:var(--surface); border:1px solid var(--border-strong); display:grid; place-items:center; color:var(--ink); transition:background .15s,border-color .15s,transform .12s; }
.scroll-btn:hover{ background:var(--surface-2); border-color:var(--ink-3); }
.scroll-btn:active{ transform:scale(.94); }

/* ---------- hero ---------- */
.hero{ padding:46px 0 90px; }
.hero-copy .h-hero{ margin:0 0 22px; }
.hero-copy .lead{ margin:0 0 30px; max-width:52ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }
.hero-visual{ position:relative; }
/* ── Hero composition (photo + tech cards) ── */
.hero-composition{
  position:relative; overflow:hidden; width:100%;
  border-radius:var(--r-lg); box-shadow:var(--sh-lg);
  background:#070e1c; aspect-ratio:4/3;
}
.hc-bg-grid{
  position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px, transparent 1px);
  background-size:28px 28px;
}
.hc-glow-l{
  position:absolute; width:400px; height:400px;
  left:-80px; top:50%; transform:translateY(-50%);
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(0,220,130,.09) 0%, transparent 65%);
}
.hc-glow-r{
  position:absolute; width:320px; height:320px;
  right:-60px; top:50%; transform:translateY(-50%);
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(48,105,152,.12) 0%, transparent 65%);
}
.hc-vignette{
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 40%, rgba(7,14,28,.65) 100%);
}
.hc-layout{
  position:relative; z-index:1; width:100%; height:100%;
  display:flex; align-items:center;
  padding:24px 28px; gap:20px;
}
/* photo — flex:0 0 44% so % resolves correctly as direct flex child */
.hc-photo-wrap{
  flex:0 0 44%; display:flex; align-items:center; justify-content:center;
  position:relative;
}
.hc-photo-halo{
  position:absolute; width:calc(100% + 28px); height:calc(100% + 28px);
  left:-14px; top:-14px; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(65,184,131,.22) 0%, transparent 65%);
}
/* ring width: explicit px, capped at 88% of photo-wrap so it never overflows */
.hc-ring{
  width:min(176px, 88%); aspect-ratio:1; border-radius:50%; padding:3px;
  background:conic-gradient(
    from 0deg, #FFD43B 0%, #306998 20%, #41B883 45%, #00DC82 65%, #44B78B 80%, #FFD43B 100%
  );
  box-shadow:0 0 0 1px rgba(255,255,255,.06), 0 0 40px rgba(65,184,131,.28), 0 0 80px rgba(65,184,131,.10);
}
.hc-ring-inner{ width:100%; height:100%; border-radius:50%; padding:4px; background:#070e1c; }
.hc-photo{ width:100%; height:100%; border-radius:50%; object-fit:cover; object-position:50% 12%; display:block; }
/* cards — flex:1 takes remaining space after photo-wrap and gap */
.hc-cards{
  flex:1; min-width:0;
  display:grid; grid-template-columns:1fr 1fr; gap:10px; align-content:center;
}
.hc-card{
  background:rgba(255,255,255,.038); border:1px solid rgba(255,255,255,.09);
  border-radius:14px; padding:20px 14px;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  position:relative; overflow:hidden; transition:transform .2s, border-color .2s;
}
.hc-card:hover{ transform:translateY(-3px); border-color:rgba(255,255,255,.18); }
.hc-card::before{ content:''; position:absolute; top:0; left:0; right:0; height:2px; }
.hc-card-python::before{ background:linear-gradient(90deg,#306998,#FFD43B); }
.hc-card-django::before{ background:linear-gradient(90deg,#44B78B,#092E20); }
.hc-card-vue::before   { background:linear-gradient(90deg,#41B883,#34495E); }
.hc-card-nuxt::before  { background:linear-gradient(90deg,#00DC82,#003C3C); }
.hc-card img{ width:42px; height:42px; object-fit:contain; display:block; flex-shrink:0; }
.hc-card-django img{ filter:brightness(1.6) saturate(1.2); }
.hc-card span{
  font-family:var(--mono); font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; font-size:11px; color:rgba(255,255,255,.78);
  white-space:nowrap;
}
@media(max-width:575.98px){
  .hero-composition{ aspect-ratio:5/3; }
  .hc-layout{ padding:16px 18px; gap:14px; }
  .hc-photo-wrap{ flex:0 0 36%; }
  .hc-ring{ width:min(120px,88%); }
  .hc-cards{ gap:8px; }
  .hc-card{ padding:14px 8px; gap:7px; border-radius:10px; }
  .hc-card img{ width:32px; height:32px; }
  .hc-card span{ font-size:9px; letter-spacing:.06em; }
}

/* float-card title (was h4) */
.float-card .fc-title{ font-size:16px; margin:4px 0 6px; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-weight:700; color:var(--ink); }
.float-card{ position:absolute; left:-30px; bottom:-30px; width:74%; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-lg); padding:16px; display:flex; gap:14px; align-items:center; }
.float-card .fc-thumb{ width:74px; height:74px; flex:0 0 74px; border-radius:var(--r-md); }
.float-card h4{ font-size:16px; margin:4px 0 6px; letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
@media (max-width:991.98px){
  .hero{ padding:30px 0 70px; }
  .hero-visual{ max-width:460px; margin-inline:auto; }
}
@media (max-width:575.98px){
  .float-card{ position:relative; left:0; bottom:0; width:auto; margin:-26px 14px 0; }
}

/* ---------- about ---------- */
.fact{ display:flex; gap:16px; align-items:flex-start; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:18px 20px; box-shadow:var(--sh-sm); height:100%; }
.fact .ic{ flex:0 0 40px; width:40px; height:40px; border-radius:11px; background:var(--accent-soft); color:var(--accent-700); display:grid; place-items:center; font-family:var(--mono); font-weight:800; font-size:15px; }
.fact .fact-name{ font-size:16px; margin:2px 0 4px; font-weight:700; color:var(--ink); }
.fact p{ margin:0; font-size:14.5px; }
.logos{ display:flex; flex-wrap:wrap; gap:16px; }
.logos .ph{ width:148px; height:60px; border-radius:var(--r-md); }

/* ---------- prose ---------- */
.prose{ font-size:18px; line-height:1.75; color:var(--ink-2); }
.prose > * + *{ margin-top:22px; }
.prose h2{ font-family:var(--mono); font-size:26px; margin-top:44px; letter-spacing:-.02em; }
.prose h3{ font-family:var(--mono); font-size:20px; margin-top:32px; }
.prose p{ margin:0; }
.prose a{ color:var(--accent); font-weight:600; text-decoration:underline; text-underline-offset:3px; }
.prose ul{ margin:0; padding-left:22px; }
.prose li + li{ margin-top:8px; }
.prose blockquote{ margin:0; padding:6px 0 6px 22px; border-left:3px solid var(--accent); color:var(--ink); font-size:20px; }
.prose .ph{ aspect-ratio:16/9; }
.codeblock{ background:#1b1e27; border-radius:var(--r-md); padding:18px 20px; overflow:auto; box-shadow:var(--sh-md); }
.codeblock pre{ margin:0; font-family:var(--mono); font-size:14px; line-height:1.7; color:#d6dcea; }
.codeblock .c-key{ color:#9aa6ff; } .codeblock .c-str{ color:#9bd5a6; } .codeblock .c-com{ color:#6b7384; }

/* ---------- breadcrumb ---------- */
.crumbs{ display:flex; align-items:center; gap:9px; font-family:var(--mono); font-size:12.5px; color:var(--ink-3); }
.crumbs a:hover{ color:var(--ink-2); }
.crumbs .sep{ opacity:.5; }
.crumbs .cur{ color:var(--ink); }

/* ---------- forms (theme Bootstrap) ---------- */
.form-label{ font-family:var(--mono); font-size:12px; letter-spacing:.05em; color:var(--ink); font-weight:600; }
.form-control,.form-select{ font-family:var(--sans); font-size:16px; color:var(--ink); background:var(--surface-2); border:1px solid var(--border-strong); border-radius:var(--r-md); padding:13px 16px; }
.form-control:focus,.form-select:focus{ border-color:var(--accent); background:var(--surface); box-shadow:0 0 0 4px var(--accent-soft); }
textarea.form-control{ min-height:140px; }
.form-check-input:checked{ background-color:var(--accent); border-color:var(--accent); }
.form-check-input:focus{ border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.form-text{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.contact-link{ display:flex; align-items:center; gap:14px; padding:14px 0; border-top:1px solid var(--border); }
.contact-link .ic{ width:40px; height:40px; border-radius:11px; background:var(--surface); border:1px solid var(--border); display:grid; place-items:center; font-family:var(--mono); font-weight:700; font-size:13px; color:var(--ink); }
.contact-link .ct-label{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.contact-link .ct-val{ color:var(--ink); font-weight:600; }

/* ---------- pagination (custom, sits beside Bootstrap .pagination) ---------- */
.pager{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:48px; flex-wrap:wrap; }
.pager a,.pager span{ font-family:var(--mono); font-size:14px; min-width:42px; height:42px; padding:0 12px; border-radius:var(--r-pill); border:1px solid var(--border-strong); background:var(--surface); display:inline-flex; align-items:center; justify-content:center; color:var(--ink-2); }
.pager .cur{ background:var(--accent); color:#fff; border-color:var(--accent); }
.pager a:hover{ border-color:var(--ink-3); color:var(--ink); }
.pager-disabled{ opacity:.45; pointer-events:none; }
.prevnext{ display:flex; justify-content:space-between; gap:18px; margin-top:8px; flex-wrap:wrap; }

/* ---------- CTA band ---------- */
.cta-band{ background:var(--ink); border-radius:var(--r-xl); padding:60px; text-align:center; color:#fff; box-shadow:var(--sh-lg); }
.cta-band h2{ color:#fff; font-family:var(--mono); font-size:clamp(28px,3.4vw,40px); letter-spacing:-.02em; margin:0 0 14px; }
.cta-band p{ color:#aab0c0; max-width:48ch; margin:0 auto 28px; }
.cta-band .btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.3); }
.cta-band .btn-ghost:hover{ background:rgba(255,255,255,.08); border-color:#fff; }
@media (max-width:575.98px){ .cta-band{ padding:40px 24px; } }

/* ---------- footer ---------- */
.site-footer{ background:var(--surface); border-top:1px solid var(--border); }
.site-footer .foottop{ padding:64px 0 36px; }
.site-footer .brand{ margin-bottom:14px; }
.site-footer p{ font-size:15px; max-width:34ch; margin:0 0 18px; }
.social{ display:flex; gap:10px; }
.social a{ width:40px; height:40px; border-radius:11px; border:1px solid var(--border); display:grid; place-items:center; font-size:18px; color:var(--ink-2); transition:background .15s,color .15s,border-color .15s; }
.social a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }
.footer-col-label{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin:0 0 16px; }
.footer-col a{ display:block; padding:6px 0; color:var(--ink-2); font-size:15px; }
.footer-col a:hover{ color:var(--accent); }
.footer-base{ border-top:1px solid var(--border); padding:20px 0; font-family:var(--mono); font-size:12px; color:var(--ink-3); display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; }

/* ==========================================================================
   page header (banner block) + back-office (customers) extensions
   ========================================================================== */
.page-head{ padding:64px 0 8px; }
.page-head .lead{ margin-top:14px; max-width:60ch; }
.border-theme{ border-color:var(--border)!important; }
.img-hero-wrap{ width:100%; max-height:420px; overflow:hidden; line-height:0; }
.img-hero-wrap img{ width:100%; height:100%; object-fit:cover; display:block; max-height:420px; }

/* tables — themed Bootstrap .table for the admin back-office */
.table{ --bs-table-bg:transparent; --bs-table-color:var(--ink-2); margin:0; vertical-align:middle; }
.table thead th{ font-family:var(--mono); font-size:11.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); border-bottom:1px solid var(--border); padding:12px 14px; }
.table tbody td{ padding:14px; border-bottom:1px solid var(--border); color:var(--ink-2); }
.table tbody tr:last-child td{ border-bottom:0; }
.table-hover tbody tr:hover{ background:var(--surface-2); }
.table a{ color:var(--accent); font-weight:600; }
.table a:hover{ color:var(--accent-700); }

/* status pills for the back-office */
.pill{ display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11.5px; font-weight:600; letter-spacing:.04em; padding:5px 11px; border-radius:var(--r-pill); border:1px solid transparent; }
.pill svg{ width:13px; height:13px; }
.pill-ok{ background:#e6f6ec; color:#1c7a43; }
.pill-warn{ background:#fdf0dd; color:#9a6312; }
.danger-note{ font-family:var(--mono); font-size:12.5px; color:#d6453b; }

/* simple data list used on detail pages */
.kv{ display:grid; grid-template-columns:1fr 1fr; gap:18px 24px; }
.kv .kv-k{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); display:block; margin-bottom:4px; }
.kv .kv-v{ color:var(--ink); font-weight:600; font-size:17px; }
.kv .kv-full{ grid-column:1 / -1; }
.kv-1col{ grid-template-columns:1fr; }
.kv-plain{ font-weight:400; }
.kv-muted{ font-weight:400; color:var(--ink-3); }
@media (max-width:575.98px){ .kv{ grid-template-columns:1fr; } }

/* empty state */
.empty-state{ text-align:center; padding:48px 16px; color:var(--ink-3); }
.empty-state .es-title{ font-family:var(--mono); font-weight:700; color:var(--ink-2); margin:10px 0 4px; }

/* cookie consent bar */
.cookie-theme-bar{ position:fixed; bottom:0; left:0; right:0; z-index:1080; background:rgba(255,255,255,.96); backdrop-filter:saturate(140%) blur(10px); border-top:1px solid var(--border); box-shadow:0 -6px 24px rgba(27,30,45,.08); padding:16px 0; }

/* htmx indicator (used on the admin search) */
.htmx-indicator{ opacity:0; transition:opacity .2s; }
.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{ opacity:1; }
