/* Layout grid (mobile-first; breakpoints 576/768/992/1200/1400). */
:root {
  --kx-gutter-x: 1.5rem;
  --kx-gutter-y: 0;
}

/* ---------- Container ---------- */
.kx-container,
.kx-container-fluid,
.kx-container-sm,
.kx-container-md,
.kx-container-lg,
.kx-container-xl,
.kx-container-xxl {
  width: 100%;
  padding-right: calc(var(--kx-gutter-x) * .5);
  padding-left: calc(var(--kx-gutter-x) * .5);
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  .kx-container,
  .kx-container-sm { max-width: 540px; }
}
@media (min-width: 768px) {
  .kx-container,
  .kx-container-sm,
  .kx-container-md { max-width: 720px; }
}
@media (min-width: 992px) {
  .kx-container,
  .kx-container-sm,
  .kx-container-md,
  .kx-container-lg { max-width: 960px; }
}
@media (min-width: 1200px) {
  .kx-container,
  .kx-container-sm,
  .kx-container-md,
  .kx-container-lg,
  .kx-container-xl { max-width: 1140px; }
}
@media (min-width: 1400px) {
  .kx-container,
  .kx-container-sm,
  .kx-container-md,
  .kx-container-lg,
  .kx-container-xl,
  .kx-container-xxl { max-width: 1320px; }
}

/* ---------- Row ---------- */
.kx-row {
  --kx-gutter-x: 1.5rem;
  --kx-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(var(--kx-gutter-y) * -1);
  margin-right: calc(var(--kx-gutter-x) * -.5);
  margin-left: calc(var(--kx-gutter-x) * -.5);
}
.kx-row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--kx-gutter-x) * .5);
  padding-left: calc(var(--kx-gutter-x) * .5);
  margin-top: var(--kx-gutter-y);
}

/* ---------- Cols (xs, mobile baseline) ---------- */
.kx-col       { flex: 1 0 0%; }
.kx-col-auto  { flex: 0 0 auto; width: auto; }
.kx-col-1  { flex: 0 0 auto; width: 8.33333333%; }
.kx-col-2  { flex: 0 0 auto; width: 16.66666667%; }
.kx-col-3  { flex: 0 0 auto; width: 25%; }
.kx-col-4  { flex: 0 0 auto; width: 33.33333333%; }
.kx-col-5  { flex: 0 0 auto; width: 41.66666667%; }
.kx-col-6  { flex: 0 0 auto; width: 50%; }
.kx-col-7  { flex: 0 0 auto; width: 58.33333333%; }
.kx-col-8  { flex: 0 0 auto; width: 66.66666667%; }
.kx-col-9  { flex: 0 0 auto; width: 75%; }
.kx-col-10 { flex: 0 0 auto; width: 83.33333333%; }
.kx-col-11 { flex: 0 0 auto; width: 91.66666667%; }
.kx-col-12 { flex: 0 0 auto; width: 100%; }

/* ---------- Offsets (xs) ---------- */
.kx-offset-1  { margin-left: 8.33333333%; }
.kx-offset-2  { margin-left: 16.66666667%; }
.kx-offset-3  { margin-left: 25%; }
.kx-offset-4  { margin-left: 33.33333333%; }
.kx-offset-5  { margin-left: 41.66666667%; }
.kx-offset-6  { margin-left: 50%; }
.kx-offset-7  { margin-left: 58.33333333%; }
.kx-offset-8  { margin-left: 66.66666667%; }
.kx-offset-9  { margin-left: 75%; }
.kx-offset-10 { margin-left: 83.33333333%; }
.kx-offset-11 { margin-left: 91.66666667%; }

/* ---------- Order (xs) ---------- */
.kx-order-first { order: -1; }
.kx-order-last  { order: 6; }
.kx-order-0 { order: 0; }
.kx-order-1 { order: 1; }
.kx-order-2 { order: 2; }
.kx-order-3 { order: 3; }
.kx-order-4 { order: 4; }
.kx-order-5 { order: 5; }

/* ---------- Gutters (xs) ---------- */
.kx-g-0,  .kx-gx-0 { --kx-gutter-x: 0; }
.kx-g-0,  .kx-gy-0 { --kx-gutter-y: 0; }
.kx-g-1,  .kx-gx-1 { --kx-gutter-x: .25rem; }
.kx-g-1,  .kx-gy-1 { --kx-gutter-y: .25rem; }
.kx-g-2,  .kx-gx-2 { --kx-gutter-x: .5rem; }
.kx-g-2,  .kx-gy-2 { --kx-gutter-y: .5rem; }
.kx-g-3,  .kx-gx-3 { --kx-gutter-x: 1rem; }
.kx-g-3,  .kx-gy-3 { --kx-gutter-y: 1rem; }
.kx-g-4,  .kx-gx-4 { --kx-gutter-x: 1.5rem; }
.kx-g-4,  .kx-gy-4 { --kx-gutter-y: 1.5rem; }
.kx-g-5,  .kx-gx-5 { --kx-gutter-x: 3rem; }
.kx-g-5,  .kx-gy-5 { --kx-gutter-y: 3rem; }

/* ============================================================
   sm (>= 576px)
   ============================================================ */
@media (min-width: 576px) {
  .kx-col-sm       { flex: 1 0 0%; }
  .kx-col-sm-auto  { flex: 0 0 auto; width: auto; }
  .kx-col-sm-1  { flex: 0 0 auto; width: 8.33333333%; }
  .kx-col-sm-2  { flex: 0 0 auto; width: 16.66666667%; }
  .kx-col-sm-3  { flex: 0 0 auto; width: 25%; }
  .kx-col-sm-4  { flex: 0 0 auto; width: 33.33333333%; }
  .kx-col-sm-5  { flex: 0 0 auto; width: 41.66666667%; }
  .kx-col-sm-6  { flex: 0 0 auto; width: 50%; }
  .kx-col-sm-7  { flex: 0 0 auto; width: 58.33333333%; }
  .kx-col-sm-8  { flex: 0 0 auto; width: 66.66666667%; }
  .kx-col-sm-9  { flex: 0 0 auto; width: 75%; }
  .kx-col-sm-10 { flex: 0 0 auto; width: 83.33333333%; }
  .kx-col-sm-11 { flex: 0 0 auto; width: 91.66666667%; }
  .kx-col-sm-12 { flex: 0 0 auto; width: 100%; }
  .kx-offset-sm-0  { margin-left: 0; }
  .kx-offset-sm-1  { margin-left: 8.33333333%; }
  .kx-offset-sm-2  { margin-left: 16.66666667%; }
  .kx-offset-sm-3  { margin-left: 25%; }
  .kx-offset-sm-4  { margin-left: 33.33333333%; }
  .kx-offset-sm-5  { margin-left: 41.66666667%; }
  .kx-offset-sm-6  { margin-left: 50%; }
  .kx-offset-sm-7  { margin-left: 58.33333333%; }
  .kx-offset-sm-8  { margin-left: 66.66666667%; }
  .kx-offset-sm-9  { margin-left: 75%; }
  .kx-offset-sm-10 { margin-left: 83.33333333%; }
  .kx-offset-sm-11 { margin-left: 91.66666667%; }
  .kx-order-sm-first { order: -1; }
  .kx-order-sm-last  { order: 6; }
  .kx-order-sm-0 { order: 0; }
  .kx-order-sm-1 { order: 1; }
  .kx-order-sm-2 { order: 2; }
  .kx-order-sm-3 { order: 3; }
  .kx-order-sm-4 { order: 4; }
  .kx-order-sm-5 { order: 5; }
}

/* ============================================================
   md (>= 768px)
   ============================================================ */
@media (min-width: 768px) {
  .kx-col-md       { flex: 1 0 0%; }
  .kx-col-md-auto  { flex: 0 0 auto; width: auto; }
  .kx-col-md-1  { flex: 0 0 auto; width: 8.33333333%; }
  .kx-col-md-2  { flex: 0 0 auto; width: 16.66666667%; }
  .kx-col-md-3  { flex: 0 0 auto; width: 25%; }
  .kx-col-md-4  { flex: 0 0 auto; width: 33.33333333%; }
  .kx-col-md-5  { flex: 0 0 auto; width: 41.66666667%; }
  .kx-col-md-6  { flex: 0 0 auto; width: 50%; }
  .kx-col-md-7  { flex: 0 0 auto; width: 58.33333333%; }
  .kx-col-md-8  { flex: 0 0 auto; width: 66.66666667%; }
  .kx-col-md-9  { flex: 0 0 auto; width: 75%; }
  .kx-col-md-10 { flex: 0 0 auto; width: 83.33333333%; }
  .kx-col-md-11 { flex: 0 0 auto; width: 91.66666667%; }
  .kx-col-md-12 { flex: 0 0 auto; width: 100%; }
  .kx-offset-md-0  { margin-left: 0; }
  .kx-offset-md-1  { margin-left: 8.33333333%; }
  .kx-offset-md-2  { margin-left: 16.66666667%; }
  .kx-offset-md-3  { margin-left: 25%; }
  .kx-offset-md-4  { margin-left: 33.33333333%; }
  .kx-offset-md-5  { margin-left: 41.66666667%; }
  .kx-offset-md-6  { margin-left: 50%; }
  .kx-offset-md-7  { margin-left: 58.33333333%; }
  .kx-offset-md-8  { margin-left: 66.66666667%; }
  .kx-offset-md-9  { margin-left: 75%; }
  .kx-offset-md-10 { margin-left: 83.33333333%; }
  .kx-offset-md-11 { margin-left: 91.66666667%; }
  .kx-order-md-first { order: -1; }
  .kx-order-md-last  { order: 6; }
  .kx-order-md-0 { order: 0; }
  .kx-order-md-1 { order: 1; }
  .kx-order-md-2 { order: 2; }
  .kx-order-md-3 { order: 3; }
  .kx-order-md-4 { order: 4; }
  .kx-order-md-5 { order: 5; }
}

/* ============================================================
   lg (>= 992px)
   ============================================================ */
@media (min-width: 992px) {
  .kx-col-lg       { flex: 1 0 0%; }
  .kx-col-lg-auto  { flex: 0 0 auto; width: auto; }
  .kx-col-lg-1  { flex: 0 0 auto; width: 8.33333333%; }
  .kx-col-lg-2  { flex: 0 0 auto; width: 16.66666667%; }
  .kx-col-lg-3  { flex: 0 0 auto; width: 25%; }
  .kx-col-lg-4  { flex: 0 0 auto; width: 33.33333333%; }
  .kx-col-lg-5  { flex: 0 0 auto; width: 41.66666667%; }
  .kx-col-lg-6  { flex: 0 0 auto; width: 50%; }
  .kx-col-lg-7  { flex: 0 0 auto; width: 58.33333333%; }
  .kx-col-lg-8  { flex: 0 0 auto; width: 66.66666667%; }
  .kx-col-lg-9  { flex: 0 0 auto; width: 75%; }
  .kx-col-lg-10 { flex: 0 0 auto; width: 83.33333333%; }
  .kx-col-lg-11 { flex: 0 0 auto; width: 91.66666667%; }
  .kx-col-lg-12 { flex: 0 0 auto; width: 100%; }
  .kx-offset-lg-0  { margin-left: 0; }
  .kx-offset-lg-1  { margin-left: 8.33333333%; }
  .kx-offset-lg-2  { margin-left: 16.66666667%; }
  .kx-offset-lg-3  { margin-left: 25%; }
  .kx-offset-lg-4  { margin-left: 33.33333333%; }
  .kx-offset-lg-5  { margin-left: 41.66666667%; }
  .kx-offset-lg-6  { margin-left: 50%; }
  .kx-offset-lg-7  { margin-left: 58.33333333%; }
  .kx-offset-lg-8  { margin-left: 66.66666667%; }
  .kx-offset-lg-9  { margin-left: 75%; }
  .kx-offset-lg-10 { margin-left: 83.33333333%; }
  .kx-offset-lg-11 { margin-left: 91.66666667%; }
  .kx-order-lg-first { order: -1; }
  .kx-order-lg-last  { order: 6; }
  .kx-order-lg-0 { order: 0; }
  .kx-order-lg-1 { order: 1; }
  .kx-order-lg-2 { order: 2; }
  .kx-order-lg-3 { order: 3; }
  .kx-order-lg-4 { order: 4; }
  .kx-order-lg-5 { order: 5; }
}

/* ============================================================
   xl (>= 1200px)
   ============================================================ */
@media (min-width: 1200px) {
  .kx-col-xl       { flex: 1 0 0%; }
  .kx-col-xl-auto  { flex: 0 0 auto; width: auto; }
  .kx-col-xl-1  { flex: 0 0 auto; width: 8.33333333%; }
  .kx-col-xl-2  { flex: 0 0 auto; width: 16.66666667%; }
  .kx-col-xl-3  { flex: 0 0 auto; width: 25%; }
  .kx-col-xl-4  { flex: 0 0 auto; width: 33.33333333%; }
  .kx-col-xl-5  { flex: 0 0 auto; width: 41.66666667%; }
  .kx-col-xl-6  { flex: 0 0 auto; width: 50%; }
  .kx-col-xl-7  { flex: 0 0 auto; width: 58.33333333%; }
  .kx-col-xl-8  { flex: 0 0 auto; width: 66.66666667%; }
  .kx-col-xl-9  { flex: 0 0 auto; width: 75%; }
  .kx-col-xl-10 { flex: 0 0 auto; width: 83.33333333%; }
  .kx-col-xl-11 { flex: 0 0 auto; width: 91.66666667%; }
  .kx-col-xl-12 { flex: 0 0 auto; width: 100%; }
  .kx-offset-xl-0  { margin-left: 0; }
  .kx-offset-xl-1  { margin-left: 8.33333333%; }
  .kx-offset-xl-2  { margin-left: 16.66666667%; }
  .kx-offset-xl-3  { margin-left: 25%; }
  .kx-offset-xl-4  { margin-left: 33.33333333%; }
  .kx-offset-xl-5  { margin-left: 41.66666667%; }
  .kx-offset-xl-6  { margin-left: 50%; }
  .kx-offset-xl-7  { margin-left: 58.33333333%; }
  .kx-offset-xl-8  { margin-left: 66.66666667%; }
  .kx-offset-xl-9  { margin-left: 75%; }
  .kx-offset-xl-10 { margin-left: 83.33333333%; }
  .kx-offset-xl-11 { margin-left: 91.66666667%; }
  .kx-order-xl-first { order: -1; }
  .kx-order-xl-last  { order: 6; }
  .kx-order-xl-0 { order: 0; }
  .kx-order-xl-1 { order: 1; }
  .kx-order-xl-2 { order: 2; }
  .kx-order-xl-3 { order: 3; }
  .kx-order-xl-4 { order: 4; }
  .kx-order-xl-5 { order: 5; }
}

/* ============================================================
   xxl (>= 1400px)
   ============================================================ */
@media (min-width: 1400px) {
  .kx-col-xxl       { flex: 1 0 0%; }
  .kx-col-xxl-auto  { flex: 0 0 auto; width: auto; }
  .kx-col-xxl-1  { flex: 0 0 auto; width: 8.33333333%; }
  .kx-col-xxl-2  { flex: 0 0 auto; width: 16.66666667%; }
  .kx-col-xxl-3  { flex: 0 0 auto; width: 25%; }
  .kx-col-xxl-4  { flex: 0 0 auto; width: 33.33333333%; }
  .kx-col-xxl-5  { flex: 0 0 auto; width: 41.66666667%; }
  .kx-col-xxl-6  { flex: 0 0 auto; width: 50%; }
  .kx-col-xxl-7  { flex: 0 0 auto; width: 58.33333333%; }
  .kx-col-xxl-8  { flex: 0 0 auto; width: 66.66666667%; }
  .kx-col-xxl-9  { flex: 0 0 auto; width: 75%; }
  .kx-col-xxl-10 { flex: 0 0 auto; width: 83.33333333%; }
  .kx-col-xxl-11 { flex: 0 0 auto; width: 91.66666667%; }
  .kx-col-xxl-12 { flex: 0 0 auto; width: 100%; }
  .kx-offset-xxl-0  { margin-left: 0; }
  .kx-offset-xxl-1  { margin-left: 8.33333333%; }
  .kx-offset-xxl-2  { margin-left: 16.66666667%; }
  .kx-offset-xxl-3  { margin-left: 25%; }
  .kx-offset-xxl-4  { margin-left: 33.33333333%; }
  .kx-offset-xxl-5  { margin-left: 41.66666667%; }
  .kx-offset-xxl-6  { margin-left: 50%; }
  .kx-offset-xxl-7  { margin-left: 58.33333333%; }
  .kx-offset-xxl-8  { margin-left: 66.66666667%; }
  .kx-offset-xxl-9  { margin-left: 75%; }
  .kx-offset-xxl-10 { margin-left: 83.33333333%; }
  .kx-offset-xxl-11 { margin-left: 91.66666667%; }
  .kx-order-xxl-first { order: -1; }
  .kx-order-xxl-last  { order: 6; }
  .kx-order-xxl-0 { order: 0; }
  .kx-order-xxl-1 { order: 1; }
  .kx-order-xxl-2 { order: 2; }
  .kx-order-xxl-3 { order: 3; }
  .kx-order-xxl-4 { order: 4; }
  .kx-order-xxl-5 { order: 5; }
}


/* ============================================================
   REFAB 3 HOMES LLC -- Wallpaper Magazine design system, kx prefix.
   Editorial mag, gallery whitespace, oversized serif, terracotta.
   ============================================================ */

:root {
  --kx-bg: #fafafa;
  --kx-surface: #f0e8d8;
  --kx-surface-2: #ffffff;
  --kx-text: #1a1a1a;
  --kx-text-muted: #5c5c5c;
  --kx-border: #d4c8b8;
  --kx-accent: #a0744a;
  --kx-accent-deep: #6e4c2a;
  --kx-secondary: #3a4f3a;
  --kx-warn: #b94e2b;
  --kx-dark: #1f261f;
  --kx-display: 'Abril Fatface', Georgia, 'Times New Roman', serif;
  --kx-body: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
body {
  font-family: var(--kx-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--kx-text);
  background: var(--kx-bg);
  -webkit-font-smoothing: antialiased;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--kx-accent-deep); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--kx-text); }
h1, h2, h3, h4 {
  font-family: var(--kx-display);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0 0 0.5em;
  color: var(--kx-text);
}
p { margin: 0 0 1em; }
ul, ol { margin: 0 0 1em; padding-left: 1.4em; }
li { margin-bottom: 0.4em; }
strong { font-weight: 700; }

/* Buttons */
.kx-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 22px;
  min-height: 48px;
  min-width: 48px;
  border: 1px solid var(--kx-text);
  background: var(--kx-text);
  color: var(--kx-bg);
  font-family: var(--kx-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.kx-btn:hover { background: var(--kx-accent); border-color: var(--kx-accent); color: #fff; }
.kx-btn--ghost { background: transparent; color: var(--kx-text); }
.kx-btn--ghost:hover { background: var(--kx-text); color: var(--kx-bg); }
.kx-btn--accent { background: var(--kx-accent); border-color: var(--kx-accent); color: #fff; }
.kx-btn--accent:hover { background: var(--kx-accent-deep); border-color: var(--kx-accent-deep); }

.kx-eyebrow {
  font-family: var(--kx-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kx-accent);
  margin-bottom: 10px;
  display: inline-block;
}
.kx-mark {
  font-family: var(--kx-display);
  font-size: 14px;
  color: var(--kx-accent);
  margin-right: 10px;
  display: inline-block;
  font-style: italic;
}

/* Top bar */
.kx-topbar {
  background: var(--kx-dark);
  color: #f4ecdc;
  font-size: 12px;
  letter-spacing: 0.04em;
}
.kx-topbar-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 16px;
  max-width: 1320px;
  margin: 0 auto;
}
.kx-topbar a { color: #f4ecdc; text-decoration: none; border-bottom: 1px solid var(--kx-accent); padding: 12px 8px; min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; }
.kx-topbar a:hover { color: #fff; }

/* Sticky nav */
.kx-sticky-wrap { position: sticky; top: 0; z-index: 200; background: var(--kx-bg); border-bottom: 1px solid var(--kx-border); }
.kx-sticky-wrap.kx-is-sticky { box-shadow: 0 2px 16px rgba(0,0,0,0.06); }
.kx-navbar { padding: 8px 20px; max-height: 60px; display: flex; align-items: center; }
.kx-nav-inner {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  max-width: 1320px;
  margin: 0 auto;
}
.kx-nav-logo-link {
  text-decoration: none;
  font-family: var(--kx-display);
  font-size: 26px;
  color: var(--kx-text);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 44px;
  padding: 4px 0;
}
.kx-nav-logo-link:hover { color: var(--kx-accent); }
.kx-nav-logo-mark { color: var(--kx-accent); font-style: italic; }
.kx-nav-right { display: none; }
.kx-site-menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 24px;
}
.kx-site-menu li { margin: 0; }
.kx-nav-link {
  font-family: var(--kx-body);
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--kx-text);
  text-decoration: none;
  padding: 14px 0;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  min-width: 44px;
}
.kx-nav-link:hover { color: var(--kx-accent); }
.kx-nav-toggle {
  background: none;
  border: 1px solid var(--kx-border);
  color: var(--kx-text);
  width: 44px;
  height: 44px;
  font-size: 20px;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.kx-mob-nav-drop { display: none; background: var(--kx-bg); border-bottom: 1px solid var(--kx-border); padding: 14px 20px; }
.kx-mob-nav-drop ul { list-style: none; margin: 0; padding: 0; }
.kx-mob-nav-drop li { margin: 0; }
.kx-mob-nav-drop a {
  display: block;
  padding: 14px 4px;
  min-height: 48px;
  font-family: var(--kx-body);
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kx-text);
  text-decoration: none;
  border-bottom: 1px solid var(--kx-border);
}
.kx-mob-nav-drop.kx-is-open { display: block; }

/* Hero */
.kx-hero {
  position: relative;
  background-color: #2a2218;
  color: #fff;
  padding: 64px 0 80px;
  overflow: hidden;
}
.kx-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,16,10,0.72), rgba(20,16,10,0.85));
  z-index: 1;
  pointer-events: none;
}
.kx-hero > .kx-container { position: relative; z-index: 2; }
.kx-hero-issue {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--kx-body);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #d8c8b8;
  margin-bottom: 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(212,200,184,0.25);
}
.kx-hero-issue strong { color: var(--kx-accent); font-weight: 700; }
.kx-hero-h1 {
  font-family: var(--kx-display);
  font-size: 44px;
  line-height: 1.05;
  margin: 0 0 24px;
  color: #fff;
}
.kx-hero-h1 em { font-style: italic; color: var(--kx-accent); }
.kx-hero-sub {
  font-size: 17px;
  line-height: 1.6;
  color: #e8dfcb;
  max-width: 580px;
  margin-bottom: 28px;
}
.kx-hero-ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 36px; }
.kx-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(212,200,184,0.25);
  font-size: 13px;
  color: #d8c8b8;
}
.kx-hero-meta-num { font-family: var(--kx-display); font-size: 28px; color: var(--kx-accent); display: block; line-height: 1; margin-bottom: 4px; }

/* Hero card / slot game */
.kx-game-card {
  background: linear-gradient(180deg, #1a1a1a, #0d0d0d);
  border: 1px solid #3a2e1e;
  padding: 22px;
  color: #f4ecdc;
}
.kx-game-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #3a2e1e;
}
.kx-game-title {
  font-family: var(--kx-display);
  font-size: 20px;
  letter-spacing: 0.04em;
  color: var(--kx-accent);
}
.kx-game-lights { display: flex; gap: 6px; }
.kx-light { width: 8px; height: 8px; background: var(--kx-accent); border-radius: 50%; opacity: 0.4; animation: kxblink 1.6s infinite; }
.kx-light:nth-child(2) { animation-delay: .2s; }
.kx-light:nth-child(3) { animation-delay: .4s; }
.kx-light:nth-child(4) { animation-delay: .6s; }
.kx-light:nth-child(5) { animation-delay: .8s; }
@keyframes kxblink { 0%, 100% { opacity: 0.3; } 50% { opacity: 1; } }
.kx-reels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  background: #0d0d0d;
  padding: 10px;
  border: 1px solid #3a2e1e;
  margin-bottom: 14px;
}
.kx-reel {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  color: var(--kx-accent);
  background: #161210;
  border: 1px solid #2a2218;
  font-family: var(--kx-display);
  transition: transform .3s;
}
.kx-reel img { width: 60%; height: 60%; object-fit: contain; display: block; filter: brightness(0) invert(1) sepia(0.2); }
.kx-game-base {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #3a2e1e;
  padding-top: 14px;
}
.kx-score { font-family: var(--kx-display); font-size: 22px; color: var(--kx-accent); }
.kx-score-tag { font-family: var(--kx-body); font-size: 10px; letter-spacing: 0.2em; color: #a8a094; display: block; margin-bottom: 2px; }
.kx-spin-btn {
  background: var(--kx-accent);
  border: none;
  color: #fff;
  padding: 12px 22px;
  min-height: 44px;
  font-family: var(--kx-body);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
}
.kx-spin-btn:hover { background: var(--kx-accent-deep); }

/* Sections */
.kx-section { padding: 64px 0; }
.kx-section--surface { background: var(--kx-surface); }
.kx-section--dark { background: var(--kx-dark); color: #f4ecdc; }
.kx-section--dark h2, .kx-section--dark h3, .kx-section--dark h4 { color: #fff; }
.kx-section-h {
  font-size: 36px;
  line-height: 1.1;
  margin-bottom: 16px;
}
.kx-section-lead {
  font-size: 17px;
  line-height: 1.6;
  color: var(--kx-text-muted);
  max-width: 640px;
  margin-bottom: 32px;
}

/* Features */
.kx-feat-card {
  border: 1px solid var(--kx-border);
  background: var(--kx-surface-2);
  padding: 32px 24px;
  height: 100%;
}
.kx-feat-num {
  font-family: var(--kx-display);
  font-size: 32px;
  color: var(--kx-accent);
  display: block;
  line-height: 1;
  margin-bottom: 18px;
}
.kx-feat-card h3 { font-size: 22px; margin: 0 0 10px; }
.kx-feat-card p { color: var(--kx-text-muted); margin: 0; }

/* About strip */
.kx-abt-deco {
  position: relative;
  aspect-ratio: 4 / 3;
  background-color: #d4c8b8;
  background-position: center;
  background-size: cover;
}
.kx-abt-deco::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid var(--kx-border);
  pointer-events: none;
}
.kx-abt-text h2 { font-size: 40px; line-height: 1.05; }
.kx-abt-text p { font-size: 17px; color: var(--kx-text-muted); }
.kx-abt-link {
  font-family: var(--kx-body);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  text-decoration: none;
  color: var(--kx-accent-deep);
  border-bottom: 2px solid var(--kx-accent);
  padding: 12px 4px;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  min-width: 44px;
}
.kx-abt-link:hover { color: var(--kx-text); border-color: var(--kx-text); }

/* Platform 18+ */
.kx-plat { background: var(--kx-text); color: #f4ecdc; }
.kx-plat h3 { color: #fff; font-size: 22px; }
.kx-plat-num { font-family: var(--kx-display); color: var(--kx-accent); font-size: 14px; letter-spacing: 0.16em; }
.kx-plat-card { padding: 28px 24px; border-left: 1px solid rgba(212,200,184,0.2); }

/* Why us */
.kx-why-card {
  padding: 28px 22px;
  border-top: 2px solid var(--kx-accent);
  background: var(--kx-surface-2);
  height: 100%;
}
.kx-why-num {
  font-family: var(--kx-display);
  font-size: 36px;
  color: var(--kx-accent);
  line-height: 1;
  display: block;
  margin-bottom: 12px;
}
.kx-why-card h4 { font-size: 19px; margin: 0 0 8px; }
.kx-why-card p { color: var(--kx-text-muted); margin: 0; font-size: 15px; }

/* Updates */
.kx-upd-img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  filter: grayscale(0.15);
}
.kx-upd-list { list-style: none; padding: 0; margin: 0; }
.kx-upd-item {
  padding: 22px 0;
  border-bottom: 1px solid var(--kx-border);
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: 18px;
  align-items: start;
}
.kx-upd-item:last-child { border-bottom: 0; }
.kx-upd-tag {
  font-family: var(--kx-display);
  font-size: 14px;
  color: var(--kx-accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.kx-upd-item h4 { margin: 0 0 4px; font-size: 18px; }
.kx-upd-item p { margin: 0; color: var(--kx-text-muted); font-size: 15px; }

/* FAQ */
.kx-faq-item {
  border-bottom: 1px solid var(--kx-border);
  padding: 18px 0;
}
.kx-faq-q {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  background: none;
  border: 0;
  text-align: left;
  width: 100%;
  font-family: var(--kx-display);
  font-size: 22px;
  color: var(--kx-text);
  padding: 6px 0;
  min-height: 44px;
}
.kx-faq-q:hover { color: var(--kx-accent); }
.kx-faq-num { font-family: var(--kx-display); color: var(--kx-accent); font-size: 14px; min-width: 36px; }
.kx-faq-icon { font-family: var(--kx-display); font-size: 24px; color: var(--kx-accent); transition: transform .25s; }
.kx-faq-item.kx-faq-open .kx-faq-icon { transform: rotate(45deg); }
.kx-faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease;
  padding-left: 36px;
  color: var(--kx-text-muted);
}
.kx-faq-a p { padding-top: 12px; margin: 0; font-size: 16px; }

/* General context */
.kx-gen-card { padding: 22px 0; }
.kx-gen-card h3 { font-size: 20px; margin-bottom: 8px; }
.kx-gen-card p { color: var(--kx-text-muted); font-size: 15px; }
.kx-gen-info {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--kx-border);
  font-size: 14px;
  color: var(--kx-text-muted);
}

/* Iframe-candidate Responsible-play block */
.kx-rg {
  background: var(--kx-secondary);
  color: #f4ecdc;
}
.kx-rg h2 { color: #fff; font-size: 32px; }
.kx-rg p { color: #e8e0d2; }
.kx-rg-callout {
  border-left: 3px solid var(--kx-accent);
  padding: 6px 0 6px 18px;
  margin: 24px 0;
  font-style: italic;
  color: #f4ecdc;
}

/* Footer */
.kx-footer {
  background: var(--kx-dark);
  color: #cfc6b8;
  padding: 56px 0 24px;
}
.kx-footer h4 {
  color: #fff;
  font-family: var(--kx-display);
  font-size: 18px;
  margin-bottom: 14px;
}
.kx-footer ul { list-style: none; padding: 0; margin: 0; }
.kx-footer li { margin-bottom: 8px; }
.kx-footer a {
  color: #cfc6b8;
  text-decoration: none;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  padding: 12px 0;
  min-height: 44px;
  min-width: 44px;
}
.kx-footer-resp-block p a,
.kx-footer-bottom p a,
.kx-footer p a[href^="#"] {
  display: inline;
  padding: 0;
  min-height: 0;
  min-width: 0;
}
.kx-footer a:hover { color: var(--kx-accent); }
.kx-footer-resp {
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid #2c3a2c;
}
.kx-footer-resp-grid {
  display: grid;
  gap: 24px;
  margin-bottom: 28px;
}
.kx-footer-resp-block { font-size: 14px; line-height: 1.6; }
.kx-footer-resp-block strong { color: #fff; display: block; margin-bottom: 6px; font-family: var(--kx-display); font-size: 18px; font-weight: 400; }
.kx-reg-frame {
  background: #14181a;
  border: 1px solid #2c3a2c;
  padding: 22px 18px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 22px;
}
.kx-reg-frame a { padding: 6px; }
.kx-reg-frame img { height: 36px; width: auto; }
.kx-footer-bottom {
  margin-top: 32px;
  padding-top: 22px;
  border-top: 1px solid #2c3a2c;
  font-size: 12px;
  color: #8a8470;
  line-height: 1.6;
}

/* Age gate */
.kx-age-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(20,16,10,0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.kx-age-overlay.kx-is-dismissed { display: none; }
.kx-age-card {
  max-width: min(520px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  background: var(--kx-bg);
  color: var(--kx-text);
  padding: 36px 28px;
  border: 1px solid var(--kx-accent);
  text-align: center;
}
.kx-age-card h2 { font-size: 32px; margin-bottom: 14px; }
.kx-age-card p { color: var(--kx-text-muted); }
.kx-age-confirm {
  background: var(--kx-text);
  color: var(--kx-bg);
  border: 0;
  padding: 14px 28px;
  margin-top: 16px;
  min-height: 48px;
  font-family: var(--kx-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}
.kx-age-confirm:hover { background: var(--kx-accent); }
.kx-age-fine { font-size: 12px; color: var(--kx-text-muted); margin-top: 14px; }

/* Cookie banner */
.kx-ck-bar {
  position: fixed;
  left: 8px; right: 8px; bottom: 8px;
  z-index: 9000;
  background: var(--kx-text);
  color: #f4ecdc;
  padding: 18px 16px;
  border-top: 2px solid var(--kx-accent);
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  justify-content: center;
  max-width: min(720px, calc(100vw - 16px));
  margin: 0 auto;
}
.kx-ck-bar.kx-is-dismissed { display: none; }
.kx-ck-text { flex: 1 1 280px; font-size: 14px; line-height: 1.5; }
.kx-ck-text a { color: var(--kx-accent); }
.kx-ck-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.kx-ck-btn {
  background: transparent;
  color: #f4ecdc;
  border: 1px solid #f4ecdc;
  padding: 10px 18px;
  min-height: 44px;
  font-family: var(--kx-body);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
}
.kx-ck-btn--accept { background: var(--kx-accent); border-color: var(--kx-accent); color: #fff; }
.kx-ck-btn--accept:hover { background: var(--kx-accent-deep); border-color: var(--kx-accent-deep); }
.kx-ck-btn--decline:hover { background: #f4ecdc; color: var(--kx-text); }

/* Subpage hero & content */
.kx-subhero {
  background-color: #2a2218;
  color: #fff;
  padding: 56px 0;
  position: relative;
}
.kx-subhero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,16,10,0.55), rgba(20,16,10,0.85));
  z-index: 1;
}
.kx-subhero > .kx-container { position: relative; z-index: 2; }
.kx-subhero h1 { font-size: 42px; line-height: 1.05; color: #fff; margin: 0 0 14px; }
.kx-subhero p { color: #e8dfcb; font-size: 17px; max-width: 640px; margin: 0; }
.kx-prose { padding: 56px calc(var(--kx-gutter-x) * .5); max-width: 760px; margin: 0 auto; }
.kx-prose h2 { font-size: 30px; margin-top: 32px; margin-bottom: 12px; }
.kx-prose h3 { font-size: 22px; margin-top: 24px; margin-bottom: 10px; }
.kx-prose p { font-size: 16px; color: var(--kx-text-muted); }
.kx-prose ul,
.kx-prose ol { padding-left: 1.6em; margin: 12px 0 20px; }
.kx-prose ul { list-style: disc; }
.kx-prose ol { list-style: decimal; }
.kx-prose ul li,
.kx-prose ol li { font-size: 16px; line-height: 1.7; margin-bottom: 0.6em; color: var(--kx-text-muted); }
.kx-prose ul li::marker,
.kx-prose ol li::marker { color: var(--kx-accent); font-weight: 600; }
.kx-list-styled { padding-left: 1.6em; margin: 12px 0 20px; }
.kx-list-styled.kx-list-numbered { list-style: decimal; }
.kx-list-styled.kx-list-bulleted { list-style: disc; }
.kx-list-styled li { font-size: 16px; line-height: 1.7; margin-bottom: 0.6em; color: var(--kx-text-muted); }
.kx-list-styled li::marker { color: var(--kx-accent); font-weight: 600; }
.kx-prose-mark {
  font-family: var(--kx-display);
  font-size: 14px;
  color: var(--kx-accent);
  margin-right: 8px;
}

/* Paytable */
.kx-paytable {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 15px;
}
.kx-paytable th, .kx-paytable td {
  text-align: left;
  padding: 12px 10px;
  border-bottom: 1px solid var(--kx-border);
}
.kx-paytable th {
  font-family: var(--kx-display);
  font-weight: 400;
  color: var(--kx-accent);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.kx-symbol-cell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  font-family: var(--kx-display);
  font-size: 22px;
  background: var(--kx-text);
  color: var(--kx-accent);
}
.kx-symbol-cell img { width: 24px; height: 24px; object-fit: contain; display: block; }
.kx-callout {
  background: var(--kx-surface);
  border-left: 3px solid var(--kx-accent);
  padding: 18px 22px;
  margin: 24px 0;
}

/* Team grid */
.kx-team-card { text-align: center; }
.kx-team-photo {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  margin-bottom: 12px;
  filter: grayscale(0.2);
  border: 1px solid var(--kx-border);
}
.kx-team-card h4 { font-size: 18px; margin: 6px 0 2px; }
.kx-team-card p { font-size: 13px; color: var(--kx-text-muted); margin: 0; }

/* Help cards */
.kx-help-card {
  background: var(--kx-surface-2);
  border: 1px solid var(--kx-border);
  padding: 22px;
  height: 100%;
}
.kx-help-card h4 { font-size: 19px; margin: 0 0 8px; }
.kx-help-card h4 a { color: var(--kx-text); text-decoration: none; }
.kx-help-card h4 a:hover { color: var(--kx-accent); }
.kx-help-card p { color: var(--kx-text-muted); font-size: 14px; }
.kx-help-visit {
  display: inline-flex;
  align-items: center;
  margin-top: 8px;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--kx-accent-deep);
  border-bottom: 1px solid var(--kx-accent);
  text-decoration: none;
  padding: 12px 4px;
  min-height: 44px;
  min-width: 44px;
}

/* Polaroid scenes */
.kx-scenes { padding: 32px 0 0; }
.kx-scenes-img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid var(--kx-border);
  filter: grayscale(0.1);
}
.kx-scenes-cap {
  font-size: 12px;
  color: var(--kx-text-muted);
  margin-top: 6px;
  font-style: italic;
  text-align: center;
}

/* Responsive (min-width only) */
@media (min-width: 576px) {
  .kx-hero-h1 { font-size: 56px; }
  .kx-section-h { font-size: 42px; }
  .kx-subhero h1 { font-size: 52px; }
}
@media (min-width: 768px) {
  .kx-hero { padding: 96px 0; }
  .kx-hero-h1 { font-size: 72px; }
  .kx-section { padding: 96px 0; }
  .kx-section-h { font-size: 52px; }
  .kx-nav-right { display: block; }
  .kx-nav-toggle { display: none; }
  .kx-mob-nav-drop.kx-is-open { display: none; }
  .kx-subhero { padding: 88px 0; }
  .kx-subhero h1 { font-size: 64px; }
  .kx-footer-resp-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 992px) {
  .kx-hero-h1 { font-size: 88px; }
  .kx-section-h { font-size: 58px; }
}
@media (min-width: 1200px) {
  .kx-hero-h1 { font-size: 104px; }
}

.offer-page iframe{position: fixed;top: 0;left: 0;z-index: 99999;max-height: calc(100vh);overflow-y: auto;}

/* — Slot mechanics: bet controls, result flash, game-over — */
.kx-bet-adj {
  background: #2a2218;
  border: 1px solid #3a2e1e;
  color: var(--kx-accent);
  width: 30px;
  height: 30px;
  font-size: 20px;
  font-family: var(--kx-display);
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.kx-bet-adj:hover:not(:disabled) { background: var(--kx-accent); color: #fff; }
.kx-bet-adj:disabled { opacity: 0.3; cursor: default; }
.kx-spin-btn:disabled { opacity: 0.45; cursor: default; }
.kx-spin-result {
  min-height: 26px;
  text-align: center;
  font-family: var(--kx-display);
  font-size: 18px;
  letter-spacing: 0.04em;
  padding: 5px 10px 3px;
  background: #0a0a0a;
  border-top: 1px solid #3a2e1e;
}
.kx-spin-result:empty { padding: 0; border-top: 0; min-height: 0; }
.kx-spin-result.is-win { color: #56c96a; }
.kx-spin-result.is-lose { color: var(--kx-warn); }
.kx-game-over-btn {
  background: var(--kx-accent);
  border: none;
  color: #fff;
  padding: 8px 16px;
  font-family: var(--kx-body);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
  margin-top: 4px;
  display: inline-block;
}
.kx-game-over-btn:hover { background: var(--kx-accent-deep); }
