/* ============================================================================
   SavingSwitch â€” Warm Marketplace design system
   Committed terracotta brand Â· Young Serif display + Hanken Grotesk body
   Single source of truth for the public frontend. Replaces master/style/media.
   ========================================================================== */

/* ---- Fonts (self-hosted) ------------------------------------------------- */
@font-face {
  font-family: 'Young Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/young-serif-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
    U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193,
    U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Young Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/young-serif-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF,
    U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020,
    U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url('../fonts/hanken-grotesk-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
    U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193,
    U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url('../fonts/hanken-grotesk-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF,
    U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020,
    U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ---- Tokens -------------------------------------------------------------- */
:root {
  /* Warm neutrals â€” intentional brand-red tint, not generic beige */
  --paper:      oklch(0.985 0.006 45);
  --paper-2:    oklch(0.963 0.013 45);
  --paper-3:    oklch(0.940 0.018 44);
  --ink:        oklch(0.245 0.018 47);
  --ink-2:      oklch(0.420 0.022 46);
  --ink-3:      oklch(0.545 0.020 45);
  --line:       oklch(0.890 0.012 45);
  --line-2:     oklch(0.825 0.016 44);

  /* Committed brand: terracotta / clay â†’ oxblood */
  --clay:       oklch(0.535 0.152 37);
  --clay-deep:  oklch(0.460 0.140 36);
  --clay-700:   oklch(0.405 0.120 34);
  --oxblood:    oklch(0.310 0.095 32);
  --oxblood-2:  oklch(0.265 0.080 33);
  --clay-soft:  oklch(0.930 0.038 44);
  --clay-softer:oklch(0.960 0.022 44);
  --on-clay:    oklch(0.985 0.014 75);

  /* Semantic (used sparingly, real state only) */
  --leaf:       oklch(0.520 0.095 150);
  --leaf-deep:  oklch(0.430 0.085 150);
  --leaf-soft:  oklch(0.935 0.040 150);
  --gold:       oklch(0.760 0.135 75);

  /* Surface var consumed by the coupon-ticket notch (set per section) */
  --surface:    var(--paper);

  /* Type */
  --font-display: 'Young Serif', 'Hanken Grotesk', Georgia, 'Times New Roman', serif;
  --font-body: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;

  --fs-900: clamp(2.1rem, 1.5rem + 2.4vw, 3.1rem);
  --fs-800: clamp(1.55rem, 1.28rem + 1.3vw, 2.2rem);   /* page-hero titles ~35px */
  --fs-700: clamp(1.3rem, 1.13rem + 0.75vw, 1.7rem);   /* section titles ~27px */
  --fs-600: clamp(1.1rem, 1.03rem + 0.32vw, 1.25rem);  /* card titles ~20px */
  --fs-500: 1.125rem;   /* 18px lead/subhead */
  --fs-400: 1rem;       /* 16px body */
  --fs-300: 0.9375rem;  /* 15px secondary */
  --fs-200: 0.8125rem;  /* 13px meta */

  /* Spacing */
  --sp-1: 0.25rem; --sp-2: 0.5rem;  --sp-3: 0.75rem; --sp-4: 1rem;
  --sp-5: 1.5rem;  --sp-6: 2rem;    --sp-7: 3rem;    --sp-8: 4rem;
  --sp-9: 6rem;    --sp-10: 8rem;
  --section-y: clamp(3.25rem, 2.4rem + 3.5vw, 5.5rem);
  --gutter: clamp(1.15rem, 0.4rem + 2.8vw, 2.75rem);
  --container: 1240px;
  --container-narrow: 760px;

  /* Radius â€” buttons/chips = pill Â· cards/media/tickets = lg Â· inputs = md */
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px; --r-pill: 999px;

  /* Shadows â€” tinted warm, layered and soft (never pure black) */
  --shadow-1: 0 1px 2px rgba(64,32,20,0.04), 0 4px 14px rgba(64,32,20,0.05);
  --shadow-2: 0 2px 6px rgba(70,32,18,0.04), 0 10px 24px rgba(70,32,18,0.06), 0 26px 56px rgba(70,32,18,0.07);
  --shadow-pop: 0 10px 30px rgba(58,24,12,0.10), 0 30px 70px rgba(58,24,12,0.16);

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --t-1: 0.16s; --t-2: 0.28s; --t-3: 0.5s;

  /* z-index scale */
  --z-base: 1; --z-dropdown: 100; --z-totop: 240; --z-sticky: 200;
  --z-header: 300; --z-drawer: 400; --z-backdrop: 500; --z-modal: 600;
}

/* ---- Reset / base -------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  font-size: var(--fs-400);
  line-height: 1.6;
  font-weight: 400;
  color: var(--ink);
  background: var(--paper);
  font-kerning: normal;
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body.no-scroll { overflow: hidden; }

img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
input, textarea, select { font: inherit; color: inherit; }
ul, ol { list-style: none; padding: 0; }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.012em;
  text-wrap: balance;
  color: var(--ink);
}
p { text-wrap: pretty; }

:focus-visible {
  outline: 3px solid var(--clay);
  outline-offset: 2px;
  border-radius: 4px;
}
::selection { background: var(--clay); color: var(--on-clay); }

/* ---- Layout primitives --------------------------------------------------- */
.ss-container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.ss-narrow { max-width: var(--container-narrow); }
.ss-section { padding-block: var(--section-y); }
.ss-section--tight { padding-block: clamp(2.5rem, 1.6rem + 3vw, 4rem); }
.ss-section--stores-alpha { padding-block: 2.5rem; }
.bg-paper-2 { background: var(--paper-2); --surface: var(--paper-2); }
.bg-clay-soft { background: var(--clay-softer); --surface: var(--clay-softer); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Section header: headline-led, NO eyebrow-per-section scaffolding */
.ss-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-5);
  margin-bottom: clamp(1.5rem, 1.1rem + 1.4vw, 2.25rem);
  flex-wrap: wrap;
}
.ss-head__title { font-size: var(--fs-700); letter-spacing: -0.015em; }
.ss-head__sub { color: var(--ink-2); margin-top: 0.5rem; max-width: 60ch; font-size: var(--fs-300); }
.ss-kicker {
  display: inline-block;
  font-size: var(--fs-200);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--clay-deep);
  margin-bottom: 0.85rem;
}
.ss-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 600;
  font-size: var(--fs-300);
  color: var(--clay-deep);
  white-space: nowrap;
  transition: gap var(--t-2) var(--ease), color var(--t-1) ease;
}
.ss-link:hover { gap: 0.7rem; color: var(--clay-700); }
.ss-link .ti { font-size: 1.1em; }

/* ---- Buttons ------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.8rem 1.4rem;
  border-radius: var(--r-pill);
  font-weight: 700;
  font-size: var(--fs-300);
  line-height: 1;
  letter-spacing: 0.005em;
  white-space: nowrap;
  transition: transform var(--t-1) var(--ease), background var(--t-2) ease,
    box-shadow var(--t-2) ease, color var(--t-2) ease, border-color var(--t-2) ease;
  will-change: transform;
}
.btn:active { transform: translateY(1px) scale(0.99); }
.btn--primary { background: var(--clay); color: var(--on-clay); box-shadow: var(--shadow-1); }
.btn--primary:hover { background: var(--clay-deep); box-shadow: var(--shadow-2); transform: translateY(-2px); }
.btn--dark { background: var(--ink); color: var(--paper); }
.btn--dark:hover { background: var(--oxblood); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--line-2); }
.btn--ghost:hover { border-color: var(--clay); color: var(--clay-deep); background: var(--clay-softer); }
.btn--on-clay { background: var(--on-clay); color: var(--clay-deep); }
.btn--on-clay:hover { background: var(--paper); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.btn--lg { padding: 1rem 1.7rem; font-size: var(--fs-400); }
.btn--block { width: 100%; }
.btn--sm { padding: 0.55rem 1rem; font-size: var(--fs-200); }

/* ---- Chips / pills / badges --------------------------------------------- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.85rem;
  border-radius: var(--r-pill);
  background: var(--paper);
  border: 1px solid var(--line);
  font-size: var(--fs-200);
  font-weight: 600;
  color: var(--ink-2);
  transition: border-color var(--t-1) ease, color var(--t-1) ease, background var(--t-1) ease, transform var(--t-1) var(--ease);
}
a.chip:hover { border-color: var(--clay); color: var(--clay-deep); transform: translateY(-1px); }
.chip--active { background: var(--clay); border-color: var(--clay); color: var(--on-clay); }
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.6rem;
  border-radius: var(--r-pill);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.badge--verified { background: var(--leaf-soft); color: var(--leaf-deep); }
.badge--code { background: var(--clay); color: var(--on-clay); }
.badge--deal { background: var(--ink); color: var(--paper); }
.badge--expired { background: var(--paper-3); color: var(--ink-3); }

/* ---- Forms --------------------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 0.45rem; }
.field > label { font-weight: 600; font-size: var(--fs-300); color: var(--ink); }
.input, .textarea, select.input {
  width: 100%;
  padding: 0.85rem 1rem;
  background: var(--paper);
  border: 1.5px solid var(--line-2);
  border-radius: var(--r-md);
  font-size: var(--fs-400);
  color: var(--ink);
  transition: border-color var(--t-1) ease, box-shadow var(--t-1) ease;
}
.input::placeholder, .textarea::placeholder { color: var(--ink-3); }
.input:focus, .textarea:focus, select.input:focus {
  outline: none;
  border-color: var(--clay);
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--clay) 18%, transparent);
}
.textarea { min-height: 150px; resize: vertical; }
.field__hint { font-size: var(--fs-200); color: var(--ink-2); }
.field__error { font-size: var(--fs-200); color: var(--clay-deep); font-weight: 600; }

.alert { padding: 0.85rem 1.1rem; border-radius: var(--r-md); font-size: var(--fs-300); font-weight: 600; }
.alert--ok { background: var(--leaf-soft); color: var(--leaf-deep); }
.alert--err { background: color-mix(in oklch, var(--clay) 14%, var(--paper)); color: var(--clay-700); }

/* ============================================================================
   HEADER
   ========================================================================== */
/* Full-width white header */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: #fff;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04);
}
.hdr {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: clamp(64px, 64px + 1vw, 76px);
}
.site-header .hdr__logo img { filter: none; }
.hdr__logo { display: inline-flex; align-items: center; flex-shrink: 0; justify-self: start; }
.hdr__logo img {height: 50px;width: auto;}
.hdr__logo-text { font-family: var(--font-display); font-size: 1.5rem; color: var(--clay-deep); }

.hdr__nav { justify-self: center; margin-inline-start: 0; }
.hdr__nav-list { display: flex; align-items: center; gap: 0.35rem; }
.hdr__nav-item { position: relative; }
.hdr__nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.55rem 0.85rem;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: var(--fs-300);
  color: var(--ink-2);
  transition: color var(--t-1) ease, background var(--t-1) ease;
}
.hdr__nav-link:hover { color: #D23A1C; background: color-mix(in oklch, #FF4D2E 9%, transparent); }
.hdr__nav-link.is-active { color: #D23A1C; background: color-mix(in oklch, #FF4D2E 11%, transparent); }
.hdr__chev { font-size: 0.9em; transition: transform var(--t-2) var(--ease); }
.hdr__nav-item:hover .hdr__chev { transform: rotate(180deg); }

.hdr__drop {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  min-width: 220px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-2);
  padding: 0.5rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--t-2) var(--ease), transform var(--t-2) var(--ease), visibility var(--t-2);
  z-index: var(--z-dropdown);
}
.hdr__nav-item:hover .hdr__drop { opacity: 1; visibility: visible; transform: translateY(0); }
.hdr__drop a { display: block; padding: 0.6rem 0.8rem; border-radius: var(--r-sm); font-size: var(--fs-300); font-weight: 500; color: var(--ink-2); transition: background var(--t-1) ease, color var(--t-1) ease; }
.hdr__drop a:hover { background: var(--clay-softer); color: var(--clay-deep); }

.hdr__actions { display: flex; align-items: center; gap: 0.6rem; justify-self: end; margin-inline-start: 0; }
.hdr__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px; height: 42px;
  border-radius: var(--r-pill);
  color: var(--ink);
  border: 1px solid var(--line);
  transition: background var(--t-1) ease, border-color var(--t-1) ease, color var(--t-1) ease;
}
.hdr__icon-btn:hover { background: var(--paper-2); border-color: var(--line-2); }
.hdr__icon-btn .ti { font-size: 1.3rem; }

/* Search */
.search { position: relative; }
.search__panel {
  position: absolute;
  top: calc(100% + 0.75rem);
  right: 0;
  width: min(440px, 92vw);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-pop);
  padding: 0.75rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px) scale(0.98);
  transform-origin: top right;
  transition: opacity var(--t-2) var(--ease), transform var(--t-2) var(--ease), visibility var(--t-2);
  z-index: var(--z-dropdown);
}
.search__panel.is-open { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.search__form { display: flex; align-items: center; gap: 0.5rem; padding: 0.2rem 0.6rem; border: 1.5px solid var(--line-2); border-radius: var(--r-md); }
.search__form:focus-within { border-color: var(--clay); }
.search__form .ti { color: var(--ink-2); font-size: 1.2rem; }
.search__input { flex: 1; border: none; outline: none; background: none; padding: 0.7rem 0; font-size: var(--fs-300); }
.search__close { color: var(--ink-2); padding: 0.3rem; }
.search__results { margin-top: 0.6rem; display: none; max-height: 60vh; overflow-y: auto; }
.search__results.active { display: block; }
.search-result { display: flex; gap: 0.75rem; padding: 0.6rem; border-radius: var(--r-md); transition: background var(--t-1) ease; }
.search-result:hover { background: var(--paper-2); }
.search-result__img { width: 56px; height: 56px; border-radius: var(--r-sm); object-fit: cover; flex-shrink: 0; }
.search-result__date { font-size: var(--fs-200); color: var(--ink-3); }
.search-result__title { font-weight: 600; font-size: var(--fs-300); color: var(--ink); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.search-empty { padding: 1rem 0.6rem; color: var(--ink-2); font-size: var(--fs-300); }

/* Burger */
.hdr__burger { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; }
.hdr__burger span { width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform var(--t-2) var(--ease), opacity var(--t-1) ease; }
.hdr__burger.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hdr__burger.is-active span:nth-child(2) { opacity: 0; }
.hdr__burger.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.mobile-nav {
  position: fixed;
  inset: 72px 0 auto 0;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  box-shadow: var(--shadow-2);
  transform: translateY(calc(-100% - 80px));
  transition: transform var(--t-3) var(--ease);
  z-index: var(--z-drawer);
  max-height: calc(100dvh - 72px);
  overflow-y: auto;
  padding: var(--sp-4) var(--gutter) var(--sp-6);
}
.mobile-nav.is-open { transform: translateY(0); }
.mobile-nav a { display: block; padding: 0.95rem 0.5rem; font-family: var(--font-display); font-size: 1.35rem; border-bottom: 1px solid var(--line); color: var(--ink); }
.mobile-nav a:hover { color: var(--clay-deep); }
.mobile-nav .btn { margin-top: var(--sp-4); }

/* ============================================================================
   FOOTER â€” committed oxblood brand surface
   ========================================================================== */
.site-footer {
  /* Re-theme footer to near-black + coral (matches the new home system).
     Scoped var overrides cascade into every existing footer rule below. */
  --oxblood: #17161B;
  --oxblood-2: #0F0E12;
  --clay: #FF4D2E;
  --clay-deep: #E23A1E;
  --on-clay: #FFFFFF;
  background: #17161B;
  color: rgba(255, 255, 255, 0.74);
}

.footer-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: var(--sp-6);
  padding-block: clamp(3rem, 2rem + 4vw, 5rem);
}
.footer-brand__logo img {height: 50px;width: auto;margin-bottom: var(--sp-4);}
.footer-brand__logo .hdr__logo-text { color: var(--on-clay); }
.footer-desc { color: color-mix(in oklch, var(--on-clay) 72%, var(--oxblood)); font-size: var(--fs-300); max-width: 38ch; }
.footer-social { display: flex; gap: 0.6rem; margin-top: var(--sp-5); }
.footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--r-pill);
  background: color-mix(in oklch, var(--on-clay) 12%, transparent);
  transition: background var(--t-2) ease, transform var(--t-1) var(--ease);
}
.footer-social a:hover { background: var(--clay); transform: translateY(-2px); }
.footer-social svg { width: 19px; height: 19px; fill: none; stroke: var(--on-clay); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.footer-social a .ti { font-size: 1.2rem; color: var(--on-clay); }

.footer-col__title { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-200); letter-spacing: 0.12em; text-transform: uppercase; color: color-mix(in oklch, var(--on-clay) 64%, var(--oxblood)); margin-bottom: var(--sp-4); }
.footer-links li { margin-bottom: 0.7rem; }
.footer-links a { display: inline-block; color: color-mix(in oklch, var(--on-clay) 86%, var(--oxblood)); font-size: var(--fs-300); transition: color var(--t-1) ease, transform var(--t-2) var(--ease); }
.footer-links a:hover { color: var(--on-clay); transform: translateX(4px); }

.footer-news__desc { color: color-mix(in oklch, var(--on-clay) 72%, var(--oxblood)); font-size: var(--fs-300); margin-bottom: var(--sp-4); }
.news-form__group { display: flex; gap: 0.5rem; background: color-mix(in oklch, var(--on-clay) 10%, transparent); border: 1px solid color-mix(in oklch, var(--on-clay) 22%, transparent); border-radius: var(--r-pill); padding: 0.35rem 0.35rem 0.35rem 1.1rem; }
.news-form__group:focus-within { border-color: var(--clay); }
.news-form__group input { flex: 1; background: none; border: none; outline: none; color: var(--on-clay); font-size: var(--fs-300); }
.news-form__group input::placeholder { color: color-mix(in oklch, var(--on-clay) 55%, var(--oxblood)); }
.news-form__group button { display: inline-flex; align-items: center; gap: 0.4rem; background: var(--clay); color: var(--on-clay); padding: 0.65rem 1.1rem; border-radius: var(--r-pill); font-weight: 700; font-size: var(--fs-200); transition: background var(--t-2) ease; }
.news-form__group button:hover { background: var(--clay-deep); }
.news-form__group button.loading { opacity: 0.7; pointer-events: none; }
.news-response { margin-top: 0.6rem; font-size: var(--fs-200); min-height: 1.1em; }
.news-response.success { color: var(--leaf-soft); }
.news-response.error { color: color-mix(in oklch, var(--gold) 80%, white); }

.footer-bottom {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  flex-wrap: wrap;
  padding-block: var(--sp-5);
  border-top: 1px solid color-mix(in oklch, var(--on-clay) 14%, transparent);
  font-size: var(--fs-200);
  color: color-mix(in oklch, var(--on-clay) 62%, var(--oxblood));
}
.footer-bottom a { color: color-mix(in oklch, var(--on-clay) 86%, var(--oxblood)); }

/* Back to top */
.to-top {
  position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem);
  width: 48px; height: 48px; border-radius: var(--r-pill);
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--clay); color: var(--on-clay); box-shadow: var(--shadow-2);
  opacity: 0; visibility: hidden; transform: translateY(12px);
  transition: opacity var(--t-2) ease, transform var(--t-2) var(--ease), visibility var(--t-2), background var(--t-2) ease;
  z-index: var(--z-totop);
}
.to-top.is-vis { opacity: 1; visibility: visible; transform: translateY(0); }
.to-top:hover { background: var(--clay-deep); transform: translateY(-3px); }
.to-top .ti { font-size: 1.4rem; }

/* ============================================================================
   COUPON TICKET â€” signature motif (real affordance, not decoration)
   ========================================================================== */
.ticket {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
  overflow: hidden;
  transition: box-shadow 0.38s cubic-bezier(0.32,0.72,0,1), transform 0.38s cubic-bezier(0.32,0.72,0,1), border-color 0.38s cubic-bezier(0.32,0.72,0,1);
}
.ticket:hover { box-shadow: 0 16px 42px -10px rgba(6,2,2,0.15); transform: translateY(-4px); border-color: rgba(139,62,47,0.28); }
.ticket__type {
  position: absolute; top: 1rem; left: 0;
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.3rem 0.7rem 0.3rem 0.85rem;
  font-size: 0.72rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
  border-radius: 0 var(--r-pill) var(--r-pill) 0;
}
.ticket__type.is-code { background: var(--clay); color: var(--on-clay); }
.ticket__type.is-deal { background: var(--ink); color: var(--paper); }
.ticket__body { padding: 2.6rem 1.5rem 1.4rem; min-width: 0; }
.ticket__meta { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 0.65rem; }
.ticket__store { font-size: var(--fs-200); font-weight: 700; color: var(--clay-deep); text-transform: uppercase; letter-spacing: 0.04em; }
.ticket__title { font-family: var(--font-body); font-weight: 700; font-size: var(--fs-500); line-height: 1.25; letter-spacing: -0.01em; margin-bottom: 0.4rem; }
.ticket__title a:hover { color: var(--clay-deep); }
.ticket__desc { color: var(--ink-2); font-size: var(--fs-300); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ticket__stats { display: flex; gap: 1rem; margin-top: 0.9rem; font-size: var(--fs-200); color: var(--ink-3); flex-wrap: wrap; }
.ticket__stats span { display: inline-flex; align-items: center; gap: 0.3rem; }
.ticket__stats .ti { font-size: 1em; }

/* Perforated action stub */
.ticket__stub {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0.5rem;
  padding: 1.4rem 1.5rem;
  min-width: 168px;
  border-left: 2px dashed var(--line-2);
}
.ticket__stub::before, .ticket__stub::after {
  content: ""; position: absolute; left: -10px; width: 20px; height: 20px;
  border-radius: var(--r-pill); background: var(--surface);
  border: 1px solid var(--line);
}
.ticket__stub::before { top: -11px; }
.ticket__stub::after { bottom: -11px; }
.ticket__discount { font-family: var(--font-body); font-weight: 800; font-size: 1.6rem; line-height: 1; color: var(--clay-deep); font-variant-numeric: tabular-nums; text-align: center; }
.ticket__discount small { display: block; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); margin-top: 0.2rem; }
.ticket__cta {
  display: inline-flex; align-items: center; gap: 0.45rem;
  padding: 0.75rem 1.15rem; border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-300); position: relative; overflow: hidden;
  background: var(--clay); color: var(--on-clay);
  transition: background 0.28s cubic-bezier(0.32,0.72,0,1), transform 0.28s cubic-bezier(0.32,0.72,0,1), box-shadow 0.28s cubic-bezier(0.32,0.72,0,1);
}
.ticket__cta:hover { background: var(--clay-deep); transform: translateY(-2px); box-shadow: 0 8px 20px -6px rgba(139,62,47,0.42); }
.ticket__cta.is-deal { background: var(--ink); }
.ticket__cta.is-deal:hover { background: var(--oxblood); }
.ticket--expired { opacity: 0.62; filter: saturate(0.7); }
.ticket--expired .ticket__cta { background: var(--ink-3); }

/* ============================================================================
   COUPON MODAL
   ========================================================================== */
.cmodal {
  position: fixed; inset: 0; z-index: var(--z-modal);
  display: none; align-items: center; justify-content: center;
  padding: var(--gutter);
  background: color-mix(in oklch, var(--oxblood-2) 60%, transparent);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  opacity: 0; transition: opacity var(--t-2) ease;
}
.cmodal.show { opacity: 1; }
.cmodal__card {
  position: relative; width: min(460px, 100%);
  background: var(--paper); border-radius: var(--r-xl);
  box-shadow: var(--shadow-pop); padding: 2.2rem 1.8rem 1.8rem;
  text-align: center; transform: scale(0.94) translateY(10px);
  transition: transform var(--t-3) var(--ease);
}
.cmodal.show .cmodal__card { transform: scale(1) translateY(0); }
.cmodal__close { position: absolute; top: 0.9rem; right: 0.9rem; width: 38px; height: 38px; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; color: var(--ink-2); transition: background var(--t-1) ease; }
.cmodal__close:hover { background: var(--paper-2); }
.cmodal__logo { width: 84px; height: 84px; margin: 0 auto 1rem; border-radius: var(--r-lg); border: 1px solid var(--line); object-fit: contain; background: #fff; padding: 0.5rem; }
.cmodal__kicker { display: inline-block; font-size: var(--fs-200); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--leaf-deep); margin-bottom: 0.4rem; }
.cmodal__title { font-size: var(--fs-600); margin-bottom: 0.5rem; }
.cmodal__status { color: var(--ink-2); font-size: var(--fs-300); margin-bottom: 1.4rem; }
.cmodal__instruction { font-size: var(--fs-200); color: var(--ink-3); margin-bottom: 0.6rem; }
.code-box {
  display: flex; align-items: stretch; gap: 0; margin-bottom: 1rem;
  border: 2px dashed var(--clay); border-radius: var(--r-md); overflow: hidden; background: var(--clay-softer);
}
.code-box.no-code { border-style: solid; border-color: var(--line-2); background: var(--paper-2); }
.code-text { flex: 1; display: flex; align-items: center; justify-content: center; padding: 0.95rem 1rem; font-weight: 800; font-size: 1.15rem; letter-spacing: 0.06em; color: var(--clay-700); }
.btn-copy { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0 1.2rem; background: var(--clay); color: var(--on-clay); font-weight: 700; font-size: var(--fs-300); transition: background var(--t-2) ease; }
.btn-copy:hover { background: var(--clay-deep); }
.btn-copy.copied { background: var(--leaf); }
.cmodal__visit { display: inline-flex; width: 100%; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.9rem; background: var(--ink); color: var(--paper); border-radius: var(--r-pill); font-weight: 700; transition: background var(--t-2) ease; }
.cmodal__visit:hover { background: var(--oxblood); }

/* ============================================================================
   SCROLL REVEAL
   ========================================================================== */
/* Reveal is load-safe: content is visible by default; only hidden once JS
   is confirmed present (html.js), so a failed/headless render never blanks. */
html.js .reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
html.js .reveal.is-in { opacity: 1; transform: none; }

/* ============================================================================
   HERO (home)
   ========================================================================== */
.hero { position: relative; background: var(--oxblood); color: var(--on-clay); overflow: hidden; }
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(120% 90% at 88% -10%, color-mix(in oklch, var(--clay) 55%, transparent), transparent 60%),
    radial-gradient(90% 80% at -10% 110%, color-mix(in oklch, var(--oxblood-2) 90%, transparent), transparent 55%);
}
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 1rem + 4vw, 4.5rem); align-items: center; padding-block: clamp(3.5rem, 2rem + 6vw, 6.5rem); }
.hero__eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.4rem 0.9rem; border-radius: var(--r-pill); background: color-mix(in oklch, var(--on-clay) 12%, transparent); font-size: var(--fs-200); font-weight: 700; letter-spacing: 0.04em; margin-bottom: 1.4rem; }
.hero__eyebrow .ti { color: var(--gold); }
.hero__title { font-size: var(--fs-900); color: var(--on-clay); line-height: 1.02; margin-bottom: 1.2rem; }
.hero__title em { font-style: normal; color: var(--gold); }
.hero__para { font-size: var(--fs-500); color: color-mix(in oklch, var(--on-clay) 80%, var(--oxblood)); max-width: 46ch; margin-bottom: 1.8rem; line-height: 1.5; }
.hero__search { display: flex; gap: 0.5rem; background: var(--paper); border-radius: var(--r-pill); padding: 0.4rem 0.4rem 0.4rem 1.2rem; box-shadow: var(--shadow-pop); max-width: 460px; }
.hero__search .ti { align-self: center; color: var(--ink-3); font-size: 1.3rem; }
.hero__search input { flex: 1; border: none; outline: none; background: none; color: var(--ink); font-size: var(--fs-300); min-width: 0; }
.hero__ctas { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-top: 1.4rem; }
.hero__trust { display: flex; gap: 1.5rem; margin-top: 2rem; flex-wrap: wrap; }
.hero__trust div { font-size: var(--fs-200); color: color-mix(in oklch, var(--on-clay) 72%, var(--oxblood)); }
.hero__trust strong { display: block; font-family: var(--font-display); font-size: 1.7rem; color: var(--on-clay); line-height: 1; margin-bottom: 0.2rem; }

.hero__visual { position: relative; }
.hero__slides { position: relative; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-pop); aspect-ratio: 4 / 3.4; background: var(--oxblood-2); }
.hero__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.9s var(--ease); }
.hero__slide.is-active { opacity: 1; }
.hero__slide img { width: 100%; height: 100%; object-fit: cover; }
.hero__slide-cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 2.5rem 1.5rem 1.3rem; background: linear-gradient(to top, color-mix(in oklch, var(--oxblood-2) 92%, transparent), transparent); }
.hero__slide-cap h3 { color: var(--on-clay); font-size: var(--fs-600); }
.hero__slide-cap a { display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 0.5rem; color: var(--gold); font-weight: 700; font-size: var(--fs-300); }
.hero__dots { position: absolute; bottom: 1rem; right: 1.2rem; display: flex; gap: 0.4rem; z-index: 2; }
.hero__dot { width: 9px; height: 9px; border-radius: var(--r-pill); background: color-mix(in oklch, var(--on-clay) 45%, transparent); cursor: pointer; transition: width var(--t-2) var(--ease), background var(--t-2) ease; border: none; }
.hero__dot.is-active { width: 26px; background: var(--gold); }

/* Floating deal badge on hero visual */
.hero__badge { position: absolute; top: 1.1rem; left: -0.8rem; background: var(--paper); color: var(--ink); border-radius: var(--r-lg); box-shadow: var(--shadow-pop); padding: 0.8rem 1.1rem; display: flex; align-items: center; gap: 0.7rem; }
.hero__badge .ti { font-size: 1.7rem; color: var(--clay); }
.hero__badge strong { display: block; font-family: var(--font-display); font-size: 1.05rem; line-height: 1; }
.hero__badge small { color: var(--ink-2); font-size: var(--fs-200); }

/* ============================================================================
   HOME â€” category mosaic, store strip, editorial
   ========================================================================== */
/* Live deals grid */
.deals-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: var(--sp-5); }

/* Store strip */
.store-strip { display: grid; grid-template-columns: repeat(auto-fill, minmax(148px, 1fr)); gap: var(--sp-3); }
.store-cell {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 1.25rem 0.9rem; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  text-decoration: none; text-align: center;
  transition: transform 0.38s cubic-bezier(0.32,0.72,0,1), box-shadow 0.38s cubic-bezier(0.32,0.72,0,1), border-color 0.38s cubic-bezier(0.32,0.72,0,1);
}
.store-cell:hover { transform: translateY(-5px) scale(1.015); box-shadow: 0 14px 36px -8px rgba(6,2,2,0.14); border-color: var(--clay); }
.store-cell__logo { width: 100%; height: 52px; display: flex; align-items: center; justify-content: center; }
.store-cell__logo img { max-height: 52px; max-width: 112px; width: auto; object-fit: contain; }
.store-cell__name { font-weight: 700; font-size: var(--fs-300); }
.store-cell__count { font-size: var(--fs-200); color: var(--clay); font-weight: 600; }

/* Category mosaic â€” columns masonry (varied heights, never an empty cell) */
.cat-mosaic { columns: 4; column-gap: var(--sp-4); }
.cat-tile { position: relative; display: flex; align-items: flex-end; break-inside: avoid; margin-bottom: var(--sp-4); height: 220px; border-radius: var(--r-lg); overflow: hidden; padding: 1.2rem; color: var(--on-clay); isolation: isolate; box-shadow: var(--shadow-1); transition: transform var(--t-2) var(--ease), box-shadow var(--t-2) ease; }
.cat-tile:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); }
.cat-tile::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(to top, color-mix(in oklch, var(--oxblood-2) 86%, transparent) 0%, color-mix(in oklch, var(--oxblood-2) 32%, transparent) 40%, transparent 66%); transition: opacity var(--t-3) ease; }
.cat-tile:hover::after { opacity: 0.82; }
.cat-tile img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-3) var(--ease); }
.cat-tile:hover img { transform: scale(1.06); }
.cat-tile__caption { display: block; position: relative; text-shadow: 0 1px 16px rgba(20,8,4,0.55); }
.cat-tile__name { display: block; font-family: var(--font-display); font-size: var(--fs-500); line-height: 1.1; }
.cat-tile__count { display: block; font-size: var(--fs-200); font-family: var(--font-body); color: color-mix(in oklch, var(--on-clay) 84%, transparent); margin-top: 0.2rem; }
.cat-tile--tall { height: 320px; }
.cat-tile--no-img { background: var(--clay); }
.cat-tile--no-img::after { background: none; }

/* Deal filter chips */
.deals-filters { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-bottom: var(--sp-5); }

/* Editorial / blog cards */
.editorial-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: clamp(2rem, 1rem + 3vw, 3.5rem); align-items: stretch; }
.post-card { display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; transition: transform var(--t-3) var(--ease), box-shadow var(--t-3) ease, border-color var(--t-3) ease; }
.post-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-2); border-color: transparent; }
.post-card__img { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.post-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.post-card:hover .post-card__img img { transform: scale(1.06); }
.post-card__body { padding: clamp(1.3rem, 1rem + 1vw, 1.6rem); display: flex; flex-direction: column; gap: 0.65rem; flex: 1; }
.post-card__date { font-size: 0.72rem; letter-spacing: 0.09em; text-transform: uppercase; color: var(--ink-3); font-weight: 700; display: inline-flex; align-items: center; gap: 0.4rem; }
.post-card__date .ti { font-size: 1rem; color: var(--clay); }
.post-card__title { font-family: var(--font-display); font-size: var(--fs-600); line-height: 1.18; letter-spacing: -0.005em; transition: color var(--t-2) ease; }
.post-card:hover .post-card__title a, .post-card__title a:hover { color: var(--clay-deep); }
.post-card__excerpt { color: var(--ink-2); font-size: var(--fs-300); line-height: 1.65; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.post-card__body .ss-link { margin-top: 0.2rem; }
.post-card--feature { box-shadow: var(--shadow-1); }
.post-card--feature .post-card__img { aspect-ratio: 16 / 9; max-height: 360px; }
.post-card--feature .post-card__title { font-size: var(--fs-700); }
.post-card--feature .post-card__body { padding: clamp(1.5rem, 1rem + 1.5vw, 2.1rem); gap: 0.8rem; }

.post-list { display: flex; flex-direction: column; }
.editorial-grid .post-list { justify-content: space-between; }
.post-mini { display: flex; gap: 1.1rem; align-items: center; padding: 1.15rem 0; border-bottom: 1px solid var(--line); }
.post-mini:first-child { padding-top: 0; }
.post-mini:last-child { border-bottom: none; padding-bottom: 0; }
.post-mini > a { flex: 0 0 auto; display: block; line-height: 0; overflow: hidden; border-radius: var(--r-md); }
.post-mini__img { width: 88px; height: 88px; min-width: 88px; border-radius: var(--r-md); object-fit: cover; display: block; transition: transform 0.6s var(--ease); }
.post-mini:hover .post-mini__img { transform: scale(1.07); }
.post-mini__title { font-family: var(--font-display); font-size: var(--fs-400); line-height: 1.22; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; transition: color var(--t-2) ease; }
.post-mini:hover .post-mini__title a, .post-mini__title a:hover { color: var(--clay-deep); }
.post-mini__date { font-size: 0.72rem; letter-spacing: 0.09em; text-transform: uppercase; color: var(--ink-3); font-weight: 700; margin-bottom: 0.25rem; display: block; }

/* Newsletter band */
.news-band { background: var(--clay-deep); color: var(--on-clay); border-radius: var(--r-xl); padding: clamp(2.2rem, 1.5rem + 3vw, 3.6rem); display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-6); align-items: center; box-shadow: var(--shadow-2); }
.news-band h2 { color: var(--on-clay); font-size: var(--fs-700); }
.news-band p { color: color-mix(in oklch, var(--on-clay) 90%, var(--clay-deep)); margin-top: 0.6rem; max-width: 44ch; }
.news-band .news-form__group { background: color-mix(in oklch, var(--on-clay) 14%, transparent); border-color: color-mix(in oklch, var(--on-clay) 30%, transparent); }
.news-band .news-form__group button { background: var(--ink); }
.news-band .news-form__group button:hover { background: var(--oxblood); }

/* Empty state */
.empty-state { text-align: center; padding: var(--sp-8) var(--gutter); color: var(--ink-2); }
.empty-state .ti { font-size: 3rem; color: var(--ink-3); margin-bottom: 0.5rem; }
.empty-state h3 { font-size: var(--fs-600); margin-bottom: 0.4rem; }

/* Disclaimer */
.disclaimer { display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; align-items: start; padding: clamp(1.5rem, 1rem + 2vw, 2.5rem); background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-lg); }
.disclaimer__icon { width: 52px; height: 52px; border-radius: var(--r-pill); background: var(--clay-softer); color: var(--clay-deep); display: inline-flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0; }
.disclaimer h2 { font-size: var(--fs-600); margin-bottom: 0.5rem; }
.disclaimer p { color: var(--ink-2); font-size: var(--fs-300); }

/* Hero stats bar */
.hero__stats-bar {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4);
  padding-top: var(--sp-5); margin-top: var(--sp-2);
  border-top: 1px solid color-mix(in oklch, var(--on-clay) 16%, transparent);
  padding-bottom: clamp(1.5rem, 1rem + 2vw, 2.5rem);
}
.hero__stats-bar strong { display: block; font-family: var(--font-display); font-size: clamp(1.6rem, 1.2rem + 1.4vw, 2.4rem); color: var(--on-clay); line-height: 1; }
.hero__stats-bar span { font-size: var(--fs-200); color: color-mix(in oklch, var(--on-clay) 70%, var(--oxblood)); }

@media (max-width: 640px) {
  .hero__stats-bar { gap: var(--sp-2); }
  .hero__badge { left: 0.5rem; padding: 0.6rem 0.8rem; }
}

/* ============================================================================
   INNER PAGE HERO + BREADCRUMB (shared: stores, categories, blog, contact)
   ========================================================================== */
.page-hero { background: var(--paper-2); border-bottom: 1px solid var(--line); padding-block: clamp(1.75rem, 1.2rem + 2.2vw, 2.75rem); min-height: 200px; display: flex; align-items: center; }
.page-hero > .ss-container { width: 100%; }
.page-hero--dark { background: var(--oxblood); color: var(--on-clay); border-bottom: none; }
.breadcrumb { display: none; }
.page-hero--dark .breadcrumb { color: color-mix(in oklch, var(--on-clay) 62%, var(--oxblood)); }
.breadcrumb a:hover { color: var(--clay-deep); }
.page-hero--dark .breadcrumb a:hover { color: var(--gold); }
.breadcrumb .ti { font-size: 1em; opacity: 0.6; }
.page-hero__title { font-size: var(--fs-800); }
.page-hero--dark .page-hero__title { color: var(--on-clay); }
.page-hero__sub { color: var(--ink-2); max-width: 62ch; margin-top: 0.7rem; font-size: var(--fs-400); }
.page-hero--dark .page-hero__sub { color: color-mix(in oklch, var(--on-clay) 80%, var(--oxblood)); }

/* ============================================================================
   STORES â€” A-Z directory
   ========================================================================== */
.az-nav { position: sticky; top: 72px; z-index: var(--z-sticky); background: color-mix(in oklch, var(--paper) 88%, transparent); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); padding-block: 0.6rem; }
.az-nav__list { display: flex; gap: 0.25rem; flex-wrap: wrap; }
.az-link { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 0.5rem; border-radius: var(--r-pill); font-weight: 700; font-size: var(--fs-300); color: var(--ink-2); border: 1px solid transparent; transition: background 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1), border-color 0.28s cubic-bezier(0.32,0.72,0,1); }
.az-link:hover { background: var(--clay-softer); color: var(--clay); border-color: rgba(139,62,47,0.2); }
.az-link.is-active { background: var(--clay); color: var(--on-clay); border-color: var(--clay); }

.store-group { padding-top: var(--sp-4); scroll-margin-top: 130px; }
.store-group__head { display: flex; align-items: center; gap: 0.85rem; margin-bottom: var(--sp-3); padding-bottom: 0.65rem; border-bottom: 1px solid var(--line); }
.store-group__letter { font-family: var(--font-display); font-size: clamp(0.72rem, 0.65rem + 0.3vw, 0.82rem); font-weight: 900; letter-spacing: 0.03em; color: var(--clay); background: var(--clay-softer); min-width: 2rem; height: 2rem; padding: 0 0.45rem; display: inline-flex; align-items: center; justify-content: center; border-radius: var(--r-md); flex-shrink: 0; }
.store-group__count { font-size: var(--fs-200); color: var(--ink-3); font-weight: 500; }
.store-group__more { margin-left: auto; font-size: var(--fs-200); font-weight: 600; display: inline-flex; align-items: center; gap: 0.3rem; color: var(--clay); transition: gap 0.28s cubic-bezier(0.32,0.72,0,1); }
.store-group__more:hover { gap: 0.55rem; }

/* ============================================================================
   STORE â€” single (premium .hx- system)
   ========================================================================== */
.hx-store-hero {
  background: var(--paper-2); border-bottom: 1px solid var(--line);
  padding-block: clamp(1.75rem, 1.2rem + 2.2vw, 2.75rem);
  min-height: 200px; display: flex; align-items: center;
}
.hx-store-hero > .ss-container { width: 100%; }
.hx-store-hero__inner { display: grid; grid-template-columns: auto 1fr; gap: clamp(1.4rem, 1rem + 2vw, 2.5rem); align-items: center; }

/* Double-bezel logo */
.hx-store-logo {
  width: 112px; height: 112px; border-radius: var(--r-xl);
  border: 1px solid var(--line); background: #fff;
  padding: 0.5rem; box-shadow: 0 2px 12px -4px rgba(6,2,2,0.1);
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
}
.hx-store-logo img { max-width: 78%; max-height: 78%; object-fit: contain; }

/* Rating */
.hx-store-rating { display: inline-flex; align-items: center; gap: 0.4rem; margin-bottom: 0.6rem; cursor: pointer; flex-wrap: wrap; }
.hx-store-rating .star { font-size: 1.2rem; transition: color 0.2s cubic-bezier(0.32,0.72,0,1); }
.hx-store-rating .star.ti-star-filled { color: var(--gold); }
.hx-store-rating .star.ti-star { color: var(--line-2); }
.hx-store-rating.locked { cursor: default; }
.hx-store-rating__text { font-size: var(--fs-300); color: var(--ink-3); font-weight: 500; }

/* Title */
.hx-store-hero__title { font-family: var(--font-display); font-size: clamp(1.5rem, 1.1rem + 2vw, 2.4rem); font-weight: 900; letter-spacing: -0.02em; line-height: 1.18; margin: 0 0 0.55rem; }

/* Verified pill â€” now used as top eyebrow */
.hx-store-verified {
  display: inline-flex; align-items: center; gap: 0.38rem;
  font-size: var(--fs-200); font-weight: 700; letter-spacing: 0.03em;
  color: var(--leaf-deep); background: var(--leaf-soft);
  border: 1px solid color-mix(in oklch, var(--leaf) 22%, transparent);
  padding: 0.28rem 0.8rem; border-radius: var(--r-pill); margin-bottom: 0.75rem;
}

/* Stats + CTA row */
.hx-store-bottom { display: flex; align-items: flex-end; gap: 2rem; flex-wrap: wrap; margin-top: 0.1rem; }
.hx-store-stats { display: flex; gap: 1.8rem; }
.hx-store-stat { display: flex; flex-direction: column; gap: 0.08rem; }
.hx-store-stat__n { font-family: var(--font-display); font-size: 1.65rem; font-weight: 900; color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums; }
.hx-store-stat__label { font-size: var(--fs-200); color: var(--ink-3); font-weight: 500; }
.hx-store-stat + .hx-store-stat { border-left: 1px solid var(--line); padding-left: 1.8rem; }

/* Visit CTA â€” button-in-button */
.hx-store-hero__cta { flex-shrink: 0; margin-left: auto; }
.hx-store-visit {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.75rem 0.75rem 0.75rem 1.25rem;
  background: var(--clay); color: var(--on-clay); border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-400); text-decoration: none; white-space: nowrap;
  transition: transform 0.38s cubic-bezier(0.32,0.72,0,1), box-shadow 0.38s cubic-bezier(0.32,0.72,0,1), background 0.28s cubic-bezier(0.32,0.72,0,1);
}
.hx-store-visit:hover { background: var(--clay-deep); transform: translateY(-3px); box-shadow: 0 12px 28px -8px rgba(139,62,47,0.48); }
.hx-store-visit__icon { width: 2rem; height: 2rem; border-radius: 50%; background: rgba(255,255,255,0.18); display: inline-flex; align-items: center; justify-content: center; font-size: 1rem; transition: transform 0.38s cubic-bezier(0.32,0.72,0,1); }
.hx-store-visit:hover .hx-store-visit__icon { transform: translateX(2px) translateY(-1px); }

/* Layout */
.hx-store-layout { display: grid; grid-template-columns: 1fr 300px; gap: clamp(1.5rem, 1rem + 2vw, 2.5rem); align-items: start; }
.hx-store-feed { min-width: 0; }
.coupons-list { display: grid; gap: 2.5rem; }

/* Popular stores in sidebar */
.hx-pop-stores { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.55rem; }
.hx-pop-store {
  display: flex; flex-direction: column; align-items: center; gap: 0.55rem;
  padding: 0.85rem 0.65rem; border-radius: var(--r-lg);
  border: 1px solid var(--line); background: #fff;
  text-decoration: none;
  transition: background 0.28s cubic-bezier(0.32,0.72,0,1), border-color 0.28s cubic-bezier(0.32,0.72,0,1), transform 0.28s cubic-bezier(0.32,0.72,0,1);
}
.hx-pop-store:hover { background: var(--clay-softer); border-color: rgba(139,62,47,0.28); transform: translateY(-2px); }
.hx-pop-store__logo { width: 56px; height: 40px; display: flex; align-items: center; justify-content: center; }
.hx-pop-store__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.hx-pop-store__name { font-size: var(--fs-300); font-weight: 700; color: var(--ink-2); text-align: center; line-height: 1.25; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

/* Offers bar */
.hx-offers-bar { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.hx-offers-title { font-family: var(--font-display); font-size: var(--fs-600); font-weight: 800; letter-spacing: -0.02em; }
.hx-offers-eyebrow { display: inline-flex; align-items: center; font-size: 0.68rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--clay); background: var(--clay-softer); border: 1px solid rgba(139,62,47,0.2); padding: 0.25rem 0.65rem; border-radius: var(--r-pill); }

/* Filter tabs */
.hx-offer-filters { display: flex; gap: 0.4rem; flex-wrap: wrap; margin-bottom: var(--sp-4); }
.hx-offer-filter { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.42rem 0.9rem; border-radius: var(--r-pill); font-size: var(--fs-300); font-weight: 600; cursor: pointer; border: 1px solid var(--line); color: var(--ink-2); background: var(--paper); transition: background 0.28s cubic-bezier(0.32,0.72,0,1), border-color 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1); }
.hx-offer-filter:hover { background: var(--clay-softer); border-color: rgba(139,62,47,0.28); color: var(--clay); }
.hx-offer-filter.chip--active { background: var(--clay); border-color: var(--clay); color: var(--on-clay); }
.hx-offer-filter__count { display: inline-flex; align-items: center; justify-content: center; min-width: 1.35rem; height: 1.35rem; padding: 0 0.25rem; border-radius: 50%; background: rgba(0,0,0,0.1); font-size: 0.65rem; font-weight: 800; }
.hx-offer-filter.chip--active .hx-offer-filter__count { background: rgba(255,255,255,0.25); }

/* Expired divider */
.hx-expired-head { display: flex; align-items: center; gap: 0.5rem; font-size: var(--fs-300); font-weight: 700; color: var(--ink-3); margin: var(--sp-6) 0 var(--sp-3); padding-top: var(--sp-5); border-top: 1px solid var(--line); }

/* Sidebar */
.hx-store-sidebar { display: grid; gap: var(--sp-4); position: sticky; top: 88px; align-self: start; }
.hx-side-panel { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 1.5rem 1.6rem; box-shadow: 0 2px 8px -4px rgba(6,2,2,0.06); }
.hx-side-panel__title { font-size: var(--fs-500); font-weight: 800; letter-spacing: -0.01em; margin-bottom: var(--sp-4); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--line); }
.hx-side-about { color: var(--ink-2); font-size: var(--fs-400); line-height: 1.65; }
.hx-side-about :is(p, ul, ol) { margin-bottom: 0.85rem; }
.hx-side-about :is(p, ul, ol):last-child { margin-bottom: 0; }
.hx-side-posts { display: grid; gap: 1.1rem; }
.hx-side-post { display: flex; gap: 0.85rem; align-items: flex-start; text-decoration: none; }
.hx-side-post__img { width: 64px; height: 50px; border-radius: var(--r-md); object-fit: cover; flex-shrink: 0; }
.hx-side-post__date { font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); }
.hx-side-post__title { font-size: var(--fs-400); font-weight: 700; color: var(--ink); line-height: 1.4; margin-top: 0.2rem; transition: color 0.22s cubic-bezier(0.32,0.72,0,1); }
.hx-side-post:hover .hx-side-post__title { color: var(--clay); }
.hx-similar-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.hx-similar-chip { display: inline-flex; align-items: center; padding: 0.45rem 0.9rem; border-radius: var(--r-pill); font-size: var(--fs-300); font-weight: 600; border: 1px solid var(--line); color: var(--ink-2); background: var(--paper-2); text-decoration: none; transition: background 0.28s cubic-bezier(0.32,0.72,0,1), border-color 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1); }
.hx-similar-chip:hover { background: var(--clay-softer); border-color: rgba(139,62,47,0.28); color: var(--clay); }
.hx-side-cats { display: grid; gap: 0.4rem; }
.hx-side-cat { display: flex; align-items: center; justify-content: space-between; padding: 0.65rem 0.9rem; border-radius: var(--r-md); background: var(--paper-2); font-weight: 600; font-size: var(--fs-400); text-decoration: none; color: var(--ink); transition: background 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1); }
.hx-side-cat:hover { background: var(--clay-softer); color: var(--clay); }
.hx-side-cat .ti { color: var(--ink-3); font-size: 0.85rem; transition: transform 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1); }
.hx-side-cat:hover .ti { transform: translateX(3px); color: var(--clay); }

@media (max-width: 900px) {
  .hx-store-layout { grid-template-columns: 1fr; }
  .hx-store-sidebar { position: static; grid-template-columns: 1fr 1fr; }
  .hx-store-hero__inner { grid-template-columns: auto 1fr; }
  .hx-store-hero__cta { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .az-nav { top: 64px; }
  .az-link { min-width: 32px; height: 32px; font-size: var(--fs-200); }
  .hx-store-hero__inner { grid-template-columns: 1fr; }
  .hx-store-sidebar { grid-template-columns: 1fr; }
  .hx-store-stats { flex-wrap: wrap; gap: 1.1rem; }
}

/* ============================================================================
   SHARED: content + sidebar, blog/guide card grid (categories, blog, search)
   ========================================================================== */
.with-sidebar { display: grid; grid-template-columns: 1fr 320px; gap: clamp(1.5rem, 1rem + 2vw, 3rem); align-items: start; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(1.5rem, 1rem + 1.6vw, 2.25rem); }

/* ============================================================================
   CATEGORIES â€” index
   ========================================================================== */
.cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: var(--sp-5); }
.cat-card { display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; transition: transform var(--t-2) var(--ease), box-shadow var(--t-2) ease, border-color var(--t-2) ease; }
.cat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--line-2); }
.cat-card__img { position: relative; aspect-ratio: 16 / 8; overflow: hidden; background: var(--clay); }
.cat-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-3) var(--ease); }
.cat-card:hover .cat-card__img img { transform: scale(1.06); }
.cat-card__img--empty { display: grid; place-items: center; background: linear-gradient(135deg, var(--clay), var(--oxblood)); color: var(--on-clay); }
.cat-card__img--empty .ti { font-size: 2.6rem; opacity: 0.9; }
.cat-card__body { padding: 1.1rem 1.25rem 1.35rem; display: flex; flex-direction: column; gap: 0.6rem; flex: 1; }
.cat-card__title { font-family: var(--font-display); font-size: var(--fs-600); line-height: 1.12; }
.cat-card__title a:hover { color: var(--clay-deep); }
.cat-card__count { font-size: var(--fs-200); color: var(--clay-deep); font-weight: 700; }
.cat-card__children { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: auto; padding-top: 0.4rem; }
.cat-card__child { font-size: var(--fs-200); font-weight: 600; color: var(--ink-2); padding: 0.3rem 0.65rem; border-radius: var(--r-pill); background: var(--paper-2); transition: background var(--t-1) ease, color var(--t-1) ease; }
.cat-card__child:hover { background: var(--clay-softer); color: var(--clay-deep); }

@media (max-width: 900px) {
  .with-sidebar { grid-template-columns: 1fr; }
  .with-sidebar .sidebar { position: static; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .with-sidebar .sidebar { grid-template-columns: 1fr; }
}

/* ============================================================================
   PAGER
   ========================================================================== */
.pager { display: flex; justify-content: center; margin-top: var(--sp-7); }
.pager ul { display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; }
.pager li a, .pager li span { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 0.6rem; border-radius: var(--r-md); font-weight: 700; font-size: var(--fs-300); border: 1px solid var(--line); color: var(--ink-2); transition: background var(--t-1) ease, color var(--t-1) ease, border-color var(--t-1) ease; }
.pager li a:hover { border-color: var(--clay); color: var(--clay-deep); background: var(--clay-softer); }
.pager li.active span { background: var(--clay); border-color: var(--clay); color: var(--on-clay); }

/* ============================================================================
   BLOG â€” single article
   ========================================================================== */
.article-hero { background: var(--paper-2); border-bottom: 1px solid var(--line); padding-block: clamp(2.2rem, 1.6rem + 3vw, 3.8rem); }
.article-hero__inner { max-width: 860px; }
.article-hero__title { font-size: clamp(1.4rem, 1.1rem + 1.15vw, 2.1rem); line-height: 1.16; margin: 0.7rem 0 1rem; }
.article-meta { display: flex; gap: 1.3rem; flex-wrap: wrap; color: var(--ink-2); font-size: var(--fs-300); }
.article-meta span { display: inline-flex; align-items: center; gap: 0.4rem; }
.article-meta .ti { color: var(--clay-deep); }

.article-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: clamp(1.5rem, 1rem + 2vw, 3.2rem); align-items: start; }
.article-figure { border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--sp-6); aspect-ratio: 16 / 8; box-shadow: var(--shadow-1); }
.article-figure img { width: 100%; height: 100%; object-fit: cover; }
.article-content { font-size: 1.1rem; line-height: 1.75; color: var(--ink); max-width: 72ch; }
.article-content > * + * { margin-top: 1.25rem; }
.article-content h2 { font-family: var(--font-display); font-size: var(--fs-700); line-height: 1.18; margin-top: 2.4rem; }
.article-content h3 { font-family: var(--font-display); font-size: var(--fs-600); line-height: 1.2; margin-top: 2rem; }
.article-content h4 { font-weight: 700; font-size: var(--fs-500); margin-top: 1.6rem; }
.article-content a { color: var(--clay-deep); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1.5px; }
.article-content a:hover { color: var(--clay-700); }
.article-content ul, .article-content ol { padding-left: 1.3rem; display: grid; gap: 0.5rem; }
.article-content ul li::marker { color: var(--clay); }
.article-content img { border-radius: var(--r-lg); margin-block: 1.6rem; width: 100%; }
.article-content blockquote { background: var(--clay-softer); border-radius: var(--r-lg); padding: 1.3rem 1.6rem; font-size: 1.2rem; font-family: var(--font-display); color: var(--clay-700); }
.article-content table { width: 100%; border-collapse: collapse; font-size: var(--fs-300); }
.article-content th, .article-content td { border: 1px solid var(--line); padding: 0.6rem 0.8rem; text-align: left; }
.article-content th { background: var(--paper-2); font-weight: 700; }

.article-share { display: flex; align-items: center; gap: 0.8rem; margin-top: var(--sp-6); padding-top: var(--sp-5); border-top: 1px solid var(--line); flex-wrap: wrap; }
.article-share__label { font-weight: 700; }
.share-btn { width: 42px; height: 42px; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line); color: var(--ink); transition: background var(--t-1) ease, color var(--t-1) ease, border-color var(--t-1) ease, transform var(--t-1) var(--ease); }
.share-btn:hover { background: var(--clay); border-color: var(--clay); color: var(--on-clay); transform: translateY(-2px); }

.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); margin-top: var(--sp-7); }
.post-nav__link { display: flex; gap: 0.9rem; align-items: center; padding: 1rem; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--paper); transition: border-color var(--t-2) ease, transform var(--t-2) var(--ease), box-shadow var(--t-2) ease; }
.post-nav__link:hover { border-color: var(--clay); transform: translateY(-2px); box-shadow: var(--shadow-1); }
.post-nav__link.next { flex-direction: row-reverse; text-align: right; }
.post-nav__thumb { width: 64px; height: 64px; border-radius: var(--r-md); object-fit: cover; flex-shrink: 0; }
.post-nav__dir { font-size: var(--fs-200); color: var(--clay-deep); font-weight: 700; display: flex; align-items: center; gap: 0.3rem; margin-bottom: 0.2rem; }
.post-nav__link.next .post-nav__dir { justify-content: flex-end; }
.post-nav__name { font-weight: 600; font-size: var(--fs-300); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.post-nav__link.is-disabled { opacity: 0.5; }

@media (max-width: 900px) {
  .article-layout { grid-template-columns: 1fr; }
  .article-content { max-width: none; }
}
@media (max-width: 640px) {
  .post-nav { grid-template-columns: 1fr; }
  .post-nav__link.next { flex-direction: row; text-align: left; }
  .post-nav__link.next .post-nav__dir { justify-content: flex-start; }
}

/* ============================================================================
   CONTACT + FORMS
   ========================================================================== */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: start; }
.contact-info__desc { color: var(--ink-2); margin: 0.8rem 0 1.5rem; }
.contact-details { display: grid; gap: 0.8rem; margin-bottom: var(--sp-5); }
.contact-item { display: flex; gap: 0.9rem; align-items: center; padding: 0.9rem 1rem; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--paper); transition: border-color var(--t-1) ease, transform var(--t-1) var(--ease); }
a.contact-item:hover { border-color: var(--clay); transform: translateY(-2px); }
.contact-item__icon { width: 44px; height: 44px; border-radius: var(--r-pill); background: var(--clay-softer); color: var(--clay-deep); display: inline-flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.contact-item strong { display: block; font-size: var(--fs-300); }
.contact-item small { color: var(--ink-2); font-size: var(--fs-200); }
.contact-social__label { font-weight: 700; font-size: var(--fs-300); margin-bottom: 0.6rem; }
.contact-social__row { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.contact-social__row a { width: 42px; height: 42px; border-radius: var(--r-pill); border: 1px solid var(--line); display: inline-flex; align-items: center; justify-content: center; color: var(--ink); transition: background var(--t-1) ease, color var(--t-1) ease, border-color var(--t-1) ease, transform var(--t-1) var(--ease); }
.contact-social__row a:hover { background: var(--clay); border-color: var(--clay); color: var(--on-clay); transform: translateY(-2px); }

.form-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-xl); padding: clamp(1.5rem, 1rem + 2vw, 2.5rem); box-shadow: var(--shadow-1); }
.form-card__head h2, .form-card__head h3 { font-size: var(--fs-600); }
.form-card__head p { color: var(--ink-2); margin: 0.4rem 0 1.3rem; font-size: var(--fs-300); }
.form-grid { display: grid; gap: var(--sp-4); }
.form-grid--2 { grid-template-columns: 1fr 1fr; }
.form-actions { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; margin-top: 0.4rem; }
.form-note { font-size: var(--fs-200); color: var(--ink-2); }
.alert-list { margin: 0; padding-left: 1.1rem; }

/* CMS page */
.cms-content { max-width: 760px; }

@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .form-grid--2 { grid-template-columns: 1fr; } }

/* ============================================================================
   REDIRECT INTERSTITIAL (standalone page)
   ========================================================================== */
.redirect-page { min-height: 100dvh; display: grid; place-items: center; background: var(--oxblood); color: var(--on-clay); padding: var(--gutter); }
.redirect-card { max-width: 480px; width: 100%; text-align: center; background: var(--paper); color: var(--ink); border-radius: var(--r-xl); padding: clamp(2rem, 1.5rem + 3vw, 3rem); box-shadow: var(--shadow-pop); }
.redirect-badge { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.4rem 0.9rem; border-radius: var(--r-pill); background: var(--leaf-soft); color: var(--leaf-deep); font-weight: 700; font-size: var(--fs-200); margin-bottom: var(--sp-5); }
.redirect-spinner { width: 54px; height: 54px; border-radius: 50%; border: 4px solid var(--clay-softer); border-top-color: var(--clay); margin: 0 auto var(--sp-5); animation: ss-spin 0.8s linear infinite; }
@keyframes ss-spin { to { transform: rotate(360deg); } }
.redirect-title { font-size: var(--fs-700); margin-bottom: 0.6rem; }
.redirect-desc { color: var(--ink-2); margin-bottom: var(--sp-5); }
.redirect-progress { height: 6px; border-radius: var(--r-pill); background: var(--clay-softer); overflow: hidden; margin-bottom: var(--sp-5); }
.redirect-progress span { display: block; height: 100%; width: 0; background: var(--clay); border-radius: inherit; animation: ss-fill 1.5s var(--ease) forwards; }
@keyframes ss-fill { to { width: 100%; } }
.redirect-hint { font-size: var(--fs-300); color: var(--ink-2); }
.redirect-hint a { color: var(--clay-deep); font-weight: 700; text-decoration: underline; }
.redirect-cancel { display: inline-flex; align-items: center; gap: 0.4rem; margin-top: var(--sp-5); color: var(--ink-3); font-size: var(--fs-200); }
.redirect-cancel:hover { color: var(--clay-deep); }
@media (prefers-reduced-motion: reduce) { .redirect-spinner { animation: none; } .redirect-progress span { animation: none; width: 100%; } }

/* ============================================================================
   HOME â€” blog-slider hero (is_slider) + ranked popular list (is_popular)
   ========================================================================== */
.hero-split { padding-top: clamp(1.25rem, 0.6rem + 1.4vw, 2rem); }
.hero-split__track { position: relative; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-2); background: var(--oxblood); }
.hero-split__slide { position: absolute; inset: 0; display: grid; grid-template-columns: 1.12fr 0.88fr; opacity: 0; transition: opacity 1s var(--ease); }
.hero-split__slide:first-child { position: relative; }
.hero-split__slide.is-active { opacity: 1; z-index: 1; }
.hero-split__media { position: relative; overflow: hidden; min-height: clamp(340px, 40vw, 470px); }
.hero-split__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-split__media::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(to right, transparent 55%, color-mix(in oklch, var(--oxblood) 65%, transparent) 100%); }
@media (prefers-reduced-motion: no-preference) {
  .hero-split__slide.is-active .hero-split__media img { animation: ss-kenburns 9s ease-out forwards; }
}
@keyframes ss-kenburns { from { transform: scale(1.02); } to { transform: scale(1.1); } }
.hero-split__panel { display: flex; flex-direction: column; justify-content: center; gap: 0.95rem; padding: clamp(1.75rem, 1.1rem + 2.6vw, 3.25rem); background: var(--oxblood); color: var(--on-clay); }
.hero-split__eyebrow { align-self: flex-start; display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.4rem 0.9rem; border-radius: var(--r-pill); background: color-mix(in oklch, var(--on-clay) 13%, transparent); border: 1px solid color-mix(in oklch, var(--on-clay) 22%, transparent); font-size: var(--fs-200); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.hero-split__eyebrow .ti { color: var(--gold); }
.hero-split__title { font-family: var(--font-display); font-size: clamp(1.35rem, 1.05rem + 1.3vw, 2.05rem); line-height: 1.2; color: var(--on-clay); letter-spacing: -0.005em; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hero-split__title a { transition: color var(--t-2) ease; }
.hero-split__title a:hover { color: var(--gold); }
.hero-split__excerpt { color: color-mix(in oklch, var(--on-clay) 74%, var(--oxblood)); font-size: var(--fs-300); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hero-split__meta { display: flex; gap: 1.2rem; flex-wrap: wrap; color: color-mix(in oklch, var(--on-clay) 62%, var(--oxblood)); font-size: var(--fs-200); }
.hero-split__meta span { display: inline-flex; align-items: center; gap: 0.4rem; }
.hero-split__meta .ti { color: var(--gold); }
.hero-split__panel .btn { align-self: flex-start; margin-top: 0.4rem; }
@media (max-width: 760px) {
  .hero-split__slide { grid-template-columns: 1fr; grid-template-rows: clamp(190px, 46vw, 280px) auto; }
  .hero-split__media { min-height: 0; }
  .hero-split__panel::before { display: none; }
}

.pop-list { display: grid; grid-template-columns: 1fr 1fr; gap: 0 var(--sp-6); }
.pop-item { display: flex; gap: 1rem; align-items: center; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.pop-rank { font-family: var(--font-display); font-size: 2rem; color: var(--clay); min-width: 1.8ch; text-align: center; line-height: 1; }
.pop-thumb { width: 72px; height: 72px; min-width: 72px; border-radius: var(--r-md); object-fit: cover; }
.pop-body { min-width: 0; }
.pop-title { font-family: var(--font-display); font-size: var(--fs-400); line-height: 1.2; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.pop-title a:hover { color: var(--clay-deep); }
.pop-date { font-size: var(--fs-200); color: var(--ink-3); margin-top: 0.3rem; }
@media (max-width: 720px) { .pop-list { grid-template-columns: 1fr; } }

/* ============================================================================
   HOME v3 â€” light, type-driven, image-free editorial  (scoped to .hx)
   Sans display (Hanken Grotesk heavy) Â· mono-neutral base + one coral accent Â·
   category-coded color tiles. No oxblood, no serif, no photo dependency.
   ========================================================================== */
.hx {
  --hx-bg:       #FAFAF8;
  --hx-surface:  #FFFFFF;
  --hx-ink:      #18181B;
  --hx-ink-2:    #56565F;
  --hx-ink-3:    #8C8C95;
  --hx-line:     #EAEAE5;
  --hx-line-2:   #DCDCD6;
  --hx-accent:   #FF4D2E;
  --hx-accent-2: #D23A1C;
  --hx-t1: #18181B;  /* tile tints â€” restrained, cohesive */
  --hx-t2: #1F5C4D;
  --hx-t3: #FF4D2E;
  --hx-t4: #2C3340;
  --hx-sans: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --hx-r: 18px;
  --hx-r-lg: 26px;
  --hx-ease: cubic-bezier(0.22, 1, 0.36, 1);
  background: var(--hx-bg);
  color: var(--hx-ink);
  font-family: var(--hx-sans);
}
.hx ::selection { background: var(--hx-accent); color: #fff; }
/* Force sans display on ALL homepage headings (override global serif --font-display) */
.hx h1, .hx h2, .hx h3, .hx h4, .hx h5, .hx h6 { font-family: var(--hx-sans); }
/* Headings on tinted/dark surfaces stay white (override global heading ink color) */
.hx-slide__title,
.hx-feature__title,
.hx-cat__name,
.hx-fcard--fill .hx-fcard__title { color: #fff; }

/* Layout primitives */
.hx-wrap { max-width: 1200px; margin-inline: auto; padding-inline: clamp(1.15rem, 0.4rem + 2.6vw, 2.5rem); }
.hx-section { padding-block: clamp(1.9rem, 1.3rem + 2vw, 3.25rem); }
.hx-section--tight { padding-block: clamp(1.5rem, 1.1rem + 1.6vw, 2.5rem); }

/* Section header */
.hx-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: clamp(1.6rem, 1.1rem + 1.6vw, 2.6rem); }
.hx-head__l { max-width: 60ch; }
.hx-kicker { display: inline-block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--hx-accent-2); margin-bottom: 0.7rem; }
.hx-h2 { font-family: var(--hx-sans); font-weight: 800; font-size: clamp(1.6rem, 1.2rem + 1.9vw, 2.6rem); line-height: 1.04; letter-spacing: -0.03em; color: var(--hx-ink); }
.hx-sub { color: var(--hx-ink-2); font-size: 1.02rem; line-height: 1.6; margin-top: 0.7rem; }
.hx-seeall { display: inline-flex; align-items: center; gap: 0.4rem; font-weight: 700; font-size: 0.92rem; color: var(--hx-ink); white-space: nowrap; transition: gap var(--t-2) var(--hx-ease), color var(--t-2) ease; }
.hx-seeall .ti { transition: transform var(--t-2) var(--hx-ease); }
.hx-seeall:hover { color: var(--hx-accent-2); gap: 0.65rem; }

/* Buttons */
.hx-btn { display: inline-flex; align-items: center; gap: 0.7rem; padding: 0.85rem 0.95rem 0.85rem 1.4rem; border-radius: var(--r-pill); font-family: var(--hx-sans); font-weight: 700; font-size: 0.98rem; letter-spacing: -0.01em; cursor: pointer; border: 1.5px solid transparent; transition: transform var(--t-1) var(--hx-ease), background var(--t-2) ease, color var(--t-2) ease, border-color var(--t-2) ease; }
.hx-btn__ring { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: var(--r-pill); flex-shrink: 0; line-height: 0; transition: transform var(--t-2) var(--hx-ease), background var(--t-2) ease; }
.hx-btn--primary { background: var(--hx-ink); color: #fff; }
.hx-btn--primary .hx-btn__ring { background: var(--hx-accent); color: #fff; }
.hx-btn--primary:hover { background: #000; transform: translateY(-2px); }
.hx-btn--primary:hover .hx-btn__ring { transform: translate(3px, -1px) scale(1.1); }
.hx-btn--primary:active { transform: translateY(0) scale(0.99); }
.hx-btn--ghost { background: transparent; color: var(--hx-ink); border-color: var(--hx-line-2); padding: 0.85rem 1.4rem; }
.hx-btn--ghost:hover { border-color: var(--hx-ink); transform: translateY(-2px); }
.hx-btn--light { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.28); }
.hx-btn--light .hx-btn__ring { background: var(--hx-accent); color: #fff; }
.hx-btn--light:hover { background: rgba(255,255,255,0.16); transform: translateY(-2px); }

/* --- Section 1: Hero â€” full-bleed cinematic slider ------------------------- */
.hxhero { position: relative; overflow: hidden; background: #110E0C; isolation: isolate; }
.hxhero__stage { position: relative; height: clamp(540px, 82vh, 768px); }

.hx .hero__slide { position: absolute; inset: 0; opacity: 0; pointer-events: none; transition: opacity 0.55s var(--hx-ease); background: var(--tint, #18181B); }
.hx .hero__slide.is-active { opacity: 1; pointer-events: auto; }

.hxhero__media { position: absolute; inset: 0; overflow: hidden; }
.hxhero__media img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); filter: brightness(1.07) contrast(1.03) saturate(1.04); }
@media (prefers-reduced-motion: no-preference) {
  .hx .hero__slide.is-active .hxhero__media img { animation: hxhero-kb 7.5s ease-out forwards; }
}
@keyframes hxhero-kb { from { transform: scale(1.05); } to { transform: scale(1.15); } }
.hxhero__media::after { content: ""; position: absolute; inset: 0; background:
  linear-gradient(96deg, rgba(12,10,9,0.84) 0%, rgba(12,10,9,0.5) 30%, rgba(12,10,9,0.1) 56%, transparent 76%),
  linear-gradient(to top, rgba(12,10,9,0.62) 0%, rgba(12,10,9,0.12) 26%, transparent 50%); }

.hxhero__overlay { position: absolute; inset: 0; z-index: 3; pointer-events: none; }
.hxhero__overlay-wrap { height: 100%; display: flex; flex-direction: column; justify-content: flex-end; padding-block: clamp(1.7rem, 1.1rem + 2vw, 2.7rem); }
.hxhero__brand { display: inline-flex; align-items: center; gap: 0.55rem; align-self: flex-start; color: rgba(255,255,255,0.82); font-weight: 700; font-size: clamp(0.9rem, 0.85rem + 0.3vw, 1.05rem); letter-spacing: -0.01em; }
.hxhero__brand .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--hx-accent); flex-shrink: 0; }
.hxhero__brand b { color: #fff; }

/* Single content block (updated per slide by JS â€” no per-slide text = no crossfade ghosting) */
.hxhero__bottom { display: flex; flex-direction: column; gap: clamp(1.8rem, 1.2rem + 2vw, 2.8rem); }
.hxhero__content { pointer-events: auto; display: flex; flex-direction: column; align-items: flex-start; max-width: 62ch; }
@keyframes hxhero-textin { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.hxhero__content.is-in .hxhero__eyebrow,
.hxhero__content.is-in .hxhero__title,
.hxhero__content.is-in .hxhero__subtitle,
.hxhero__content.is-in .hxhero__ctas { animation: hxhero-textin 0.7s var(--hx-ease) backwards; }
.hxhero__content.is-in .hxhero__title { animation-delay: 0.06s; }
.hxhero__content.is-in .hxhero__subtitle { animation-delay: 0.10s; }
.hxhero__content.is-in .hxhero__ctas { animation-delay: 0.16s; }
.hxhero__eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.42rem 0.95rem; border-radius: var(--r-pill); background: rgba(255,255,255,0.14); color: #fff; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 1.1rem; }
.hxhero__eyebrow .ti { color: var(--hx-accent); font-size: 0.95rem; }
.hxhero__title { font-family: var(--hx-sans); font-weight: 800; font-size: clamp(1.25rem, 0.75rem + 1.85vw, 2.1rem); line-height: 1.1; letter-spacing: -0.028em; color: #fff; max-width: 32ch; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hxhero__title a { color: #fff; transition: color var(--t-2) ease; }
.hxhero__title a:hover { color: rgba(255,255,255,0.82); }
.hxhero__subtitle { color: rgba(255,255,255,0.78); font-size: clamp(0.85rem, 0.78rem + 0.3vw, 0.97rem); font-weight: 400; line-height: 1.52; margin-top: 0.6rem; max-width: 42ch; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hxhero__ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: 1.5rem; }
.hx-btn--ondark { background: rgba(255,255,255,0.13); color: #fff; border-color: rgba(255,255,255,0.26); }
.hx-btn--ondark:hover { background: rgba(255,255,255,0.22); transform: translateY(-2px); }
.hxhero__botrow { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.hx .hero__dots { display: flex; gap: 0.5rem; pointer-events: auto; }
.hx .hero__dot { position: relative; overflow: hidden; width: 30px; height: 4px; border-radius: var(--r-pill); background: rgba(255,255,255,0.32); border: none; cursor: pointer; padding: 0; transition: width var(--t-2) var(--hx-ease); }
.hx .hero__dot.is-active { width: 48px; }
.hx .hero__dot.is-active::after { content: ""; position: absolute; inset: 0; border-radius: inherit; background: var(--hx-accent); transform-origin: left; animation: hxhero-prog 6s linear forwards; }
@keyframes hxhero-prog { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.hxhero:hover .hero__dot.is-active::after { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) { .hx .hero__dot.is-active::after { animation: none; transform: scaleX(1); } }
.hxhero__controls { display: flex; align-items: center; gap: 1.1rem; pointer-events: auto; }
.hxhero__count { color: rgba(255,255,255,0.82); font-weight: 700; font-size: 0.92rem; font-variant-numeric: tabular-nums; letter-spacing: 0.08em; }
.hxhero__arrows { display: flex; gap: 0.5rem; }
.hxhero__arrow { width: 46px; height: 46px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.3); background: rgba(255,255,255,0.08); color: #fff; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: background var(--t-2) ease, border-color var(--t-2) ease, transform 0.4s var(--hx-ease); }
.hxhero__arrow:hover { background: var(--hx-accent); border-color: var(--hx-accent); transform: scale(1.07); }
.hxhero__arrow:active { transform: scale(0.93); }
.hxhero__arrow .ti { font-size: 1.3rem; }

@media (max-width: 700px) {
  .hxhero__stage { height: clamp(460px, 86vh, 620px); }
  .hxhero__count { display: none; }
}

/* --- Section 2: Featured â€” image-free asymmetric bento --------------------- */
.hx-bento { display: grid; grid-template-columns: 1.55fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: clamp(0.8rem, 0.5rem + 0.9vw, 1.2rem); }

.hx-feature { grid-row: 1 / 3; position: relative; border-radius: var(--hx-r-lg); overflow: hidden; background: var(--tint, #18181B); color: #fff; padding: clamp(1.6rem, 1rem + 2.2vw, 2.7rem); display: flex; flex-direction: column; justify-content: flex-end; min-height: clamp(420px, 46vw, 560px); box-shadow: 0 18px 44px -22px rgba(20,18,16,0.55); transition: transform 0.55s var(--hx-ease), box-shadow 0.55s ease; }
.hx-feature:hover { transform: translateY(-5px); box-shadow: 0 30px 64px -24px rgba(20,18,16,0.6); }
.hx-feature__mark { position: absolute; top: -0.12em; right: 0.06em; font-weight: 800; font-size: clamp(7rem, 17vw, 12rem); line-height: 1; letter-spacing: -0.06em; color: rgba(255,255,255,0.07); pointer-events: none; }
.hx-feature__badge { display: inline-flex; align-items: center; gap: 0.45rem; align-self: flex-start; padding: 0.38rem 0.85rem; border-radius: var(--r-pill); background: rgba(255,255,255,0.16); font-size: 0.74rem; font-weight: 700; letter-spacing: 0.04em; }
.hx-feature__title { position: relative; font-weight: 800; font-size: clamp(1.55rem, 1rem + 2.1vw, 2.45rem); line-height: 1.05; letter-spacing: -0.03em; margin-top: 1rem; max-width: 19ch; display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.hx-feature__meta { font-size: 0.82rem; font-weight: 600; color: rgba(255,255,255,0.65); margin-top: 0.9rem; display: flex; align-items: center; gap: 0.5rem; }
.hx-feature__cta { display: inline-flex; align-items: center; gap: 0.55rem; align-self: flex-start; margin-top: 1.5rem; padding: 0.6rem 0.6rem 0.6rem 1.15rem; border-radius: var(--r-pill); background: #fff; color: var(--hx-ink); font-weight: 700; font-size: 0.9rem; transition: transform 0.45s var(--hx-ease); }
.hx-feature__cta .ring { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 50%; background: var(--hx-accent); color: #fff; transition: transform 0.45s var(--hx-ease); }
.hx-feature:hover .hx-feature__cta .ring { transform: translate(3px, -1px) scale(1.1); }
.hx-feature__link { position: absolute; inset: 0; z-index: 1; }

.hx-fcard { position: relative; border-radius: var(--hx-r); overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; gap: 1.1rem; padding: 1.15rem 1.2rem; background: var(--hx-surface); border: 1px solid var(--hx-line); transition: transform 0.45s var(--hx-ease), box-shadow 0.45s ease, border-color 0.3s ease; }
.hx-fcard:hover { transform: translateY(-4px); box-shadow: 0 16px 34px -18px rgba(20,18,16,0.3); border-color: transparent; }
.hx-fcard__tag { width: 38px; height: 38px; border-radius: 11px; display: inline-flex; align-items: center; justify-content: center; background: var(--hx-bg); color: var(--hx-accent-2); font-size: 1.15rem; border: 1px solid var(--hx-line); flex-shrink: 0; }
.hx-fcard__body { display: flex; flex-direction: column; gap: 0.4rem; }
.hx-fcard__date { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--hx-ink-3); }
.hx-fcard__title { font-weight: 800; font-size: 1.02rem; line-height: 1.2; letter-spacing: -0.015em; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hx-fcard--fill { background: var(--tint, #1F5C4D); border-color: transparent; color: #fff; }
.hx-fcard--fill .hx-fcard__tag { background: rgba(255,255,255,0.16); color: #fff; border-color: transparent; }
.hx-fcard--fill .hx-fcard__date { color: rgba(255,255,255,0.6); }
.hx-fcard__link { position: absolute; inset: 0; }

@media (max-width: 860px) {
  .hx-bento { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .hx-feature { grid-column: 1 / 3; grid-row: auto; min-height: 300px; }
}
@media (max-width: 540px) {
  .hx-bento { grid-template-columns: 1fr; }
  .hx-feature { grid-column: auto; }
}

/* --- Section 3: Categories â€” image-free color-coded tiles ------------------- */
.hx-cats { display: grid; grid-template-columns: repeat(auto-fill, minmax(214px, 1fr)); gap: clamp(0.8rem, 0.5rem + 0.9vw, 1.15rem); }
.hx-cat { position: relative; border-radius: var(--hx-r); overflow: hidden; background: var(--tint, #18181B); color: #fff; min-height: 156px; padding: 1.25rem 1.3rem; display: flex; flex-direction: column; justify-content: flex-end; box-shadow: 0 12px 30px -20px rgba(20,18,16,0.45); transition: transform 0.45s var(--hx-ease), box-shadow 0.45s ease; }
.hx-cat:hover { transform: translateY(-4px); box-shadow: 0 22px 46px -22px rgba(20,18,16,0.55); }
.hx-cat__mark { position: absolute; top: -0.2em; right: 0.05em; font-weight: 800; font-size: 6.5rem; line-height: 1; color: rgba(255,255,255,0.09); pointer-events: none; }
.hx-cat__name { position: relative; font-weight: 800; font-size: 1.12rem; letter-spacing: -0.02em; line-height: 1.12; }
.hx-cat__count { position: relative; font-size: 0.78rem; font-weight: 700; opacity: 0.62; margin-top: 0.3rem; }
.hx-cat__arrow { position: absolute; top: 1.15rem; left: 1.3rem; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,0.16); display: inline-flex; align-items: center; justify-content: center; opacity: 0; transform: translateY(-5px); transition: opacity 0.3s ease, transform 0.3s var(--hx-ease); }
.hx-cat:hover .hx-cat__arrow { opacity: 1; transform: translateY(0); }
.hx-cat__link { position: absolute; inset: 0; }

/* --- Section 4: Latest â€” light typographic card grid ----------------------- */
.hx-latest { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(0.9rem, 0.5rem + 1vw, 1.4rem); }
.hx-post { position: relative; background: var(--hx-surface); border: 1px solid var(--hx-line); border-radius: var(--hx-r); padding: 1.4rem 1.5rem 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; transition: transform 0.45s var(--hx-ease), box-shadow 0.45s ease, border-color 0.3s ease; }
.hx-post:hover { transform: translateY(-4px); box-shadow: 0 18px 38px -20px rgba(20,18,16,0.28); border-color: transparent; }
.hx-post__top { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
.hx-post__num { font-weight: 800; font-size: 0.95rem; letter-spacing: 0.02em; color: var(--hx-accent-2); font-variant-numeric: tabular-nums; }
.hx-post__date { font-size: 0.74rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--hx-ink-3); }
.hx-post__title { font-weight: 800; font-size: 1.18rem; line-height: 1.2; letter-spacing: -0.02em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hx-post__excerpt { color: var(--hx-ink-2); font-size: 0.92rem; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hx-post__read { display: inline-flex; align-items: center; gap: 0.4rem; margin-top: auto; padding-top: 0.4rem; color: var(--hx-ink); font-weight: 700; font-size: 0.9rem; transition: gap var(--t-2) var(--hx-ease), color var(--t-2) ease; }
.hx-post__read .ti { transition: transform var(--t-2) var(--hx-ease); }
.hx-post:hover .hx-post__read { color: var(--hx-accent-2); gap: 0.65rem; }
.hx-post__link { position: absolute; inset: 0; }

/* --- Section 5: Popular â€” image-free horizontal rail ----------------------- */
.hx-rail__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: clamp(1.6rem, 1.1rem + 1.6vw, 2.6rem); }
.hx-rail__arrows { display: flex; gap: 0.55rem; align-items: center; flex-shrink: 0; }
.hx .carousel-arrow { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: var(--r-pill); border: 1.5px solid var(--hx-line-2); color: var(--hx-ink); background: var(--hx-surface); cursor: pointer; transition: background var(--t-2) ease, border-color var(--t-2) ease, transform 0.4s var(--hx-ease), color var(--t-2) ease; }
.hx .carousel-arrow:hover { background: var(--hx-ink); border-color: var(--hx-ink); color: #fff; transform: scale(1.06); }
.hx .carousel-arrow:active { transform: scale(0.93); }
.hx .carousel-arrow .ti { font-size: 1.25rem; }

.hx .carousel-viewport { overflow: hidden; -webkit-mask-image: linear-gradient(to right, transparent 0, #000 2%, #000 98%, transparent 100%); mask-image: linear-gradient(to right, transparent 0, #000 2%, #000 98%, transparent 100%); }
.hx .carousel-track { display: flex; gap: clamp(1rem, 0.7rem + 1vw, 1.4rem); overflow-x: auto; scroll-behavior: smooth; scroll-snap-type: x mandatory; -ms-overflow-style: none; scrollbar-width: none; cursor: grab; user-select: none; padding: 0.25rem 0 1rem; }
.hx .carousel-track::-webkit-scrollbar { display: none; }
.hx .carousel-track.is-dragging { cursor: grabbing; scroll-behavior: auto; }
.hx .carousel-slide { flex: 0 0 clamp(258px, 27vw, 308px); scroll-snap-align: start; display: flex; }

.hx-rcard { position: relative; width: 100%; display: flex; flex-direction: column; background: var(--hx-surface); border: 1px solid var(--hx-line); border-radius: var(--hx-r); overflow: hidden; transition: transform 0.5s var(--hx-ease), box-shadow 0.5s ease, border-color 0.3s ease; }
.hx-rcard:hover { transform: translateY(-6px); box-shadow: 0 20px 44px -20px rgba(20,18,16,0.3); border-color: transparent; }
.hx-rcard__cover { position: relative; background: var(--tint, #18181B); color: #fff; padding: 1.2rem 1.3rem 1.15rem; min-height: 124px; display: flex; flex-direction: column; justify-content: space-between; gap: 1rem; }
.hx-rcard__chip { align-self: flex-start; display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.32rem 0.75rem; border-radius: var(--r-pill); background: rgba(255,255,255,0.16); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.03em; }
.hx-rcard__rank { font-weight: 800; font-size: 2.3rem; line-height: 1; letter-spacing: -0.04em; }
.hx-rcard__rank small { font-size: 0.9rem; font-weight: 700; opacity: 0.55; }
.hx-rcard__body { padding: 1.05rem 1.3rem 1.3rem; display: flex; flex-direction: column; gap: 0.45rem; flex: 1; }
.hx-rcard__date { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--hx-ink-3); }
.hx-rcard__title { font-weight: 800; font-size: 1.05rem; line-height: 1.2; letter-spacing: -0.018em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.hx-rcard__read { display: inline-flex; align-items: center; gap: 0.4rem; margin-top: auto; padding-top: 0.3rem; color: var(--hx-ink); font-weight: 700; font-size: 0.88rem; transition: gap var(--t-2) var(--hx-ease), color var(--t-2) ease; }
.hx-rcard__read .ti { transition: transform var(--t-2) var(--hx-ease); }
.hx-rcard:hover .hx-rcard__read { color: var(--hx-accent-2); gap: 0.65rem; }
.hx-rcard__link { position: absolute; inset: 0; z-index: 1; }

.hx-rail__cta { display: flex; justify-content: center; margin-top: clamp(2rem, 1.4rem + 1.6vw, 3rem); }

@media (max-width: 760px) {
  .hx .carousel-slide { flex: 0 0 min(282px, 80vw); }
  .hx-rail__arrows { display: none; }
}

/* --- Section 6: Disclaimer note -------------------------------------------- */
.hx-note { display: flex; gap: 1.1rem; align-items: flex-start; background: var(--hx-surface); border: 1px solid var(--hx-line); border-radius: var(--hx-r); padding: clamp(1.3rem, 1rem + 1.2vw, 1.9rem); }
.hx-note__icon { width: 46px; height: 46px; border-radius: 13px; background: var(--hx-bg); border: 1px solid var(--hx-line); display: inline-flex; align-items: center; justify-content: center; color: var(--hx-accent-2); font-size: 1.4rem; flex-shrink: 0; }
.hx-note h2 { font-weight: 800; font-size: 1.12rem; letter-spacing: -0.02em; margin-bottom: 0.35rem; color: var(--hx-ink); }
.hx-note p { color: var(--hx-ink-2); font-size: 0.95rem; line-height: 1.65; }

/* ============================================================================
   HOME v3 â€” image layers (image-led; color tiles are the fallback)
   ========================================================================== */
/* Full-bleed overlay media on dark cards (hero slide, feature, category) */
.hx-media { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hx-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.8s var(--hx-ease); }
.hx-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(17,14,12,0.90) 0%, rgba(17,14,12,0.46) 46%, rgba(17,14,12,0.12) 100%); }
.hx .hero__slide:hover .hx-media img,
.hx-feature:hover .hx-media img,
.hx-cat:hover .hx-media img { transform: scale(1.05); }
/* Lift card content above the media layer */
.hx-slide__top, .hx-slide__btm { position: relative; z-index: 1; }
.hx-feature__inner { position: relative; z-index: 1; display: flex; flex-direction: column; }
.hx-cat__inner { position: relative; z-index: 1; }

/* White-card top images (featured side, latest) */
.hx-fcard__media, .hx-post__media { border-radius: 12px; overflow: hidden; flex-shrink: 0; }
.hx-fcard__media { aspect-ratio: 16 / 10; }
.hx-post__media { aspect-ratio: 16 / 9; margin-bottom: 0.2rem; }
.hx-fcard__media img, .hx-post__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--hx-ease); }
.hx-fcard:hover .hx-fcard__media img, .hx-post:hover .hx-post__media img { transform: scale(1.06); }
.hx-fcard--media { padding-top: 0; padding-bottom: 1rem; gap: 0.75rem; }
.hx-fcard--media .hx-fcard__media { margin: -1.15rem -1.2rem 0; border-radius: 0; aspect-ratio: 16 / 9; }

/* Popular rail cover image */
.hx-rcard__media { position: absolute; inset: 0; z-index: 0; }
.hx-rcard__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.7s var(--hx-ease); }
.hx-rcard:hover .hx-rcard__media img { transform: scale(1.06); }
.hx-rcard__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(17,14,12,0.82) 0%, rgba(17,14,12,0.32) 100%); }
.hx-rcard__cover > .hx-rcard__chip, .hx-rcard__cover > .hx-rcard__rank { position: relative; z-index: 1; }

/* ---- Slider picks section ------------------------------------------------ */
.hx-srow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
}
.hx-scard {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--ink);
  display: block;
  cursor: pointer;
}
.hx-scard__media { position: absolute; inset: 0; }
.hx-scard__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.65s var(--ease);
  filter: brightness(0.92) saturate(1.06);
}
.hx-scard:hover .hx-scard__media img { transform: scale(1.07); }
.hx-scard__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,8,7,0.88) 0%, rgba(10,8,7,0.38) 52%, rgba(10,8,7,0.06) 100%);
}
.hx-scard__body {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.15rem 1.1rem;
  z-index: 2;
}
.hx-scard__tag {
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.9);
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.26rem 0.65rem; border-radius: var(--r-pill);
  margin-bottom: 0.5rem;
}
.hx-scard__title {
  font-family: var(--font-body); font-weight: 700;
  font-size: clamp(0.88rem, 0.78rem + 0.38vw, 1rem);
  color: #fff; line-height: 1.28;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.hx-scard__link { position: absolute; inset: 0; z-index: 3; }

/* ============================================================================
   Blog index â€” page header band, hero card, pager
   ========================================================================== */

/* Page header band */
.hx-page-head {
  background: var(--paper-2);
  border-bottom: 1px solid var(--line);
  padding: clamp(1.75rem, 1.2rem + 2.2vw, 2.75rem) 0 clamp(1.5rem, 1rem + 2vw, 2.25rem);
  min-height: 200px;
  display: flex;
  align-items: center;
}
.hx-page-head > .hx-wrap { width: 100%; }
.hx-breadcrumb { display: none; }
.hx-breadcrumb a { color: var(--ink-3); text-decoration: none; }
.hx-breadcrumb a:hover { color: var(--clay); }
.hx-breadcrumb i { font-size: 0.72rem; opacity: 0.6; }
.hx-page-head__title {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.55rem, 1.2rem + 1.4vw, 2.2rem);
  color: var(--ink); line-height: 1.2; margin-bottom: 0.5rem;
}
.hx-page-head__sub {
  font-size: clamp(0.88rem, 0.84rem + 0.2vw, 1rem);
  color: var(--ink-3); max-width: 58ch; line-height: 1.55;
}

/* Blog hero card */
.hx-blog-hero {
  position: relative; border-radius: var(--r-xl); overflow: hidden;
  aspect-ratio: 21 / 8; background: var(--ink);
  display: block; cursor: pointer; margin-bottom: 1.2rem;
}
.hx-blog-hero__link { position: absolute; inset: 0; z-index: 3; }
.hx-blog-hero__media { position: absolute; inset: 0; }
.hx-blog-hero__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s var(--ease);
  filter: brightness(0.85) saturate(1.08);
}
.hx-blog-hero__media--fallback { background: var(--oxblood); }
.hx-blog-hero:hover .hx-blog-hero__media img { transform: scale(1.04); }
.hx-blog-hero__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,8,7,0.92) 0%, rgba(10,8,7,0.44) 46%, rgba(10,8,7,0.06) 100%);
}
.hx-blog-hero__body {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 2;
  padding: clamp(1.25rem, 0.8rem + 1.8vw, 2.25rem);
}
.hx-blog-hero__date {
  display: inline-flex; align-items: center; gap: 0.35rem;
  color: rgba(255,255,255,0.62); font-size: 0.78rem; font-weight: 500;
  letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 0.6rem;
}
.hx-blog-hero__title {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.25rem, 0.9rem + 1.55vw, 2rem);
  color: #fff; line-height: 1.22; max-width: 44ch; margin-bottom: 1rem;
}
.hx-blog-hero__cta {
  display: inline-flex; align-items: center; gap: 0.45rem;
  color: rgba(255,255,255,0.78); font-size: 0.88rem; font-weight: 600;
}
.hx-blog-hero__cta i { transition: transform var(--t-2) var(--ease); }
.hx-blog-hero:hover .hx-blog-hero__cta i { transform: translateX(5px); }

/* spacing between zones */
.hx-blog-srow { margin-bottom: 1.2rem; }

/* Empty state */
.hx-empty {
  text-align: center; padding: clamp(3rem, 2rem + 4vw, 5rem) 1rem;
  display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
}
.hx-empty__icon { font-size: 2.5rem; color: var(--line-2); }
.hx-empty__title { font-size: var(--fs-600); font-weight: 700; color: var(--ink); }
.hx-empty__sub { color: var(--ink-3); font-size: var(--fs-300); max-width: 40ch; }

/* Pager â€” CI built-in (legacy) */
.hx-pager { display: flex; justify-content: center; padding-top: 2.75rem; }
.hx-pager .pager ul { display: flex; align-items: center; gap: 0.3rem; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.hx-pager .pager li a,
.hx-pager .pager li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 2.2rem; height: 2.2rem; padding: 0 0.7rem;
  border-radius: var(--r-pill); font-size: 0.875rem; font-weight: 500;
  border: 1px solid var(--line); color: var(--ink-2); background: var(--paper);
  text-decoration: none; transition: all var(--t-2) var(--ease);
}
.hx-pager .pager li a:hover { background: var(--clay-softer); border-color: var(--clay); color: var(--clay-deep); }
.hx-pager .pager li.active span { background: var(--clay); color: var(--on-clay); border-color: var(--clay); font-weight: 700; }

/* Pager â€” custom markup (categories, stores single-alpha) */
.hx-pager { display: flex; align-items: center; justify-content: center; gap: 0.4rem; flex-wrap: wrap; padding-top: 2.75rem; }
.hx-pager__pages { display: flex; align-items: center; gap: 0.3rem; flex-wrap: wrap; }
.hx-pager__btn,
.hx-pager__page {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.35rem;
  min-width: 2.2rem; height: 2.2rem; padding: 0 0.75rem;
  border-radius: var(--r-pill); font-size: 0.82rem; font-weight: 600;
  border: 1px solid var(--line); color: var(--ink-2); background: var(--paper);
  text-decoration: none;
  transition: background 0.28s cubic-bezier(0.32,0.72,0,1), border-color 0.28s cubic-bezier(0.32,0.72,0,1), color 0.28s cubic-bezier(0.32,0.72,0,1), transform 0.28s cubic-bezier(0.32,0.72,0,1);
}
.hx-pager__btn:hover,
.hx-pager__page:hover { background: var(--clay-softer); border-color: rgba(139,62,47,0.35); color: var(--clay); transform: translateY(-1px); }
.hx-pager__page.is-active { background: var(--clay); color: var(--on-clay); border-color: var(--clay); font-weight: 700; pointer-events: none; }
.hx-pager__btn--disabled { opacity: 0.38; pointer-events: none; }
.hx-pager__ellipsis { display: inline-flex; align-items: center; justify-content: center; min-width: 2rem; height: 2.2rem; font-size: 0.82rem; color: var(--ink-3); }

@media (max-width: 640px) {
  .hx-blog-hero { aspect-ratio: 4 / 3; }
}

/* ============================================================================
   Single blog post â€” cinematic hero, article body, TOC, share, post-nav
   ========================================================================== */

/* Cinematic hero */
.hx-article-hero {
  position: relative;
  height: clamp(320px, 58vh, 560px);
  background: var(--ink); overflow: hidden;
}
.hx-article-hero__media { position: absolute; inset: 0; }
.hx-article-hero__media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.72) saturate(1.1);
}
.hx-article-hero__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,8,7,0.94) 0%, rgba(10,8,7,0.56) 42%, rgba(10,8,7,0.14) 78%, rgba(10,8,7,0.06) 100%);
}
.hx-article-hero__body {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 2;
  padding-bottom: clamp(1.5rem, 1rem + 2vw, 2.5rem);
}
.hx-article-hero__breadcrumb {
  display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
  font-size: 0.75rem; color: rgba(255,255,255,0.52); margin-bottom: 0.9rem;
}
.hx-article-hero__breadcrumb a { color: rgba(255,255,255,0.52); text-decoration: none; }
.hx-article-hero__breadcrumb a:hover { color: rgba(255,255,255,0.9); }
.hx-article-hero__breadcrumb i { font-size: 0.66rem; opacity: 0.5; }
.hx-article-hero__title {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.45rem, 1rem + 2vw, 2.65rem);
  color: #fff; line-height: 1.18; margin-bottom: 1rem;
}
.hx-article-hero__meta {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0.9rem;
  font-size: 0.8rem; color: rgba(255,255,255,0.62);
}
.hx-article-hero__meta span { display: flex; align-items: center; gap: 0.3rem; }

/* Article 2-col layout */
.hx-article {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: clamp(2rem, 1.5rem + 2vw, 3.5rem);
  align-items: start;
}
.hx-article__main { min-width: 0; }

/* Rich text content */
.hx-article__content {
  font-size: clamp(1rem, 0.97rem + 0.12vw, 1.08rem);
  line-height: 1.78; color: var(--ink-2); max-width: 68ch;
}
.hx-article__content p { margin-bottom: 1.4em; }
.hx-article__content h2 {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.2rem, 1rem + 0.8vw, 1.5rem);
  color: var(--ink); line-height: 1.22; margin: 2em 0 0.65em;
}
.hx-article__content h3 {
  font-family: var(--font-body); font-weight: 700;
  font-size: clamp(1.05rem, 0.95rem + 0.4vw, 1.2rem);
  color: var(--ink); line-height: 1.3; margin: 1.6em 0 0.5em;
}
.hx-article__content h4 { font-weight: 700; font-size: 1rem; color: var(--ink); margin: 1.4em 0 0.4em; }
.hx-article__content a { color: var(--clay); text-decoration: underline; text-underline-offset: 2px; }
.hx-article__content a:hover { color: var(--clay-deep); }
.hx-article__content ul, .hx-article__content ol { padding-left: 1.5rem; margin-bottom: 1.4em; display: grid; gap: 0.4em; }
.hx-article__content li::marker { color: var(--clay); }
.hx-article__content blockquote {
  border-left: 3px solid var(--clay); margin: 1.6em 0;
  padding: 0.9em 1.2em; background: var(--clay-softer);
  border-radius: 0 var(--r-md) var(--r-md) 0; font-style: italic; color: var(--ink);
}
.hx-article__content img { max-width: 100%; border-radius: var(--r-md); margin: 1em 0; }
.hx-article__content table { width: 100%; border-collapse: collapse; margin-bottom: 1.4em; font-size: 0.95em; }
.hx-article__content th, .hx-article__content td { border: 1px solid var(--line); padding: 0.6rem 0.8rem; text-align: left; }
.hx-article__content th { background: var(--paper-2); font-weight: 700; color: var(--ink); }
.hx-article__content pre { background: var(--ink); color: var(--paper); border-radius: var(--r-md); padding: 1.1rem 1.25rem; overflow-x: auto; margin-bottom: 1.4em; font-size: 0.88em; }
.hx-article__content code { font-size: 0.88em; background: var(--paper-3); padding: 0.1em 0.35em; border-radius: 4px; }
.hx-article__content pre code { background: none; padding: 0; }

/* Sticky TOC */
.hx-toc {
  position: sticky; top: calc(76px + 1.5rem);
  max-height: calc(100vh - 76px - 3rem); overflow-y: auto;
  padding: 1.15rem 1.1rem; border: 1px solid var(--line);
  border-radius: var(--r-lg); background: var(--paper);
}
.hx-toc--empty { display: none; }
.hx-toc__title {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 0.75rem;
}
.hx-toc__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.05rem; }
.hx-toc__list a {
  display: block; padding: 0.3rem 0.55rem; font-size: 0.8rem; color: var(--ink-3);
  text-decoration: none; line-height: 1.35; border-radius: var(--r-sm);
  border-left: 2px solid transparent; transition: all var(--t-2) var(--ease);
}
.hx-toc__list a:hover { color: var(--ink); background: var(--paper-2); }
.hx-toc__list a.is-active { color: var(--clay); border-left-color: var(--clay); background: var(--clay-softer); font-weight: 600; }
.hx-toc__h3 a { padding-left: 1rem; font-size: 0.76rem; }

/* Share strip */
.hx-share {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0.55rem;
  padding: 1.2rem 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  margin-top: 2.5rem; max-width: 68ch;
}
.hx-share__label {
  font-size: 0.76rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--ink-3); margin-right: 0.2rem;
}
.hx-share__btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.05rem; height: 2.05rem; border-radius: var(--r-pill);
  border: 1px solid var(--line); background: var(--paper);
  color: var(--ink-2); font-size: 1rem; text-decoration: none;
  transition: all var(--t-2) var(--ease); cursor: pointer;
}
.hx-share__btn:hover { background: var(--clay); border-color: var(--clay); color: var(--on-clay); }
.hx-share__btn--copy.is-copied { background: var(--leaf); border-color: var(--leaf); color: #fff; }

/* Prev/Next nav */
.hx-post-nav {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem;
}
.hx-post-nav__link {
  display: flex; align-items: center; gap: 0.85rem; padding: 1rem 1.1rem;
  border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--paper);
  text-decoration: none; transition: all var(--t-2) var(--ease);
}
.hx-post-nav__link:hover:not(.hx-post-nav__link--disabled) { border-color: var(--clay); background: var(--clay-softer); }
.hx-post-nav__link--next { flex-direction: row-reverse; text-align: right; }
.hx-post-nav__link--disabled { opacity: 0.38; pointer-events: none; }
.hx-post-nav__thumb {
  width: 60px; height: 60px; object-fit: cover;
  border-radius: var(--r-md); flex-shrink: 0;
}
.hx-post-nav__dir {
  display: flex; align-items: center; gap: 0.3rem;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--clay); margin-bottom: 0.3rem;
}
.hx-post-nav__link--next .hx-post-nav__dir { justify-content: flex-end; }
.hx-post-nav__name {
  font-size: 0.86rem; font-weight: 600; color: var(--ink); line-height: 1.32;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Section divider for "More guides" */
.hx-section-divider {
  display: flex; align-items: center; gap: 1rem; margin: 3rem 0 2rem;
}
.hx-section-divider__line { flex: 1; height: 1px; background: var(--line); }
.hx-section-divider__label {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3); white-space: nowrap;
}

@media (max-width: 880px) {
  .hx-article { grid-template-columns: 1fr; }
  .hx-toc { display: none; }
  .hx-post-nav { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .hx-article-hero { height: clamp(260px, 52vw, 340px); }
  .hx-article-hero__title { font-size: clamp(1.2rem, 0.9rem + 1.5vw, 1.6rem); }
}

/* ============================================================================
   CMS pages (show.php) & Contact page
   ========================================================================== */

/* CMS body â€” narrow reading column for generic pages */
.hx-cms-body {
  max-width: 72ch;
  padding-bottom: 2rem;
}

/* Contact two-col grid */
.hx-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 2rem + 3vw, 5rem);
  align-items: start;
}

/* Info column */
.hx-contact-info__heading {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.3rem, 1rem + 1.2vw, 1.85rem);
  color: var(--ink); line-height: 1.2; margin-bottom: 1rem;
}
.hx-contact-info__desc {
  font-size: 1rem; line-height: 1.72; color: var(--ink-2);
  margin-bottom: 2rem; max-width: 44ch;
}
.hx-contact-details { display: grid; gap: 0.65rem; margin-bottom: 2rem; }

.hx-contact-item {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.85rem 1rem; border: 1px solid var(--line);
  border-radius: var(--r-lg); background: var(--paper);
  text-decoration: none; transition: all var(--t-2) var(--ease);
}
.hx-contact-item:hover { border-color: var(--clay); background: var(--clay-softer); }
.hx-contact-item__icon {
  display: flex; align-items: center; justify-content: center;
  width: 2.4rem; height: 2.4rem; border-radius: var(--r-pill);
  background: var(--clay-softer); color: var(--clay);
  font-size: 1.1rem; flex-shrink: 0;
}
.hx-contact-item__body { display: flex; flex-direction: column; gap: 0.1rem; }
.hx-contact-item__body strong { font-size: 0.82rem; font-weight: 700; color: var(--ink); }
.hx-contact-item__body small { font-size: 0.8rem; color: var(--ink-3); }

.hx-contact-social__label {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 0.6rem;
}
.hx-contact-social__row { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.hx-contact-social__row a {
  display: flex; align-items: center; justify-content: center;
  width: 2.05rem; height: 2.05rem; border-radius: var(--r-pill);
  border: 1px solid var(--line); background: var(--paper);
  color: var(--ink-2); font-size: 1rem; text-decoration: none;
  transition: all var(--t-2) var(--ease);
}
.hx-contact-social__row a:hover { background: var(--clay); border-color: var(--clay); color: var(--on-clay); }

/* Form card (right column) */
.hx-form-card {
  border: 1px solid var(--line); border-radius: var(--r-xl);
  background: var(--paper);
  padding: clamp(1.5rem, 1.25rem + 1.5vw, 2.25rem);
}
.hx-form-card__title {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.35rem);
  color: var(--ink); margin-bottom: 0.3rem;
}
.hx-form-card__sub { font-size: 0.88rem; color: var(--ink-3); margin-bottom: 1.5rem; }

.hx-form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
}
.hx-form-card .field { display: grid; gap: 0.38rem; margin-bottom: 1rem; }
.hx-form-card label { font-size: 0.82rem; font-weight: 600; color: var(--ink-2); }
.hx-form-actions {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: 0.5rem;
}
.hx-form-note { font-size: 0.8rem; color: var(--ink-3); }

@media (max-width: 768px) {
  .hx-contact-grid { grid-template-columns: 1fr; }
  .hx-form-row { grid-template-columns: 1fr; }
}

/* ============================================================================
   About Us â€” split hero + creative body
   ========================================================================== */

.hx-about-hero {
  background: var(--oxblood);
  padding: clamp(2rem, 1rem + 3vw, 3.5rem) 0;
  position: relative; overflow: hidden;
}
/* Subtle grid texture overlay */
.hx-about-hero::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 48px 48px;
}
/* Radial vignette on top of grid */
.hx-about-hero::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 100% at 60% 50%, transparent 30%, rgba(96,12,12,0.7) 100%);
}

/* Two-column split */
.hx-about-hero__split {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 6rem); align-items: center;
}
.hx-about-hero__tag {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.28rem 0.85rem; border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(255,255,255,0.55);
  margin-bottom: 1.4rem;
}
.hx-about-hero__headline {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(2.2rem, 1rem + 3.5vw, 4rem);
  color: #fff; line-height: 1.05; margin-bottom: 1.1rem;
}
.hx-about-hero__headline em { font-style: normal; color: var(--clay); }
.hx-about-hero__sub {
  font-size: clamp(0.95rem, 0.85rem + 0.4vw, 1.1rem);
  color: rgba(255,255,255,0.6); line-height: 1.7; margin-bottom: 2rem;
}
.hx-about-hero__links { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }

/* Primary button on dark bg */
.hx-btn--hero-primary {
  background: var(--clay); color: #fff;
  border: none; font-weight: 700;
  transition: background 0.2s, transform 0.15s;
}
.hx-btn--hero-primary:hover { background: #c44a1a; transform: translateY(-1px); }
.hx-btn--hero-ghost {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.22);
  color: rgba(255,255,255,0.8); font-weight: 600;
  transition: background 0.2s, border-color 0.2s;
}
.hx-btn--hero-ghost:hover { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.4); color: #fff; }

/* Right â€” glass stat card grid */
.hx-about-stat-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
}
.hx-about-stat-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-xl);
  padding: clamp(1.1rem, 1vw + 0.5rem, 1.6rem);
  display: flex; flex-direction: column; gap: 0.3rem;
  transition: background 0.25s, border-color 0.25s;
  position: relative; overflow: hidden;
}
.hx-about-stat-card::after {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
}
.hx-about-stat-card:hover {
  background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2);
}
.hx-about-stat-card__num {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.5rem, 0.8rem + 2vw, 2.4rem);
  color: var(--clay); line-height: 1;
}
.hx-about-stat-card__label {
  font-size: 0.78rem; color: rgba(255,255,255,0.48);
  font-weight: 500; line-height: 1.3;
}
/* Wide bottom card spanning full width */
.hx-about-stat-card--wide { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 1.25rem; }
.hx-about-stat-card--wide .hx-about-stat-card__num { font-size: clamp(1.8rem, 1rem + 2.5vw, 2.8rem); }
.hx-about-stat-card--wide .hx-about-stat-card__icon {
  width: 2.8rem; height: 2.8rem; border-radius: 50%;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  font-size: 1.2rem; color: var(--clay);
}

/* About body â€” two-col with decorative sidebar */
.hx-about-body {
  display: grid; grid-template-columns: 1fr 268px;
  gap: clamp(2.5rem, 2rem + 2vw, 4rem); align-items: start;
}
.hx-about-pull {
  position: sticky; top: calc(76px + 1.5rem);
  display: flex; flex-direction: column; gap: 1.25rem;
}
.hx-about-quote {
  padding: 1.35rem 1.5rem;
  border-left: 3px solid var(--clay);
  border-radius: 0 var(--r-lg) var(--r-lg) 0;
  background: var(--paper-2);
}
.hx-about-quote__text {
  font-size: 1rem; font-weight: 700; font-style: italic;
  color: var(--ink); line-height: 1.55; margin-bottom: 0.6rem;
}
.hx-about-quote__attr {
  font-size: 0.75rem; color: var(--ink-3); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
}
.hx-about-cta-card {
  padding: 1.5rem; border-radius: var(--r-xl);
  background: var(--oxblood);
  display: flex; flex-direction: column; gap: 0.75rem;
  position: relative; overflow: hidden;
}
.hx-about-cta-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, transparent 60%);
  pointer-events: none;
}
.hx-about-cta-card__title { font-weight: 800; font-size: 1.05rem; color: #fff; line-height: 1.2; }
.hx-about-cta-card__sub { font-size: 0.82rem; color: rgba(255,255,255,0.6); line-height: 1.5; }

/* About â€” editorial manifesto block (right side of split hero) */
.hx-about-manifesto {
  padding: 1.5rem 1.5rem 1.5rem 2.25rem;
  border-left: 2px solid rgba(255,255,255,0.18);
}
.hx-about-manifesto__icon {
  font-size: 1.8rem; color: var(--clay); margin-bottom: 1rem; line-height: 1;
}
.hx-about-manifesto__text {
  font-family: var(--font-body); font-weight: 800;
  font-size: clamp(1.8rem, 0.8rem + 2.8vw, 3.2rem);
  color: rgba(255,255,255,0.92);
  line-height: 1.1; margin-bottom: 1.75rem;
}
.hx-about-manifesto__text em { font-style: normal; color: var(--clay); }
.hx-about-manifesto__pills {
  display: flex; flex-wrap: wrap; gap: 0.55rem;
}
.hx-about-manifesto__pill {
  display: inline-flex; align-items: center; gap: 0.38rem;
  padding: 0.3rem 0.9rem; border-radius: var(--r-pill);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  font-size: 0.77rem; color: rgba(255,255,255,0.65); font-weight: 500;
}
.hx-about-manifesto__pill i { color: var(--clay); font-size: 0.75rem; }

/* CMS legal page â€” wide single-column prose */
.hx-cms-prose { max-width: 860px; }
.hx-cms-prose .hx-article__content { max-width: none; }

/* Page badge (legal pages) */
.hx-page-badge {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.22rem 0.75rem; border-radius: var(--r-pill);
  background: var(--clay-softer); color: var(--clay);
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; margin-bottom: 0.75rem;
}

/* Legal/doc page head â€” decorative large icon */
.hx-page-head--doc { position: relative; overflow: hidden; }
.hx-page-head--doc .hx-page-head__deco {
  position: absolute; right: max(2rem, 6%); top: 50%;
  transform: translateY(-50%);
  font-size: clamp(6rem, 9vw, 10rem);
  color: var(--clay);
  line-height: 1; pointer-events: none; user-select: none;
  opacity: 0.12;
}
.hx-doc-meta {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  margin-top: 0.75rem;
}
.hx-doc-meta__item {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.78rem; color: var(--ink-3);
}

@media (max-width: 900px) {
  .hx-about-hero__split { grid-template-columns: 1fr; }
  .hx-about-stat-grid { grid-template-columns: repeat(2, 1fr); }
  .hx-about-hero__stat-right { display: none; }
  .hx-about-body { grid-template-columns: 1fr; }
  .hx-about-pull { position: static; flex-direction: row; flex-wrap: wrap; }
  .hx-about-quote, .hx-about-cta-card { flex: 1; min-width: 230px; }
  .hx-page-head--doc .hx-page-head__deco { opacity: 0.2; font-size: 5rem; }
}
@media (max-width: 560px) {
  .hx-about-stat-grid { grid-template-columns: 1fr 1fr; }
  .hx-about-stat-card--wide { grid-column: 1 / -1; flex-direction: column; align-items: flex-start; }
}

/* ============================================================================
   Categories index â€” overlay card grid + live filter
   ============================================================================ */

/* Categories index â€” editorial page head modifier */
.hx-page-head--cats .hx-page-head__eyebrow {
  display: inline-flex; align-items: center; gap: 0.38rem;
  font-size: 0.65rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--clay); background: var(--clay-softer);
  border: 1px solid rgba(139,62,47,0.22); padding: 0.3rem 0.8rem;
  border-radius: var(--r-pill); margin-bottom: 1rem;
}

/* Filter â€” full-width row, prominent */
.hx-cat-filter-row { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; margin-bottom: clamp(1.75rem, 1.2rem + 1.5vw, 2.75rem); flex-wrap: wrap; }
.hx-cat-filter { position: relative; flex: 1; min-width: 240px; max-width: 520px; }
.hx-cat-filter i { position: absolute; left: 1.1rem; top: 50%; transform: translateY(-50%); color: var(--clay); font-size: 1rem; pointer-events: none; }
.hx-cat-filter__input { width: 100%; padding: 0.72rem 1.3rem 0.72rem 2.85rem; border: 1px solid var(--line); border-radius: var(--r-pill); background: var(--paper); color: var(--ink); font-size: 0.9rem; font-family: var(--hx-sans); font-weight: 500; transition: border-color 0.3s cubic-bezier(0.32,0.72,0,1), box-shadow 0.3s cubic-bezier(0.32,0.72,0,1); }
.hx-cat-filter__input:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px var(--clay-softer); }
.hx-cat-filter__input::placeholder { color: var(--ink-3); font-weight: 400; }
.hx-cat-filter-count { font-size: 0.75rem; font-weight: 700; color: var(--ink-3); letter-spacing: 0.04em; white-space: nowrap; }

/* Overlay card grid */
.hx-cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(0.65rem, 0.4rem + 1vw, 1.25rem); align-items: start; }

/* Group: card + inline subcategory list stacked */
.hx-cat-group { display: flex; flex-direction: column; gap: 0.5rem; }
.hx-cat-group--wide { grid-column: span 2; }

/* When subs present: group expands horizontally â€” card left, subs right */
.hx-cat-group--has-subs {
  grid-column: span 2;
  flex-direction: row;
  gap: 0;
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 2px 12px -4px rgba(6,2,2,0.08);
  transition: transform 0.5s cubic-bezier(0.32,0.72,0,1),
              box-shadow 0.5s cubic-bezier(0.32,0.72,0,1);
}
.hx-cat-group--has-subs:hover {
  transform: translateY(-5px);
  box-shadow: 0 2px 12px -4px rgba(6,2,2,0.08), 0 22px 55px -12px rgba(6,2,2,0.22);
}
/* Card: left half, square, no self-radius */
.hx-cat-group--has-subs .hx-cat-card,
.hx-cat-group--has-subs .hx-cat-card--wide {
  flex: 0 0 50%;
  aspect-ratio: 1 / 1;
  border-radius: 0;
}
.hx-cat-group--has-subs .hx-cat-card:hover { transform: none; box-shadow: none; }

/* Subs panel: right half */
.hx-cat-group__subs {
  flex: 1;
  background: var(--paper);
  border-left: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hx-cat-group__sub {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.55rem 0.9rem;
  border-bottom: 1px solid var(--line);
  color: var(--ink-2); font-size: 0.78rem; font-weight: 500;
  text-decoration: none;
  transition: background 0.22s cubic-bezier(0.32,0.72,0,1),
              color 0.22s cubic-bezier(0.32,0.72,0,1);
}
.hx-cat-group__sub:last-child { border-bottom: none; }
.hx-cat-group__sub:hover { background: var(--clay-softer); color: var(--clay); }
.hx-cat-group__sub i { font-size: 0.75rem; color: var(--clay); opacity: 0.55; flex-shrink: 0; transition: opacity 0.22s; }
.hx-cat-group__sub:hover i { opacity: 1; }
.hx-cat-group__sub-name { flex: 1; }
.hx-cat-group__sub-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 1.55rem; height: 1.55rem; padding: 0 0.32rem;
  border-radius: 50%; border: 1px solid var(--line);
  font-size: 0.6rem; font-weight: 800; color: var(--ink-3);
  flex-shrink: 0;
  transition: border-color 0.22s, color 0.22s, background 0.22s;
}
.hx-cat-group__sub:hover .hx-cat-group__sub-count {
  background: var(--clay); border-color: var(--clay); color: #fff;
}

.hx-cat-card { position: relative; display: block; text-decoration: none; border-radius: var(--r-xl); overflow: hidden; aspect-ratio: 1 / 1; background: var(--oxblood); transition: transform 0.5s cubic-bezier(0.32,0.72,0,1), box-shadow 0.5s cubic-bezier(0.32,0.72,0,1); }
.hx-cat-card:hover { transform: translateY(-6px) scale(1.013); box-shadow: 0 24px 60px -14px rgba(6,2,2,0.38); }
.hx-cat-card--wide { aspect-ratio: 2 / 1; }

.hx-cat-card__bg { position: absolute; inset: 0; overflow: hidden; }
.hx-cat-card__bg img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.65s cubic-bezier(0.32,0.72,0,1); }
.hx-cat-card:hover .hx-cat-card__bg img { transform: scale(1.08); }

.hx-cat-card__fallback { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.hx-cat-card__fallback::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, var(--oxblood) 0%, var(--clay-700) 100%); }
.hx-cat-card__fallback i { position: relative; z-index: 1; font-size: 2.8rem; color: rgba(255,255,255,0.13); }

.hx-cat-card__scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(6,2,2,0.95) 0%, rgba(6,2,2,0.62) 52%, rgba(6,2,2,0.08) 100%); }
.hx-cat-card--wide .hx-cat-card__scrim { background: linear-gradient(to right, rgba(6,2,2,0.88) 0%, rgba(6,2,2,0.38) 60%, rgba(6,2,2,0.04) 100%), linear-gradient(to top, rgba(6,2,2,0.7) 0%, transparent 55%); }

.hx-cat-card__body { position: absolute; bottom: 0; left: 0; right: 0; z-index: 1; padding: 1rem 1.1rem 1.15rem; }
.hx-cat-card--wide .hx-cat-card__body { top: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 1.35rem 1.5rem 1.5rem; }

.hx-cat-card__count { display: block; font-size: 0.65rem; font-weight: 800; color: var(--clay-soft); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 0.22rem; }
.hx-cat-card__name { font-family: var(--hx-sans); font-weight: 800; font-size: clamp(0.9rem, 0.78rem + 0.5vw, 1.15rem); color: #fff; line-height: 1.18; letter-spacing: -0.015em; }
.hx-cat-card--wide .hx-cat-card__name { font-size: clamp(1.2rem, 0.9rem + 1.2vw, 1.8rem); }

/* Empty state */
.hx-empty { text-align: center; padding: clamp(3.5rem, 4vw, 5.5rem) 2rem; }
.hx-empty i { font-size: 2.4rem; display: block; margin-bottom: 0.65rem; color: var(--hx-line-2); }
.hx-empty p { color: var(--hx-ink-3); font-size: 0.95rem; }

@media (max-width: 960px) { .hx-cat-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) {
  .hx-cat-grid { grid-template-columns: repeat(2, 1fr); gap: 0.55rem; }
  .hx-cat-card { aspect-ratio: 4/5; }
  .hx-cat-card--wide { aspect-ratio: 16/9; }
}
@media (max-width: 380px) {
  .hx-cat-grid { grid-template-columns: 1fr; }
  .hx-cat-group--wide { grid-column: span 1; }
  .hx-cat-card--wide { aspect-ratio: 4/3; }
}

/* ============================================================================
   Category show â€” hero + subcategories strip + related categories
   ============================================================================ */

/* â”€â”€ Category hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hx-cat-hero { position: relative; overflow: hidden; background: var(--paper-2); border-bottom: 1px solid var(--line); }
.hx-cat-hero--img { border-bottom: none; background: var(--oxblood); min-height: 300px; display: flex; flex-direction: column; justify-content: center; }
.hx-cat-hero__bg { position: absolute; inset: 0; }
.hx-cat-hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.3; }
.hx-cat-hero__scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(6,2,2,0.9) 0%, rgba(6,2,2,0.62) 55%, rgba(6,2,2,0.3) 100%); }
.hx-cat-hero__body { position: relative; z-index: 1; padding-top: clamp(1.75rem, 2.5vw, 2.75rem); padding-bottom: clamp(2rem, 2.8vw, 3.25rem); text-align: center; }
.hx-cat-hero__body .hx-breadcrumb { justify-content: center; }
.hx-cat-hero__text { display: flex; flex-direction: column; align-items: center; gap: 0.6rem; margin-top: 1rem; }
.hx-cat-hero__title { font-family: var(--hx-sans); font-weight: 800; font-size: clamp(1.5rem, 1rem + 2.5vw, 2.75rem); line-height: 1.1; letter-spacing: -0.025em; color: var(--ink); }
.hx-cat-hero--img .hx-cat-hero__title { color: #fff; }
.hx-cat-hero__desc { font-size: 0.92rem; line-height: 1.65; max-width: 54ch; color: var(--ink-3); }
.hx-cat-hero--img .hx-cat-hero__desc { color: rgba(255,255,255,0.6); }

/* Badge */
.hx-cat-head__badge { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.38rem 0.9rem; border-radius: var(--r-pill); background: var(--clay-softer); color: var(--clay); font-size: 0.75rem; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; }
.hx-cat-head__badge--light { background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.88); border: 1px solid rgba(255,255,255,0.18); }

/* Breadcrumb on dark hero */
.hx-breadcrumb--light a { color: rgba(255,255,255,0.5); }
.hx-breadcrumb--light a:hover { color: rgba(255,255,255,0.9); }
.hx-breadcrumb--light span { color: rgba(255,255,255,0.75); }
.hx-breadcrumb--light i { color: rgba(255,255,255,0.25); }

/* â”€â”€ Subcategories bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hx-cat-subtopics-bar { border-bottom: 1px solid var(--hx-line); background: var(--hx-surface); }
.hx-cat-subtopics-bar .hx-wrap { display: flex; align-items: center; gap: 1rem; padding-top: 0.7rem; padding-bottom: 0.7rem; flex-wrap: wrap; }
.hx-cat-subtopics-label { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.7rem; font-weight: 700; color: var(--hx-ink-3); letter-spacing: 0.09em; text-transform: uppercase; white-space: nowrap; flex-shrink: 0; }
.hx-cat-subtopics { display: flex; flex-wrap: wrap; gap: 0.38rem; }
.hx-cat-subtopic { display: inline-flex; align-items: center; gap: 0.38rem; padding: 0.26rem 0.8rem; border-radius: var(--r-pill); border: 1px solid var(--hx-line); background: transparent; color: var(--hx-ink-2); font-size: 0.8rem; font-weight: 500; transition: border-color 0.2s, color 0.2s, background 0.2s; }
.hx-cat-subtopic:hover { border-color: var(--clay); color: var(--clay); background: var(--clay-softer); }
.hx-cat-subtopic__count { background: var(--hx-line); border-radius: var(--r-pill); padding: 0.05rem 0.38rem; font-size: 0.62rem; font-weight: 700; color: var(--hx-ink-3); }

/* â”€â”€ Related categories â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hx-related-cats { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: clamp(1.5rem, 1.2rem + 1vw, 2.25rem); }
.hx-related-cat { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.42rem 1rem; border-radius: var(--r-pill); border: 1px solid var(--hx-line); background: var(--hx-surface); color: var(--hx-ink-2); font-size: 0.855rem; font-weight: 500; transition: border-color 0.22s, color 0.22s, background 0.22s; }
.hx-related-cat:hover { border-color: var(--clay); color: var(--clay); background: var(--clay-softer); }
.hx-related-cat__count { background: var(--hx-line); border-radius: var(--r-pill); padding: 0.08rem 0.44rem; font-size: 0.7rem; color: var(--hx-ink-3); font-weight: 700; }

/* ============================================================================
   @@APPEND_POINT@@  â€” per-page section styles get inserted above this line
   ========================================================================== */

/* ---- Responsive ---------------------------------------------------------- */
@media (max-width: 1024px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__visual { order: -1; max-width: 560px; }
  .editorial-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .cat-mosaic { columns: 3; }
}
@media (max-width: 880px) {
  .hdr__nav, .hdr__cta-explore { display: none; }
  .hdr__burger { display: flex; }
  .news-band { grid-template-columns: 1fr; }
  .hx-srow { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .hdr { height: 64px; }
  .mobile-nav { inset-block-start: 64px; }
  .ticket { grid-template-columns: 1fr; }
  .ticket__stub { border-left: none; border-top: 2px dashed var(--line-2); flex-direction: row; justify-content: space-between; min-width: 0; }
  .ticket__stub::before, .ticket__stub::after { left: auto; top: auto; }
  .ticket__stub::before { top: -11px; left: -11px; }
  .ticket__stub::after { top: -11px; right: -11px; bottom: auto; left: auto; }
  .footer-top { grid-template-columns: 1fr; gap: var(--sp-5); }
  .cat-mosaic { columns: 2; }
  .cat-tile { height: 180px; }
  .cat-tile--tall { height: 240px; }
  .post-card--row { flex-direction: column; }
  .post-card--row .post-card__img { width: 100%; aspect-ratio: 16 / 10; }
  .deals-grid { grid-template-columns: 1fr; }
  .ss-head { align-items: flex-start; }
  .hx-srow { grid-template-columns: 1fr; }
}

/* ---- Reduced motion ------------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ---- Print --------------------------------------------------------------- */
@media print {
  .site-header, .site-footer, .to-top, .cmodal, .hero__dots { display: none !important; }
  body { background: #fff; color: #000; }
}

/* ============================================================================
   BLOG ENGINE â€” coupon blocks, comparison table, FAQ, store CTA  (ss- prefix)
   ========================================================================== */

/* Coupon block */
.ss-coupon-block {
  display: flex; align-items: center; gap: 1rem;
  background: var(--clay-softer); border: 1px solid rgba(139,62,47,0.22);
  border-radius: var(--r-lg); padding: 1rem 1.25rem;
  margin: 1.75rem 0; flex-wrap: wrap;
}
.ss-coupon-store {
  font-size: 0.65rem; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--clay); flex-shrink: 0;
}
.ss-coupon-title {
  flex: 1; font-size: var(--fs-400); font-weight: 700; color: var(--ink);
  min-width: 140px;
}
.ss-coupon-cta {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.55rem 1.1rem; background: var(--clay); color: var(--on-clay);
  border-radius: var(--r-pill); font-size: var(--fs-200); font-weight: 800;
  letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none;
  transition: background 0.25s cubic-bezier(0.32,0.72,0,1); white-space: nowrap;
}
.ss-coupon-cta:hover { background: var(--clay-deep); }

/* Comparison table */
.ss-compare-table {
  width: 100%; border-collapse: collapse;
  margin: 1.75rem 0; font-size: var(--fs-300);
}
.ss-compare-table th {
  background: var(--paper-2); font-weight: 800; font-size: var(--fs-200);
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.7rem 0.9rem; text-align: left;
  border-bottom: 2px solid var(--line);
}
.ss-compare-table td {
  padding: 0.65rem 0.9rem; border-bottom: 1px solid var(--line); color: var(--ink-2);
}
.ss-compare-table tr:last-child td { border-bottom: none; }
.ss-compare-table a { color: var(--clay); font-weight: 700; text-decoration: none; white-space: nowrap; }
.ss-compare-table a:hover { text-decoration: underline; }

/* In-article store CTA */
.ss-store-cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  margin-top: 1.25rem; padding: 0.75rem 1.5rem;
  background: var(--clay); color: var(--on-clay);
  border-radius: var(--r-pill); font-weight: 800; font-size: var(--fs-400);
  text-decoration: none;
  transition: background 0.25s cubic-bezier(0.32,0.72,0,1), transform 0.25s cubic-bezier(0.32,0.72,0,1);
}
.ss-store-cta:hover { background: var(--clay-deep); transform: translateY(-2px); }

/* FAQ section â€” Schema.org FAQPage compatible */
.ss-faq {
  margin-top: 2.5rem; border-top: 2px solid var(--line); padding-top: 1.75rem;
}
.ss-faq > h2 {
  font-size: var(--fs-600); font-weight: 800; margin-bottom: 1.25rem;
}
.ss-faq__item {
  border-bottom: 1px solid var(--line); padding: 0;
}
.ss-faq__item:last-child { border-bottom: none; }
/* Accordion: question is the toggle, answer collapses (JS sets max-height) */
.ss-faq__q {
  font-size: var(--fs-400); font-weight: 700; color: var(--ink);
  margin: 0; cursor: pointer; position: relative;
  padding: 1.1rem 2.25rem 1.1rem 0; list-style: none;
  transition: color 0.2s ease;
}
.ss-faq__q:hover { color: var(--clay); }
.ss-faq__q::after {
  content: ''; position: absolute; right: 0.4rem; top: 50%;
  width: 0.7rem; height: 0.7rem; margin-top: -0.45rem;
  border-right: 2px solid var(--clay); border-bottom: 2px solid var(--clay);
  transform: rotate(45deg); transform-origin: center;
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
}
.ss-faq__q.is-open::after { transform: rotate(-135deg); margin-top: -0.2rem; }
.ss-faq__a {
  font-size: var(--fs-300); color: var(--ink-2); line-height: 1.65;
  max-height: 0; overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.32,0.72,0,1);
}
.ss-faq__q.is-open + .ss-faq__a { padding-bottom: 1.1rem; }
.ss-faq__a div { margin: 0; }

/* Blog-engine CTA buttons sit inside .hx-article__content, whose `a` rule (clay text +
   underline) would otherwise make these clay-on-clay buttons unreadable. Override it. */
.ss-coupon-block .ss-coupon-cta,
a.ss-store-cta {
  color: var(--on-clay); text-decoration: none;
}
.ss-coupon-block .ss-coupon-cta:hover { color: var(--on-clay); }
a.ss-store-cta:hover { color: var(--on-clay); text-decoration: none; }
.ss-compare-table a, .ss-related__list a { text-decoration: none; }

/* Inline blog images (AI-generated, contextual) */
.ss-blog-figure {
  margin: 2rem 0; padding: 0; border-radius: var(--r-lg); overflow: hidden;
  background: var(--paper-2); border: 1px solid var(--line);
  box-shadow: 0 18px 40px -24px rgba(54,32,24,0.45);
}
.ss-blog-figure img {
  display: block; width: 100%; height: auto; object-fit: cover;
}
.ss-blog-figure figcaption {
  font-size: var(--fs-200); color: var(--ink-3, var(--ink-2));
  padding: 0.6rem 0.9rem; letter-spacing: 0.01em;
  border-top: 1px solid var(--line); background: var(--paper);
}
.ss-blog-figure .ss-credit { opacity: 0.6; font-style: italic; margin-left: 0.4rem; }

/* Related guides â€” blog-to-blog interlinking.
   Selectors are doubled-up (.ss-related .ss-related__list) to out-rank the theme's
   generic `.hx-article__content ul { display:grid; padding-left:1.5rem }` rule. */
.ss-related {
  margin-top: 2.5rem; border-top: 2px solid var(--line); padding-top: 1.5rem; clear: both;
}
.ss-related > h2 { font-size: var(--fs-500); font-weight: 800; margin: 0 0 1rem; }
.ss-related .ss-related__list {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.6rem;
}
.ss-related .ss-related__list li { margin: 0; padding: 0; }
.ss-related__list a {
  display: block; padding: 0.7rem 1rem; border-radius: var(--r-md, 12px);
  background: var(--clay-softer); color: var(--clay); font-weight: 700;
  text-decoration: none; font-size: var(--fs-300);
  transition: background 0.25s cubic-bezier(0.32,0.72,0,1), transform 0.25s cubic-bezier(0.32,0.72,0,1);
}
.ss-related__list a:hover { background: var(--clay); color: var(--on-clay); transform: translateY(-2px); }

@media (max-width: 640px) {
  .ss-coupon-block { flex-direction: column; align-items: flex-start; }
  .ss-compare-table { font-size: var(--fs-200); }
  .ss-compare-table th, .ss-compare-table td { padding: 0.5rem 0.6rem; }
  .ss-faq > h2 { font-size: var(--fs-500); }
  .ss-blog-figure { margin: 1.5rem 0; }
  .ss-related__list { grid-template-columns: 1fr; }
}
