/* === assets/css/daBase.css === */
/* ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ STYLESHEET — daBase.css
   Classification: Absolute Base (NEUTRAL, NON-OVERRIDING)
   Version: 2.0.0 (Layered - No !important)
   File: /assets/css/daBase.css
   Maintainer: DΛREΛKT_ Core UI Team

   Changes (2.0.0):
   - Wrapped in @layer daBase for proper cascade control
   - Removed all !important declarations
   - Safety reset targets pages with NO data-site only
   ─────────────────────────────────────────────────────────────────────────── */

@layer daBase {

/* GLOBAL RESET — foundation only */
html, body {
  margin: 0;
  padding: 0;
  background-color: var(--background-color, #ffffff);
  color: var(--text-color, #111111);
  font-family: var(--font-family-base, 'Inter', 'Roboto', sans-serif);
  min-height: 100vh;
  width: 100%;
  box-sizing: border-box;
  /* 🔒 GENESIS: Prevent horizontal scroll - site should never scroll sideways */
  overflow-x: hidden;
}

*, *::before, *::after {
  box-sizing: inherit;
}

/* LAYOUT ROOTS — NEVER CLAMP OR CENTER AUTOMATICALLY */
#app,
#layout-wrapper,
main,
section,
header,
footer {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

/* Layout structure */
#app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

#layout-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
}

/* ZONES */
#layout-wrapper > header,
#layout-wrapper > nav,
#layout-wrapper > main,
#layout-wrapper > footer,
#header-zone,
#nav-zone,
#layout-zones,
#content-zone,
#footer-zone {
  align-self: stretch;
  width: 100%;
  max-width: none;
}

/* FLEX UTILITIES */
.flex { display: flex; align-items: stretch; }
.flex-center { display: flex; align-items: center; justify-content: center; }

.flex > button,
.flex > [role="button"],
.flex > input,
.flex > select,
.flex > textarea {
  flex: 0 0 auto;
  min-width: max-content;
}

.grow    { flex: 1 1 auto; min-width: 0; }
.no-grow { flex: 0 0 auto; min-width: max-content; }

:where([flex],[data-flex]) {
  flex: 0 0 auto;
  align-self: auto;
  min-width: max-content;
}

/* GRID UTILITIES */
.grid  { display: grid; gap: var(--spacing-sm, 8px); }
.grid-2{ grid-template-columns: repeat(2, 1fr); }
.grid-3{ grid-template-columns: repeat(3, 1fr); }
.grid-4{ grid-template-columns: repeat(4, 1fr); }

/* CONTAINERS — no auto max-width or centering EVER */
.container,
.section {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

/* Optional helper for explicit centering (only when asked) */
.container.center,
.section.center {
  margin-left: auto;
  margin-right: auto;
  max-width: var(--container-max, 1200px);
  padding-left: var(--spacing-sm, 8px);
  padding-right: var(--spacing-sm, 8px);
}

/* BOX + SPACERS */
.box {
  background: var(--background-color, #fff);
  padding: var(--spacing-md, 16px);
  border-radius: 0.5rem;
  box-shadow: 0 0 8px rgba(0,0,0,.2);
  transition: box-shadow .3s ease;
}
.box:hover { box-shadow: 0 0 12px rgba(0,0,0,.3); }

.spacer    { display: block; width: 100%; }
.spacer-xs { height: var(--spacing-xs, 4px); }
.spacer-sm { height: var(--spacing-sm, 8px); }
.spacer-md { height: var(--spacing-md, 16px); }
.spacer-lg { height: var(--spacing-lg, 24px); }

/* BACKGROUND + BORDERS */
[data-background] {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

[data-border-shadow] {
  border-style: solid;
  border-width: 0px;
  border-color: var(--color-border, #cccccc);
  box-shadow: none;
}

/* ANIMATIONS (safe defaults) */
[data-animation] {
  opacity: 0;
  transform: translateY(20px);
  transition-property: opacity, transform;
  transition-timing-function: ease-out;
}
[data-animation].active { opacity: 1; transform: translateY(0); }
[data-animation="fade-in"].active    { opacity: 1; }
[data-animation="slide-up"].active   { transform: translateY(0); }
[data-animation="slide-left"].active { transform: translateX(0); }
[data-animation="slide-right"].active{ transform: translateX(0); }
[data-animation="zoom-in"].active    { transform: scale(1); }
[data-animation="rotate-in"].active  { transform: rotate(0deg); }

/* ─────────────────────────────────────────────────────────────
   BOOT MODE — Scoped: only triggers when engine is booting
   ───────────────────────────────────────────────────────────── */
body[data-engine="boot"],
#boot-center {
  background: var(--boot-bg, #000);
  color: var(--boot-fg, #0f0);
  font-family: var(--font-family-base, monospace);
  min-height: 100vh;
}

#boot-center {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

/* Safety reset when NO site is mounted (prevents white flick on site pages) */
html:not([data-site]) body:not([data-site]) {
  background: var(--background-color, #ffffff);
  color: var(--text-color, #111111);
}

}

/* === assets/css/core.css === */
/* ─── DΛREΛKT_ STYLESHEET — core ─────────────────────────────────────────────
   Classification: Core | Reset + Theme Tokens + Globals (atom-safe)
   Version: 2.2.0  (neutral, non-opinionated, no implicit clamping/centering)
   File: /assets/css/core.css
   ─────────────────────────────────────────────────────────────────────────── */

@layer reset, base, atoms, modules, site;

/* ─── RESET (lowest) ─────────────────────────────────────────────────────── */
@layer reset {
  *, *::before, *::after { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; height: 100%; width: 100%; }
}

/* ─── BASE (neutral foundation; NEVER clamps/centers) ───────────────────── */
@layer base {

  /* THEME TOKENS */
  :root{
    --bg:#ffffff; --text:#111111;
    --primary:#4f46e5; --secondary:#3ea8ff;
    --font-main:'Inter','Roboto',sans-serif;

    --gap-xs:.25rem; --gap-sm:.5rem; --gap-md:1rem; --gap-lg:2rem;

    --ctl-h:28px; --ctl-pad-x:10px;
    --ctl-bg:#111; --ctl-bd:#333; --ctl-fg:#bcbcbc; --ctl-fg-muted:#8aa; --ctl-focus:#3ea8ff;
  }
  :root[data-theme="dark"]{
    --bg:#000; --text:#bcbcbc;
    --ctl-bg:#111; --ctl-bd:#333; --ctl-fg:#bcbcbc; --ctl-fg-muted:#8aa; --ctl-focus:#3ea8ff;
  }

  /* BODY (no max-width, no auto-center) */
  body{
    font-family:var(--font-main);
    background-color:var(--bg);
    color:var(--text);
    line-height:1.6;
    font-size:16px;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    background-size:cover;
    width:100%;
    min-height:100vh;
  }

  /* TYPOGRAPHY */
  h1,h2,h3,h4,h5,h6{ font-family:var(--font-main); font-weight:600; line-height:1.2; }
  p{ margin:0 0 var(--gap-md) 0; }

  /* LINKS */
  a{ color:var(--primary); text-decoration:none; transition:color .25s ease; }
  a:hover{ text-decoration:underline; }

  /* BUTTONS (visuals only; no layout constraints) */
  button{
    font-family:var(--font-main); font-size:1rem;
    padding:var(--gap-sm) var(--gap-md);
    border:none; border-radius:6px; cursor:pointer;
    background-color:var(--primary); color:#fff;
    transition:background-color .25s ease, color .25s ease, border-color .25s ease;
    -webkit-tap-highlight-color:transparent;
  }
  button:hover{ background-color:var(--secondary); }
  button:disabled{ opacity:.6; cursor:not-allowed; }

  /* IMAGES */
  img{ max-width:100%; height:auto; display:block; }

  /* CONTAINER (neutral) — NO implicit width/max/centering */
  .container, .section{
    width:100%;
    max-width:none;
    margin:0;
    padding:0;
  }

  /* EXPLICIT, OPT-IN helpers (use only when you want them) */
  .center{ margin-left:auto; margin-right:auto; }
  .clamp{ max-width:var(--container-max,1200px); }
  .pad-x{ padding-left:var(--gap-lg); padding-right:var(--gap-lg); }
  .w-100{ width:100%; }

  /* BUTTON VARIANTS (visual only) */
  .back-btn{
    display:inline-block; padding:.5rem 1rem; border-radius:8px;
    background-color:var(--primary); color:#fff; border:2px solid var(--primary);
    transition:background-color .25s ease, color .25s ease, border-color .25s ease;
  }
  .back-btn:hover{ background-color:var(--secondary); }

  .btn-primary,#save-theme-btn{ background-color:var(--primary); color:#fff; border:2px solid var(--primary); }
  .btn-primary:hover,#save-theme-btn:hover{ background-color:var(--secondary); }

  .btn-secondary,#reset-theme-btn{ background-color:transparent; color:var(--primary); border:2px solid var(--primary); }
  .btn-secondary:hover,#reset-theme-btn:hover{ background-color:var(--primary); color:var(--bg); }

  .btn-danger,#factory-reset-btn{ background-color:#e11d48; color:#fff; border:2px solid #e11d48; }
  .btn-danger:hover,#factory-reset-btn:hover{ background-color:#be123c; border-color:#be123c; }

  /* Reduced motion */
  @media (prefers-reduced-motion: reduce){
    *{ scroll-behavior:auto; }
  }
}


/* System-wide: visually boost Λ */
.lambda {
  display: inline-block;
  transform: scale(1.22) translateY(-0.04em);
  transform-origin: center;
  text-shadow: 0 0 8px rgba(255,255,255,.14);
}

.lambda {
  transform: scale(1.25) translateY(-0.03em);
  text-shadow: 0 6px 10px rgb(255, 0, 0);
}


/* DΛREΛKT_ — Lambda Identity Glow */
.lambda {
  display: inline-block;
  transform: scale(1.22) translateY(-0.03em);
  transform-origin: center;
  color: #fff;
  text-shadow:
    0 0 4px rgba(255, 0, 0, 0.6),
    0 0 12px rgba(255, 0, 0, 0.4),
    0 0 20px rgba(255, 0, 0, 0.3);
  animation: lambdaGlow 4s ease-in-out infinite alternate;
}

/* Subtle breathing glow animation */
@keyframes lambdaGlow {
  0% {
    text-shadow:
      0 0 2px rgba(255, 0, 0, 0.5),
      0 0 8px rgba(255, 0, 0, 0.4),
      0 0 16px rgba(255, 0, 0, 0.3);
  }
  100% {
    text-shadow:
      0 0 6px rgba(255, 80, 80, 0.8),
      0 0 18px rgba(255, 0, 0, 0.6),
      0 0 30px rgba(255, 0, 0, 0.4);
  }
}

.lambda {
  opacity: 0;
  animation:
    lambdaBoot 0.8s ease-out forwards,
    lambdaGlow 4s ease-in-out infinite alternate 0.8s;
}

@keyframes lambdaBoot {
  0%, 10%, 20%, 30%, 40%, 50% {
    opacity: 0;
  }
  55%, 60%, 70%, 80%, 100% {
    opacity: 1;
  }
}



/* atoms/modules/site layers intentionally left to your project */

/* === tools/modules/ui.canvas/ui.canvas.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.canvas
   Version: 3.1.0 | Genesis-Final • Wrapping-Aware • Theme-Safe
   Classification: Core UI | Structural Root | Frameless Baseline
   Maintainer: DΛREΛKT_ CORE UI TEAM
   Host: Global (RuthBowers / Dareakt / Diagnostics / Dev)
   ──────────────────────────────────────────────────────────────── */
@layer ui.canvas {

  /* ── Root Canvas (Frameless Structural Container) ───────────── */
  .ui-canvas[data-module="ui.canvas"],
  .ui-canvas[data-mod="ui_canvas"] {
    width: 100%;
    box-sizing: border-box;
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    isolation: isolate;

    /* Token-aware visual styling */
    padding-inline: var(--edge, 32px);
    background: var(--bg, var(--site-bg, transparent));
    color: var(--fg, var(--site-fg, inherit));

    /* Responsive + scroll control (body owns scroll by default) */
    overflow-y: visible;
    overscroll-behavior: auto;
    scrollbar-gutter: auto;
  }

  /* ── Centered & Max Width Variant ───────────────────────────── */
  .ui-canvas[data-module="ui.canvas"][data-center="1"],
  .ui-canvas[data-mod="ui_canvas"][data-center="1"] {
    margin-inline: auto;
    max-width: var(--max, 14400px);
  }

  /* ── Vertical stacking rhythm (using --stack token) ─────────── */
  /* Default: no auto stacking (content-driven layout) */
  .ui-canvas[data-module="ui.canvas"] > * + *,
  .ui-canvas[data-mod="ui_canvas"] > * + * {
    margin-top: 0;
  }

  /* ── Layout Intent: Editorial pages opt in to stacking ───────── */
  body[data-layout="viewport"] .ui-canvas[data-module="ui.canvas"] > * + *,
  body[data-layout="viewport"] .ui-canvas[data-mod="ui_canvas"] > * + * {
    margin-top: var(--stack, 24px);
  }

  /* ── Scroll toggle (false = lock body scroll) ───────────────── */
  .ui-canvas[data-module="ui.canvas"][data-scroll="0"],
  .ui-canvas[data-mod="ui_canvas"][data-scroll="0"] {
    overflow-y: hidden !important;
  }

  /* ── Scroll toggle (true = canvas owns scroll) ───────────────── */
  .ui-canvas[data-module="ui.canvas"][data-scroll="1"],
  .ui-canvas[data-mod="ui_canvas"][data-scroll="1"] {
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable both-edges;
  }

  /* ── Theme + Scope Awareness ────────────────────────────────── */
  .ui-canvas[data-module="ui.canvas"][data-theme="dark"],
  .ui-canvas[data-mod="ui_canvas"][data-theme="dark"] {
    background: var(--site-bg-dark, #111);
    color: var(--site-fg-dark, #eee);
  }
  .ui-canvas[data-module="ui.canvas"][data-theme="light"],
  .ui-canvas[data-mod="ui_canvas"][data-theme="light"] {
    background: var(--site-bg-light, #fff);
    color: var(--site-fg-light, #111);
  }

  /* ── Internal Helpers (isolate nested atoms) ────────────────── */
  .ui-canvas[data-module="ui.canvas"],
  .ui-canvas[data-mod="ui_canvas"]
  :where(.ui-navbar__inner,
         .ui-section-top__inner,
         .ui-copy__wrap,
         .ui-list__wrap,
         .ui-grid__wrap) {
    padding: 0;
    margin: 0;
  }

  .ui-canvas[data-module="ui.canvas"],
  .ui-canvas[data-mod="ui_canvas"]
  :where(.ui-grid, .ui-grid__wrap, .ui-grid__cell) {
    max-width: none;
    margin: 0;
    padding: 0;
  }

  /* ── Responsive Safety (Stack fallback below 900px) ─────────── */
  @media (max-width: 900px) {
    .ui-canvas[data-module="ui.canvas"],
    .ui-canvas[data-mod="ui_canvas"] {
      padding-inline: var(--edge-mobile, 16px);
    }
  }

  /* ── Debug Overlay (opt-in via data-debug="1") ──────────────── */
  .ui-canvas[data-module="ui.canvas"][data-debug="1"]::before,
  .ui-canvas[data-mod="ui_canvas"][data-debug="1"]::before {
    content: "ui.canvas active";
    position: absolute;
    top: 0.25rem;
    right: 0.5rem;
    font-size: 10px;
    color: var(--fg, #999);
    opacity: 0.4;
    pointer-events: none;
    z-index: 9999;
  }

  /* ── Shadow Isolation Gate (no bleed outside canvas) ───────── */
  .ui-canvas[data-module="ui.canvas"] *,
  .ui-canvas[data-mod="ui_canvas"] * {
    box-sizing: inherit;
  }

  /* ── Layout Intent: Full-height only when explicitly requested ───────── */
  body[data-layout="viewport"] .ui-canvas[data-module="ui.canvas"],
  body[data-layout="viewport"] .ui-canvas[data-mod="ui_canvas"] {
    min-height: 100vh;
    height: 100%;
  }
}

/* === tools/modules/ui.layout/ui.layout.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.layout
   Classification : Structural Atom | Grid/Flex Coordinator
   Version        : 3.3.0 | Genesis-Final • Self-Healing • Token-Safe • Canvas-Aware
   Maintainer     : DΛREΛKT_ UI TEAM
   ──────────────────────────────────────────────────────────────── */
@layer ui.layout {

  /* ── Root Layout Container ───────────────────────────────────── */
  .ui-layout[data-module="ui.layout"],
  .ui-layout[data-mod="ui_layout"] {
    display: grid;
    width: 100%;
    min-width: 0;
    min-height: auto;
    box-sizing: border-box;
    position: relative;
    isolation: isolate;

    gap: var(--ui-layout-gap, 0);
    padding-block: var(--ui-layout-padY, 0);
    padding-inline: var(--ui-layout-padX, 0);

    background: var(--ui-layout-bg, transparent);
    color: var(--ui-layout-fg, inherit);
    align-items: var(--ui-layout-align, stretch);
    justify-content: var(--ui-layout-justify, start);

    /* Full-bleed by default — override only if needed */
    margin-inline: 0 !important;
    max-width: none !important;
  }

  /* ── Layout Intent: Only viewport layouts stretch ───────── */
  body[data-layout="viewport"] .ui-layout[data-module="ui.layout"],
  body[data-layout="viewport"] .ui-layout[data-mod="ui_layout"] {
    min-height: 100%;
  }

  /* ── Mode: Grid ──────────────────────────────────────────────── */
  .ui-layout[data-mode="grid"] {
    display: grid;
    grid-template-columns: repeat(
      var(--ui-layout-cols, auto-fit),
      minmax(var(--ui-layout-cell-min, 200px), 1fr)
    );
  }

  /* ── Mode: Flex ──────────────────────────────────────────────── */
  .ui-layout[data-mode="flex"] {
    display: flex;
    flex-direction: row;
    flex-wrap: var(--ui-layout-wrap, wrap);
    align-items: var(--ui-layout-align, stretch);
    justify-content: var(--ui-layout-justify, start);
  }

  /* ── Flex Column Mode (for main layout) ──────────────────────── */
  .ui-layout[data-mode="flex"][data-direction="column"] {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    /* 🔧 FIX: Column layouts must NOT wrap — wrapping pushes children
       into new columns (off-screen right) when content exceeds container height.
       Vertical overflow should scroll, not create horizontal columns. */
    flex-wrap: nowrap;
  }

  /* ── Layout Intent: Full-height only when explicitly requested ───────── */
  body[data-layout="viewport"] .ui-layout[data-mode="flex"][data-direction="column"] {
    min-height: 100%;
  }

  /* ── Mode: Stack ─────────────────────────────────────────────── */
  .ui-layout[data-mode="stack"] {
    display: flex;
    flex-direction: column;
    align-items: var(--ui-layout-align, stretch);
    justify-content: var(--ui-layout-justify, start);
  }

  /* ── Mode: Split (two-column) ───────────────────────────────── */
  .ui-layout[data-mode="split"] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ui-layout-gap, 32px);
  }

  /* ── Mode: Center ────────────────────────────────────────────── */
  .ui-layout[data-mode="center"] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: auto;
  }

  /* ── Layout Intent: Center mode stretches only in viewport layout ───────── */
  body[data-layout="viewport"] .ui-layout[data-mode="center"] {
    min-height: 100%;
  }

  /* ── Cells ───────────────────────────────────────────────────── */
  .ui-layout__cell {
    display: block;
    min-width: 0;
    flex: 0 0 auto;
    box-sizing: border-box;
  }

  /* Main area grows to fill available space (pushes footer to bottom) */
  .ui-layout__cell[data-area="main"] {
    flex: 1 1 auto;
  }

  /* ── Bleed Mode: Remove padding when section declares bleed intent ───────────────── */
  .ui-layout__cell[data-area="main"][data-bleed="true"] {
    padding-inline: 0;
  }

  /* ── Canvas Awareness (inside ui.canvas) ─────────────────────── */
  .ui-canvas[data-mod="ui_canvas"] :where(.ui-layout) {
    width: 100%;
    margin: 0 !important;
    background: var(--ui-layout-bg, transparent);
  }

  /* ── Responsive Stacking (token-controlled) ─────────────────── */
  @media (max-width: 1280px) {
    .ui-layout[data-stack="lg"] {
      grid-template-columns: 1fr !important;
      flex-direction: column !important;
    }
  }
  @media (max-width: 960px) {
    .ui-layout[data-stack="md"] {
      grid-template-columns: 1fr !important;
      flex-direction: column !important;
    }
  }
  @media (max-width: 640px) {
    .ui-layout[data-stack="sm"] {
      grid-template-columns: 1fr !important;
      flex-direction: column !important;
    }
  }
  @media (max-width: 480px) {
    .ui-layout[data-stack="xs"] {
      grid-template-columns: 1fr !important;
      flex-direction: column !important;
    }
  }

  /* ── Debug Overlay (opt-in) ──────────────────────────────────── */
  /* .ui-layout[data-debug="1"]::before {
       content: "ui.layout active";
       position: absolute;
       top: 0.25rem;
       right: 0.75rem;
       font-size: 10px;
       opacity: 0.4;
       color: #999;
       pointer-events: none;
     } */
}

/* === tools/modules/ui.navbar/ui.navbar.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.navbar
   Classification : UI Atom | Navigation Bar | Wrapping-Aware | Themeable
   Version        : 2.0.0 | Genesis-Final • BEM-Consistent • Responsive • Bus-Linked
   File           : /tools/modules/ui.navbar/ui.navbar.css
   Maintainer     : DΛREΛKT_ UI TEAM
   Runtime Tokens : --ui-navbar-bg, --ui-navbar-bd, --ui-navbar-fg,
                    --ui-navbar-link, --ui-navbar-hover, --ui-navbar-active,
                    --ui-navbar-padY, --ui-navbar-padX, --ui-navbar-gap,
                    --ui-navbar-logo-fs, --ui-navbar-link-fs
   ────────────────────────────────────────────────────────────────────────────── */

/* ─── Layer: Tokens ──────────────────────────────────────────────────────────── */
@layer tokens {
  :root {
    --ui-navbar-bg:      var(--site-bg, #fff);
    --ui-navbar-bd:      var(--site-border, #eee);
    --ui-navbar-fg:      var(--site-fg, #111);
    --ui-navbar-link:    var(--site-fg, #111);
    --ui-navbar-hover:   #000;
    --ui-navbar-active:  #000;
    --ui-navbar-padY:    16px;
    --ui-navbar-padX:    0px;    /* canvas handles side padding */
    --ui-navbar-gap:     24px;
    --ui-navbar-logo-fs: 18px;
    --ui-navbar-link-fs: 15px;
  }
}

/* ─── Layer: Atoms ───────────────────────────────────────────────────────────── */
@layer atoms {
  /* wrapping container */
  .ui-navbar__wrap {
    width: 100%;
    background: var(--ui-navbar-bg);
    border-bottom: 1px solid var(--ui-navbar-bd);
    position: relative;
    z-index: var(--ui-navbar-z, 100);
  }

  /* root element */
  .ui-navbar {
    width: 100%;
    color: var(--ui-navbar-fg);
  }

  /* inner flex row: logo left / menu right */
  .ui-navbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ui-navbar-gap);
    padding: var(--ui-navbar-padY) var(--ui-navbar-padX);
    box-sizing: border-box;
    width: 100%;
  }

  /* logo */
  .ui-navbar__logo {
    font-size: var(--ui-navbar-logo-fs);
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--ui-navbar-fg);
    text-decoration: none;
    white-space: nowrap;
    display: inline-block;
    cursor: pointer;
    flex-shrink: 0; /* Prevent logo from shrinking */
  }

  /* menu list */
  .ui-navbar__menu {
    display: flex;
    align-items: center;
    gap: var(--ui-navbar-gap);
    list-style: none;
    margin: 0;
    padding: 0;
    margin-left: auto; /* Push menu to the right */
  }

  .ui-navbar__item {
    margin: 0;
    padding: 0;
  }

  .ui-navbar__link {
    color: var(--ui-navbar-link);
    font-size: var(--ui-navbar-link-fs);
    line-height: 1;
    text-decoration: none;
    padding: 2px 0;
    transition: color .15s ease, text-decoration .15s ease;
  }

  .ui-navbar__link:hover,
  .ui-navbar__link:focus {
    color: var(--ui-navbar-hover);
    text-decoration: underline;
  }

  .ui-navbar__link[aria-current="page"] {
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
    color: var(--ui-navbar-active);
  }

  /* ── Dropdown submenu ──────────────────────────────────────────────────── */
  .ui-navbar__item--has-dropdown {
    position: relative;
  }

  .ui-navbar__dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    list-style: none;
    margin: 0;
    padding: 0.5rem 0;
    min-width: 180px;
    background: var(--ui-navbar-bg);
    border: 1px solid var(--ui-navbar-bd);
    border-radius: 6px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    z-index: 200;
  }

  .ui-navbar__item--has-dropdown:hover > .ui-navbar__dropdown,
  .ui-navbar__item--has-dropdown:focus-within > .ui-navbar__dropdown {
    display: block;
  }

  .ui-navbar__dropdown-item {
    margin: 0;
    padding: 0;
  }

  .ui-navbar__dropdown-link {
    display: block;
    padding: 0.4rem 1rem;
    white-space: nowrap;
    font-size: calc(var(--ui-navbar-link-fs) - 1px);
  }

  .ui-navbar__dropdown-link:hover,
  .ui-navbar__dropdown-link:focus {
    background: rgba(0, 0, 0, 0.04);
  }

  /* ── Hamburger button (hidden on desktop) ──────────────────────────────── */
  .ui-navbar__burger {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    flex-direction: column;
    gap: 5px;
    z-index: 201;
  }

  .ui-navbar__burger span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--ui-navbar-fg);
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
  }

  .ui-navbar__burger--open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .ui-navbar__burger--open span:nth-child(2) {
    opacity: 0;
  }

  .ui-navbar__burger--open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  /* optional wrapping diagnostics (builder/inspector layer) */
  .ui-navbar__wrap[data-state="warn"] { outline: 1px dashed orange; }
  .ui-navbar__wrap[data-state="error"] { outline: 1px dashed red; }
  .ui-navbar__wrap[data-state="trust"] { outline: 1px dashed limegreen; }

  /* ── Mobile: hamburger + slide-down menu ─────────────────────────────── */
  @media (max-width: 720px) {
    .ui-navbar__burger {
      display: flex;
    }

    .ui-navbar__inner {
      flex-wrap: wrap;
    }

    .ui-navbar__menu {
      display: none;
      flex-direction: column;
      width: 100%;
      gap: 0;
      padding: 0.5rem 0;
      order: 3;
    }

    .ui-navbar__menu--open {
      display: flex;
    }

    .ui-navbar__item {
      width: 100%;
    }

    .ui-navbar__link {
      display: block;
      padding: 0.75rem 0;
      border-bottom: 1px solid var(--ui-navbar-bd);
    }

    .ui-navbar__dropdown {
      position: static;
      transform: none;
      box-shadow: none;
      border: none;
      padding: 0 0 0 1.5rem;
      min-width: auto;
      background: transparent;
    }

    .ui-navbar__item--has-dropdown > .ui-navbar__dropdown {
      display: block;
    }

    .ui-navbar__dropdown-link {
      padding: 0.5rem 0;
      border-bottom: 1px solid var(--ui-navbar-bd);
    }
  }
}

/* === tools/modules/ui.section.footer/ui.section.footer.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.section.footer
   Classification : Layout Section | Footer | Genesis-Final
   Version        : 2.0.1 | Wrapper-Safe • Token-Aligned • Responsive
   File           : /tools/modules/ui.section.footer/ui.section.footer.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ──────────────────────────────────────────────────────────────── */

@layer ui.section.footer {
  /* ─── Root Scope ─────────────────────────────────────────────── */
  .ui-section-footer[data-mod="ui_section_footer"] {
    box-sizing: border-box;
    width: 100%;
    background: var(--ui-sec-footer-bg, var(--site-bg));
    color: var(--ui-sec-footer-fg, var(--site-fg));
    padding: var(--ui-sec-footer-padY, 40px) var(--ui-sec-footer-padX, 24px);
    text-align: center;
    border-top: 1px solid color-mix(in srgb, currentColor 10%, transparent);
    isolation: isolate;
    position: relative;
    z-index: var(--ui-sec-footer-z, 1);
  }

  /* ─── Inner Wrapper ──────────────────────────────────────────── */
  .ui-section-footer__inner {
    max-width: var(--ui-sec-footer-maxWidth, 1200px);
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(0.5rem, 1.5vw, 1rem);
    line-height: 1.5;
  }

  /* ─── Links Navigation ───────────────────────────────────────── */
  .ui-section-footer__links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(0.75rem, 2vw, 1.25rem);
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .ui-section-footer__links a {
    color: inherit;
    text-decoration: none;
    opacity: 0.8;
    font-weight: 500;
    letter-spacing: 0.02em;
    transition: opacity 0.25s ease, color 0.25s ease;
  }

  .ui-section-footer__links a:hover,
  .ui-section-footer__links a:focus-visible {
    opacity: 1;
    color: var(--ui-sec-footer-link-hover, var(--site-accent, currentColor));
  }

  /* ─── Credits ───────────────────────────────────────────────── */
  .ui-section-footer__credits {
    font-size: 0.9rem;
    opacity: 0.7;
    line-height: 1.4;
    text-wrap: balance;
  }

  /* ─── Responsive Adjustments ────────────────────────────────── */
  @media (max-width: 768px) {
    .ui-section-footer[data-mod="ui_section_footer"] {
      padding: calc(var(--ui-sec-footer-padY, 40px) * 0.75)
        calc(var(--ui-sec-footer-padX, 24px) * 0.75);
    }

    .ui-section-footer__inner {
      gap: 0.5rem;
    }

    .ui-section-footer__credits {
      font-size: 0.8rem;
    }
  }
}

/* === tools/modules/ui.section.composer/ui.section.composer.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.section.composer
   Classification : Orchestrator | Page Composer | JSON-Driven Renderer | Wrapping-Aware
   Version        : 3.1.0 | Genesis-Final • Token-Harmonized • Layer-Scoped • Schema-Aligned
   File           : /tools/modules/ui.section.composer/ui.section.composer.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

/* ─── Layer Declaration ─────────────────────────────────────────────────────── */
@layer site, ui.section;

/* ─── Base Container ────────────────────────────────────────────────────────── */
.ui-section-composer {
  display: flex;
  flex-direction: column;
  gap: var(--site-pad, 3rem);
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  position: relative;
  isolation: isolate;
  contain: layout paint;
}

/* ─── Fade-in Animation (deprecated - using opacity transition instead) ───── */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ─── Section Placeholder — Production Fallback ─────────────────────────────── */
.section-placeholder {
  padding: clamp(1rem, 2vw, 2rem);
  text-align: center;
  font-size: 0.9rem;
  color: var(--ui-muted, #777);
  border: 1px dashed var(--ui-border, #ccc);
  border-radius: var(--ui-radius, 0.5rem);
  background: var(--ui-bg-alt, #fafafa);
  margin-inline: auto;
  width: min(100%, 900px);
  opacity: 0.85;
  line-height: 1.5;
  backdrop-filter: var(--ui-blur, none);
}

/* ─── Developer Mode Placeholder (DAREAKT_MODE=dev) ─────────────────────────── */
.section-placeholder.dev {
  background: #fff5f5;
  border-color: #ff8888;
  color: #d33;
  font-family: ui-monospace, monospace;
  font-weight: 600;
  letter-spacing: 0.5px;
  padding: 1.5rem;
  box-shadow: inset 0 0 6px rgba(255, 0, 0, 0.1);
}

/* ─── Token Harmony — Site Layer Bridge ─────────────────────────────────────── */
body[data-site] .ui-section-composer {
  --ui-border: var(--site-border, #ccc);
  --ui-bg-alt: var(--site-bg-alt, #fafafa);
  --ui-muted: var(--site-muted, #666);
  --ui-radius: var(--site-radius, 0.5rem);
  --ui-blur: var(--site-blur, none);
}

/* ─── Wrapping Awareness — Structural Markers ───────────────────────────────── */
.ui-section-composer[data-wrapping="layout"] {
  outline: 1px dotted rgba(0, 128, 255, 0.25);
  outline-offset: 3px;
}
.ui-section-composer[data-wrapping="canvas"] {
  outline: 1px dashed rgba(0, 200, 128, 0.25);
  outline-offset: 3px;
}

/* ─── Debug Overlay — Optional Diagnostic Grid ──────────────────────────────── */
.ui-section-composer[data-debug="true"] {
  outline: 1px dotted rgba(0, 0, 0, 0.25);
  outline-offset: 2px;
  background-image: repeating-linear-gradient(
    45deg,
    rgba(0, 0, 0, 0.02) 0,
    rgba(0, 0, 0, 0.02) 2px,
    transparent 2px,
    transparent 4px
  );
}

/* === tools/modules/ui.section.body/ui.section.body.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.section.body
   Classification : Layout Section | JSON-driven | Genesis Safe
   Version        : 2.1.0 | Edge-Token-Aware • DOM-Return-Guaranteed
   File           : /tools/modules/ui.section.body/ui.section.body.css
   Maintainer     : DΛREΛKT_ UI TEAM

   ARCHITECTURE:
   Root (.ui-section-body) = full-width background container.
     → padding-block for vertical spacing
     → NO padding-inline (background must go edge-to-edge)

   Inner (.ui-section-body__inner) = content constraint container.
     → padding-inline via --edge token (site controls the value)
     → optional max-width + centering via data-width="content"
     → NO responsive scaling here — sites set --edge at breakpoints

   Token chain:  --edge  →  --ui-sec-body-padX  →  24px (hardcoded fallback)
   Sites ONLY need to set --edge. Everything responds automatically.
   ──────────────────────────────────────────────────────────────── */

@layer ui.section.body {

  /* ─── Root: full-width background container ──────────────────── */
  .ui-section-body[data-module="ui.section.body"] {
    box-sizing: border-box;
    width: 100%;
    background: var(--ui-sec-body-bg, var(--site-bg));
    color: var(--ui-sec-body-fg, var(--site-fg));
    padding-block: var(--ui-sec-body-padY, 48px);
    padding-inline: 0;
    margin: 0;
  }

  /* ─── Inner: content container with edge padding ─────────────── */
  .ui-section-body__inner {
    max-width: none;
    margin-inline: 0;
    padding-inline: var(--edge, var(--ui-sec-body-padX, 24px));
  }

  /* ─── Opt-in: constrained content width ──────────────────────── */
  .ui-section-body[data-width="content"] .ui-section-body__inner {
    max-width: var(--ui-body-max, 1200px);
    margin-inline: auto;
  }

  /* ─── Opt-in: full-bleed (no padding, no constraint) ─────────── */
  .ui-section-body[data-width="bleed"] .ui-section-body__inner {
    padding-inline: 0;
    margin-inline: 0;
    max-width: none;
  }
}

/* === tools/modules/ui.section.top/ui.section.top.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.section.top
   Classification : Layout Section | Hero/Intro | Genesis-Final
   Version        : 2.0.0 | Wrapper-Safe • Bus-Aware • Responsive
   File           : /tools/modules/ui.section.top/ui.section.top.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ──────────────────────────────────────────────────────────────── */

@layer ui.section.top {
  .ui-section-top[data-mod="ui_section_top"] {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    box-sizing: border-box;
    width: 100%;
    min-height: var(--ui-st-height, 60vh);
    background: var(--ui-st-bg, var(--site-bg));
    color: var(--ui-st-fg, var(--site-fg));
    text-align: var(--ui-st-align, center);
    padding: clamp(2rem, 4vw, 6rem);
    margin: 0 auto;
    background-size: cover;
    background-position: center;
  }

  .ui-section-top__inner {
    max-width: 1000px;
    margin-inline: auto;
  }

  .ui-section-top__title {
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: 1.2;
    margin: 0;
  }

  .ui-section-top__subtitle {
    font-size: clamp(1.125rem, 2vw, 1.5rem);
    margin-top: 0.75em;
    opacity: 0.85;
  }

  .ui-section-top__actions {
    margin-top: clamp(1.5rem, 3vw, 3rem);
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
  }

  /* ─── Responsive Tweaks ──────────────────────────────────────── */
  @media (max-width: 768px) {
    .ui-section-top[data-mod="ui_section_top"] {
      padding: clamp(1.5rem, 5vw, 3rem);
    }
  }
}

/* === tools/modules/ui.section.fromJson/ui.section.fromJson.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.sections.fromJson
   Classification : UI Atom | Structured JSON Renderer | Token-Aware | Genesis-Final
   Version        : 2.0.0 | Site-Harmonized • Wrapping-Scoped • Bus-Aware
   File           : /tools/modules/ui.sections.fromJson/ui.sections.fromJson.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

/* ─── Layer Declaration ─────────────────────────────────────────────────────── */
@layer site, ui.sections;

/* ─── Base Wrapper ──────────────────────────────────────────────────────────── */
.ui-sections__wrap {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: var(--section-gap, 2.5rem);
  contain: layout paint;
  position: relative;
  isolation: isolate;
  transition: opacity 0.3s ease, transform 0.3s ease;
  animation: fadeIn 0.6s ease both;
}

/* ─── Section Container ─────────────────────────────────────────────────────── */
.ui-section {
  width: 100%;
  border-top: 1px solid var(--ui-border, #e0e0e0);
  padding-top: var(--section-pad-top, 1.25rem);
  margin-block: var(--section-margin, 2.25rem);
  color: var(--ui-fg, var(--site-fg, #111));
}

/* ─── Typography Tokens ─────────────────────────────────────────────────────── */
.ui-sec__prompt {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--ui-muted, var(--site-muted, #666));
  margin: 0 0 0.35rem 0;
  opacity: 0.9;
}

.ui-sec__title {
  font-size: clamp(1.25rem, 2.5vw, 1.65rem);
  font-weight: 700;
  line-height: 1.3;
  margin: 0.25rem 0 0.5rem 0;
  color: var(--ui-fg, var(--site-fg, #111));
}

.ui-sec__blurb {
  color: var(--ui-muted, var(--site-muted, #555));
  margin: 0 0 0.75rem 0;
  font-style: italic;
  line-height: 1.6;
}

/* ─── Lists ─────────────────────────────────────────────────────────────────── */
.ui-sec__list {
  list-style: none;
  margin: 0.35rem 0 0.75rem 0;
  padding: 0;
}

.ui-sec__list > li {
  margin: 0.2rem 0;
  color: var(--ui-fg, var(--site-fg, #222));
  line-height: 1.5;
}

/* ─── Groups & Subtitles ────────────────────────────────────────────────────── */
.ui-sec__group {
  margin-top: 1rem;
}

.ui-sec__group-head {
  font-weight: 600;
  margin: 0.75rem 0 0.4rem 0;
  color: var(--ui-fg, var(--site-fg, #111));
}

/* ─── Token Harmony — Site Layer Bridge ─────────────────────────────────────── */
body[data-site] .ui-sections__wrap {
  --ui-border: var(--site-border, #e0e0e0);
  --ui-fg: var(--site-fg, #111);
  --ui-muted: var(--site-muted, #666);
}

/* ─── Reveal Animation ──────────────────────────────────────────────────────── */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ─── Debug Outline (Dev Mode) ──────────────────────────────────────────────── */
.ui-sections__wrap[data-debug="true"] {
  outline: 1px dashed rgba(0, 0, 0, 0.25);
  background-image: repeating-linear-gradient(
    45deg,
    rgba(0, 0, 0, 0.02) 0,
    rgba(0, 0, 0, 0.02) 2px,
    transparent 2px,
    transparent 4px
  );
}

/* === tools/modules/ui.copy.fromJson/ui.copy.fromJson.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — ui.copy (shared styles)
   Version: 1.0.0
   • Typography tokens for readable copy blocks
   • Generic/neutral defaults - sites can override via CSS custom properties
   ──────────────────────────────────────────────────────────────────────────── */

@layer ui.copy {
  :root {
    --ui-copy-max: 720px;
    --ui-copy-margin-inline: auto; /* Allow sites to override centering */
    --ui-copy-gap: 1rem;
    --ui-copy-fg: #222;
    --ui-copy-fs: 1.125rem;
    --ui-copy-lh: 1.65;
  }

  .ui-copy__wrap {
    width: 100%;
    display: block;
  }

  .ui-copy {
    max-width: var(--ui-copy-max, 720px);
    margin: 0 var(--ui-copy-margin-inline, auto);
  }

  /* Inside columns/grids, left-align by default — centering only for standalone */
  .ui-columns__cell .ui-copy,
  .ui-grid__cell .ui-copy {
    --ui-copy-margin-inline: 0;
  }

  .ui-copy__item {
    margin: 0 0 var(--ui-copy-gap, 1rem) 0;
    color: var(--ui-copy-fg, #222);
    font-size: var(--ui-copy-fs, 1.125rem);
    line-height: var(--ui-copy-lh, 1.65);
  }

  .ui-copy__item em {
    font-style: italic;
  }

  /* ─── List mode ────────────────────────────────────────────────────── */
  .ui-copy__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ui-copy-list-gap, 0.35rem);
  }

  .ui-copy__list-item {
    display: flex;
    align-items: flex-start;
    gap: var(--ui-copy-list-marker-gap, 0.75rem);
    color: var(--ui-copy-fg, #222);
    font-size: var(--ui-copy-fs, 1.125rem);
    line-height: var(--ui-copy-lh, 1.65);
  }

  .ui-copy__list-item::before {
    content: "";
    flex-shrink: 0;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--ui-copy-list-marker, currentColor);
    opacity: var(--ui-copy-list-marker-opacity, 0.45);
    /* Center dot with first line: half line-height minus half dot */
    margin-top: calc(var(--ui-copy-lh, 1.65) / 2 * 1em - 3px);
  }

  /* Variant: accent — ring marker matching site accent */
  .ui-copy__list--accent .ui-copy__list-item::before {
    width: 8px;
    height: 8px;
    margin-top: calc(var(--ui-copy-lh, 1.65) / 2 * 1em - 4px);
    background: var(--ui-copy-list-marker-bg, rgba(232, 101, 26, 0.15));
    border: 2px solid var(--ui-copy-list-marker-border, var(--site-accent, #E8651A));
    opacity: 1;
  }
}

/* === tools/modules/ui.columns/ui.columns.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — COLUMNS
   Two-column layout with independent vertical stacks.
   ──────────────────────────────────────────────────────────────── */
@layer components {
  .ui-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: var(--ui-columns-gap, calc(var(--site-pad) * 3));
    width: 100%;
  }

  .ui-columns__column,
  .ui-columns__cell {
    display: flex;
    flex-direction: column;
    gap: var(--site-pad, 2rem);
    min-width: 0;
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
    position: relative;
  }

  .ui-columns__column > * {
    display: block;
    width: 100%;
    flex-shrink: 0;
  }

  /* Allow flex containers to override block display */
  .ui-columns__column > [data-module="ui.flex"] {
    display: flex;
    width: auto;
  }

  /* ─── Responsive Stacking ────────────────────────────────────── */
  /* Tablet - stack columns */
  /* !important required because SSR/runtime may set grid-template-columns via inline style */
  @media (max-width: 1024px) {
    .ui-columns {
      grid-template-columns: 1fr !important;
      row-gap: calc(var(--site-pad, 2rem) * 1.5);
    }
  }

  /* Mobile - tighter spacing */
  @media (max-width: 640px) {
    .ui-columns {
      row-gap: var(--site-pad, 2rem);
    }

    .ui-columns__column {
      gap: var(--site-pad-sm, 1rem);
    }
  }
}


/* === tools/modules/ui.grid/ui.grid.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — GRID ATOM
   Classification : Layout Atom | Responsive | Matrix-Aware | Theme + Token Harmonized
   Version        : 5.0.0 | Genesis-Final • Matrix-Aware • Deterministic-ID • Safe-Fallback
   File           : /tools/modules/ui.grid/ui.grid.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ──────────────────────────────────────────────────────────────── */

@layer ui.grid {

  /* ─── Root Grid Container ───────────────────────────────────── */
  /* CORE RULE — grid NEVER sets width/margin/padding (layout-agnostic) */
  /* Width controlled via token — wrapper/layout layer owns sizing */
  .ui-grid[data-module="ui.grid"]:not(.module-wrapper),
  .ui-grid[data-mod="ui_grid"]:not(.module-wrapper) {
    display: grid;
    width: var(--ui-grid-width, auto);
    gap: var(--ui-grid-gap, var(--site-pad, 2rem));
    grid-template-columns: var(--ui-grid-cols, repeat(2, 1fr));
    align-items: var(--ui-grid-align, start);
    justify-content: var(--ui-grid-justify, start);
    box-sizing: border-box;
    position: relative;
    isolation: isolate;
    transition: all 0.25s ease-in-out;
    /* Width/margin/padding controlled by wrapper/layout layer */
  }

  /* ─── Matrix-Aware Hooks (new) ───────────────────────────────── */
  /* Targets any cell by new deterministic data attributes */
  .ui-grid__cell[data-index],
  .ui-grid__cell[data-row],
  .ui-grid__cell[data-col],
  .ui-grid__cell[data-area] {
    min-width: 0;
    contain: content;
    display: block;
    position: relative;
    width: 100%;
  }

  /* Optional: visual aid for matrix grids when debugging */
  .ui-grid[data-debug="true"] .ui-grid__cell::before {
    content: attr(data-area);
    position: absolute;
    top: 4px;
    left: 6px;
    font-size: 9px;
    color: rgba(0, 0, 0, 0.35);
    font-family: monospace;
    pointer-events: none;
  }

  /* ─── Variant Modifiers ─────────────────────────────────────── */
  .ui-grid[data-variant="auto"]  { grid-auto-flow: row dense; }
  .ui-grid[data-variant="fixed"] { grid-auto-flow: row; }
  .ui-grid[data-variant="stack"] { grid-template-columns: 1fr !important; }

  /* ─── Ownership Diagnostics (Hierarchy Aware) ───────────────── */
  .ui-grid[data-owner="ui.layout"],
  .ui-grid[data-owner="ui.canvas"],
  .ui-grid[data-owner="ui.section"],
  .ui-grid[data-owner="ui.section.composer"] {
    border: none;
  }

  /* ─── Debug Visualization (Optional Dev Aid) ────────────────── */
  .ui-grid[data-debug="true"] .ui-grid__cell {
    outline: 1px dashed rgba(0, 0, 0, 0.15);
    background: rgba(0, 0, 0, 0.02);
  }

  .ui-grid[data-debug="true"][data-owner="document"] {
    outline: 1px dashed rgba(255, 0, 0, 0.25);
    outline-offset: 2px;
  }

  /* ─── Responsive Collapse (Stack Rules) ─────────────────────── */
  /* Tablet breakpoint — 3+ column grids collapse to 2 columns, 2-column grids to 1 */
  @media (max-width: 1024px) {
    .ui-grid[data-module="ui.grid"][data-cols="2"],
    .ui-grid[data-module="ui.grid"]:not([data-cols]) {
      --ui-grid-cols: 1fr;
    }
    .ui-grid[data-module="ui.grid"][data-cols="3"],
    .ui-grid[data-module="ui.grid"][data-cols="4"],
    .ui-grid[data-module="ui.grid"][data-cols="5"],
    .ui-grid[data-module="ui.grid"][data-cols="6"] {
      --ui-grid-cols: repeat(2, 1fr);
    }
  }

  /* Smaller tablet - stack everything with data-stack */
  @media (max-width: 900px) {
    .ui-grid[data-stack="true"],
    .ui-grid[data-variant="auto"][data-stack="true"] {
      grid-template-columns: 1fr !important;
      gap: var(--site-pad-sm, 1rem);
    }
  }

  /* Small tablet / large phone — ALL multi-column grids go single column */
  @media (max-width: 768px) {
    .ui-grid[data-module="ui.grid"][data-cols="3"],
    .ui-grid[data-module="ui.grid"][data-cols="4"],
    .ui-grid[data-module="ui.grid"][data-cols="5"],
    .ui-grid[data-module="ui.grid"][data-cols="6"] {
      --ui-grid-cols: 1fr;
      grid-template-columns: 1fr !important;
      gap: var(--site-pad-sm, 1rem);
    }
  }

  /* Mobile - all grids single column */
  /* Note: !important required because SSR/runtime set --ui-grid-cols via inline style */
  @media (max-width: 640px) {
    .ui-grid[data-module="ui.grid"] {
      --ui-grid-cols: 1fr;
      grid-template-columns: 1fr !important;
      gap: var(--site-pad-sm, 1rem);
    }
  }

  /* ─── Theme Awareness (Site Token Bridges) ───────────────────── */
  [data-theme="dark"] .ui-grid {
    --ui-grid-gap: var(--site-pad, 1.5rem);
    color: var(--site-fg, #eee);
    background-color: transparent;
  }

  [data-theme="light"] .ui-grid {
    --ui-grid-gap: var(--site-pad, 2rem);
    color: var(--site-fg, #111);
    background-color: transparent;
  }

  /* ─── Motion Reduction (Accessibility Compliance) ────────────── */
  @media (prefers-reduced-motion: reduce) {
    .ui-grid { transition: none !important; }
  }

  /* ─── Genesis Token Bridges (System Defaults) ────────────────── */
  /* Note: --ui-grid-width is NOT defined at :root to force explicit author intent */
  /* Authors must define it on wrapper/layout layer for contained grids */
  :root {
    --ui-grid-gap: var(--site-pad, 2rem);
    --ui-grid-cols: repeat(2, 1fr);
    --ui-grid-align: start;
    --ui-grid-justify: start;
    --ui-grid-padX: 0px;
    --ui-grid-padY: 0px;
  }

  /* ─── Fallback Styling (Fail-Safe) ───────────────────────────── */
  .ui-grid__fallback,
  .ui-grid__error {
    display: block;
    padding: 1rem;
    background: rgba(255, 0, 0, 0.05);
    color: var(--site-fg, #333);
    font-family: monospace;
    font-size: 0.9rem;
    border-radius: 4px;
    text-align: center;
  }

  /* ─── Development Highlight (Optional Aid) ───────────────────── */
  .ui-grid[data-debug="true"]::after {
    content: attr(data-version);
    position: absolute;
    top: 2px;
    right: 4px;
    font-size: 9px;
    color: rgba(0, 0, 0, 0.25);
    font-family: monospace;
  }
}

/* === tools/modules/ui.hero/ui.hero.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.hero
   Version: 1.0.0 | Genesis-Final • Tokenized • Responsive • Reveal-Animated
   Classification: Atom | Visual | Hero Banner
   Maintainer: DΛREΛKT_ UI TEAM
   ─────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* ─── Root Container ──────────────────────────────────────────────────────── */
  [data-module="ui.hero"].ui-hero {
    position: relative;
    width: 100%;
    height: var(--ui-hero-height, 60vh);
    min-height: 280px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;

  }

  /* ─── Compact Variant ─────────────────────────────────────────────────────── */
  [data-module="ui.hero"].ui-hero[data-variant="compact"] {
    --ui-hero-height: 40vh;
    min-height: 200px;
  }

  /* ─── Background Layer ────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
  }

  /* ─── Overlay ─────────────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      to top,
      var(--ui-hero-overlay-color, rgba(0, 0, 0, 1)) 0%,
      transparent 100%
    );
    opacity: var(--ui-hero-overlay-opacity, 0.45);
    z-index: 1;
    pointer-events: none;
  }

  /* ─── Content Layer ───────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem 1.5rem;
    max-width: 900px;
    width: 100%;
    box-sizing: border-box;
    gap: 1rem;
  }

  /* ─── Alignment Variants ──────────────────────────────────────────────────── */
  [data-module="ui.hero"][data-align="left"] .ui-hero__content {
    align-items: flex-start;
    text-align: left;
    margin-left: 5%;
    margin-right: auto;
  }

  [data-module="ui.hero"][data-align="right"] .ui-hero__content {
    align-items: flex-end;
    text-align: right;
    margin-left: auto;
    margin-right: 5%;
  }

  /* ─── Title ───────────────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__title {
    font-family: var(--font-heading, inherit);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 700;
    line-height: 1.15;
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    margin: 0;
    letter-spacing: -0.01em;
  }

  /* ─── Subtitle ────────────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__subtitle {
    font-family: var(--font-body, inherit);
    font-size: clamp(1rem, 2.5vw, 1.35rem);
    font-weight: 400;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.9);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
    margin: 0;
    max-width: 640px;
  }

  /* ─── Trust Line (primary differentiator — authority / credibility) ──────── */
  [data-module="ui.hero"] .ui-hero__trust {
    font-family: var(--font-body, inherit);
    font-size: clamp(1.05rem, 2.2vw, 1.25rem);
    font-weight: 500;
    font-style: italic;
    line-height: 1.45;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
    margin: 0.5rem 0 0.15rem;
    max-width: 640px;
  }

  /* ─── USP (secondary differentiator — operational promise) ──────────────── */
  [data-module="ui.hero"] .ui-hero__usp {
    font-family: var(--font-body, inherit);
    font-size: clamp(0.9rem, 1.8vw, 1.05rem);
    font-weight: 600;
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.88);
    letter-spacing: 0.01em;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
    margin: 0.15rem 0 0;
    max-width: 640px;
  }

  /* ─── Lede (supporting voice copy from content JSON) ─────────────────────── */
  [data-module="ui.hero"] .ui-hero__lede {
    font-family: var(--font-body, inherit);
    font-size: clamp(0.85rem, 1.6vw, 0.95rem);
    font-weight: 400;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.7);
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
    margin: 0;
    max-width: 580px;
  }

  /* ─── CTA Button ──────────────────────────────────────────────────────────── */
  [data-module="ui.hero"] .ui-hero__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 2rem;
    font-family: var(--font-body, inherit);
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background: var(--color-primary, #3fa9f5);
    border: 2px solid transparent;
    border-radius: 6px;
    text-decoration: none;
    cursor: pointer;
    transition:
      background 0.2s ease,
      transform 0.15s ease,
      box-shadow 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    margin-top: 1.25rem;
  }

  [data-module="ui.hero"] .ui-hero__cta:hover {
    background: var(--color-primary-hover, #2b8ad4);
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
  }

  [data-module="ui.hero"] .ui-hero__cta:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  }

  [data-module="ui.hero"] .ui-hero__cta:focus-visible {
    outline: 2px solid var(--color-primary, #3fa9f5);
    outline-offset: 3px;
  }

  /* ─── Compact Variant: Reduced Content Sizing ─────────────────────────────── */
  [data-module="ui.hero"][data-variant="compact"] .ui-hero__title {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
  }

  [data-module="ui.hero"][data-variant="compact"] .ui-hero__subtitle {
    font-size: clamp(0.9rem, 2vw, 1.1rem);
  }

  [data-module="ui.hero"][data-variant="compact"] .ui-hero__cta {
    padding: 0.6rem 1.5rem;
    font-size: 0.9rem;
  }

  /* ─── Responsive: Tablet ──────────────────────────────────────────────────── */
  @media (max-width: 768px) {
    [data-module="ui.hero"].ui-hero {
      min-height: 240px;
    }

    [data-module="ui.hero"] .ui-hero__content {
      padding: 1.5rem 1rem;
      gap: 0.75rem;
    }

    [data-module="ui.hero"] .ui-hero__title {
      font-size: clamp(1.5rem, 6vw, 2.5rem);
    }

    [data-module="ui.hero"] .ui-hero__subtitle {
      font-size: clamp(0.9rem, 3vw, 1.15rem);
    }

    /* Force center alignment on mobile for readability */
    [data-module="ui.hero"][data-align="left"] .ui-hero__content,
    [data-module="ui.hero"][data-align="right"] .ui-hero__content {
      align-items: center;
      text-align: center;
      margin-left: auto;
      margin-right: auto;
    }
  }

  /* ─── Responsive: Small Mobile ────────────────────────────────────────────── */
  @media (max-width: 480px) {
    [data-module="ui.hero"].ui-hero {
      min-height: 200px;
    }

    [data-module="ui.hero"] .ui-hero__content {
      padding: 1rem 0.75rem;
    }

    [data-module="ui.hero"] .ui-hero__cta {
      width: 100%;
      max-width: 280px;
    }
  }
}

/* === tools/modules/ui.faq/ui.faq.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI -- MODULE: ui.faq
   Classification : UI Atom | FAQ Accordion | Accessible
   Version        : 1.0.0 | Genesis-Final . Layered . Token-Scoped
   File           : /tools/modules/ui.faq/ui.faq.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* --- Wrapper ─────────────────────────────────────────────────────────────── */
  .ui-faq__wrap {
    width: 100%;
    display: block;
    box-sizing: border-box;
  }

  /* --- Title ───────────────────────────────────────────────────────────────── */
  .ui-faq__title {
    margin: 0 0 1.5rem 0;
    font-size: var(--ui-faq-title-fs, 1.5rem);
    font-weight: var(--ui-faq-title-fw, 700);
    color: var(--ui-faq-question-fg, currentColor);
    line-height: 1.3;
  }

  /* --- List Container ──────────────────────────────────────────────────────── */
  .ui-faq__list {
    display: flex;
    flex-direction: column;
    gap: var(--ui-faq-gap, 0px);
  }

  /* --- Item (<details>) ────────────────────────────────────────────────────── */
  .ui-faq__item {
    border-bottom: var(--ui-faq-border, 1px solid rgba(0, 0, 0, 0.1));
    overflow: hidden;
  }

  .ui-faq__item:first-child {
    border-top: var(--ui-faq-border, 1px solid rgba(0, 0, 0, 0.1));
  }

  /* --- Question (<summary>) ────────────────────────────────────────────────── */
  .ui-faq__question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    font-size: var(--ui-faq-question-fs, 1.0625rem);
    font-weight: var(--ui-faq-question-fw, 600);
    color: var(--ui-faq-question-fg, currentColor);
    cursor: pointer;
    list-style: none;
    user-select: none;
    transition: color 0.2s ease;
    line-height: 1.4;
  }

  /* Remove default marker across browsers */
  .ui-faq__question::-webkit-details-marker {
    display: none;
  }
  .ui-faq__question::marker {
    content: "";
  }

  /* Chevron indicator (CSS-only) */
  .ui-faq__question::after {
    content: "";
    flex-shrink: 0;
    width: 0.625rem;
    height: 0.625rem;
    margin-left: 1rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.25s ease;
    opacity: 0.6;
  }

  /* Rotate chevron when open */
  .ui-faq__item[open] > .ui-faq__question::after {
    transform: rotate(-135deg);
  }

  /* Hover state */
  .ui-faq__question:hover {
    color: var(--ui-faq-question-hover-fg, currentColor);
    opacity: 0.8;
  }

  /* Focus visible for keyboard accessibility */
  .ui-faq__question:focus-visible {
    outline: 2px solid var(--ui-faq-focus-ring, currentColor);
    outline-offset: 2px;
    border-radius: 2px;
  }

  /* --- Answer ──────────────────────────────────────────────────────────────── */
  .ui-faq__answer {
    padding: 0 0 1.25rem 0;
    color: var(--ui-faq-answer-fg, rgba(0, 0, 0, 0.7));
    font-size: var(--ui-faq-answer-fs, 1rem);
    line-height: 1.65;
  }

  .ui-faq__answer p {
    margin: 0;
  }

  .ui-faq__answer p + p {
    margin-top: 0.75rem;
  }

  /* --- Smooth open/close animation ─────────────────────────────────────────── */
  .ui-faq__item .ui-faq__answer {
    animation: uiFaqFadeIn 0.25s ease forwards;
  }

  @keyframes uiFaqFadeIn {
    from {
      opacity: 0;
      transform: translateY(-4px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  /* --- Responsive ──────────────────────────────────────────────────────────── */
  @media (max-width: 640px) {
    .ui-faq__title {
      font-size: var(--ui-faq-title-fs-sm, 1.25rem);
    }
    .ui-faq__question {
      font-size: var(--ui-faq-question-fs-sm, 1rem);
      padding: 0.875rem 0;
    }
    .ui-faq__answer {
      font-size: var(--ui-faq-answer-fs-sm, 0.9375rem);
    }
  }
}

/* --- Design Tokens (overridable via theme or site tokens) ──────────────────
   These ensure the FAQ renders cleanly out of the box. Override as needed.
   -------------------------------------------------------------------------- */
:root {
  --ui-faq-border: 1px solid rgba(0, 0, 0, 0.1);
  --ui-faq-question-fg: currentColor;
  --ui-faq-answer-fg: rgba(0, 0, 0, 0.7);
  --ui-faq-gap: 0px;
}

/* === tools/modules/ui.pricing.table/ui.pricing.table.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI -- MODULE: ui.pricing.table
   Classification : UI Atom | Pricing Table | Responsive
   Version        : 1.0.0 | Genesis-Final . Layered . Token-Scoped
   File           : /tools/modules/ui.pricing.table/ui.pricing.table.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* --- Wrapper ─────────────────────────────────────────────────────────────── */
  .ui-pricing__wrap {
    width: 100%;
    display: block;
    box-sizing: border-box;
  }

  /* --- Title ───────────────────────────────────────────────────────────────── */
  .ui-pricing__title {
    margin: 0 0 1.5rem 0;
    font-size: var(--ui-pricing-title-fs, 1.5rem);
    font-weight: var(--ui-pricing-title-fw, 700);
    color: var(--ui-pricing-title-fg, currentColor);
    line-height: 1.3;
  }

  /* ─── Table Variant ─────────────────────────────────────────────────────── */

  /* Scrollable wrapper for horizontal overflow on mobile */
  .ui-pricing__table-wrap {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .ui-pricing__table {
    width: 100%;
    border-collapse: collapse;
    min-width: 480px;
    background: var(--ui-pricing-bg, #fff);
    border: 1px solid var(--ui-pricing-border, rgba(0, 0, 0, 0.1));
  }

  /* Header */
  .ui-pricing__table thead {
    background: var(--ui-pricing-header-bg, #f7f7f8);
  }

  .ui-pricing__table th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-size: var(--ui-pricing-th-fs, 0.875rem);
    font-weight: 600;
    color: var(--ui-pricing-th-fg, #555);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: 2px solid var(--ui-pricing-border, rgba(0, 0, 0, 0.1));
  }

  /* Body cells */
  .ui-pricing__table td {
    padding: 0.75rem 1rem;
    font-size: var(--ui-pricing-td-fs, 1rem);
    color: var(--ui-pricing-fg, #333);
    border-bottom: 1px solid var(--ui-pricing-border, rgba(0, 0, 0, 0.06));
  }

  /* Alternating row colors */
  .ui-pricing__row:nth-child(even) {
    background: var(--ui-pricing-row-alt-bg, rgba(0, 0, 0, 0.02));
  }

  /* Service column */
  .ui-pricing__service {
    font-weight: 500;
  }

  /* Price column -- highlighted and bold */
  .ui-pricing__price {
    font-weight: 700;
    color: var(--ui-pricing-accent, #1a73e8);
    white-space: nowrap;
  }

  /* Notes column */
  .ui-pricing__notes {
    font-size: var(--ui-pricing-notes-fs, 0.9375rem);
    color: var(--ui-pricing-notes-fg, #666);
  }

  /* ─── Cards Variant ─────────────────────────────────────────────────────── */

  .ui-pricing__cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--ui-pricing-card-gap, 1.25rem);
  }

  .ui-pricing__card {
    background: var(--ui-pricing-bg, #fff);
    border: 1px solid var(--ui-pricing-border, rgba(0, 0, 0, 0.1));
    border-left: 4px solid var(--ui-pricing-accent, #1a73e8);
    border-radius: var(--ui-pricing-card-radius, 6px);
    padding: 1.5rem;
    transition: box-shadow 0.2s ease;
  }

  .ui-pricing__card:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  }

  /* Card service name */
  .ui-pricing__card-service {
    margin: 0 0 0.75rem 0;
    font-size: var(--ui-pricing-card-service-fs, 1.125rem);
    font-weight: 600;
    color: var(--ui-pricing-fg, #222);
    line-height: 1.3;
  }

  /* Card price */
  .ui-pricing__card-price {
    font-size: var(--ui-pricing-card-price-fs, 1.5rem);
    font-weight: 700;
    color: var(--ui-pricing-accent, #1a73e8);
    margin: 0 0 0.75rem 0;
    line-height: 1.2;
  }

  .ui-pricing__card-price span {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--ui-pricing-notes-fg, #666);
  }

  /* Card notes */
  .ui-pricing__card-notes {
    margin: 0;
    font-size: var(--ui-pricing-notes-fs, 0.9375rem);
    color: var(--ui-pricing-notes-fg, #666);
    line-height: 1.5;
  }

  /* ─── Responsive ────────────────────────────────────────────────────────── */
  @media (max-width: 640px) {
    .ui-pricing__title {
      font-size: var(--ui-pricing-title-fs-sm, 1.25rem);
    }

    /* Cards stack to single column */
    .ui-pricing__cards {
      grid-template-columns: 1fr;
    }

    .ui-pricing__card-price {
      font-size: var(--ui-pricing-card-price-fs-sm, 1.25rem);
    }
  }
}

/* --- Design Tokens (overridable via theme or site tokens) ──────────────────
   These ensure the pricing table renders cleanly out of the box. Override as needed.
   -------------------------------------------------------------------------- */
:root {
  --ui-pricing-accent: #1a73e8;
  --ui-pricing-bg: #fff;
  --ui-pricing-border: rgba(0, 0, 0, 0.1);
  --ui-pricing-header-bg: #f7f7f8;
  --ui-pricing-fg: #333;
  --ui-pricing-notes-fg: #666;
  --ui-pricing-card-gap: 1.25rem;
  --ui-pricing-card-radius: 6px;
}

/* === tools/modules/ui.tour.card/ui.tour.card.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.tour.card
   Version: 1.0.0 | Genesis-Final • Tokenized • Responsive
   Classification: Atom | Content Display | Tour Card Grid
   Maintainer: DΛREΛKT_ UI TEAM
   ─────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* ─── Tokens ─────────────────────────────────────────────────────────────── */
  .ui-tour-card__wrap {
    --ui-tour-card-accent: #F26522;
    --ui-tour-card-radius: 12px;
    --ui-tour-card-cols: 2;
  }

  /* ─── Wrap ───────────────────────────────────────────────────────────────── */
  .ui-tour-card__wrap {
    display: block;
    width: 100%;
  }

  /* ─── Section Title ──────────────────────────────────────────────────────── */
  .ui-tour-card__title {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 1rem;
    color: inherit;
  }

  /* ─── Grid Layout ────────────────────────────────────────────────────────── */
  .ui-tour-card__grid {
    display: grid;
    grid-template-columns: repeat(var(--ui-tour-card-cols, 2), 1fr);
    gap: 1.25rem;
  }

  /* ─── List Layout ────────────────────────────────────────────────────────── */
  .ui-tour-card__list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
  }

  /* ─── Card ───────────────────────────────────────────────────────────────── */
  .ui-tour-card {
    border: 2px solid var(--ui-tour-card-accent);
    border-radius: var(--ui-tour-card-radius);
    overflow: hidden;
    background: var(--ui-tour-card-bg, #fff);
    transition: box-shadow 0.25s ease, transform 0.25s ease;
  }

  .ui-tour-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
  }

  /* ─── Link (covers entire card) ──────────────────────────────────────────── */
  .ui-tour-card__link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    height: 100%;
  }

  /* ─── Image Section ──────────────────────────────────────────────────────── */
  .ui-tour-card__image-wrap {
    position: relative;
    overflow: hidden;
  }

  .ui-tour-card__image {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }

  /* ─── Price Badge ────────────────────────────────────────────────────────── */
  .ui-tour-card__price {
    position: absolute;
    bottom: 0.5rem;
    right: 0.5rem;
    background: var(--ui-tour-card-accent);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.3rem 0.65rem;
    border-radius: 6px;
    line-height: 1.2;
    white-space: nowrap;
  }

  /* ─── Body ───────────────────────────────────────────────────────────────── */
  .ui-tour-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 0.85rem 1rem 1rem;
    flex: 1;
  }

  .ui-tour-card__name {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
    line-height: 1.3;
    color: var(--ui-tour-card-name-color, #1a1a1a);
  }

  .ui-tour-card__desc {
    font-size: 0.9rem;
    line-height: 1.45;
    margin: 0;
    color: var(--ui-tour-card-desc-color, #555);
    flex: 1;
  }

  .ui-tour-card__cta {
    display: inline-block;
    margin-top: 0.3rem;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ui-tour-card-accent);
    transition: opacity 0.2s ease;
  }

  .ui-tour-card__link:hover .ui-tour-card__cta {
    opacity: 0.8;
  }

  /* ─── Responsive: 1 column on mobile ─────────────────────────────────────── */
  @media (max-width: 768px) {
    .ui-tour-card__grid {
      grid-template-columns: 1fr;
    }
  }
}

/* === tools/modules/ui.itinerary/ui.itinerary.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.itinerary
   Classification : UI Atom | Timeline Renderer | Token-Scoped
   Version        : 1.0.0 | Genesis-Final • Layered • Token-Scoped
   File           : /tools/modules/ui.itinerary/ui.itinerary.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* ─── Tokens ───────────────────────────────────────────────────────────── */
  :root {
    --ui-itinerary-marker-size: 40px;
    --ui-itinerary-marker-bg: #F26522;
    --ui-itinerary-marker-fg: #fff;
    --ui-itinerary-marker-font-size: 1rem;
    --ui-itinerary-line-color: #ddd;
    --ui-itinerary-line-width: 2px;
    --ui-itinerary-content-gap: 1.25rem;
    --ui-itinerary-title-fs: 1.5rem;
    --ui-itinerary-title-fw: 700;
    --ui-itinerary-title-fg: inherit;
    --ui-itinerary-step-title-fs: 1.125rem;
    --ui-itinerary-step-title-fw: 600;
    --ui-itinerary-step-desc-fg: #555;
    --ui-itinerary-image-radius: 8px;
    --ui-itinerary-image-max-w: 100%;
    --ui-itinerary-step-gap: 0;
    --ui-itinerary-step-pad-bottom: 2rem;
    --ui-itinerary-reveal-duration: 0.4s;
  }

  /* ─── Wrapper ──────────────────────────────────────────────────────────── */
  .ui-itinerary__wrap {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  /* ─── Section Title ────────────────────────────────────────────────────── */
  .ui-itinerary__title {
    margin: 0 0 1.5rem 0;
    font-size: var(--ui-itinerary-title-fs);
    font-weight: var(--ui-itinerary-title-fw);
    color: var(--ui-itinerary-title-fg);
  }

  /* ─── Ordered List (reset) ─────────────────────────────────────────────── */
  .ui-itinerary__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ui-itinerary-step-gap);
  }

  /* ─── Step Item ────────────────────────────────────────────────────────── */
  .ui-itinerary__step {
    display: flex;
    align-items: flex-start;
    gap: var(--ui-itinerary-content-gap);
    padding-bottom: var(--ui-itinerary-step-pad-bottom);
    position: relative;

    /* Reveal animation */
    opacity: 0;
    transform: translateY(12px);
    animation: uiItineraryReveal var(--ui-itinerary-reveal-duration) ease forwards;
  }

  /* Stagger animation per step */
  .ui-itinerary__step:nth-child(1)  { animation-delay: 0s; }
  .ui-itinerary__step:nth-child(2)  { animation-delay: 0.08s; }
  .ui-itinerary__step:nth-child(3)  { animation-delay: 0.16s; }
  .ui-itinerary__step:nth-child(4)  { animation-delay: 0.24s; }
  .ui-itinerary__step:nth-child(5)  { animation-delay: 0.32s; }
  .ui-itinerary__step:nth-child(6)  { animation-delay: 0.40s; }
  .ui-itinerary__step:nth-child(7)  { animation-delay: 0.48s; }
  .ui-itinerary__step:nth-child(8)  { animation-delay: 0.56s; }
  .ui-itinerary__step:nth-child(9)  { animation-delay: 0.64s; }
  .ui-itinerary__step:nth-child(10) { animation-delay: 0.72s; }

  @keyframes uiItineraryReveal {
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  /* ─── Timeline Variant: Connecting Line ────────────────────────────────── */
  .ui-itinerary__list[data-variant="timeline"] .ui-itinerary__step:not(:last-child)::after {
    content: "";
    position: absolute;
    left: calc(var(--ui-itinerary-marker-size) / 2);
    top: var(--ui-itinerary-marker-size);
    bottom: 0;
    width: var(--ui-itinerary-line-width);
    background: var(--ui-itinerary-line-color);
    transform: translateX(-50%);
  }

  /* ─── Marker (Numbered Circle) ─────────────────────────────────────────── */
  .ui-itinerary__marker {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--ui-itinerary-marker-size);
    height: var(--ui-itinerary-marker-size);
    border-radius: 50%;
    background: var(--ui-itinerary-marker-bg);
    position: relative;
    z-index: 1;
  }

  .ui-itinerary__number {
    font-size: var(--ui-itinerary-marker-font-size);
    font-weight: 700;
    color: var(--ui-itinerary-marker-fg);
    line-height: 1;
    user-select: none;
  }

  /* ─── Content Area ─────────────────────────────────────────────────────── */
  .ui-itinerary__content {
    flex: 1;
    min-width: 0;
    padding-top: 0.35rem; /* Align text baseline with marker center */
  }

  .ui-itinerary__step-title {
    margin: 0 0 0.35rem 0;
    font-size: var(--ui-itinerary-step-title-fs);
    font-weight: var(--ui-itinerary-step-title-fw);
    color: inherit;
  }

  .ui-itinerary__step-desc {
    margin: 0 0 0.75rem 0;
    line-height: 1.6;
    color: var(--ui-itinerary-step-desc-fg);
  }

  .ui-itinerary__step-image {
    display: block;
    max-width: var(--ui-itinerary-image-max-w);
    height: auto;
    border-radius: var(--ui-itinerary-image-radius);
    margin-top: 0.5rem;
  }

  /* ─── Clamp / Read More ────────────────────────────────────────────────── */
  .ui-itinerary__step-desc-wrap {
    position: relative;
  }

  .ui-itinerary__step-desc-wrap[data-clamp] .ui-itinerary__step-desc {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    -webkit-line-clamp: var(--ui-itinerary-clamp-lines, 4);
  }

  .ui-itinerary__step-desc-wrap.is-expanded .ui-itinerary__step-desc {
    display: block;
    -webkit-line-clamp: unset;
    overflow: visible;
  }

  .ui-itinerary__read-more {
    display: none;
    background: none;
    border: none;
    padding: 0.25rem 0;
    cursor: pointer;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--ui-itinerary-marker-bg, #F26522);
    opacity: 0.85;
    transition: opacity 0.2s ease;
  }
  .ui-itinerary__read-more:hover {
    opacity: 1;
  }

  /* Show button only when content is actually clamped */
  .ui-itinerary__step-desc-wrap[data-clamp] .ui-itinerary__read-more {
    display: inline-block;
  }
  .ui-itinerary__step-desc-wrap.is-expanded .ui-itinerary__read-more {
    display: inline-block;
  }
  /* Hide when not needed (JS adds .no-clamp if text fits) */
  .ui-itinerary__step-desc-wrap.no-clamp .ui-itinerary__read-more {
    display: none;
  }

  /* ─── Numbered Variant (no connecting line, simpler look) ──────────────── */
  .ui-itinerary__list[data-variant="numbered"] .ui-itinerary__step::after {
    display: none;
  }

  /* ─── Responsive: Mobile ───────────────────────────────────────────────── */
  @media (max-width: 600px) {
    :root {
      --ui-itinerary-marker-size: 32px;
      --ui-itinerary-marker-font-size: 0.875rem;
      --ui-itinerary-content-gap: 0.75rem;
      --ui-itinerary-step-pad-bottom: 1.5rem;
      --ui-itinerary-title-fs: 1.25rem;
    }
  }
}

/* === tools/modules/ui.contact.form/ui.contact.form.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.contact.form
   Version: 1.0.0 | Genesis-Final • Tokenized • Responsive • BEM-Locked
   Classification: Atom | Form | Contact
   Maintainer: DΛREΛKT_ UI TEAM
   ─────────────────────────────────────────────────────────────────────────────── */

@layer atoms {

  /* ─── Tokens ─────────────────────────────────────────────────────────────── */
  :root {
    --ui-contact-form-accent:   var(--theme-accent, #005cff);
    --ui-contact-form-radius:   8px;
    --ui-contact-form-error:    var(--theme-error, #e53935);
    --ui-contact-form-success:  var(--theme-success, #2e7d32);

    --ui-contact-form-gap:      20px;
    --ui-contact-form-field-gap: 6px;
    --ui-contact-form-pad:      14px 16px;

    --ui-contact-form-bg:       var(--theme-surface, #fff);
    --ui-contact-form-border:   var(--theme-border, #d0d0d0);
    --ui-contact-form-fg:       var(--theme-text, #1a1a1a);
    --ui-contact-form-label-fg: var(--theme-text-secondary, #444);

    --ui-contact-form-btn-fg:   var(--theme-text-inverse, #fff);
    --ui-contact-form-btn-bg:   var(--ui-contact-form-accent);
    --ui-contact-form-btn-hover: var(--theme-accent-hover, #0047d9);
  }

  /* ─── Wrap ───────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"].ui-contact-form__wrap {
    width: 100%;
    max-width: 640px;
    margin: 0 auto;
    box-sizing: border-box;
  }

  /* ─── Title ──────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__title {
    font-family: var(--font-heading, inherit);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: 700;
    color: var(--ui-contact-form-fg);
    margin: 0 0 8px 0;
    line-height: 1.3;
  }

  /* ─── Description ────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__desc {
    font-family: var(--font-body, inherit);
    font-size: 1rem;
    color: var(--ui-contact-form-label-fg);
    margin: 0 0 var(--ui-contact-form-gap) 0;
    line-height: 1.5;
  }

  /* ─── Form ───────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form {
    display: grid;
    gap: var(--ui-contact-form-gap);
    width: 100%;
  }

  /* ─── Field ──────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__field {
    display: grid;
    gap: var(--ui-contact-form-field-gap);
  }

  /* ─── Label ──────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__label {
    font-family: var(--font-body, inherit);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ui-contact-form-label-fg);
    line-height: 1.3;
  }

  /* ─── Input / Textarea / Select ──────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__input {
    -webkit-appearance: none;
    appearance: none;
    font: inherit;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--ui-contact-form-fg);
    background: var(--ui-contact-form-bg);
    border: 1px solid var(--ui-contact-form-border);
    border-radius: var(--ui-contact-form-radius);
    padding: var(--ui-contact-form-pad);
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
  }

  [data-module="ui.contact.form"] .ui-contact-form__input::placeholder {
    color: var(--theme-text-muted, #999);
    opacity: 1;
  }

  [data-module="ui.contact.form"] .ui-contact-form__input:focus {
    outline: none;
    border-color: var(--ui-contact-form-accent);
    box-shadow: 0 0 0 3px rgba(0, 92, 255, 0.12);
  }

  /* ─── Textarea ───────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__textarea {
    resize: vertical;
    min-height: 120px;
  }

  /* ─── Select ─────────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__select {
    cursor: pointer;
  }

  /* ─── Error State ────────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__field--error .ui-contact-form__input {
    border-color: var(--ui-contact-form-error);
    box-shadow: 0 0 0 3px rgba(229, 57, 53, 0.1);
  }

  [data-module="ui.contact.form"] .ui-contact-form__error {
    font-size: 0.8rem;
    color: var(--ui-contact-form-error);
    line-height: 1.3;
    min-height: 0;
  }

  [data-module="ui.contact.form"] .ui-contact-form__error:empty {
    display: none;
  }

  /* ─── Submit Button ──────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__submit {
    -webkit-appearance: none;
    appearance: none;
    font: inherit;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1;
    color: var(--ui-contact-form-btn-fg);
    background: var(--ui-contact-form-btn-bg);
    border: none;
    border-radius: var(--ui-contact-form-radius);
    padding: 14px 32px;
    cursor: pointer;
    user-select: none;
    transition: background 0.2s ease, opacity 0.2s ease;
    text-align: center;
    margin-top: 4px;
  }

  [data-module="ui.contact.form"] .ui-contact-form__submit:hover {
    background: var(--ui-contact-form-btn-hover);
  }

  [data-module="ui.contact.form"] .ui-contact-form__submit:focus-visible {
    outline: 2px solid var(--ui-contact-form-accent);
    outline-offset: 2px;
  }

  [data-module="ui.contact.form"] .ui-contact-form__submit:active {
    opacity: 0.9;
  }

  [data-module="ui.contact.form"] .ui-contact-form__submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
  }

  /* ─── Status Messages ────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__status {
    font-size: 0.95rem;
    line-height: 1.4;
    min-height: 0;
    text-align: center;
  }

  [data-module="ui.contact.form"] .ui-contact-form__status:empty {
    display: none;
  }

  [data-module="ui.contact.form"] .ui-contact-form__status--success {
    color: var(--ui-contact-form-success);
    font-weight: 500;
  }

  [data-module="ui.contact.form"] .ui-contact-form__status--error {
    color: var(--ui-contact-form-error);
    font-weight: 500;
  }

  /* ─── Contact Info ───────────────────────────────────────────────────────── */
  [data-module="ui.contact.form"] .ui-contact-form__contact-info {
    font-size: 0.9rem;
    color: var(--ui-contact-form-label-fg);
    margin-top: var(--ui-contact-form-gap);
    text-align: center;
    line-height: 1.5;
  }

  /* ─── Responsive: Mobile ─────────────────────────────────────────────────── */
  @media (max-width: 640px) {
    [data-module="ui.contact.form"].ui-contact-form__wrap {
      max-width: 100%;
      padding: 0 16px;
    }

    [data-module="ui.contact.form"] .ui-contact-form__submit {
      width: 100%;
    }
  }

  /* ─── Reduced Motion ─────────────────────────────────────────────────────── */
  @media (prefers-reduced-motion: reduce) {
    [data-module="ui.contact.form"] .ui-contact-form__input,
    [data-module="ui.contact.form"] .ui-contact-form__submit {
      transition: none;
    }
  }
}

/* === tools/modules/ui.card/ui.card.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.card
   Version: 1.0.0 | Genesis-Final • Bus-Aware • Wrap-Safe • Tokenized
   Classification: Atom | Content Display | Card Container
   Maintainer: DΛREΛKT_ UI TEAM
   ─────────────────────────────────────────────────────────────────────────────── */

@layer atoms {
  [data-atom="ui.card"] .ui-card {
    display: flex;
    flex-direction: column;
    background: var(--ui-card-bg, rgba(255,255,255,.05));
    border: 1px solid var(--ui-card-bd, rgba(255,255,255,.1));
    border-radius: var(--ui-card-radius, 12px);
    overflow: hidden;
  }

  [data-atom="ui.card"] .ui-card[data-padding="none"] {
    padding: 0;
  }

  [data-atom="ui.card"] .ui-card[data-padding="sm"] {
    padding: var(--ui-card-pad-sm, 12px);
  }

  [data-atom="ui.card"] .ui-card[data-padding="md"] {
    padding: var(--ui-card-pad-md, 24px);
  }

  [data-atom="ui.card"] .ui-card[data-padding="lg"] {
    padding: var(--ui-card-pad-lg, 32px);
  }

  [data-atom="ui.card"] .ui-card[data-variant="elevated"] {
    box-shadow: var(--ui-card-shadow, 0 2px 8px rgba(0,0,0,.1));
    border-color: transparent;
  }

  [data-atom="ui.card"] .ui-card[data-variant="outlined"] {
    border-width: 2px;
  }
}

/* === tools/modules/ui.image/ui.image.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — IMAGE
   Classification : UI Atom | Simple Image Display
   Version        : 1.0.0 | Genesis • Image Primitive
   File           : /tools/modules/ui.image/ui.image.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ──────────────────────────────────────────────────────────────── */

@layer ui.image {

  /* ─── Image Container (figure) ──────────────────────────────── */
  .ui-image[data-module="ui.image"],
  [data-module="ui.image"] {
    display: block;
    width: var(--ui-image-width, auto);
    max-width: var(--ui-image-max-width, 100%);
    height: var(--ui-image-height, auto);
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
    border-radius: var(--ui-image-border-radius, 0);
  }

  /* ─── The Image Element ─────────────────────────────────────── */
  .ui-image__img,
  [data-module="ui.image"] > img {
    display: block;
    width: 100%;
    height: var(--ui-image-height, auto);
    aspect-ratio: var(--ui-image-aspect-ratio, auto);
    object-fit: var(--ui-image-object-fit, cover);
    border-radius: var(--ui-image-border-radius, 0);
  }

  /* ─── Caption ───────────────────────────────────────────────── */
  .ui-image__caption,
  [data-module="ui.image"] > figcaption {
    margin-top: 0.5rem;
    font-size: 0.875rem;
    color: var(--site-fg-muted, #666);
    text-align: center;
  }

  /* ─── Loading State ─────────────────────────────────────────── */
  [data-module="ui.image"] > img[loading="lazy"] {
    opacity: 0;
    transition: opacity 0.3s ease;
  }

  [data-module="ui.image"] > img[loading="lazy"][data-loaded="true"],
  [data-module="ui.image"] > img:not([loading="lazy"]) {
    opacity: 1;
  }

  /* ─── Theme Awareness ───────────────────────────────────────── */
  [data-theme="dark"] .ui-image__caption,
  [data-theme="dark"] [data-module="ui.image"] > figcaption {
    color: var(--site-fg-muted, #aaa);
  }

  /* ─── Motion Reduction ──────────────────────────────────────── */
  @media (prefers-reduced-motion: reduce) {
    [data-module="ui.image"] > img {
      transition: none !important;
    }
  }

  /* ─── Genesis Token Bridges ─────────────────────────────────── */
  :root {
    --ui-image-width: auto;
    --ui-image-max-width: 100%;
    --ui-image-height: auto;
    --ui-image-aspect-ratio: auto;
    --ui-image-object-fit: cover;
    --ui-image-border-radius: 0;
  }

  /* ─── Debug Visualization ───────────────────────────────────── */
  [data-module="ui.image"][data-debug="true"] {
    outline: 1px dashed rgba(255, 128, 0, 0.3);
    outline-offset: 2px;
  }
}

/* === tools/modules/ui.map/ui.map.css === */
/* ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.map
   Classification : UI Atom | Map Handler | Responsive
   Version        : 1.0.0
   File           : /tools/modules/ui.map/ui.map.css
   ───────────────────────────────────────────────────────────────────────────── */

@layer ui.map {

/* ─── Container ──────────────────────────────────────────────────────────────── */
.ui-map {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  border-radius: var(--ui-radius, 8px);
  background: var(--ui-bg-muted, #f5f5f5);
}

/* ─── Map Container ─────────────────────────────────────────────────────────── */
.ui-map-container {
  position: relative;
  width: 100%;
  height: 400px;
  min-height: 300px;
  z-index: 1;
}

/* Responsive heights */
@media (max-width: 768px) {
  .ui-map-container {
    height: 300px;
  }
}

@media (min-width: 1024px) {
  .ui-map-container {
    height: 500px;
  }
}

/* ─── Error & Fallback States ───────────────────────────────────────────────── */
.ui-map-error,
.ui-map-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 400px;
  background: var(--ui-bg-muted, #f5f5f5);
  color: var(--ui-fg-muted, #666);
  border: 1px dashed var(--ui-border, #ddd);
  border-radius: var(--ui-radius, 8px);
  font-size: 14px;
  font-family: var(--ui-font-body, system-ui, sans-serif);
}

.ui-map-error {
  color: var(--ui-error, #dc2626);
  border-color: var(--ui-error, #dc2626);
}

/* ─── Leaflet Overrides ─────────────────────────────────────────────────────── */
/* Ensure map controls are properly styled */
.ui-map .leaflet-control-zoom a {
  background-color: var(--ui-bg, #fff);
  color: var(--ui-fg, #333);
}

.ui-map .leaflet-control-zoom a:hover {
  background-color: var(--ui-bg-hover, #f0f0f0);
}

/* Ensure map attribution is readable */
.ui-map .leaflet-control-attribution {
  background-color: rgba(255, 255, 255, 0.8);
  font-size: 11px;
  padding: 2px 5px;
}

/* ─── Loading State ─────────────────────────────────────────────────────────── */
.ui-map.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 40px;
  border: 3px solid var(--ui-border, #ddd);
  border-top-color: var(--ui-accent, #2d5016);
  border-radius: 50%;
  animation: ui-map-spin 0.8s linear infinite;
  z-index: 10;
}

@keyframes ui-map-spin {
  to { transform: translate(-50%, -50%) rotate(360deg); }
}

/* ─── Dark Mode Support ─────────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  .ui-map {
    background: var(--ui-bg-dark, #1a1a1a);
  }

  .ui-map-error,
  .ui-map-fallback {
    background: var(--ui-bg-dark, #1a1a1a);
    border-color: var(--ui-border-dark, #333);
    color: var(--ui-fg-dark, #ccc);
  }

  .ui-map .leaflet-control-zoom a {
    background-color: var(--ui-bg-dark, #2a2a2a);
    color: var(--ui-fg-dark, #eee);
  }

  .ui-map .leaflet-control-zoom a:hover {
    background-color: var(--ui-bg-hover-dark, #3a3a3a);
  }
}
}

/* === tools/modules/ui.accordion/ui.accordion.css === */
/* DAREACT UI - ui.accordion | Genesis-Final | @layer atoms */
@layer atoms {
  [data-atom="ui.accordion"] .ui-accordion__trigger {
    appearance: none;
    width: 100%;
    text-align: left;
    padding: var(--ui-accordion-pad, 0.75rem 1rem);
    background: var(--ui-accordion-bg, transparent);
    color: inherit;
    border: none;
    cursor: pointer;
    font: inherit;
  }
  [data-atom="ui.accordion"] .ui-accordion__trigger:hover {
    background: var(--ui-accordion-bg-hover, rgba(0,0,0,.05));
  }
  [data-atom="ui.accordion"] .ui-accordion__panel {
    padding: var(--ui-accordion-panel-pad, 0 1rem 1rem);
  }
}

/* === tools/modules/ui.aboutBlock/ui.aboutBlock.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — ABOUT BLOCK
   Semantic unit that renders intro text + notes list together.
   ──────────────────────────────────────────────────────────────── */
@layer components {
  .ui-about-block {
    display: block;
    width: 100%;
  }

  .ui-about-block__intro {
    margin: 0 0 1.5rem 0;
  }

  .ui-about-block__list {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .ui-about-block__list::before,
  .ui-about-block__list::after {
    display: none;
  }

  .ui-about-block__item {
    margin: 0 0 0.5rem 0;
    padding: 0;
  }
}


/* === tools/modules/ui.serviceBlock/ui.serviceBlock.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — SERVICE BLOCK
   Semantic unit that renders heading + description + image.
   ──────────────────────────────────────────────────────────────── */
@layer components {
  .ui-service-block {
    display: block;
    width: 100%;
  }

  /* Icon styling - subtle marker, not a badge */
  .ui-service-block__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: 0.5rem;
    color: var(--site-accent, #2d5016);
    opacity: 0.7;
    /* No background - icon as marker only */
  }

  .ui-service-block__icon svg {
    width: 22px;
    height: 22px;
    stroke-width: 1.75;
  }

  .ui-service-block__title {
    margin: 0 0 0.375rem 0;
    font-weight: 650;
    line-height: 1.25;
  }

  /* Clickable card — stretched link pattern */
  .ui-service-block[data-href] {
    position: relative;
  }

  .ui-service-block__title a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
  }

  /* Stretched link: ::after covers the whole card */
  .ui-service-block__link::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
  }

  .ui-service-block__title a:hover {
    color: var(--site-accent, #2d5016);
    border-bottom-color: var(--site-accent, #2d5016);
  }

  .ui-service-block__subtitle {
    display: block;
    font-size: 0.8rem;
    color: var(--site-muted, #888);
    margin-bottom: 0.375rem;
    letter-spacing: 0.3px;
  }

  .ui-service-block__description {
    margin: 0 0 1rem 0;
    line-height: 1.5;
    color: var(--site-muted, #555);
  }

  /* Image frame - soft, summer afternoon feel */
  .ui-service-block__image-wrap {
    margin-top: 1rem;
    border: 6px solid var(--site-border, #a8d5a8);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  }

  .ui-service-block__image {
    width: 100%;
    height: auto;
    display: block;
  }

  .ui-service-block__list {
    margin: 0;
    padding: 0;
    list-style: none !important;
  }

  .ui-service-block__list::before,
  .ui-service-block__list::after {
    display: none;
  }

  .ui-service-block__item {
    margin: 0 0 0.5rem 0;
    padding: 0;
    list-style: none !important;
  }

  .ui-service-block__item::before,
  .ui-service-block__item::after {
    display: none;
    content: none;
  }
}

/* === tools/modules/ui.divider/ui.divider.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: ui.divider
   Version: 1.0.0 | Genesis-Final • Bus-Aware • Wrap-Safe • Tokenized
   Classification: Atom | Content Display | Divider/Separator
   Maintainer: DΛREΛKT_ UI TEAM
   ─────────────────────────────────────────────────────────────────────────────── */

@layer atoms {
  [data-atom="ui.divider"] .ui-divider {
    border: none;
    margin: var(--ui-divider-margin, 16px 0);
  }

  [data-atom="ui.divider"] .ui-divider[data-orientation="horizontal"] {
    width: 100%;
    height: var(--ui-divider-thickness, 1px);
    background: var(--ui-divider-color, rgba(255,255,255,.2));
  }

  [data-atom="ui.divider"] .ui-divider[data-orientation="vertical"] {
    width: var(--ui-divider-thickness, 1px);
    height: 100%;
    margin: 0 var(--ui-divider-margin, 16px);
    display: inline-block;
    vertical-align: middle;
  }

  [data-atom="ui.divider"] .ui-divider[data-variant="dashed"] {
    background: none;
    border-top: var(--ui-divider-thickness, 1px) dashed var(--ui-divider-color, rgba(255,255,255,.2));
  }

  [data-atom="ui.divider"] .ui-divider[data-variant="dotted"] {
    background: none;
    border-top: var(--ui-divider-thickness, 1px) dotted var(--ui-divider-color, rgba(255,255,255,.2));
  }

  /* ─── Pine / Wave variant ───────────────────────────────────── */
  [data-atom="ui.divider"] .ui-divider--pine {
    border: none;
    margin: 0;
    width: 100%;
    height: var(--ui-divider-pine-height, 160px);
    background-repeat: repeat-x;
    background-position: top center;
    background-size: 900px var(--ui-divider-pine-height, 160px);
    pointer-events: none;
    position: relative;
    z-index: 2;
  }

  [data-atom="ui.divider"] .ui-divider--pine[data-flip] {
    background-position: bottom center;
  }

  /* ─── Nami (波) / Ocean wave variant ──────────────────────── */
  [data-atom="ui.divider"] .ui-divider--nami {
    border: none;
    margin: -1px 0;
    width: 100%;
    height: var(--ui-divider-pine-height, 160px);
    background-repeat: repeat-x;
    background-position: top center;
    background-size: 900px var(--ui-divider-pine-height, 160px);
    pointer-events: none;
    position: relative;
    z-index: 2;
  }

  [data-atom="ui.divider"] .ui-divider--nami[data-flip] {
    background-position: bottom center;
  }
}

/* === tools/modules/ui.photo.scatter/ui.photo.scatter.css === */
/* ────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — PHOTO SCATTER
   "Photos thrown on a table" composition.
   Middle card straight, sides slightly rotated with overlap.
   ──────────────────────────────────────────────────────────────── */
@layer components {

  .ui-photo-scatter {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 1.5rem;
    min-height: 380px;
  }

  /* ─── Individual card ────────────────────────────────────── */
  .ui-photo-scatter__card {
    position: absolute;
    width: 36%;
    max-width: 400px;
    border-radius: var(--site-radius, 12px);
    overflow: hidden;
    background: #fff;
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.14),
                0  4px 10px rgba(0, 0, 0, 0.06);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
  }

  /* Left card — rotated left, shifted left */
  .ui-photo-scatter__card[data-index="0"] {
    transform: rotate(-3deg) translateX(-42%);
    z-index: 1;
    filter: brightness(0.92) saturate(0.95);
  }

  /* Middle card — straight, on top */
  .ui-photo-scatter__card[data-index="1"] {
    transform: rotate(0deg) translateY(-4%);
    z-index: 2;
  }

  /* Right card — rotated right, shifted right */
  .ui-photo-scatter__card[data-index="2"] {
    transform: rotate(3deg) translateX(42%);
    z-index: 1;
    filter: brightness(0.92) saturate(0.95);
  }

  /* ─── Hover — lift only, keep rotation (desktop) ─────────── */
  @media (hover: hover) {
    .ui-photo-scatter__card[data-index="0"]:hover {
      transform: rotate(-3deg) translateX(-42%) translateY(-4px);
      box-shadow: 0 26px 46px rgba(0, 0, 0, 0.18);
      z-index: 3;
    }
    .ui-photo-scatter__card[data-index="1"]:hover {
      transform: rotate(0deg) translateY(-8%);
      box-shadow: 0 26px 46px rgba(0, 0, 0, 0.18);
      z-index: 3;
    }
    .ui-photo-scatter__card[data-index="2"]:hover {
      transform: rotate(3deg) translateX(42%) translateY(-4px);
      box-shadow: 0 26px 46px rgba(0, 0, 0, 0.18);
      z-index: 3;
    }
  }

  /* ─── Image fill ─────────────────────────────────────────── */
  .ui-photo-scatter__img {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
  }

  /* ─── Mobile — stack vertically, no rotation ─────────────── */
  @media (max-width: 768px) {
    .ui-photo-scatter {
      flex-direction: column;
      gap: clamp(1.25rem, 4vw, 2rem);
      min-height: auto;
      margin-top: 1rem;
    }

    .ui-photo-scatter__card {
      position: static;
      width: 100%;
      max-width: 100%;
      transform: none !important;
      border-radius: calc(var(--site-radius, 12px) * 0.75);
    }

    .ui-photo-scatter__card[data-index="0"],
    .ui-photo-scatter__card[data-index="1"],
    .ui-photo-scatter__card[data-index="2"] {
      transform: none;
      z-index: auto;
      filter: none;
    }

    /* First image — subtle landing elevation */
    .ui-photo-scatter__card[data-index="0"] {
      box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
    }

    /* Cap image height so scroll pacing stays comfortable */
    .ui-photo-scatter__img {
      max-height: 60vh;
    }
  }
}

/* === tools/modules/ui.media.pipeline/ui.media.pipeline.css === */
@layer ui.media.pipeline {
  /* ────────────────────────────────────────────────────────────────────────────
     DΛREΛKT_ — UI Media Pipeline
     Version: 2.0.0 | Genesis-Final • Wrapping-Aware • Token-Safe
     Classification: UI Atom | Visual Media Handler
     File: /tools/modules/ui.media.pipeline/ui.media.pipeline.css
     Maintainer: DΛREΛKT_ UI TEAM
     ──────────────────────────────────────────────────────────────────────────── */

  /* ─── Root Tokens (wrapping-safe) ─────────────────────────────────────────── */
  :root,
  body[data-site="dareakt"],
  body[data-site="diagnostics"],
  body[data-site="ruthbowers"] {
    --ui-media-radius: 0.5rem;
    --ui-media-bg: #111;
    --ui-media-fit: cover;
    --ui-media-opacity: 1;
    --ui-media-gap: 1rem;
    --ui-media-width: 100%; /* Allow sites to override width */
    --ui-media-max-width: none; /* Allow sites to constrain max-width */
    --ui-media-border: none; /* Allow sites to add borders */
    --ui-media-border-radius: var(--ui-media-radius);
  }

  /* ─── Wrapper Layout ──────────────────────────────────────────────────────── */
  .ui-media-pipeline {
    display: grid;
    width: var(--ui-media-width, 100%);
    max-width: var(--ui-media-max-width, none);
    gap: var(--ui-media-gap);
    align-items: start;
    justify-items: center;
    box-sizing: border-box;
    margin-inline: var(--ui-media-margin-inline, auto); /* Allow sites to override centering */
  }

  /* ─── Core Media Styling ──────────────────────────────────────────────────── */
  .ui-media {
    display: block;
    width: var(--ui-media-width, 100%);
    max-width: var(--ui-media-max-width, 100%);
    height: auto;
    border: var(--ui-media-border, none);
    border-radius: var(--ui-media-border-radius, var(--ui-media-radius, 0.5rem));
    background: var(--ui-media-bg);
    object-fit: var(--ui-media-fit);
    opacity: var(--ui-media-opacity);
    margin-inline: var(--ui-media-margin-inline, auto); /* Allow sites to override centering */
    transition:
      opacity 0.3s ease-out,
      filter 0.3s ease-out,
      transform 0.3s ease-out;
  }

  .ui-media[data-loaded="true"] {
    opacity: 1;
    filter: none;
    transform: none;
  }

  .ui-media:not([data-loaded="true"]) {
    opacity: 0.5;
    filter: blur(2px) brightness(0.8);
    transform: scale(0.98);
  }

  video.ui-media {
    max-width: 100%;
    border-radius: var(--ui-media-border-radius);
  }

  /* ─── Fallback / Error State ──────────────────────────────────────────────── */
  .ui-media-fallback,
  .ui-media-error {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    width: 100%;
    min-height: 120px;
    color: #aaa;
    background: rgba(0, 0, 0, 0.25);
    border: 1px dashed rgba(255, 255, 255, 0.15);
    border-radius: var(--ui-media-radius);
    font-size: 0.875rem;
  }

  /* ─── Thematic Overlays (optional site variants) ──────────────────────────── */
  body[data-site="dareakt"] .ui-media-pipeline {
    --ui-media-bg: rgba(10, 20, 40, 0.85);
  }

  body[data-site="diagnostics"] .ui-media-pipeline {
    --ui-media-bg: rgba(24, 24, 24, 0.85);
  }

  body[data-site="ruthbowers"] .ui-media-pipeline {
    --ui-media-bg: rgba(255, 255, 255, 0.85);
  }

  /* ─── Transition Safety (SPA reloads) ─────────────────────────────────────── */
  .ui-media-pipeline {
    will-change: opacity, filter, transform;
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     MOSAIC VARIANT — Art-directed collage gallery
     ═══════════════════════════════════════════════════════════════════════════ */

  .ui-media--mosaic {
    --mosaic-gap: var(--ui-media-mosaic-gap, 6px);
    --mosaic-radius: var(--ui-media-mosaic-radius, 8px);
    --mosaic-row-h: var(--ui-media-mosaic-row, 220px);
    display: grid;
    gap: var(--mosaic-gap);
    width: 100%;
  }

  /* ─── Tile base ──────────────────────────────────────────────────────────── */
  .ui-media--mosaic__tile {
    position: relative;
    margin: 0;
    overflow: hidden;
    border-radius: var(--mosaic-radius);
    cursor: pointer;
    background: var(--ui-media-bg, #111);
  }

  .ui-media--mosaic__tile img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0;
    transition: transform 0.4s ease, filter 0.4s ease;
  }

  .ui-media--mosaic__tile:hover img {
    transform: scale(1.04);
    filter: brightness(0.75);
  }

  /* ─── Caption overlay ────────────────────────────────────────────────────── */
  .ui-media--mosaic__tile figcaption {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding: 1rem;
    background: linear-gradient(0deg, rgba(0,0,0,0.55) 0%, transparent 60%);
    color: #fff;
    font-size: 0.8rem;
    line-height: 1.35;
    letter-spacing: 0.01em;
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
  }

  .ui-media--mosaic__tile:hover figcaption {
    opacity: 1;
  }

  /* ═══ Grid patterns by image count ══════════════════════════════════════════ */

  /* 1 image — full-width hero */
  .ui-media--mosaic[data-count="1"] {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(300px, 50vh);
  }

  /* 3 images — large left + 2 stacked right */
  .ui-media--mosaic[data-count="3"] {
    grid-template-columns: 3fr 2fr;
    grid-template-rows: var(--mosaic-row-h) var(--mosaic-row-h);
  }
  .ui-media--mosaic[data-count="3"] .ui-media--mosaic__tile[data-index="0"] {
    grid-row: 1 / 3;
  }

  /* 4 images — large left + 2 stacked right + 1 wide bottom */
  .ui-media--mosaic[data-count="4"] {
    grid-template-columns: 3fr 2fr;
    grid-template-rows: var(--mosaic-row-h) var(--mosaic-row-h) var(--mosaic-row-h);
  }
  .ui-media--mosaic[data-count="4"] .ui-media--mosaic__tile[data-index="0"] {
    grid-row: 1 / 3;
  }
  .ui-media--mosaic[data-count="4"] .ui-media--mosaic__tile[data-index="3"] {
    grid-column: 1 / -1;
  }

  /* 6 images — hero mosaic: 2x2 top-left + 2 stacked right + 3 bottom */
  .ui-media--mosaic[data-count="6"] {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: var(--mosaic-row-h) var(--mosaic-row-h) var(--mosaic-row-h);
    grid-template-areas:
      "a a b"
      "a a c"
      "d e f";
  }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="0"] { grid-area: a; }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="1"] { grid-area: b; }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="2"] { grid-area: c; }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="3"] { grid-area: d; }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="4"] { grid-area: e; }
  .ui-media--mosaic[data-count="6"] .ui-media--mosaic__tile[data-index="5"] { grid-area: f; }

  /* 7 images — 6-tile mosaic + 1 wide bottom */
  .ui-media--mosaic[data-count="7"] {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: var(--mosaic-row-h) var(--mosaic-row-h) var(--mosaic-row-h) var(--mosaic-row-h);
    grid-template-areas:
      "a a b"
      "a a c"
      "d e f"
      "g g g";
  }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="0"] { grid-area: a; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="1"] { grid-area: b; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="2"] { grid-area: c; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="3"] { grid-area: d; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="4"] { grid-area: e; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="5"] { grid-area: f; }
  .ui-media--mosaic[data-count="7"] .ui-media--mosaic__tile[data-index="6"] { grid-area: g; }

  /* Fallback for other counts: auto-dense 3-col grid */
  .ui-media--mosaic:not([data-count="1"]):not([data-count="3"]):not([data-count="4"]):not([data-count="6"]):not([data-count="7"]) {
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: var(--mosaic-row-h);
    grid-auto-flow: dense;
  }
  /* First tile always spans 2x2 in fallback */
  .ui-media--mosaic:not([data-count="1"]):not([data-count="3"]):not([data-count="4"]):not([data-count="6"]):not([data-count="7"]) .ui-media--mosaic__tile[data-index="0"] {
    grid-column: span 2;
    grid-row: span 2;
  }

  /* ═══ Responsive ════════════════════════════════════════════════════════════ */
  @media (max-width: 1024px) {
    .ui-media--mosaic,
    .ui-media--mosaic[data-count="6"],
    .ui-media--mosaic[data-count="7"] {
      grid-template-columns: repeat(2, 1fr) !important;
      grid-template-rows: auto !important;
      grid-template-areas: none !important;
      grid-auto-rows: 200px;
    }
    .ui-media--mosaic .ui-media--mosaic__tile {
      grid-column: auto !important;
      grid-row: auto !important;
      grid-area: auto !important;
    }
    /* First image spans full width on tablet */
    .ui-media--mosaic .ui-media--mosaic__tile[data-index="0"] {
      grid-column: 1 / -1 !important;
      grid-row: auto !important;
      min-height: 280px;
    }
  }

  @media (max-width: 600px) {
    .ui-media--mosaic {
      grid-template-columns: 1fr !important;
      grid-auto-rows: 220px;
    }
    .ui-media--mosaic .ui-media--mosaic__tile[data-index="0"] {
      min-height: 250px;
    }
  }

  /* ═══ Lightbox ══════════════════════════════════════════════════════════════ */
  .ui-media-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.92);
    backdrop-filter: blur(8px);
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
  }

  .ui-media-lightbox[data-open="true"] {
    opacity: 1;
    pointer-events: auto;
  }

  .ui-media-lightbox__img {
    max-width: 90vw;
    max-height: 85vh;
    object-fit: contain;
    border-radius: 4px;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.6);
    user-select: none;
  }

  .ui-media-lightbox__close {
    position: absolute;
    top: 1.25rem;
    right: 1.5rem;
    width: 40px;
    height: 40px;
    border: none;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 1.5rem;
    line-height: 1;
    border-radius: 50%;
    cursor: pointer;
    transition: background 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .ui-media-lightbox__close:hover {
    background: rgba(255, 255, 255, 0.25);
  }

  .ui-media-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    font-size: 1.5rem;
    border-radius: 50%;
    cursor: pointer;
    transition: background 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .ui-media-lightbox__nav:hover {
    background: rgba(255, 255, 255, 0.25);
  }
  .ui-media-lightbox__nav--prev { left: 1rem; }
  .ui-media-lightbox__nav--next { right: 1rem; }

  .ui-media-lightbox__caption {
    position: absolute;
    bottom: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.875rem;
    text-align: center;
    max-width: 80vw;
    line-height: 1.4;
  }

  .ui-media-lightbox__counter {
    position: absolute;
    top: 1.5rem;
    left: 1.5rem;
    color: rgba(255, 255, 255, 0.55);
    font-size: 0.8rem;
    font-variant-numeric: tabular-nums;
  }
}

/* === tools/modules/ui.tags/ui.tags.css === */
/* /tools/modules/ui.tags/ui.tags.css
   ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI ATOM — ui.tags CSS
   Version: 1.0.0 | minimal tokens • host-wins • BEM-only
   ───────────────────────────────────────────────────────────────────────────── */

@layer components {

  .ui-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
  }

  .ui-tags__item {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.85rem;
    border-radius: var(--tags-r, 999px);
    background: var(--tags-bg, rgba(0, 0, 0, 0.05));
    color: var(--tags-fg, currentColor);
    border: 1px solid var(--tags-br, rgba(0, 0, 0, 0.08));
    font-size: var(--tags-fz, 0.8125rem);
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    user-select: none;
  }

}

/* === tools/modules/ui.priceTag/ui.priceTag.css === */
/* /tools/modules/ui.priceTag/ui.priceTag.css
   ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI ATOM — ui.priceTag CSS
   Version: 1.0.0 | minimal tokens • host-wins • BEM-only
   ───────────────────────────────────────────────────────────────────────────── */

@layer components {

  .ui-price-tag {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
  }

  .ui-price-tag__amount {
    font-size: var(--price-fz, 1.35rem);
    font-weight: var(--price-fw, 700);
    color: var(--price-fg, currentColor);
    line-height: 1.3;
  }

  .ui-price-tag__note {
    font-size: var(--price-note-fz, 0.8125rem);
    color: var(--price-note-fg, inherit);
    opacity: 0.7;
    line-height: 1.4;
  }

  /* ── Variants — multiple price tiers ──────────────────────────── */
  .ui-price-tag__variant {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
  }

  .ui-price-tag__variant + .ui-price-tag__variant {
    margin-top: 0.35rem;
    padding-top: 0.35rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
  }

}

/* === tools/modules/ui.dayLabel/ui.dayLabel.css === */
/* /tools/modules/ui.dayLabel/ui.dayLabel.css
   ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI ATOM — ui.dayLabel CSS
   Version: 1.0.0 | minimal tokens • host-wins • BEM-only
   ───────────────────────────────────────────────────────────────────────────── */

@layer components {

  .ui-day-label {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 1rem;
    border-radius: var(--day-label-r, 6px);
    background: var(--day-label-bg, rgba(0, 0, 0, 0.06));
    color: var(--day-label-fg, currentColor);
    font-size: var(--day-label-fz, 0.875rem);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: var(--day-label-tt, uppercase);
    line-height: 1.4;
    user-select: none;
  }

  .ui-day-label__prefix {
    opacity: 0.7;
    font-weight: 400;
  }

  .ui-day-label__text {
    /* inherits parent styling */
  }

}

/* === tools/modules/social.instagram/social.instagram.css === */
/* ─────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ UI — MODULE: social.instagram
   Classification : UI Atom | Social Feed | Responsive Grid
   Version        : 2.1.0
   File           : /tools/modules/social.instagram/social.instagram.css
   ───────────────────────────────────────────────────────────────────────────── */

@layer atoms {

/* ─── Tokens ─────────────────────────────────────────────────────────────────── */
:root {
  --social-ig-cols: 4;
  --social-ig-gap: 4px;
  --social-ig-radius: 0;
  --social-ig-caption-bg: rgba(0, 0, 0, 0.65);
  --social-ig-caption-fg: #fff;
  --social-ig-accent: #E1306C;
  --social-ig-accent-hover: #c9245a;
  --social-ig-header-gap: 0.5rem;
  --social-ig-follow-padding: 0.75rem 2rem;
  --social-ig-skeleton-bg: #e8e8e8;
}

/* ─── Wrapper ────────────────────────────────────────────────────────────────── */
.social-ig__wrap {
  display: block;
  width: 100%;
}

/* ─── Header ─────────────────────────────────────────────────────────────────── */
.social-ig__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--social-ig-header-gap);
  margin-bottom: 1.5rem;
  text-align: center;
}

.social-ig__title {
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ui-fg, #111);
}

.social-ig__handle {
  display: inline-block;
  font-size: 1rem;
  font-weight: 500;
  color: var(--social-ig-accent);
  text-decoration: none;
  transition: color 0.2s ease;
}

a.social-ig__handle:hover,
a.social-ig__handle:focus-visible {
  color: var(--social-ig-accent-hover);
  text-decoration: underline;
}

/* ─── Grid (default layout) ──────────────────────────────────────────────────── */
.social-ig__grid {
  display: grid;
  grid-template-columns: repeat(var(--social-ig-cols, 4), 1fr);
  grid-auto-rows: 1fr;
  gap: var(--social-ig-gap);
}

/* ─── Layout: Masonry (CSS columns) ──────────────────────────────────────────── */
.social-ig__grid--masonry {
  display: block;
  columns: var(--social-ig-cols, 4);
  column-gap: var(--social-ig-gap);
}

.social-ig__grid--masonry .social-ig__post {
  aspect-ratio: auto;
  break-inside: avoid;
  margin-bottom: var(--social-ig-gap);
}

.social-ig__grid--masonry .social-ig__image {
  height: auto;
}

/* ─── Layout: Carousel (horizontal scroll) ───────────────────────────────────── */
.social-ig__grid--carousel {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  gap: var(--social-ig-gap);
  padding-bottom: 0.5rem;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.social-ig__grid--carousel::-webkit-scrollbar {
  display: none;
}

.social-ig__grid--carousel .social-ig__post {
  flex: 0 0 min(240px, 70vw);
  scroll-snap-align: start;
  aspect-ratio: 1 / 1;
}

/* Carousel navigation */
.social-ig__carousel-nav {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1rem;
}

.social-ig__carousel-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 2px solid var(--social-ig-accent);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease;
  color: var(--social-ig-accent);
  font-size: 1rem;
  line-height: 1;
  padding: 0;
}

.social-ig__carousel-btn:hover {
  background: var(--social-ig-accent);
  color: #fff;
}

/* ─── Layout: Highlight (first large, rest in grid) ──────────────────────────── */
.social-ig__grid--highlight {
  display: grid;
  grid-template-columns: repeat(var(--social-ig-cols, 4), 1fr);
  grid-template-rows: auto;
  gap: var(--social-ig-gap);
}

.social-ig__grid--highlight .social-ig__post:first-child {
  grid-column: 1 / 3;
  grid-row: 1 / 3;
}

/* ─── Post Cell ──────────────────────────────────────────────────────────────── */
.social-ig__post {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  border-radius: var(--social-ig-radius);
  background: var(--ui-bg-muted, #f0f0f0);
  text-decoration: none;
}

/* Bulletproof square enforcement via padding trick (fallback for older browsers) */
@supports not (aspect-ratio: 1 / 1) {
  .social-ig__post {
    height: 0;
    padding-bottom: 100%;
  }
}

.social-ig__post:focus-visible {
  outline: 2px solid var(--social-ig-accent);
  outline-offset: 2px;
}

/* ─── Hidden Posts (Load More) ──────────────────────────────────────────────── */
.social-ig__post--hidden {
  display: none;
}

/* ─── Image ──────────────────────────────────────────────────────────────────── */
.social-ig__image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.social-ig__post:hover .social-ig__image {
  transform: scale(1.05);
}

/* ─── Caption Overlay ────────────────────────────────────────────────────────── */
.social-ig__caption {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 1rem;
  background: var(--social-ig-caption-bg);
  color: var(--social-ig-caption-fg);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.social-ig__post:hover .social-ig__caption,
.social-ig__post:focus-within .social-ig__caption {
  opacity: 1;
}

.social-ig__caption p {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ─── Engagement Overlay ─────────────────────────────────────────────────────── */
.social-ig__engagement {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.25rem 0.5rem;
  background: rgba(0, 0, 0, 0.55);
  border-radius: 6px;
  font-size: 0.75rem;
  color: #fff;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.social-ig__post:hover .social-ig__engagement,
.social-ig__post:focus-within .social-ig__engagement {
  opacity: 1;
}

.social-ig__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

.social-ig__stat svg {
  flex-shrink: 0;
}

/* ─── Actions Row (Load More + Follow) ──────────────────────────────────────── */
.social-ig__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}

/* ─── Load More Button ──────────────────────────────────────────────────────── */
.social-ig__load-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 2rem;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--ui-fg, #333);
  background: var(--ui-bg-muted, #f0f0f0);
  border: 1px solid #d0d0d0;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

.social-ig__load-more:hover,
.social-ig__load-more:focus-visible {
  background: #e4e4e4;
  border-color: #b0b0b0;
  transform: translateY(-1px);
}

.social-ig__load-more:active {
  transform: translateY(0);
}

.social-ig__load-more:focus-visible {
  outline: 2px solid var(--social-ig-accent);
  outline-offset: 2px;
}

/* ─── Follow Button ──────────────────────────────────────────────────────────── */
.social-ig__follow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  padding: var(--social-ig-follow-padding);
  font-size: 0.9375rem;
  font-weight: 600;
  color: #fff;
  background: var(--social-ig-accent);
  border: none;
  border-radius: 6px;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.15s ease;
}

.social-ig__follow svg {
  flex-shrink: 0;
}

.social-ig__follow:hover,
.social-ig__follow:focus-visible {
  background: var(--social-ig-accent-hover);
  transform: translateY(-1px);
}

.social-ig__follow:focus-visible {
  outline: 2px solid var(--social-ig-accent);
  outline-offset: 2px;
}

.social-ig__follow:active {
  transform: translateY(0);
}

/* ─── Skeleton Loading ───────────────────────────────────────────────────────── */
.social-ig__skeleton {
  pointer-events: none;
}

.social-ig__skeleton .social-ig__post {
  background: var(--social-ig-skeleton-bg);
  animation: social-ig-shimmer 1.5s ease-in-out infinite;
}

.social-ig__skeleton .social-ig__post:nth-child(2) {
  animation-delay: 0.15s;
}

.social-ig__skeleton .social-ig__post:nth-child(3) {
  animation-delay: 0.3s;
}

.social-ig__skeleton .social-ig__post:nth-child(4) {
  animation-delay: 0.45s;
}

@keyframes social-ig-shimmer {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ─── Error State ────────────────────────────────────────────────────────────── */
.social-ig__error {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--social-ig-accent);
  font-size: 0.9375rem;
  opacity: 0.7;
}

/* ─── Lightbox ───────────────────────────────────────────────────────────────── */
.social-ig__lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.9);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.social-ig__lightbox[data-active="true"] {
  opacity: 1;
  pointer-events: auto;
}

.social-ig__lightbox-img {
  max-width: 90vw;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.5);
}

.social-ig__lightbox-caption {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  max-width: 600px;
  text-align: center;
  color: #fff;
  font-size: 0.9375rem;
  line-height: 1.5;
  padding: 0.75rem 1.5rem;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 8px;
}

.social-ig__lightbox-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.15);
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 1.5rem;
  cursor: pointer;
  transition: background 0.2s ease;
}

.social-ig__lightbox-close:hover {
  background: rgba(255, 255, 255, 0.3);
}

.social-ig__lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.15);
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 1.25rem;
  cursor: pointer;
  transition: background 0.2s ease;
}

.social-ig__lightbox-nav:hover {
  background: rgba(255, 255, 255, 0.3);
}

.social-ig__lightbox-nav--prev {
  left: 1.5rem;
}

.social-ig__lightbox-nav--next {
  right: 1.5rem;
}

/* ─── Responsive: Large tablet (5 columns) ─────────────────────────────────── */
@media (max-width: 1024px) {
  .social-ig__grid:not(.social-ig__grid--carousel) {
    --social-ig-cols: 5;
  }

  .social-ig__grid--masonry {
    columns: 5;
  }
}

/* ─── Responsive: Tablet (4 columns) ───────────────────────────────────────── */
@media (max-width: 768px) {
  .social-ig__grid:not(.social-ig__grid--carousel) {
    --social-ig-cols: 4;
  }

  .social-ig__grid--masonry {
    columns: 4;
  }

  .social-ig__title {
    font-size: 1.5rem;
  }

  .social-ig__caption p {
    -webkit-line-clamp: 2;
  }

  .social-ig__lightbox-nav {
    width: 40px;
    height: 40px;
  }

  .social-ig__lightbox-nav--prev { left: 0.75rem; }
  .social-ig__lightbox-nav--next { right: 0.75rem; }
}

/* ─── Responsive: Mobile (2 columns) ──────────────────────────────────────── */
@media (max-width: 480px) {
  .social-ig__grid:not(.social-ig__grid--carousel) {
    --social-ig-cols: 2;
  }

  .social-ig__grid--masonry {
    columns: 2;
  }

  .social-ig__grid--highlight .social-ig__post:first-child {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .social-ig__title {
    font-size: 1.25rem;
  }

  .social-ig__header {
    margin-bottom: 1rem;
  }

  .social-ig__actions {
    margin-top: 1rem;
    flex-direction: column;
  }

  .social-ig__follow,
  .social-ig__load-more {
    font-size: 0.9rem;
    padding: 0.6rem 1.5rem;
  }

  .social-ig__lightbox-caption {
    font-size: 0.8125rem;
    bottom: 1rem;
    padding: 0.5rem 1rem;
  }
}

/* ─── Dark Mode Support ──────────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  .social-ig__title {
    color: var(--ui-fg-dark, #eee);
  }

  .social-ig__post {
    background: var(--ui-bg-dark, #1a1a1a);
  }

  .social-ig__load-more {
    background: #2a2a2a;
    color: #eee;
    border-color: #444;
  }

  .social-ig__load-more:hover {
    background: #333;
    border-color: #555;
  }
}

} /* end @layer atoms */

/* === tools/modules/social.facebook/social.facebook.css === */
/* ──────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ SOCIAL -- MODULE: social.facebook
   Classification : Social Atom | Facebook Feed | Smash Balloons Masonry
   Version        : 4.0.0 | Genesis-Final . Layered . Token-Scoped
   File           : /tools/modules/social.facebook/social.facebook.css
   Maintainer     : DΛREΛKT_ UI TEAM
   ────────────────────────────────────────────────────────────────────────────── */

@layer atoms {
  /* --- Tokens ──────────────────────────────────────────────────────────────── */
  :root {
    --social-fb-accent: #1877F2;
    --social-fb-radius: 12px;
    --social-fb-gap: 1rem;
    --social-fb-card-bg: #fff;
    --social-fb-card-border: #e0e0e0;
    --social-fb-card-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    --social-fb-card-shadow-hover: 0 4px 16px rgba(0, 0, 0, 0.1);
    --social-fb-text-fg: #333;
    --social-fb-date-fg: #65676b;
    --social-fb-title-fg: #111;
    --social-fb-follow-fg: var(--social-fb-accent);
    --social-fb-skeleton-bg: #e8e8e8;
    --social-fb-skeleton-shine: #f5f5f5;
    --social-fb-cols: 3;
  }

  /* --- Wrapper — full width of parent container ──────────────────────────── */
  .social-fb__wrap {
    width: 100%;
    display: block;
    box-sizing: border-box;
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     HERO HEADER — Cover Photo + Page Identity (full width)
     ═══════════════════════════════════════════════════════════════════════════ */

  .social-fb__hero {
    border-radius: var(--social-fb-radius);
    overflow: hidden;
    border: 1px solid var(--social-fb-card-border);
    background: var(--social-fb-card-bg);
    box-shadow: var(--social-fb-card-shadow);
    margin-bottom: var(--social-fb-gap);
  }

  /* --- Cover Photo ────────────────────────────────────────────────────────── */
  .social-fb__cover {
    position: relative;
    width: 100%;
    overflow: hidden;
  }

  .social-fb__cover-img {
    width: 100%;
    aspect-ratio: 820 / 312;
    object-fit: cover;
    display: block;
  }

  /* Fan count badge — bottom-right of cover */
  .social-fb__fan-badge {
    position: absolute;
    bottom: 0.75rem;
    right: 0.75rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(4px);
    padding: 0.35rem 0.65rem;
    border-radius: 6px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #1877F2;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
  }

  /* --- Page Identity ──────────────────────────────────────────────────────── */
  .social-fb__page-identity {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
  }

  .social-fb__avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 3px solid var(--social-fb-card-bg);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
  }

  .social-fb__page-info {
    flex: 1;
    min-width: 0;
    text-align: left;
  }

  .social-fb__page-name {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--social-fb-title-fg);
    text-decoration: none;
    line-height: 1.3;
  }

  a.social-fb__page-name:hover {
    text-decoration: underline;
  }

  .social-fb__page-about {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    color: var(--social-fb-date-fg);
    line-height: 1.4;
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     LEGACY HEADER — Fallback when no page meta
     ═══════════════════════════════════════════════════════════════════════════ */

  .social-fb__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: var(--social-fb-gap);
    flex-wrap: wrap;
  }

  .social-fb__title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--social-fb-title-fg);
    line-height: 1.3;
  }

  .social-fb__page-link {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--social-fb-accent);
    text-decoration: none;
    white-space: nowrap;
    transition: opacity 0.2s ease;
  }

  .social-fb__page-link:hover {
    opacity: 0.75;
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     POST FEED — CSS Columns for true masonry (no empty space)
     CSS columns fills top→bottom per column, so SSR reorders posts using
     column-fill interleaving to achieve left→right row-first reading order.
     ═══════════════════════════════════════════════════════════════════════════ */

  .social-fb__feed {
    columns: var(--social-fb-cols);
    column-gap: var(--social-fb-gap);
  }

  /* --- Individual Post ────────────────────────────────────────────────────── */
  .social-fb__post {
    background: var(--social-fb-card-bg);
    border: 1px solid var(--social-fb-card-border);
    border-radius: var(--social-fb-radius);
    overflow: hidden;
    box-shadow: var(--social-fb-card-shadow);
    transition: box-shadow 0.25s ease;
    display: flex;
    flex-direction: column;
    break-inside: avoid;            /* prevent column breaks mid-card */
    margin-bottom: var(--social-fb-gap); /* vertical spacing between cards */
  }

  .social-fb__post:hover {
    box-shadow: var(--social-fb-card-shadow-hover);
  }

  /* Hidden posts for Load More */
  .social-fb__post--hidden {
    display: none;
  }

  /* --- Post Header (avatar + author + date) ───────────────────────────────── */
  .social-fb__post-header {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.75rem 0.875rem 0.375rem;
    text-align: left;
  }

  .social-fb__post-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
  }

  .social-fb__post-meta {
    flex: 1;
    min-width: 0;
  }

  .social-fb__post-author {
    display: block;
    font-weight: 700;
    font-size: 0.8125rem;
    color: var(--social-fb-title-fg);
    line-height: 1.3;
  }

  .social-fb__post-date {
    display: block;
    font-size: 0.75rem;
    color: var(--social-fb-date-fg);
    line-height: 1.3;
  }

  /* --- Post Text ──────────────────────────────────────────────────────────── */
  .social-fb__post-text {
    padding: 0.375rem 0.875rem 0.5rem;
    text-align: left;
  }

  .social-fb__post-text p {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--social-fb-text-fg);
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .social-fb__post-text-full {
    display: none;
  }

  .social-fb__post-text-full[hidden] {
    display: none;
  }

  .social-fb__post-text-full:not([hidden]) {
    display: block;
  }

  /* See More button — inline, styled as link */
  .social-fb__see-more {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    font-weight: 600;
    color: var(--social-fb-date-fg);
    cursor: pointer;
    font-size: 0.8125rem;
  }

  .social-fb__see-more:hover {
    text-decoration: underline;
  }

  /* --- Post Image ─────────────────────────────────────────────────────────── */
  .social-fb__post-image-wrap {
    overflow: hidden;
    line-height: 0;
    margin: 0 0.625rem;
    border-radius: 8px;
  }

  .social-fb__post-image {
    width: 100%;
    display: block;
    object-fit: cover;
    border-radius: 8px;
  }

  /* --- Post Image Gallery (thumbnail strip below hero) ──────────────────── */
  .social-fb__post-thumbs {
    display: flex;
    gap: 3px;
    line-height: 0;
    margin: 3px 0.625rem 0;
  }

  .social-fb__post-thumb {
    flex: 1;
    position: relative;
    overflow: hidden;
    min-width: 0;
    border-radius: 6px;
  }

  .social-fb__post-thumb img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    border-radius: 6px;
  }

  .social-fb__post-thumb--more::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    border-radius: 6px;
  }

  .social-fb__post-thumb-badge {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-size: 1.125rem;
    font-weight: 700;
    z-index: 1;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
  }

  /* --- Post Footer (engagement + action links) ────────────────────────────── */
  .social-fb__post-footer {
    padding: 0.5rem 0.875rem 0.625rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-top: auto;         /* push footer to bottom of card */
    border-top: 1px solid #f0f0f0;
  }

  /* --- Engagement Stats ──────────────────────────────────────────────────── */
  .social-fb__engagement {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    font-size: 0.75rem;
    color: var(--social-fb-date-fg);
  }

  .social-fb__stat {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
  }

  .social-fb__stat svg {
    flex-shrink: 0;
    opacity: 0.7;
  }

  /* --- Post Action Links ─────────────────────────────────────────────────── */
  .social-fb__post-actions {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
  }

  .social-fb__post-link {
    color: var(--social-fb-date-fg);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s ease;
  }

  .social-fb__post-link:hover {
    color: var(--social-fb-accent);
    text-decoration: underline;
  }

  .social-fb__post-action-sep {
    color: var(--social-fb-date-fg);
    opacity: 0.5;
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     ACTIONS ROW — Load More + Follow
     ═══════════════════════════════════════════════════════════════════════════ */

  .social-fb__actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-top: var(--social-fb-gap);
  }

  /* Load More Button */
  .social-fb__load-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 2.5rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--social-fb-accent);
    background: var(--social-fb-card-bg);
    border: 2px solid var(--social-fb-accent);
    border-radius: calc(var(--social-fb-radius) * 0.67);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
  }

  .social-fb__load-more:hover {
    background: var(--social-fb-accent);
    color: #fff;
  }

  .social-fb__load-more:active {
    transform: scale(0.97);
  }

  /* Follow Button */
  .social-fb__follow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--social-fb-follow-fg);
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: calc(var(--social-fb-radius) * 0.5);
    transition: background 0.2s ease, color 0.2s ease;
  }

  .social-fb__follow:hover {
    background: rgba(24, 119, 242, 0.08);
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     SKELETON LOADING
     ═══════════════════════════════════════════════════════════════════════════ */

  .social-fb__skeleton .social-fb__post {
    border-color: transparent;
  }

  @keyframes social-fb-shimmer {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     RESPONSIVE
     ═══════════════════════════════════════════════════════════════════════════ */

  /* 2 columns for medium screens */
  @media (max-width: 900px) {
    :root {
      --social-fb-cols: 2;
    }
  }

  /* 1 column for small screens */
  @media (max-width: 600px) {
    :root {
      --social-fb-cols: 1;
    }

    .social-fb__avatar {
      width: 48px;
      height: 48px;
    }

    .social-fb__page-name {
      font-size: 1.1rem;
    }

    .social-fb__post-footer {
      flex-direction: column;
      align-items: flex-start;
    }
  }

  /* ═══════════════════════════════════════════════════════════════════════════
     DARK MODE
     ═══════════════════════════════════════════════════════════════════════════ */

  @media (prefers-color-scheme: dark) {
    .social-fb__wrap {
      --social-fb-card-bg: #1e1e1e;
      --social-fb-card-border: #333;
      --social-fb-text-fg: #ddd;
      --social-fb-date-fg: #999;
      --social-fb-title-fg: #eee;
    }
  }
}

/* === sites/okitour/css/site.css === */
/* ───────────────────────────────────────────────────────────────────────────────
   DΛREΛKT_ SITE CSS — OKITOUR.JP — PREMIUM REDESIGN
   Classification : Site Stylesheet | Authoritative | Loads LAST
   Version        : 2.0.0
   File           : /sites/okitour/css/site.css
   ─────────────────────────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════════════════
   @FONT-FACE — Single font family: DM Sans (self-hosted, no external CDN)
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── DM Sans — All text ──────────────────────────────────────────────────────── */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url('/assets/fonts/dm-sans-latin-ext-400-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url('/assets/fonts/dm-sans-latin-400-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url('/assets/fonts/dm-sans-latin-ext-500-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url('/assets/fonts/dm-sans-latin-500-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url('/assets/fonts/dm-sans-latin-ext-600-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url('/assets/fonts/dm-sans-latin-600-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url('/assets/fonts/dm-sans-latin-ext-700-normal.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: 'DM Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url('/assets/fonts/dm-sans-latin-700-normal.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;
}

/* ═══════════════════════════════════════════════════════════════════════════════ */

@layer reset, base, modules, components, utilities, overrides;

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: RESET
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer reset {
  *, *::before, *::after {
    box-sizing: border-box;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: BASE — Premium Design Tokens
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer base {
  :root,
  body[data-site="okitour"] {
    /* ── Colors — deeper, more premium ───────────────────────────────────── */
    --site-bg: #F5EFE4;
    --site-fg: #1B2A3D;
    --site-fg-secondary: #2D3E50;
    --site-accent: #E8651A;
    --site-accent-hover: #D45A15;
    --site-accent-light: #FFF5ED;
    --site-muted: #7A8B9C;
    --site-surface: #F7F7F7;
    --site-border: #E8E0D8;
    --site-success: #52c41a;
    --site-error: #ff4d4f;

    /* ── Section Backgrounds ─────────────────────────────────────────────── */
    --site-bg-sand: #F5EFE4;
    --site-bg-ocean: #EAF4F1;
    --site-bg-sunset: #FEF0E7;
    --site-surface-warm: #FAF7F3;

    /* ── Typography — single font family ──────────────────────────────────── */
    --site-font-heading: 'DM Sans', sans-serif;
    --site-font-body: 'DM Sans', sans-serif;
    --site-font-accent: 'DM Sans', sans-serif;
    --site-font-family: 'DM Sans', sans-serif;
    --site-font-size: 17px;
    --site-line-height: 1.7;
    --site-heading-weight: 700;
    --site-heading-line-height: 1.2;
    --letter-spacing-caps: 0.12em;

    /* ── Spacing — generous, premium breathing room ──────────────────────── */
    --site-pad: 1.5rem;
    --site-pad-lg: 3rem;
    --site-pad-sm: 0.75rem;
    --edge: 48px;
    --section-padding-y: clamp(80px, 10vw, 140px);
    --content-max-width: 1140px;
    --content-narrow: 720px;
    --card-gap: 32px;

    /* ── Layout ───────────────────────────────────────────────────────────── */
    --site-max-width: 1200px;
    --site-radius: 12px;
    --site-radius-sm: 8px;
    --button-radius: 8px;

    /* ── Shadows & Effects — subtle, layered ──────────────────────────────── */
    --shadow-card: 0 2px 8px rgba(27,42,61,0.06), 0 8px 24px rgba(27,42,61,0.04);
    --shadow-card-hover: 0 4px 12px rgba(27,42,61,0.08), 0 16px 40px rgba(27,42,61,0.06);
    --shadow-nav: 0 1px 3px rgba(27,42,61,0.08);
    --site-shadow: var(--shadow-card);
    --site-shadow-hover: var(--shadow-card-hover);
    --transition-default: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-fast: 0.15s ease;

    /* ── Module Token Overrides ───────────────────────────────────────────── */
    --ui-card-bg: #FFFFFF;
    --ui-card-bd: var(--site-border);
    --ui-card-radius: var(--site-radius);
    --ui-hero-overlay-color: rgba(10, 18, 36, 1);
    --ui-hero-overlay-opacity: 0.45;
    --ui-tour-card-accent: var(--site-accent);
    --ui-tour-card-radius: var(--site-radius);
    --ui-pricing-accent: var(--site-accent);
    --ui-pricing-border: var(--site-border);
    --ui-pricing-header-bg: var(--site-surface);
    --ui-faq-border: var(--site-border);
    --ui-faq-question-fg: var(--site-fg);
    --ui-faq-answer-fg: var(--site-muted);
    --ui-itinerary-marker-bg: var(--site-accent);
    --ui-itinerary-line-color: var(--site-border);
    --ui-contact-form-accent: var(--site-accent);
    --ui-contact-form-radius: var(--site-radius-sm);
    --social-ig-radius: var(--site-radius-sm);
    --social-fb-radius: var(--site-radius);
  }

  body[data-site="okitour"] {
    font-family: var(--site-font-body);
    font-size: var(--site-font-size);
    line-height: var(--site-line-height);
    color: var(--site-fg);
    background: var(--site-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: MODULES — Module Overrides for OkiTour
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer modules {

  /* ── Canvas ──────────────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-canvas {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }

  /* ── Layout ──────────────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-layout {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  body[data-site="okitour"] .ui-layout__cell[data-area="main"] {
    flex: 1;
  }

  /* ── Sticky Header ──────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-layout__cell[data-area="header"] {
    position: sticky;
    top: 0;
    z-index: 2000;
    background: var(--site-bg-sand);
  }

  /* ── Footer cell ────────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-layout__cell[data-area="footer"] {
    background: var(--site-fg);
  }

  /* ── Navbar — premium glassmorphism ────────────────────────────────────── */
  body[data-site="okitour"] .ui-navbar {
    --ui-navbar-bg: rgba(245, 239, 228, 0.88);
    --ui-navbar-fg: var(--site-fg);
    --ui-navbar-accent: var(--site-accent);
    --ui-navbar-height: 72px;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    padding-inline: var(--edge);
    backdrop-filter: blur(12px) saturate(1.4);
    -webkit-backdrop-filter: blur(12px) saturate(1.4);
  }

  body[data-site="okitour"] img.ui-navbar__logo {
    max-height: 44px;
    width: auto;
  }

  body[data-site="okitour"] .ui-navbar__link {
    font-family: var(--site-font-accent);
    font-weight: 500;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    transition: color var(--transition-fast);
    position: relative;
  }

  body[data-site="okitour"] .ui-navbar__link:hover {
    color: var(--site-accent);
  }

  body[data-site="okitour"] .ui-navbar__link--active {
    color: var(--site-accent);
    border-bottom: 2px solid var(--site-accent);
    padding-bottom: 4px;
  }

  /* ── Divider wrapper ────────────────────────────────────────────────────── */
  body[data-site="okitour"] .module-wrapper.module-ui-divider {
    padding: 0;
    margin: 0;
    overflow: visible;
    line-height: 0;
  }

  body[data-site="okitour"] .module-wrapper.module-ui-divider[data-id^="divider-hero"] {
    margin-top: -160px;
    position: relative;
    z-index: 10;
  }

  /* ── Footer — padding ──────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-section-footer {
    padding: 0;
  }

  body[data-site="okitour"] .ui-section-footer a {
    color: var(--site-accent);
    text-decoration: none;
    transition: color 0.2s ease;
  }

  body[data-site="okitour"] .ui-section-footer a:hover {
    color: #fff;
  }

  /* ── Hero Overrides ────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-hero__content {
    padding: 4.5rem 2rem calc(3.5rem + 160px);
    max-width: 800px;
    gap: 0.5rem;
  }

  body[data-site="okitour"] .ui-hero[data-variant="compact"] {
    min-height: 50vh;
  }

  body[data-site="okitour"] .ui-hero[data-variant="compact"] .ui-hero__content {
    padding: 2.5rem 1.5rem calc(2.5rem + 160px);
  }

  body[data-site="okitour"] .ui-hero__title {
    font-family: var(--site-font-heading);
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 400;
    font-style: normal;
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] .ui-hero__subtitle {
    font-family: var(--site-font-body);
    font-size: clamp(1rem, 2vw, 1.25rem);
    font-weight: 400;
    letter-spacing: 0.01em;
  }

  /* CTA — refined rectangle, NOT pill */
  body[data-site="okitour"] .ui-hero__cta,
  body[data-site="okitour"] a.ui-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--site-accent);
    color: #fff;
    border: none;
    padding: 16px 36px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    transition: background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
    margin-top: 1.75rem;
    box-shadow: 0 4px 16px rgba(232, 101, 26, 0.3);
  }

  /* CTA arrow */
  body[data-site="okitour"] .ui-hero__cta::after,
  body[data-site="okitour"] a.ui-hero__cta::after {
    content: '\2192';
    transition: transform var(--transition-fast);
  }

  body[data-site="okitour"] .ui-hero__cta:hover,
  body[data-site="okitour"] a.ui-hero__cta:hover {
    background: var(--site-accent-hover);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(232, 101, 26, 0.4);
  }

  body[data-site="okitour"] .ui-hero__cta:hover::after,
  body[data-site="okitour"] a.ui-hero__cta:hover::after {
    transform: translateX(4px);
  }

  body[data-site="okitour"] .ui-hero__cta:active,
  body[data-site="okitour"] a.ui-hero__cta:active {
    transform: translateY(1px);
    box-shadow: 0 2px 8px rgba(232, 101, 26, 0.2);
  }

  /* ── Tour Cards ────────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-tour-card {
    border: none;
    border-radius: var(--site-radius);
    overflow: hidden;
    transition: box-shadow var(--transition-default), transform var(--transition-default);
    background: #fff;
    box-shadow: var(--shadow-card);
  }

  body[data-site="okitour"] .ui-tour-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] .ui-tour-card__price {
    background: var(--site-accent);
    color: #fff;
    font-family: var(--site-font-accent);
    font-weight: 700;
    padding: 0.375rem 0.75rem;
    border-radius: var(--site-radius-sm);
    font-size: 0.875rem;
  }

  body[data-site="okitour"] .ui-tour-card__cta {
    font-family: var(--site-font-accent);
    color: var(--site-accent);
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s ease;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
  }

  body[data-site="okitour"] .ui-tour-card__cta::after {
    content: '\2192';
    transition: transform var(--transition-fast);
  }

  body[data-site="okitour"] .ui-tour-card:hover .ui-tour-card__cta::after {
    transform: translateX(4px);
  }

  body[data-site="okitour"] .ui-tour-card__cta:hover {
    color: var(--site-accent-hover);
  }

  /* ── Jednodenní Tour Cards — Premium Layout ───────────────────────────── */
  body[data-site="okitour"] #nabidka-tours .ui-tour-card__grid {
    max-width: 1080px;
    margin: 0 auto;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card {
    border: none;
    border-radius: var(--site-radius);
    background: #fff;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__image-wrap {
    position: relative;
    overflow: hidden;
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.08));
    pointer-events: none;
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card:hover .ui-tour-card__image {
    transform: scale(1.05);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__body {
    padding: 1.35rem 1.5rem 1.5rem;
    gap: 0.5rem;
    text-align: left;
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__name {
    font-family: var(--site-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--site-fg);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__desc {
    line-height: 1.65;
    color: var(--site-fg-secondary);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__price {
    background: var(--site-accent);
    color: #fff;
    font-weight: 700;
    padding: 0.4rem 0.85rem;
    border-radius: var(--button-radius);
    font-size: 0.85rem;
    letter-spacing: 0.01em;
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__cta {
    margin-top: 0.4rem;
    font-weight: 600;
    color: var(--site-accent);
    transition: color 0.2s ease;
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card__cta:hover {
    color: var(--site-accent-hover);
  }

  body[data-site="okitour"] #nabidka-tours .ui-tour-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: calc(50% - 0.75rem);
    justify-self: center;
  }

  /* ── Pricing Table ─────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-pricing__table {
    border-collapse: collapse;
    width: 100%;
  }

  body[data-site="okitour"] .ui-pricing__table th {
    background: var(--site-surface);
    font-family: var(--site-font-accent);
    font-weight: 600;
    text-align: left;
    padding: 0.75rem 1rem;
    border-bottom: 2px solid var(--site-accent);
  }

  body[data-site="okitour"] .ui-pricing__table td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--site-border);
  }

  body[data-site="okitour"] .ui-pricing__price {
    font-weight: 700;
    color: var(--site-accent);
    white-space: nowrap;
  }

  /* ── FAQ ────────────────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-faq__item {
    border-bottom: 1px solid var(--site-border);
  }

  body[data-site="okitour"] .ui-faq__question {
    font-family: var(--site-font-accent);
    font-weight: 600;
    font-size: 1.1rem;
    padding: 1.25rem 0;
    cursor: pointer;
    color: var(--site-fg);
    transition: color 0.2s ease;
    list-style: none;
  }

  body[data-site="okitour"] .ui-faq__question:hover {
    color: var(--site-accent);
  }

  body[data-site="okitour"] .ui-faq__question::marker {
    display: none;
  }

  body[data-site="okitour"] .ui-faq__answer {
    padding: 0 0 1.25rem 0;
    color: var(--site-muted);
    line-height: 1.7;
  }

  /* ── Itinerary — moved to unlayered section (needs to beat @layer atoms) ── */

  /* ── Contact Form ──────────────────────────────────────────────────────── */
  body[data-site="okitour"] .ui-contact-form__input {
    border: 1px solid var(--site-border);
    border-radius: var(--site-radius-sm);
    padding: 0.75rem 1rem;
    font-family: var(--site-font-body);
    font-size: 1rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    width: 100%;
  }

  body[data-site="okitour"] .ui-contact-form__input:focus {
    outline: none;
    border-color: var(--site-accent);
    box-shadow: 0 0 0 3px var(--site-accent-light);
  }

  body[data-site="okitour"] .ui-contact-form__submit {
    background: var(--site-accent);
    color: #fff;
    border: none;
    padding: 16px 36px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition-fast), transform var(--transition-fast);
  }

  body[data-site="okitour"] .ui-contact-form__submit:hover {
    background: var(--site-accent-hover);
    transform: translateY(-1px);
  }

  body[data-site="okitour"] .ui-contact-form__submit:active {
    transform: translateY(1px);
  }

  body[data-site="okitour"] .ui-contact-form__submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
  }

  /* ── Social Feeds — Instagram ──────────────────────────────────────────── */
  body[data-site="okitour"] .social-ig__header {
    margin-bottom: 1.75rem;
  }

  body[data-site="okitour"] .social-ig__title {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] .social-ig__handle {
    font-family: var(--site-font-accent);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--site-accent);
  }

  /* Instagram follow — ghost/outline button */
  body[data-site="okitour"] .social-ig__follow,
  body[data-site="okitour"] a.social-ig__follow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 12px 28px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    border: 2px solid var(--site-accent);
    color: var(--site-accent);
    background: transparent;
    transition: all var(--transition-fast);
    box-shadow: none;
  }

  body[data-site="okitour"] .social-ig__follow:hover,
  body[data-site="okitour"] a.social-ig__follow:hover {
    background: var(--site-accent);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(232, 101, 26, 0.3);
    opacity: 1;
  }

  body[data-site="okitour"] .social-ig__load-more {
    padding: 12px 28px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 0.92rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    background: transparent;
    color: var(--site-fg);
    border: 1.5px solid rgba(0,0,0,0.15);
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
  }

  body[data-site="okitour"] .social-ig__load-more:hover {
    background: rgba(0,0,0,0.03);
    border-color: rgba(0,0,0,0.3);
    transform: translateY(-1px);
  }

  /* Instagram image hover */
  body[data-site="okitour"] .social-ig__post {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    cursor: pointer;
  }

  body[data-site="okitour"] .social-ig__image {
    transition: transform var(--transition-default), filter var(--transition-default);
  }

  body[data-site="okitour"] .social-ig__post:hover .social-ig__image {
    transform: scale(1.03);
    filter: brightness(1.05);
  }

  /* ── Social Feeds — Facebook ───────────────────────────────────────────── */
  body[data-site="okitour"] .social-fb__title {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] .social-fb__load-more {
    padding: 12px 28px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 0.92rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    background: transparent;
    color: var(--site-fg);
    border: 1.5px solid rgba(0,0,0,0.15);
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
  }

  body[data-site="okitour"] .social-fb__load-more:hover {
    background: rgba(0,0,0,0.03);
    border-color: rgba(0,0,0,0.3);
    transform: translateY(-1px);
  }

  /* Facebook follow — ghost/outline button (matching Instagram) */
  body[data-site="okitour"] .social-fb__follow,
  body[data-site="okitour"] a.social-fb__follow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 12px 28px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    border: 2px solid var(--site-accent);
    color: var(--site-accent);
    background: transparent;
    transition: all var(--transition-fast);
    box-shadow: none;
  }

  body[data-site="okitour"] .social-fb__follow:hover,
  body[data-site="okitour"] a.social-fb__follow:hover {
    background: var(--site-accent);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(232, 101, 26, 0.3);
    opacity: 1;
  }

  /* Facebook post cards — premium masonry treatment */
  body[data-site="okitour"] .social-fb__post {
    border-radius: var(--site-radius);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-default), transform var(--transition-default);
    background: #fff;
  }

  body[data-site="okitour"] .social-fb__post:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] .social-fb__post-image {
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] .social-fb__post:hover .social-fb__post-image {
    transform: scale(1.05);
  }

  /* Post actions — "View on Facebook" link — styled as accent link */
  body[data-site="okitour"] .social-fb__post-actions {
    margin-top: 8px;
  }

  body[data-site="okitour"] .social-fb__post-link {
    font-family: var(--site-font-accent);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--site-accent);
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  body[data-site="okitour"] .social-fb__post-link:hover {
    color: var(--site-accent-hover);
  }

  body[data-site="okitour"] .social-fb__post-action-sep {
    margin: 0 6px;
    color: var(--site-muted);
    opacity: 0.4;
  }

  /* Engagement stats — subdued, smaller */
  body[data-site="okitour"] .social-fb__engagement {
    font-family: var(--site-font-accent);
    font-size: 0.75rem;
    color: var(--site-muted);
    opacity: 0.7;
  }

  body[data-site="okitour"] .social-fb__stat {
    margin-right: 10px;
  }

  body[data-site="okitour"] .social-fb__stat svg {
    vertical-align: -2px;
    opacity: 0.6;
  }

  /* Post header — author + date */
  body[data-site="okitour"] .social-fb__post-author {
    font-family: var(--site-font-accent);
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--site-fg);
  }

  body[data-site="okitour"] .social-fb__post-date {
    font-size: 0.8125rem;
    color: var(--site-muted);
  }

  /* Post text */
  body[data-site="okitour"] .social-fb__post-text {
    line-height: 1.6;
    color: var(--site-fg-secondary);
  }

  body[data-site="okitour"] .social-fb__see-more {
    font-family: var(--site-font-accent);
    font-weight: 500;
    color: var(--site-accent);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-size: inherit;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: COMPONENTS — Page-Specific Styles
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer components {

  /* ── Page: Home ────────────────────────────────────────────────────────── */
  body[data-site="okitour"][data-page="home"] .okitour-intro {
    text-align: center;
    max-width: var(--content-narrow);
    margin: 0 auto;
    padding: var(--site-pad-lg) var(--site-pad);
  }

  body[data-site="okitour"][data-page="home"] .okitour-intro h2 {
    font-family: var(--site-font-heading);
    font-size: var(--text-section-title, clamp(1.75rem, 3vw, 2.5rem));
    font-weight: 400;
    margin-bottom: 1rem;
    color: var(--site-fg);
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"][data-page="home"] .okitour-intro p {
    font-size: 1.0625rem;
    color: var(--site-fg-secondary);
    line-height: 1.7;
  }

  /* ── Intro Section — Treatment A: orange bar (ONLY here) ───────────── */
  body[data-site="okitour"] #intro-section .ui-section-body__inner {
    text-align: center;
    max-width: var(--content-narrow);
    margin: 0 auto;
  }

  body[data-site="okitour"] #intro-section h2.ui-copy__item {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    margin-bottom: 0.5rem;
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] #intro-section h2.ui-copy__item::after {
    content: "";
    display: block;
    width: 48px;
    height: 3px;
    background: var(--site-accent);
    border-radius: 2px;
    margin: 16px auto 24px;
  }

  body[data-site="okitour"] #intro-section p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-fg-secondary);
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto;
  }

  /* Bridge line */
  body[data-site="okitour"] #intro-section .module-wrapper[data-id="bridge-line"] p.ui-copy__item {
    color: var(--site-muted);
    opacity: 0.65;
    margin-top: 0.25rem;
    margin-bottom: 0;
    letter-spacing: 0.01em;
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="bridge-line"]::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    margin: 1rem auto 0;
  }

  /* ── Values Grid (feature cards) — premium, no-border treatment ──────── */
  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] {
    max-width: 960px;
    margin: 1.25rem auto 0;
    text-align: center;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-grid {
    --ui-grid-align: stretch;
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    padding: 40px 32px;
    background: var(--site-bg);
    border-radius: var(--site-radius);
    box-shadow: none;
    border: none;
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block:hover {
    box-shadow: var(--shadow-card);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block__icon {
    width: 64px;
    height: 64px;
    opacity: 1;
    margin-bottom: 20px;
    background: var(--site-accent-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block__icon svg {
    width: 28px;
    height: 28px;
    stroke-width: 1.75;
    color: var(--site-accent);
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block__title {
    font-family: var(--site-font-accent);
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    margin-bottom: 12px;
    color: var(--site-fg);
  }

  body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block__description {
    line-height: 1.6;
    color: var(--site-muted);
    max-width: 240px;
    margin: 0 auto;
  }

  @media (max-width: 768px) {
    body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] {
      gap: 1rem;
    }

    body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-grid {
      grid-template-columns: 1fr;
    }

    body[data-site="okitour"] #intro-section .module-wrapper[data-id="values-grid"] .ui-service-block {
      padding: 28px 24px;
    }
  }

  /* ── Categories Section — Treatment B: no accent bar ───────────────── */
  body[data-site="okitour"] #categories-section .ui-section-body__inner {
    text-align: center;
    max-width: 960px;
    margin: 0 auto;
  }

  body[data-site="okitour"] #categories-section h2.ui-copy__item {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    margin-bottom: 0.35rem;
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  /* NO ::after — Treatment B */

  body[data-site="okitour"] #categories-section p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-muted);
    line-height: 1.7;
    max-width: 540px;
    margin: 0 auto;
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__title {
    display: none;
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__grid {
    max-width: 960px;
    margin: 1.5rem auto 0;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card {
    border: none;
    border-radius: var(--site-radius);
    background: var(--site-bg);
    box-shadow: var(--shadow-card);
    overflow: hidden;
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__image-wrap {
    position: relative;
    overflow: hidden;
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,0.18) 100%);
    pointer-events: none;
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card:hover .ui-tour-card__image {
    transform: scale(1.05);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__body {
    padding: 28px 28px 24px;
    gap: 0.45rem;
    text-align: left;
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__name {
    font-family: var(--site-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--site-fg);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__desc {
    line-height: 1.65;
    color: var(--site-fg-secondary);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card__cta {
    margin-top: 16px;
    font-family: var(--site-font-accent);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--site-accent);
    transition: color 0.2s ease;
    position: relative;
    display: inline-block;
  }

  /* Animated underline on link hover */
  body[data-site="okitour"] #categories-section .ui-tour-card__cta::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--site-accent);
    transition: width var(--transition-default);
  }

  body[data-site="okitour"] #categories-section .ui-tour-card:hover .ui-tour-card__cta::after {
    width: 100%;
  }

  /* ── Facebook Section — Treatment C: thin rule ──────────────────────── */
  body[data-site="okitour"] #facebook-section .ui-section-body__inner {
    text-align: center;
    padding-inline: 0;
  }

  body[data-site="okitour"] #facebook-section h2.ui-copy__item {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    margin-bottom: 0.35rem;
    letter-spacing: -0.01em;
    line-height: var(--site-heading-line-height);
  }

  /* Treatment C — thin rule ABOVE heading */
  body[data-site="okitour"] #facebook-section h2.ui-copy__item::before {
    content: "";
    display: block;
    width: 80px;
    height: 1px;
    background: var(--site-border);
    margin: 0 auto 24px;
  }

  body[data-site="okitour"] #facebook-section p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-muted);
    line-height: 1.7;
    max-width: 540px;
    margin: 0 auto 1.5rem;
  }

  /* ── Nabídka Choices ───────────────────────────────────────────────────── */
  body[data-site="okitour"] #nabidka-choices .ui-grid[data-id="nabidka-grid"] {
    --ui-grid-align: stretch;
    max-width: 960px;
    margin: 0 auto;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--site-bg);
    border-radius: var(--site-radius);
    overflow: hidden;
    border: none;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-default), transform var(--transition-default);
    padding: 0;
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__image-wrap {
    order: -1;
    position: relative;
    overflow: hidden;
    margin: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 50%, rgba(0,0,0,0.12) 100%);
    pointer-events: none;
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
    height: 100%;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block:hover .ui-service-block__image {
    transform: scale(1.05);
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__title {
    padding: 1.5rem 1.75rem 0;
    font-family: var(--site-font-heading);
    font-size: 1.35rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--site-accent);
    margin: 0;
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__title a {
    color: inherit;
    text-decoration: none;
  }

  body[data-site="okitour"] #nabidka-choices .ui-service-block__description {
    padding: 0.5rem 1.75rem 1.75rem;
    line-height: 1.65;
    color: var(--site-muted);
    flex: 1;
    margin: 0;
  }

  @media (max-width: 768px) {
    body[data-site="okitour"] #nabidka-choices .ui-grid[data-id="nabidka-grid"] {
      grid-template-columns: 1fr;
      gap: 1.5rem;
    }
  }

  /* ── Nabídka Intro ─────────────────────────────────────────────────────── */
  body[data-site="okitour"] #nabidka-intro .ui-copy {
    max-width: 52ch;
    text-align: left;
    margin-inline: auto;
  }

  body[data-site="okitour"] #nabidka-intro p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-muted);
    line-height: 1.6;
    margin-bottom: 1.1em;
  }

  body[data-site="okitour"] #nabidka-intro .ui-copy:first-child p.ui-copy__item {
    color: var(--site-fg-secondary);
    opacity: 0.88;
  }

  body[data-site="okitour"] #nabidka-intro .ui-copy:first-child {
    border-left: 3px solid var(--site-accent);
    padding-left: 1.25rem;
    padding-block: 0.25rem;
  }

  /* Notice callout */
  body[data-site="okitour"] #nabidka-intro .ui-copy__wrap[data-id="jednodenni-notice"] .ui-copy {
    margin-top: 1.5rem;
    border-left: none;
    padding: 1.15rem 1.5rem;
    background: var(--site-accent-light);
    border-radius: 10px;
    border: 1px solid rgba(232, 101, 26, 0.15);
  }

  body[data-site="okitour"] #nabidka-intro .ui-copy__wrap[data-id="jednodenni-notice"] p.ui-copy__item {
    line-height: 1.55;
    color: var(--site-muted);
    margin-bottom: 0;
  }

  @media (max-width: 768px) {
    body[data-site="okitour"] #nabidka-intro .ui-copy:nth-child(2)::after {
      content: "";
      display: block;
      width: 2px;
      height: 24px;
      background: var(--site-accent);
      opacity: 0.35;
      margin: 0.75rem 0 0 0;
    }
  }

  /* ── Special Intro ─────────────────────────────────────────────────────── */
  body[data-site="okitour"] #special-intro p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-muted);
    line-height: 1.6;
    margin-bottom: 1.1em;
  }

  body[data-site="okitour"] #special-intro .ui-copy__wrap[data-id="special-desc"] .ui-copy {
    border-left: 3px solid var(--site-accent);
    padding-left: 1.25rem;
    padding-block: 0.25rem;
  }

  body[data-site="okitour"] #special-intro .ui-copy__wrap[data-id="special-desc"] p.ui-copy__item {
    color: var(--site-fg-secondary);
    opacity: 0.88;
  }

  body[data-site="okitour"] #special-intro .ui-copy__wrap[data-id="special-notice"] .ui-copy {
    margin-top: 1.5rem;
    border-left: none;
    padding: 1.15rem 1.5rem;
    background: var(--site-accent-light);
    border-radius: 10px;
    border: 1px solid rgba(232, 101, 26, 0.15);
  }

  body[data-site="okitour"] #special-intro .ui-copy__wrap[data-id="special-notice"] p.ui-copy__item {
    line-height: 1.55;
    color: var(--site-muted);
    margin-bottom: 0;
  }

  /* ── Special Programs — premium tour cards ─────────────────────────────── */
  body[data-site="okitour"] #special-programs .ui-tour-card__grid {
    max-width: 1080px;
    margin: 0 auto;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card {
    border: none;
    border-radius: var(--site-radius);
    background: #fff;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__image-wrap {
    position: relative;
    overflow: hidden;
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.08));
    pointer-events: none;
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card:hover .ui-tour-card__image {
    transform: scale(1.05);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__body {
    padding: 28px 28px 24px;
    gap: 0.5rem;
    text-align: left;
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__name {
    font-family: var(--site-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--site-fg);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__desc {
    line-height: 1.65;
    color: var(--site-fg-secondary);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__price {
    background: var(--site-accent);
    color: #fff;
    font-weight: 700;
    padding: 0.4rem 0.85rem;
    border-radius: var(--button-radius);
    font-size: 0.85rem;
    letter-spacing: 0.01em;
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__cta {
    margin-top: 0.4rem;
    font-weight: 600;
    color: var(--site-accent);
    transition: color 0.2s ease;
  }

  body[data-site="okitour"] #special-programs .ui-tour-card__cta:hover {
    color: var(--site-accent-hover);
  }

  body[data-site="okitour"] #special-programs .ui-tour-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: calc(50% - 0.75rem);
    justify-self: center;
  }

  /* ── Služby Intro ──────────────────────────────────────────────────────── */
  body[data-site="okitour"] #sluzby-intro p.ui-copy__item {
    font-size: 1.0625rem;
    color: var(--site-muted);
    line-height: 1.6;
    margin-bottom: 1.1em;
  }

  body[data-site="okitour"] #sluzby-intro .ui-copy__wrap[data-id="sluzby-desc"] .ui-copy {
    border-left: 3px solid var(--site-accent);
    padding-left: 1.25rem;
    padding-block: 0.25rem;
  }

  body[data-site="okitour"] #sluzby-intro .ui-copy__wrap[data-id="sluzby-desc"] p.ui-copy__item {
    color: var(--site-fg-secondary);
    opacity: 0.88;
  }

  body[data-site="okitour"] #sluzby-intro .ui-copy__wrap[data-id="sluzby-notice"] .ui-copy {
    margin-top: 1.5rem;
    border-left: none;
    padding: 1.15rem 1.5rem;
    background: var(--site-accent-light);
    border-radius: 10px;
    border: 1px solid rgba(232, 101, 26, 0.15);
  }

  body[data-site="okitour"] #sluzby-intro .ui-copy__wrap[data-id="sluzby-notice"] p.ui-copy__item {
    line-height: 1.55;
    color: var(--site-muted);
    margin-bottom: 0;
  }

  /* ── Služby Cards ──────────────────────────────────────────────────────── */
  body[data-site="okitour"] #sluzby-cards .ui-tour-card__grid {
    max-width: 1080px;
    margin: 0 auto;
    gap: var(--card-gap);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card {
    border: none;
    border-radius: var(--site-radius);
    background: #fff;
    box-shadow: var(--shadow-card);
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-4px);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__image-wrap {
    position: relative;
    overflow: hidden;
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.08));
    pointer-events: none;
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
    display: block;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card:hover .ui-tour-card__image {
    transform: scale(1.05);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__body {
    padding: 28px 28px 24px;
    gap: 0.5rem;
    text-align: left;
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__name {
    font-family: var(--site-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--site-fg);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__desc {
    line-height: 1.65;
    color: var(--site-fg-secondary);
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__price {
    background: var(--site-accent);
    color: #fff;
    font-weight: 700;
    padding: 0.4rem 0.85rem;
    border-radius: var(--button-radius);
    font-size: 0.85rem;
    letter-spacing: 0.01em;
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__cta {
    margin-top: 0.4rem;
    font-weight: 600;
    color: var(--site-accent);
    transition: color 0.2s ease;
  }

  body[data-site="okitour"] #sluzby-cards .ui-tour-card__cta:hover {
    color: var(--site-accent-hover);
  }

  body[data-site="okitour"][data-page^="nabidka"] .page-title,
  body[data-site="okitour"][data-page^="sluzby"] .page-title {
    font-family: var(--site-font-heading);
    font-size: 2rem;
    font-weight: 400;
    text-align: center;
    margin-bottom: var(--site-pad-lg);
    color: var(--site-fg);
  }

  /* ── Tour Header — Premium Boutique Experience ──────────────────────── */

  /* Section container with warm ambient gradient */
  body[data-site="okitour"] #tour-header {
    position: relative;
    overflow: visible;
  }
  body[data-site="okitour"] #tour-header::before {
    display: none;
  }

  /* Force grid display */
  body[data-site="okitour"] #tour-header .ui-columns {
    display: grid;
    width: 100%;
    align-items: start;
  }

  /* ── Left sidebar — premium fact card with accent top border ───────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] {
    position: relative;
    background: #fff;
    border-radius: 2px var(--site-radius) var(--site-radius) var(--site-radius);
    box-shadow: var(--shadow-card);
    padding: 2.25rem 2rem;
    display: flex;
    flex-direction: column;
    gap: 0;
    align-self: start;
    z-index: 10;
    border-top: 3px solid var(--site-accent);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
  }

  /* Inner warm glow at top of card */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"]::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(180deg, rgba(232, 101, 26, 0.03) 0%, transparent 100%);
    border-radius: var(--site-radius) var(--site-radius) 0 0;
    pointer-events: none;
    z-index: 0;
  }

  @media (hover: hover) {
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"]:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow-card-hover);
    }
  }

  /* ── Day label — subtle pill badge ─────────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-day-label {
    --day-label-bg: rgba(232, 101, 26, 0.1);
    --day-label-fg: var(--site-accent);
    --day-label-r: 20px;
    --day-label-fz: 0.8rem;
    --day-label-tt: uppercase;
    letter-spacing: 0.06em;
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.9rem;
    margin-bottom: 0.5rem;
  }
  body[data-site="okitour"] #tour-header .ui-day-label__text {
    font-weight: 600;
    line-height: 1.3;
  }
  /* Remove accent bar — not needed for pill style */
  body[data-site="okitour"] #tour-header .module-wrapper.module-ui-dayLabel::after {
    display: none;
  }

  /* ── Tour title in left column ───────────────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] h2.ui-copy__item {
    font-family: var(--site-font-heading, 'DM Sans', sans-serif);
    font-size: 1.75rem;
    font-weight: 400;
    color: var(--site-fg, #2C2218);
    line-height: 1.25;
    margin: 0 0 0.75rem;
    letter-spacing: -0.01em;
  }

  /* ── Tags — rounded rect, warmer tones ─────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    --tags-bg: #f0ebe5;
    --tags-fg: var(--site-fg-secondary);
    --tags-br: transparent;
    --tags-r: 6px;
    --tags-fz: 0.78rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    margin-bottom: 0.75rem;
  }
  body[data-site="okitour"] #tour-header .ui-tags__item {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.9rem;
    border-radius: var(--tags-r, 6px);
    background: var(--tags-bg);
    color: var(--tags-fg);
    border: 1px solid var(--tags-br);
    font-size: var(--tags-fz, 0.78rem);
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    transition: background 0.2s ease, border-color 0.2s ease;
  }
  /* All tags uniform — no first-child emphasis */

  /* ── Price — supportive, not dominant ──────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-price-tag {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    gap: 0.5rem;
    --price-fg: var(--site-fg);
    --price-fz: 1.05rem;
    --price-fw: 600;
    --price-note-fg: var(--site-muted);
    --price-note-fz: 0.78rem;
    padding: 0.75rem 0 0;
    margin-bottom: 0;
    position: relative;
  }
  body[data-site="okitour"] #tour-header .ui-price-tag__amount {
    font-weight: 600;
    letter-spacing: 0;
  }
  body[data-site="okitour"] #tour-header .ui-price-tag__note {
    opacity: 0.55;
    margin-top: 0;
    line-height: 1.5;
  }

  /* ── Info items (duration, group) — icon bullets ──────────────────── */
  body[data-site="okitour"] #tour-header .ui-copy__list-item {
    color: var(--site-fg-secondary);
    font-weight: 500;
    padding-left: 1.6rem;
  }
  body[data-site="okitour"] #tour-header .ui-copy__list--accent .ui-copy__list-item::before {
    width: 15px;
    height: 15px;
    border-radius: 0;
    border: none;
    background: none;
    top: 0.2em;
    opacity: 0.5;
  }
  /* clock icon — duration */
  body[data-site="okitour"] #tour-header .ui-copy__list--accent .ui-copy__list-item:nth-child(1)::before {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232D3E50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E") no-repeat center / contain;
  }
  /* users icon — group size */
  body[data-site="okitour"] #tour-header .ui-copy__list--accent .ui-copy__list-item:nth-child(2)::before {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%232D3E50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E") no-repeat center / contain;
  }

  /* ── Right column ──────────────────────────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
    padding-left: 2rem;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] .ui-copy {
    max-width: none;
  }

  /* ── Intro paragraph — editorial quote treatment ───────────────────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] > .module-wrapper:first-child {
    border-left: 3px solid rgba(232, 101, 26, 0.3);
    padding-left: 1.5rem;
    margin-bottom: 0.5rem;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] > .module-wrapper:first-child p.ui-copy__item {
    font-size: 1.05rem;
    line-height: 1.75;
    color: var(--site-fg-secondary);
  }

  /* ── Section headings (V ceně / Není v ceně) ─────────────────────── */
  body[data-site="okitour"] #tour-header h3.ui-copy__item {
    font-family: var(--site-font-body);
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    color: var(--site-fg);
    margin-top: 0;
    margin-bottom: 0.5rem;
    padding-bottom: 0.35rem;
    border-bottom: 2px solid rgba(232, 101, 26, 0.15);
  }

  /* ── Left card section dividers — breathing room between offer/practical ── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] h3.ui-copy__item {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
  }
  /* First h3 after price tag — no top border, just spacing */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] .module-ui-priceTag + .module-wrapper h3.ui-copy__item {
    border-top: none;
    padding-top: 0.5rem;
  }

  /* ── Left card list items — tighter alignment ────────────────────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] .ui-copy__list-item {
    padding-left: 1.25rem;
    line-height: 1.65;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] .ui-copy__list-item::before {
    top: 0.55em;
    width: 5px;
    height: 5px;
  }

  /* Right column — compact paragraphs */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] p.ui-copy__item {
    line-height: 1.6;
    margin: 0;
  }

  /* ── Includes/excludes — curated card ──────────────────────────────── */
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] {
    display: grid;
    width: 100%;
    margin-top: 1.5rem;
    background: var(--site-surface-warm);
    border-radius: 8px;
    padding: 1.5rem;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] [data-area="left"],
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] [data-area="right"] {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    background: none;
    box-shadow: none;
    padding: 0;
    border: none;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] h3.ui-copy__item {
    margin-top: 0;
  }
  body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] .ui-copy__list-item {
    line-height: 1.6;
    color: var(--site-fg-secondary);
  }

  /* ── Tour Header Responsive ─────────────────────────────────────────── */
  @media (max-width: 1024px) {
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] {
      gap: 0.5rem;
    }
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] {
      padding-left: 0;
      margin-top: 1rem;
    }
    /* Stacked: intro quote switches to top border */
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] > .module-wrapper:first-child {
      border-left: none;
      padding-left: 0;
      border-top: 3px solid rgba(232, 101, 26, 0.2);
      padding-top: 1.25rem;
    }
  }

  @media (max-width: 640px) {
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] {
      padding: 1.5rem 1.25rem;
    }
    body[data-site="okitour"] #tour-header .ui-tags__item {
      font-size: 0.72rem;
      padding: 0.25rem 0.7rem;
    }
    body[data-site="okitour"] #tour-header .ui-day-label {
      --day-label-fz: 0.75rem;
    }
    body[data-site="okitour"] #tour-header .ui-columns[data-id="tour-includes-cols"] {
      padding: 1rem;
    }
    body[data-site="okitour"] #tour-header .ui-price-tag {
      --price-fz: 0.95rem;
    }
  }

  /* ── Tour section headings (Fotogalerie, Více z nabídky, etc.) ────────── */
  body[data-site="okitour"] #tour-gallery h3.ui-copy__item,
  body[data-site="okitour"] #tour-related h3.ui-copy__item {
    font-family: var(--site-font-heading, 'DM Sans', sans-serif);
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--site-fg);
    text-align: center;
    letter-spacing: -0.01em;
    margin: 0 0 0.5rem;
    line-height: 1.3;
  }
  body[data-site="okitour"] #tour-gallery h3.ui-copy__item::after,
  body[data-site="okitour"] #tour-related h3.ui-copy__item::after {
    content: "";
    display: block;
    width: 40px;
    height: 2px;
    background: var(--site-accent, #E8651A);
    border-radius: 2px;
    margin: 0.75rem auto 1.5rem;
    opacity: 0.5;
  }

  /* ── Tour Detail Pages ─────────────────────────────────────────────────── */
  body[data-site="okitour"] .tour-detail__intro {
    font-size: 1.15rem;
    color: var(--site-muted);
    line-height: 1.8;
    max-width: 800px;
    margin: 0 auto var(--site-pad-lg);
  }

  body[data-site="okitour"] .tour-detail__price-badge {
    display: inline-block;
    background: var(--site-accent-light);
    color: var(--site-accent);
    font-weight: 700;
    font-size: 1.25rem;
    padding: 0.75rem 1.5rem;
    border-radius: var(--site-radius);
    border: 2px solid var(--site-accent);
    margin: var(--site-pad) 0;
  }

  body[data-site="okitour"] .tour-detail__cta-btn {
    display: inline-block;
    background: var(--site-accent);
    color: #fff;
    padding: 16px 36px;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-weight: 600;
    text-decoration: none;
    transition: background var(--transition-fast);
    margin-top: 1rem;
  }

  body[data-site="okitour"] .tour-detail__cta-btn:hover {
    background: var(--site-accent-hover);
  }

  /* ── Page: About (O nás) — Editorial Redesign ────────────────────────── */

  /* Hero: full-height, warm overlay */
  body[data-site="okitour"][data-page="o-nas"] .ui-hero .ui-hero__overlay {
    background: linear-gradient(
      to bottom,
      rgba(60, 25, 5, 0.55) 0%,
      rgba(60, 25, 5, 0.40) 50%,
      rgba(60, 25, 5, 0.60) 100%
    );
    opacity: 1;
  }
  body[data-site="okitour"][data-page="o-nas"] .ui-hero__bg {
    background-position: center 38% !important;
  }

  /* Section 1: Intro — narrow centered reading column */
  body[data-site="okitour"] #about-intro .ui-section-body__inner {
    max-width: 680px;
    margin-inline: auto;
    text-align: center;
  }
  body[data-site="okitour"] #about-intro h2.ui-copy__item {
    font-family: var(--site-font-heading, 'DM Sans', sans-serif);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 400;
    color: var(--site-accent);
    letter-spacing: -0.02em;
    line-height: 1.3;
    margin-bottom: 1.5rem;
  }
  body[data-site="okitour"] #about-intro h2.ui-copy__item::after {
    display: none;
  }
  body[data-site="okitour"] #about-intro p.ui-copy__item {
    line-height: 1.75;
    text-align: left;
  }

  /* Pullquotes — shared left accent bar style */
  body[data-site="okitour"] .module-wrapper--about-intro-quote,
  body[data-site="okitour"] .module-wrapper--about-itoman-quote,
  body[data-site="okitour"] .module-wrapper--about-activities-quote,
  body[data-site="okitour"] .module-wrapper--about-story-quote {
    max-width: 680px;
    margin: 2rem auto 0;
    padding: 1.25rem 2rem;
    border-left: 4px solid var(--site-accent);
    background: rgba(232, 101, 26, 0.04);
    border-radius: 0 var(--site-radius) var(--site-radius) 0;
  }
  body[data-site="okitour"] .module-wrapper--about-intro-quote p.ui-copy__item,
  body[data-site="okitour"] .module-wrapper--about-itoman-quote p.ui-copy__item,
  body[data-site="okitour"] .module-wrapper--about-activities-quote p.ui-copy__item,
  body[data-site="okitour"] .module-wrapper--about-story-quote p.ui-copy__item {
    font-family: var(--site-font-heading, 'DM Sans', sans-serif);
    font-size: clamp(1.05rem, 2vw, 1.2rem);
    font-weight: 400;
    color: var(--site-accent);
    line-height: 1.6;
    font-style: italic;
    margin: 0;
  }

  /* Section 2: Itoman — image left 60%, text right 40% */
  body[data-site="okitour"] #about-itoman h2.ui-copy__item,
  body[data-site="okitour"] #about-activities h2.ui-copy__item {
    font-family: var(--site-font-heading);
    font-size: clamp(1.4rem, 2.5vw, 1.85rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
  }
  body[data-site="okitour"] #about-itoman h2.ui-copy__item::after,
  body[data-site="okitour"] #about-activities h2.ui-copy__item::after {
    display: none;
  }
  body[data-site="okitour"] #about-itoman p.ui-copy__item,
  body[data-site="okitour"] #about-activities p.ui-copy__item {
    line-height: 1.75;
  }

  /* Image / map wrappers — subtle shadow, NO orange border */
  body[data-site="okitour"] #about-itoman .ui-columns[data-id="about-itoman-cols"] > [data-area="left"] .module-wrapper,
  body[data-site="okitour"] #about-activities .ui-columns[data-id="about-activities-cols"] > [data-area="right"] .module-wrapper {
    border-radius: var(--site-radius);
    box-shadow: 0 8px 32px rgba(27, 42, 61, 0.10);
    overflow: hidden;
  }

  /* Map — stretch to fill the full column height */
  body[data-site="okitour"] #about-itoman .ui-columns[data-id="about-itoman-cols"] > [data-area="left"] {
    display: flex;
    flex-direction: column;
  }
  body[data-site="okitour"] #about-itoman .ui-columns[data-id="about-itoman-cols"] > [data-area="left"] .module-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
  }
  body[data-site="okitour"] #about-itoman .ui-map {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 400px;
  }
  body[data-site="okitour"] #about-itoman .ui-map-container {
    flex: 1;
    height: auto;
    min-height: 400px;
  }

  /* Column vertical centering */
  body[data-site="okitour"] #about-itoman .ui-columns[data-id="about-itoman-cols"] > [data-area="right"],
  body[data-site="okitour"] #about-activities .ui-columns[data-id="about-activities-cols"] > [data-area="left"] {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  /* Pullquotes inside columns — full-width of column */
  body[data-site="okitour"] #about-itoman .module-wrapper--about-itoman-quote,
  body[data-site="okitour"] #about-activities .module-wrapper--about-activities-quote {
    max-width: none;
    margin: 1.5rem 0 0;
  }

  /* Section 4: Values grid — ocean background */
  body[data-site="okitour"] #about-values .ui-section-body__inner {
    max-width: var(--content-max-width, 1140px);
    margin-inline: auto;
  }
  body[data-site="okitour"] #about-values h2.ui-copy__item {
    text-align: center;
    font-family: var(--site-font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    margin-bottom: 2rem;
  }
  body[data-site="okitour"] #about-values h2.ui-copy__item::after {
    display: none;
  }
  /* Equal-height cards — match homepage values-grid style */
  body[data-site="okitour"] #about-values .ui-grid {
    align-items: stretch;
  }
  body[data-site="okitour"] #about-values .ui-grid__cell {
    display: flex;
  }
  body[data-site="okitour"] #about-values .module-wrapper.module-ui-serviceBlock {
    flex: 1;
  }
  body[data-site="okitour"] #about-values .ui-service-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    padding: 40px 32px;
    background: rgba(255, 255, 255, 0.7);
    border-radius: var(--site-radius);
    box-shadow: none;
    border: none;
    transition: box-shadow var(--transition-default), transform var(--transition-default);
  }
  body[data-site="okitour"] #about-values .ui-service-block:hover {
    box-shadow: var(--shadow-card);
    transform: translateY(-4px);
  }
  body[data-site="okitour"] #about-values .ui-service-block__icon {
    width: 64px;
    height: 64px;
    opacity: 1;
    margin-bottom: 20px;
    background: var(--site-accent-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  body[data-site="okitour"] #about-values .ui-service-block__icon svg {
    width: 28px;
    height: 28px;
    stroke-width: 1.75;
    color: var(--site-accent);
  }
  body[data-site="okitour"] #about-values .ui-service-block__title {
    font-family: var(--site-font-accent);
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    margin-bottom: 12px;
    color: var(--site-fg);
  }
  body[data-site="okitour"] #about-values .ui-service-block__description {
    line-height: 1.6;
    color: var(--site-muted);
    max-width: 240px;
  }

  /* Story section — text left, diploma right */
  body[data-site="okitour"] #about-story .ui-columns[data-id="about-story-cols"] > [data-area="left"] {
    display: flex;
    flex-direction: column;
    gap: 0;
    justify-content: start;
  }
  body[data-site="okitour"] #about-story .ui-columns[data-id="about-story-cols"] > [data-area="right"] {
    display: flex;
    flex-direction: column;
    align-self: start;
    padding-top: 0.5rem;
  }
  body[data-site="okitour"] #about-story .ui-columns[data-id="about-story-cols"] > [data-area="right"] .module-wrapper {
    border-radius: var(--site-radius);
    box-shadow: 0 8px 32px rgba(27, 42, 61, 0.10);
    overflow: hidden;
  }
  body[data-site="okitour"] #about-story h2.ui-copy__item::after {
    display: none;
  }

  /* Closing section — centered text + family photo */
  body[data-site="okitour"] #about-closing .ui-section-body__inner {
    text-align: center;
    max-width: var(--content-max-width, 1100px);
    margin: 0 auto;
  }
  body[data-site="okitour"] #about-closing p.ui-copy__item {
    font-size: clamp(1.1rem, 2vw, 1.25rem);
    margin-bottom: 0.25rem;
  }
  body[data-site="okitour"] #about-closing h3.ui-copy__item {
    font-family: var(--site-font-heading, 'DM Sans', sans-serif);
    font-size: clamp(1.3rem, 2.5vw, 1.75rem);
    font-weight: 700;
    color: var(--site-fg);
    margin-bottom: 2rem;
  }
  body[data-site="okitour"] #about-closing h3.ui-copy__item::after {
    display: none;
  }
  /* Family photo — shadow only, NO orange border */
  body[data-site="okitour"] #about-closing .module-wrapper.module-ui-image {
    border-radius: var(--site-radius);
    box-shadow: 0 8px 32px rgba(27, 42, 61, 0.10);
    max-width: 800px;
    margin-inline: auto;
    overflow: hidden;
  }

  /* Responsive — about columns collapse */
  @media (max-width: 900px) {
    body[data-site="okitour"] #about-itoman .ui-columns[data-id="about-itoman-cols"],
    body[data-site="okitour"] #about-activities .ui-columns[data-id="about-activities-cols"],
    body[data-site="okitour"] #about-story .ui-columns[data-id="about-story-cols"] {
      grid-template-columns: 1fr !important;
    }
    body[data-site="okitour"] #about-itoman .ui-map {
      min-height: 320px;
    }
    body[data-site="okitour"] #about-itoman .ui-map-container {
      min-height: 320px;
    }
    body[data-site="okitour"] #about-activities .ui-columns[data-id="about-activities-cols"] > [data-area="right"] .ui-image,
    body[data-site="okitour"] #about-story .ui-columns[data-id="about-story-cols"] > [data-area="right"] .ui-image {
      max-width: 500px;
      margin-inline: auto;
    }
    body[data-site="okitour"] .module-wrapper--about-itoman-quote,
    body[data-site="okitour"] .module-wrapper--about-activities-quote {
      max-width: 680px;
      margin-inline: auto;
    }
  }

  /* ── Section Headers (shared) ──────────────────────────────────────────── */
  body[data-site="okitour"] .section-header {
    text-align: center;
    margin-bottom: var(--site-pad-lg);
  }

  body[data-site="okitour"] .section-header h2 {
    font-family: var(--site-font-heading);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 400;
    color: var(--site-fg);
    margin-bottom: 0.5rem;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] .section-header p {
    font-size: 1.0625rem;
    color: var(--site-muted);
  }

  /* ── Related Tours ─────────────────────────────────────────────────────── */
  body[data-site="okitour"] .related-tours {
    margin-top: var(--site-pad-lg);
    padding-top: var(--site-pad-lg);
    border-top: 1px solid var(--site-border);
  }

  body[data-site="okitour"] .related-tours h3 {
    font-family: var(--site-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    margin-bottom: 1rem;
    color: var(--site-fg);
  }

  body[data-site="okitour"] .related-tours__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  body[data-site="okitour"] .related-tours__list a {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: var(--site-surface);
    color: var(--site-accent);
    border-radius: var(--site-radius-sm);
    text-decoration: none;
    font-family: var(--site-font-accent);
    font-weight: 500;
    transition: background 0.2s ease;
    border: 1px solid var(--site-border);
  }

  body[data-site="okitour"] .related-tours__list a:hover {
    background: var(--site-accent-light);
    border-color: var(--site-accent);
  }

  /* ── Pre-Footer CTA Band ───────────────────────────────────────────────── */
  body[data-site="okitour"] .okitour-footer__cta-band {
    background: var(--site-accent);
    padding: 48px var(--edge);
    text-align: center;
  }

  body[data-site="okitour"] .okitour-footer__cta-band h3 {
    font-family: var(--site-font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 400;
    color: #fff;
    margin: 0 0 20px;
    line-height: var(--site-heading-line-height);
  }

  body[data-site="okitour"] .okitour-footer__cta-band a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 32px;
    border: 2px solid #fff;
    color: #fff;
    background: transparent;
    border-radius: var(--button-radius);
    font-family: var(--site-font-accent);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: all var(--transition-fast);
  }

  body[data-site="okitour"] .okitour-footer__cta-band a:hover {
    background: #fff;
    color: var(--site-accent);
  }

  /* ── Footer Grid ───────────────────────────────────────────────────────── */
  body[data-site="okitour"] .okitour-footer__grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 48px;
    padding: 60px var(--edge) 32px;
    max-width: var(--content-max-width);
    margin: 0 auto;
  }

  body[data-site="okitour"] .okitour-footer__col-heading {
    font-family: var(--site-font-accent);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #fff;
    margin: 0 0 16px;
  }

  /* Brand column */
  body[data-site="okitour"] .okitour-footer__brand-top {
    display: flex;
    align-items: center;
    gap: 16px;
  }

  body[data-site="okitour"] .okitour-footer__logo {
    height: 40px;
    width: auto;
    filter: invert(1) hue-rotate(180deg) saturate(1.2) brightness(1.1);
  }

  body[data-site="okitour"] .okitour-footer__shisa {
    width: 48px;
    height: auto;
    opacity: 0.7;
    transition: opacity var(--transition-fast);
  }

  body[data-site="okitour"] .okitour-footer__shisa:hover {
    opacity: 1;
  }

  body[data-site="okitour"] .okitour-footer__brand-tagline {
    font-size: 0.9375rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.6;
    margin: 12px 0 20px;
  }

  body[data-site="okitour"] .okitour-footer__brand-social {
    display: flex;
    gap: 16px;
  }

  body[data-site="okitour"] .okitour-footer__brand-social a {
    color: rgba(255,255,255,0.7);
    font-family: var(--site-font-accent);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  body[data-site="okitour"] .okitour-footer__brand-social a:hover {
    color: #fff;
  }

  /* Nav column */
  body[data-site="okitour"] .okitour-footer__nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
  }

  body[data-site="okitour"] .okitour-footer__nav-list li {
    margin-bottom: 10px;
  }

  body[data-site="okitour"] .okitour-footer__nav-list a {
    color: rgba(255,255,255,0.7);
    font-size: 0.9375rem;
    text-decoration: none;
    transition: color var(--transition-fast);
  }

  body[data-site="okitour"] .okitour-footer__nav-list a:hover {
    color: #fff;
  }

  /* Contact column */
  body[data-site="okitour"] .okitour-footer__contact-info {
    font-size: 0.9375rem;
    color: rgba(255,255,255,0.7);
    line-height: 1.8;
  }

  body[data-site="okitour"] .okitour-footer__contact-info a {
    color: var(--site-accent);
  }

  body[data-site="okitour"] .okitour-footer__contact-info a:hover {
    color: #fff;
  }

  body[data-site="okitour"] .okitour-footer__contact-address {
    margin-bottom: 8px;
    line-height: 1.5;
  }

  /* Footer bottom */
  body[data-site="okitour"] .okitour-footer__bottom {
    border-top: 1px solid rgba(255,255,255,0.1);
    padding: 24px var(--edge) 32px;
    margin-top: 0;
    text-align: center;
    max-width: var(--content-max-width);
    margin-inline: auto;
  }

  body[data-site="okitour"] .okitour-footer__bottom p {
    font-size: 0.875rem;
    color: rgba(255,255,255,0.4);
    margin: 0;
  }

  @media (max-width: 768px) {
    body[data-site="okitour"] .okitour-footer__grid {
      grid-template-columns: 1fr;
      gap: 32px;
      padding: 40px var(--edge) 24px;
    }

    body[data-site="okitour"] .okitour-footer__cta-band {
      padding: 36px var(--edge);
    }
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: UTILITIES — Responsive Breakpoints
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer utilities {

  /* ── Tablet (max 1024px) ───────────────────────────────────────────────── */
  @media (max-width: 1024px) {
    body[data-site="okitour"] {
      --site-pad: 1.25rem;
      --site-pad-lg: 2rem;
      --edge: 32px;
    }

    body[data-site="okitour"] .ui-hero {
      --ui-hero-height: 50vh;
    }

    body[data-site="okitour"] .ui-hero[data-compact="true"] {
      --ui-hero-height: 30vh;
    }
  }

  /* ── Mobile (max 768px) ────────────────────────────────────────────────── */
  @media (max-width: 768px) {
    body[data-site="okitour"] {
      --site-pad: 1rem;
      --site-pad-lg: 1.5rem;
      --site-font-size: 16px;
      --edge: 24px;
    }

    body[data-site="okitour"] .ui-hero {
      --ui-hero-height: 45vh;
    }

    body[data-site="okitour"] .ui-hero[data-compact="true"] {
      --ui-hero-height: 25vh;
    }

    body[data-site="okitour"] .ui-hero[data-compact="true"] .ui-hero__content {
      padding: 2rem 1.25rem calc(2rem + 100px);
    }

    body[data-site="okitour"] .ui-navbar {
      --ui-navbar-height: 60px;
    }

    body[data-site="okitour"] .ui-contact-form__submit {
      width: 100%;
    }

    body[data-site="okitour"] .ui-pricing__table-wrap {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
    }

    body[data-site="okitour"] .section-header h2 {
      font-size: 1.5rem;
    }
  }

  /* ── Small Mobile (max 480px) ──────────────────────────────────────────── */
  @media (max-width: 480px) {
    body[data-site="okitour"] {
      --site-pad: 0.75rem;
      --site-pad-lg: 1.25rem;
      --edge: 16px;
    }

    body[data-site="okitour"] .ui-hero {
      --ui-hero-height: 40vh;
    }

  }

  /* ── Scroll-triggered reveal (CSS-only states) ─────────────────────────── */
  body[data-site="okitour"] .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body[data-site="okitour"] .revealed {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYER: OVERRIDES — Final Authority
   ═══════════════════════════════════════════════════════════════════════════════ */
@layer overrides {

  /* ── Smooth page transitions ───────────────────────────────────────────── */
  body[data-site="okitour"] [data-area="main"] {
    transition: opacity 0.3s ease, visibility 0.3s ease;
  }

  body[data-site="okitour"] [data-area="main"][data-transitioning="true"] {
    opacity: 0;
    visibility: hidden;
  }

  /* ── Scroll behavior ───────────────────────────────────────────────────── */
  html[data-site="okitour"] {
    scroll-behavior: smooth;
  }

  /* ── Links — animated underline reveal ─────────────────────────────────── */
  body[data-site="okitour"] a:not([class]) {
    color: var(--site-accent);
    text-decoration: none;
    position: relative;
    transition: color var(--transition-fast);
  }

  body[data-site="okitour"] a:not([class])::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--site-accent);
    transition: width var(--transition-default);
  }

  body[data-site="okitour"] a:not([class]):hover {
    color: var(--site-accent-hover);
  }

  body[data-site="okitour"] a:not([class]):hover::after {
    width: 100%;
  }

  /* ── Headings — premium serif ──────────────────────────────────────────── */
  body[data-site="okitour"] h1,
  body[data-site="okitour"] h2,
  body[data-site="okitour"] h3,
  body[data-site="okitour"] h4 {
    font-family: var(--site-font-heading);
    font-weight: 400;
    line-height: var(--site-heading-line-height);
    color: var(--site-fg);
  }

  /* Tour header h3 — force body font (overrides global heading serif above) */
  body[data-site="okitour"] #tour-header h3.ui-copy__item {
    font-family: var(--site-font-body);
  }

  /* ── Images ────────────────────────────────────────────────────────────── */
  body[data-site="okitour"] img {
    max-width: 100%;
    height: auto;
  }

  /* ── Social feed images ────────────────────────────────────────────────── */
  body[data-site="okitour"] .social-ig__post {
    aspect-ratio: 1 / 1;
    overflow: hidden;
  }

  body[data-site="okitour"] .social-ig__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   UNLAYERED — Section content padding & overrides
   Unlayered rules ALWAYS beat layered rules (including module @layer).
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Canvas: zero side-padding — sections/hero/dividers go edge-to-edge.
   background: sand — overrides theme=light #fff fallback in module @layer */
body[data-site="okitour"] .ui-canvas[data-module="ui.canvas"],
body[data-site="okitour"] .ui-canvas[data-mod="ui_canvas"] {
  padding-inline: 0;
  background: var(--site-bg, #F5EFE4);
}

/* Section body: no side-padding (bg bleeds edge-to-edge); __inner owns content inset */
body[data-site="okitour"] .ui-section-body {
  padding-inline: 0;
}

body[data-site="okitour"] .ui-section-body__inner {
  padding-inline: var(--edge);
}

/* ── Section spacing — generous, premium breathing room ────────────────── */
body[data-site="okitour"] #intro-section {
  padding-block: 0 0;
}

body[data-site="okitour"] #categories-section {
  padding-block: clamp(16px, 2vw, 24px) clamp(24px, 3vw, 40px);
}

body[data-site="okitour"] #facebook-section {
  padding-block: clamp(60px, 8vw, 100px) clamp(40px, 6vw, 80px);
}

/* SSR hidden posts — module CSS not available at initial render, so site CSS must handle */
body[data-site="okitour"] .social-fb__post--hidden,
body[data-site="okitour"] .social-ig__post--hidden {
  display: none;
}

body[data-site="okitour"] #facebook-section .ui-section-body__inner {
  padding-inline: 0;
}

/* ── Footer — unlayered to beat module @layer ───────────────────────────── */
body[data-site="okitour"] .ui-section-footer[data-mod="ui_section_footer"] {
  background: var(--site-fg);
  color: rgba(255,255,255,0.85);
  padding: 0;
  border-top: none;
}

body[data-site="okitour"] .okitour-footer__cta-band {
  background: var(--site-accent);
  padding: 48px var(--edge);
  text-align: center;
}

body[data-site="okitour"] .okitour-footer__cta-band h3 {
  font-family: var(--site-font-heading);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 400;
  color: #fff;
  margin: 0 0 20px;
  line-height: var(--site-heading-line-height);
}

body[data-site="okitour"] .okitour-footer__cta-band a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  border: 2px solid #fff;
  color: #fff;
  background: transparent;
  border-radius: var(--button-radius);
  font-family: var(--site-font-accent);
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
}

body[data-site="okitour"] .okitour-footer__cta-band a:hover {
  background: #fff;
  color: var(--site-accent);
}

body[data-site="okitour"] .okitour-footer__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 48px;
  padding: 60px var(--edge) 32px;
  max-width: var(--content-max-width);
  margin: 0 auto;
}

body[data-site="okitour"] .okitour-footer__col {
  text-align: left;
}

body[data-site="okitour"] .okitour-footer__col-heading {
  font-family: var(--site-font-accent);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #fff;
  margin: 0 0 16px;
}

body[data-site="okitour"] .okitour-footer__logo {
  height: 44px;
  width: auto;
  filter: invert(1) hue-rotate(180deg) saturate(1.2) brightness(1.1);
  margin-bottom: 12px;
}

body[data-site="okitour"] .okitour-footer__brand-tagline {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.5;
  margin: 0 0 16px;
  max-width: 280px;
}

body[data-site="okitour"] .okitour-footer__brand-social {
  display: flex;
  gap: 16px;
}

body[data-site="okitour"] .okitour-footer__brand-social a {
  color: var(--site-accent);
  font-family: var(--site-font-accent);
  font-size: 0.85rem;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}

body[data-site="okitour"] .okitour-footer__brand-social a:hover {
  color: #fff;
}

body[data-site="okitour"] .okitour-footer__nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

body[data-site="okitour"] .okitour-footer__nav-list li {
  margin-bottom: 8px;
}

body[data-site="okitour"] .okitour-footer__nav-list a {
  color: rgba(255,255,255,0.65);
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s ease;
}

body[data-site="okitour"] .okitour-footer__nav-list a:hover {
  color: #fff;
}

body[data-site="okitour"] .okitour-footer__contact-info {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
}

body[data-site="okitour"] .okitour-footer__contact-info p {
  margin: 0 0 6px;
}

body[data-site="okitour"] .okitour-footer__contact-info a {
  color: var(--site-accent);
  text-decoration: none;
}

body[data-site="okitour"] .okitour-footer__contact-info a:hover {
  color: #fff;
}

body[data-site="okitour"] .okitour-footer__contact-address {
  margin-bottom: 10px;
  line-height: 1.4;
}

body[data-site="okitour"] .okitour-footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 24px var(--edge) 32px;
  text-align: center;
  max-width: var(--content-max-width);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

body[data-site="okitour"] .okitour-footer__bottom .okitour-footer__shisa {
  width: 40px;
  height: auto;
  opacity: 0.55;
}

body[data-site="okitour"] .okitour-footer__bottom p {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.4);
  margin: 0;
}

@media (max-width: 768px) {
  body[data-site="okitour"] .okitour-footer__grid {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 40px var(--edge) 24px;
  }

  body[data-site="okitour"] .okitour-footer__cta-band {
    padding: 36px var(--edge);
  }
}

body[data-site="okitour"] #nabidka-intro {
  padding-block: 1rem 1rem;
}

body[data-site="okitour"] #nabidka-intro .ui-section-body__inner {
  position: relative;
  max-width: 800px;
  margin-inline: auto;
  padding-top: 2.5rem;
}

body[data-site="okitour"] #nabidka-intro .ui-section-body__inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 3px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.08);
}

body[data-site="okitour"] #nabidka-choices {
  padding-block: clamp(40px, 5vw, 80px) clamp(60px, 8vw, 120px);
}

/* ── Nabídka cards — UNLAYERED overrides ─────────────────────────────────── */
body[data-site="okitour"] #nabidka-choices .ui-service-block__image-wrap {
  margin: 0;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

body[data-site="okitour"] #nabidka-choices .ui-service-block__title {
  margin: 0;
  color: var(--site-accent);
}

body[data-site="okitour"] #nabidka-choices .ui-service-block__title a {
  color: inherit;
  text-decoration: none;
}

body[data-site="okitour"] #nabidka-choices .ui-service-block__description {
  margin: 0;
}

/* ── Hero overlays — page-specific ───────────────────────────────────────── */
body[data-site="okitour"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,18,36,0.25) 0%,
    rgba(10,18,36,0.52) 35%,
    rgba(10,18,36,0.62) 65%,
    rgba(10,18,36,0.70) 100%
  );
  opacity: 1;
}

body[data-site="okitour"] .ui-hero__bg {
  background-position: center 65%;
}

body[data-site="okitour"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: var(--ui-hero-overlay-color, rgba(10,18,36,1));
}

/* Nabídka hero overlays */
body[data-site="okitour"][data-page^="nabidka"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,18,36,0.52) 0%,
    rgba(10,18,36,0.35) 50%,
    rgba(10,18,36,0.18) 100%
  );
  opacity: 1;
}

body[data-site="okitour"][data-page^="nabidka"] .ui-hero__bg {
  background-position: center 40%;
}

body[data-site="okitour"][data-page^="nabidka/jednodenni"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,18,36,0.48) 0%,
    rgba(10,18,36,0.32) 50%,
    rgba(10,18,36,0.15) 100%
  );
  opacity: 1;
}

body[data-site="okitour"][data-page^="nabidka/jednodenni"] .ui-hero__bg {
  background-position: center 55%;
}

body[data-site="okitour"][data-page^="nabidka/special"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,18,36,0.45) 0%,
    rgba(10,18,36,0.30) 50%,
    rgba(10,18,36,0.12) 100%
  );
  opacity: 1;
}

body[data-site="okitour"][data-page^="nabidka/special"] .ui-hero__bg {
  background-position: center 40%;
}

body[data-site="okitour"][data-page^="sluzby"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,18,36,0.50) 0%,
    rgba(10,18,36,0.35) 50%,
    rgba(10,18,36,0.18) 100%
  );
  opacity: 1;
}

body[data-site="okitour"][data-page^="sluzby"] .ui-hero__bg {
  background-position: center 60%;
}

/* ── Instagram module — sand background ──────────────────────────────────── */
body[data-site="okitour"] .module-wrapper.module-social-instagram {
  background: var(--site-bg-sand);
}

body[data-site="okitour"] .social-ig__wrap {
  padding: clamp(40px, 6vw, 80px) var(--edge) clamp(32px, 5vw, 60px);
}

/* ── Header + Navbar — UNLAYERED ─────────────────────────────────────────── */
body[data-site="okitour"] .ui-layout__cell[data-area="header"] {
  background: var(--site-bg-sand);
}
body[data-site="okitour"] .ui-navbar {
  --ui-navbar-bg: rgba(245, 239, 228, 0.92);
  background: rgba(245, 239, 228, 0.92);
  backdrop-filter: blur(12px) saturate(1.4);
  -webkit-backdrop-filter: blur(12px) saturate(1.4);
}

/* ── Footer — UNLAYERED ──────────────────────────────────────────────────── */
body[data-site="okitour"] .ui-section-footer {
  --ui-sec-footer-bg: var(--site-fg);
  --ui-sec-footer-fg: rgba(255,255,255,0.7);
  background: var(--site-fg);
  color: rgba(255,255,255,0.7);
  border-top: none;
}

/* ── Hero text — premium layered typography ──────────────────────────────── */
body[data-site="okitour"] .ui-hero__title {
  color: #fff;
  font-family: var(--site-font-heading);
  font-weight: 400;
  font-style: normal;
  letter-spacing: -0.01em;
  line-height: 1.15;
  text-shadow:
    0 2px 4px rgba(0,0,0,0.6),
    0 4px 24px rgba(0,0,0,0.4);
}

body[data-site="okitour"] .ui-hero__subtitle {
  color: rgba(255,255,255,0.95);
  font-family: var(--site-font-body);
  font-weight: 400;
  letter-spacing: 0.02em;
  text-shadow:
    0 1px 3px rgba(0,0,0,0.6),
    0 3px 16px rgba(0,0,0,0.35);
}

body[data-site="okitour"] .ui-hero__trust {
  color: rgba(255,255,255,0.92);
  font-size: clamp(0.9rem, 1.8vw, 1.05rem);
  font-style: italic;
  font-weight: 300;
  letter-spacing: 0.01em;
  text-shadow:
    0 1px 3px rgba(0,0,0,0.55),
    0 2px 12px rgba(0,0,0,0.3);
}

body[data-site="okitour"] .ui-hero__usp {
  font-family: var(--site-font-accent);
  color: rgba(255,255,255,0.9);
  font-size: clamp(0.8rem, 1.5vw, 0.9rem);
  font-weight: 500;
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  text-shadow:
    0 1px 3px rgba(0,0,0,0.5),
    0 2px 10px rgba(0,0,0,0.25);
}

/* ── Itinerary — Premium Zigzag Cards (unlayered to beat @layer atoms) ── */

/* Container */
body[data-site="okitour"] .ui-itinerary__wrap {
  max-width: 960px;
  margin: 0 auto;
}

/* Section title */
body[data-site="okitour"] .ui-itinerary__title {
  font-family: var(--site-font-heading);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--site-fg);
  margin-bottom: 2.5rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid rgba(232, 101, 26, 0.15);
}

/* Kill default timeline line */
body[data-site="okitour"] .ui-itinerary__list[data-variant="timeline"] .ui-itinerary__step::after {
  display: none;
}

/* Step list */
body[data-site="okitour"] .ui-itinerary__list {
  gap: 1.75rem;
}

/* ── Each step = card ──────────────────────────────────────────────────── */
body[data-site="okitour"] .ui-itinerary__step {
  display: block;
  padding: 0;
  padding-bottom: 0;
  background: #fff;
  border-radius: var(--site-radius);
  box-shadow: 0 1px 12px rgba(0, 0, 0, 0.06);
  overflow: hidden;
  position: relative;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

@media (hover: hover) {
  body[data-site="okitour"] .ui-itinerary__step:hover {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.10);
    transform: translateY(-2px);
  }
}

/* ── Marker — large ghost number on text side ─────────────────────────── */
body[data-site="okitour"] .ui-itinerary__marker {
  position: absolute;
  top: 0.75rem;
  left: 1.25rem;
  width: auto;
  height: auto;
  background: none;
  box-shadow: none;
  border-radius: 0;
  z-index: 2;
}

body[data-site="okitour"] .ui-itinerary__number {
  background: transparent;
  color: #f0cdb8;
  font-weight: 800;
  font-size: 4rem;
  line-height: 1;
  font-family: var(--site-font-heading);
  text-shadow: 2px 3px 5px rgba(0, 0, 0, 0.10);
}

/* Even steps: marker on right side (text side) */
body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__marker {
  left: auto;
  right: 1.25rem;
}

/* Fade ghost number when text is expanded so it doesn't overlay readable text */
body[data-site="okitour"] .ui-itinerary__step:has(.is-expanded) .ui-itinerary__marker {
  opacity: 0.15;
  transition: opacity 0.3s ease;
}

/* ── Content — image-heavy 2-col (7fr image / 5fr text) ───────────────── */
body[data-site="okitour"] .ui-itinerary__content {
  display: grid;
  grid-template-columns: 5fr 7fr;
  grid-template-rows: 1fr auto;
  padding: 0;
  min-width: 0;
}

body[data-site="okitour"] .ui-itinerary__step-title {
  grid-column: 1;
  grid-row: 1;
  font-family: var(--site-font-heading);
  font-weight: 400;
  font-size: 1.2rem;
  color: var(--site-fg);
  letter-spacing: -0.01em;
  margin: 0;
  padding: 2rem 1.75rem 0.75rem 1.75rem;
  align-self: end;
  position: relative;
}

/* Accent bar under title */
body[data-site="okitour"] .ui-itinerary__step-title::after {
  content: "";
  display: block;
  width: 40px;
  height: 3px;
  background: var(--site-accent);
  border-radius: 2px;
  margin-top: 0.75rem;
  opacity: 0.6;
}

body[data-site="okitour"] .ui-itinerary__step-desc-wrap,
body[data-site="okitour"] .ui-itinerary__step-desc {
  grid-column: 1;
  grid-row: 2;
  color: var(--site-muted);
  line-height: 1.7;
  max-width: none;
  margin: 0;
  padding: 0.75rem 1.75rem 1.75rem 1.75rem;
  align-self: start;
  border-left: 3px solid rgba(232, 101, 26, 0.12);
  margin-left: 1.75rem;
  padding-left: 1rem;
  padding-right: 1.75rem;
}
/* When wrapped, inner <p> inherits text styles but not layout */
body[data-site="okitour"] .ui-itinerary__step-desc-wrap .ui-itinerary__step-desc {
  grid-column: unset;
  grid-row: unset;
  padding: 0;
  margin: 0;
  border-left: none;
  margin-left: 0;
}
body[data-site="okitour"] .ui-itinerary__read-more {
  margin-top: 0.35rem;
  font-size: 0.8125rem;
}

/* Image — right column, spans both rows, cover crop */
body[data-site="okitour"] .ui-itinerary__step-image {
  grid-column: 2;
  grid-row: 1 / -1;
  width: 100%;
  min-height: 340px;
  height: 100%;
  max-width: none;
  object-fit: cover;
  border-radius: 0;
  margin: 0;
  box-shadow: none;
  display: block;
  transition: transform 0.5s ease;
}

@media (hover: hover) {
  body[data-site="okitour"] .ui-itinerary__step:hover .ui-itinerary__step-image {
    transform: scale(1.04);
  }
}

/* ── Zigzag: even steps = image left (7fr), text right (5fr) ──────────── */
body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__content {
  grid-template-columns: 7fr 5fr;
}

body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-title {
  grid-column: 2;
}

body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-desc-wrap,
body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-desc {
  grid-column: 2;
}

body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-image {
  grid-column: 1;
  grid-row: 1 / -1;
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  body[data-site="okitour"] .ui-itinerary__content,
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__content {
    grid-template-columns: 1fr;
  }
  body[data-site="okitour"] .ui-itinerary__step-image,
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-image {
    grid-column: 1;
    grid-row: 1;
    height: 220px;
  }
  body[data-site="okitour"] .ui-itinerary__step-title,
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-title {
    grid-column: 1;
    grid-row: 2;
    padding: 1.25rem 1.25rem 0;
  }
  body[data-site="okitour"] .ui-itinerary__step-desc-wrap,
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-desc-wrap,
  body[data-site="okitour"] .ui-itinerary__step-desc,
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__step-desc {
    grid-column: 1;
    grid-row: 3;
    padding: 0.35rem 1.25rem 1.25rem;
  }
  body[data-site="okitour"] .ui-itinerary__marker {
    left: 0.75rem;
  }
  body[data-site="okitour"] .ui-itinerary__step:nth-child(even) .ui-itinerary__marker {
    left: 0.75rem;
    right: auto;
  }
}

@media (max-width: 640px) {
  body[data-site="okitour"] .ui-itinerary__title {
    font-size: 1.35rem;
    margin-bottom: 1.5rem;
  }
  body[data-site="okitour"] .ui-itinerary__step-image {
    min-height: 180px;
    max-height: 250px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   MOSAIC GALLERY — Site-level overrides for ui.media.pipeline mosaic variant
   ═══════════════════════════════════════════════════════════════════════════════ */

body[data-site="okitour"] .ui-media--mosaic {
  --ui-media-mosaic-gap: 5px;
  --ui-media-mosaic-radius: 10px;
  --ui-media-mosaic-row: 240px;
}

body[data-site="okitour"] .ui-media--mosaic__tile {
  box-shadow: 0 2px 12px rgba(60, 25, 5, 0.12);
}

body[data-site="okitour"] .ui-media--mosaic__tile figcaption {
  font-family: var(--site-font-body, 'DM Sans', sans-serif);
  font-size: 0.8rem;
  letter-spacing: 0.02em;
}

body[data-site="okitour"] .module-wrapper--tour-gallery .ui-section__body-inner {
  max-width: 1100px;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   JAPONSKO VE ŠKOLE — Premium School Program Page
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Hero — visible image with warm gradient overlay ─────────────────── */
body[data-site="okitour"][data-page="skoly"] .ui-hero[data-variant="compact"] {
  min-height: 55vh;
}

body[data-site="okitour"][data-page="skoly"] .ui-hero[data-variant="compact"] .ui-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(60, 25, 5, 0.35) 0%,
    rgba(60, 25, 5, 0.25) 40%,
    rgba(60, 25, 5, 0.55) 100%
  );
  opacity: 1;
}

body[data-site="okitour"][data-page="skoly"] .ui-hero__bg {
  background-position: center 35%;
}

body[data-site="okitour"][data-page="skoly"] .ui-hero[data-variant="compact"] .ui-hero__content {
  padding-bottom: calc(2.5rem + 160px);
}

body[data-site="okitour"][data-page="skoly"] .ui-hero__title {
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 600;
  letter-spacing: -0.02em;
}

body[data-site="okitour"][data-page="skoly"] .ui-hero__cta {
  background: var(--site-accent);
  border: 2px solid rgba(255, 255, 255, 0.25);
  border-radius: 6px;
  padding: 0.8rem 2.25rem;
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  margin-top: 1.5rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
  transition: background 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease;
}

body[data-site="okitour"][data-page="skoly"] .ui-hero__cta:hover {
  background: #d45a15;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

/* School intro section — decorative top line + spacing */
body[data-site="okitour"] #school-intro {
  padding-block: 1rem 1rem;
}
body[data-site="okitour"] #school-intro .ui-section-body__inner {
  position: relative;
  padding-top: 2.5rem;
}
body[data-site="okitour"] #school-intro .ui-section-body__inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 3px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.08);
}

/* ── Intro section — accent-border lead + image left / text right ────── */

/* Space between lead text and columns below */
body[data-site="okitour"] #school-intro .ui-section-body__inner > .module-wrapper:first-child {
  margin-bottom: 2.5rem;
}

/* Constrain + center the lead copy block */
body[data-site="okitour"] #school-intro .ui-section-body__inner > .module-wrapper:first-child .ui-copy {
  max-width: 68ch;
  text-align: left;
  margin-inline: auto;
  border-left: 3px solid var(--site-accent);
  padding-left: 1.25rem;
  padding-block: 0.25rem;
}

/* Lead statement — editorial feel, aligned with site */
body[data-site="okitour"] #school-intro .ui-section-body__inner > .module-wrapper:first-child p.ui-copy__item {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.005em;
  color: var(--site-fg-secondary);
  opacity: 0.88;
  margin-bottom: 0;
}

/* Columns: image LEFT (5fr), text RIGHT (7fr) */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] {
  display: flex;
  flex-direction: column;
  align-self: start;
}

/* Shadow on wrapper — keeps it separate from overflow clip */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] .module-wrapper {
  border-radius: var(--site-radius);
  box-shadow: 0 8px 32px rgba(60, 25, 5, 0.15);
  transition: box-shadow 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] .ui-image__img {
  display: block;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (hover: hover) {
  body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] .module-wrapper:hover {
    box-shadow: 0 16px 48px rgba(60, 25, 5, 0.28);
  }
  body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] .module-wrapper:hover .ui-image__img {
    transform: scale(1.05);
  }
}

/* Right column — premium text layout */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] {
  display: flex;
  flex-direction: column;
  gap: 0;
  justify-content: start;
  padding-left: clamp(0px, 2vw, 24px);
}

/* Description text — vertical accent on text only */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:first-child p.ui-copy__item {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--site-fg);
  border-bottom: none;
  margin-bottom: 0;
  letter-spacing: 0.005em;
}
/* Centered decorative line between content blocks */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:first-child,
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:nth-child(3) {
  padding-bottom: 1.75rem;
  margin-bottom: 1.5rem;
  position: relative;
}
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:first-child::after,
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:nth-child(3)::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 3px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.08);
}

/* Description — styled first line */
body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="right"] > .module-wrapper:first-child p.ui-copy__item::first-line {
  font-weight: 600;
  color: var(--site-fg);
}

/* Audience heading — underline accent like program section */
/* ── Global section heading style for okitour — underline accent ──────── */
body[data-site="okitour"] .ui-copy__item:is(h2, h3) {
  font-family: var(--site-font-heading, 'DM Sans', sans-serif);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--site-fg);
  margin-bottom: 1.5rem;
  padding-left: 0;
  border-left: none;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
body[data-site="okitour"] .ui-copy__item:is(h2, h3)::after {
  content: '';
  display: block;
  width: 50px;
  height: 4px;
  border-radius: 2px;
  background: var(--site-accent);
  margin: 12px auto 0;
}
/* Tour header headings already have border-bottom decoration — no bar */
body[data-site="okitour"] #tour-header .ui-copy__item:is(h2, h3)::after {
  display: none;
}

/* Inside columns/grids headings are left-aligned — bar follows */
body[data-site="okitour"] .ui-columns__cell .ui-copy__item:is(h2, h3)::after,
body[data-site="okitour"] .ui-grid__cell .ui-copy__item:is(h2, h3)::after {
  margin-left: 0;
  margin-right: auto;
}

/* ── Global list style for okitour ────────────────────────────────────── */
body[data-site="okitour"] .ui-copy__list {
  --ui-copy-list-gap: 0.1rem;
}
body[data-site="okitour"] .ui-copy__list-item {
  color: var(--site-fg);
  padding-block: 0.35em;
  margin-left: 2rem;
  border-bottom: 1px solid rgba(60, 25, 5, 0.06);
}
body[data-site="okitour"] .ui-copy__list-item::before {
  width: 7px;
  height: 7px;
  margin-top: calc(var(--ui-copy-lh, 1.65) / 2 * 1em - 3.5px);
  background: var(--site-accent);
  border: none;
  opacity: 0.45;
}
body[data-site="okitour"] .ui-copy__list-item:last-child {
  border-bottom: none;
}

/* ── Program section — expectations LEFT, images RIGHT ───────────────── */

/* Left column — text layout */
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="left"] {
  display: flex;
  flex-direction: column;
  gap: 0;
  justify-content: start;
  padding-right: clamp(0px, 2vw, 24px);
}

/* Decorative divider above closing note */
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="left"] > .module-wrapper:nth-last-child(2) {
  padding-bottom: 1.75rem;
  margin-bottom: 1.5rem;
  position: relative;
}
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="left"] > .module-wrapper:nth-last-child(2)::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 3px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.08);
}

/* Closing note — soft aside after the expectations list */
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="left"] > .module-wrapper:last-child p.ui-copy__item {
  margin-top: 1.25rem;
  padding-left: 1.25rem;
  border-left: 3px solid rgba(232, 101, 26, 0.3);
  line-height: 1.7;
  color: var(--site-fg-secondary);
}

/* Right column: stacked images */
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-self: start;
  padding-top: 0.5rem;
}

/* Shadow on wrapper — keeps it separate from overflow clip */
body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] .module-wrapper {
  border-radius: var(--site-radius);
  box-shadow: 0 8px 32px rgba(60, 25, 5, 0.15);
  transition: box-shadow 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] .ui-image__img {
  display: block;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (hover: hover) {
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] .module-wrapper:hover {
    box-shadow: 0 16px 48px rgba(60, 25, 5, 0.28);
  }
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] .module-wrapper:hover .ui-image__img {
    transform: scale(1.05);
  }
}

/* ── Info card — price/contact LEFT, practical info RIGHT ────────────── */

/* Left column: title + price + contact */
body[data-site="okitour"][data-page="skoly"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Contact paragraph — accent card style (now in left column) */
body[data-site="okitour"][data-page="skoly"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="left"] > .module-wrapper:last-child p.ui-copy__item {
  margin-top: 1.5rem;
  padding: 1.25rem 1.5rem;
  background: rgba(232, 101, 26, 0.06);
  border-left: 3px solid var(--site-accent);
  border-radius: 0 var(--site-radius) var(--site-radius) 0;
  font-weight: 500;
  color: var(--site-fg);
  line-height: 1.6;
}

/* Right column — remove inherited quote bar from wrapper */
body[data-site="okitour"][data-page="skoly"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] > .module-wrapper:first-child {
  border-left: none;
  padding-left: 0;
}

/* Right column practical list items */
body[data-site="okitour"][data-page="skoly"] #tour-header .ui-columns[data-id="tour-header-cols"] > [data-area="right"] .ui-copy__list-item {
  line-height: 1.65;
  margin-bottom: 0.55rem;
  padding-left: 1.25rem;
}

/* Email links — prominent accent */
body[data-site="okitour"] .ui-link--email {
  color: var(--site-accent);
  text-decoration: none;
  font-weight: 600;
  transition: opacity 0.2s ease;
}

body[data-site="okitour"] .ui-link--email:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* ── Gallery section — compact mosaic ─────────────────────────────────── */

body[data-site="okitour"] #school-gallery {
  padding-top: 1rem;
  padding-bottom: 2rem;
}

body[data-site="okitour"] #school-gallery h2.ui-copy__item {
  font-family: var(--site-font-heading, 'DM Sans', sans-serif);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: 1rem;
  text-align: center;
}

/* Compact mosaic for school gallery — tighter tiles */
body[data-site="okitour"] #school-gallery .ui-media--mosaic {
  --ui-media-mosaic-row: 200px;
  --ui-media-mosaic-gap: 6px;
  --ui-media-mosaic-radius: 8px;
}

/* Force 3-col on school gallery even at tablet */
@media (min-width: 600px) {
  body[data-site="okitour"] #school-gallery .ui-media--mosaic {
    grid-template-columns: repeat(3, 1fr) !important;
    grid-auto-rows: 200px !important;
    grid-template-rows: unset !important;
    grid-template-areas: unset !important;
  }
  body[data-site="okitour"] #school-gallery .ui-media--mosaic .ui-media--mosaic__tile {
    grid-column: auto !important;
    grid-row: auto !important;
    grid-area: auto !important;
  }
  /* First tile spans 2x2 for hero effect */
  body[data-site="okitour"] #school-gallery .ui-media--mosaic .ui-media--mosaic__tile[data-index="0"] {
    grid-column: span 2 !important;
    grid-row: span 2 !important;
    min-height: unset !important;
  }
}

/* ── Responsive — school page ────────────────────────────────────────── */
@media (max-width: 900px) {
  body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] {
    grid-template-columns: 1fr !important;
  }
  body[data-site="okitour"] #school-intro .ui-columns[data-id="school-intro-cols"] > [data-area="left"] .ui-image {
    max-width: 400px;
  }
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] {
    grid-template-columns: 1fr !important;
  }
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] {
    flex-direction: row;
    gap: 1rem;
  }
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] .module-wrapper {
    flex: 1;
  }
  body[data-site="okitour"][data-page="skoly"] #tour-header .ui-columns[data-id="tour-header-cols"] {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  body[data-site="okitour"][data-page="skoly"] .ui-hero[data-variant="compact"] {
    min-height: 45vh;
  }
  body[data-site="okitour"] #school-program .ui-columns[data-id="school-program-cols"] > [data-area="right"] {
    flex-direction: column;
  }
}

