/* ==========================================================================
   Wander with Fran — main stylesheet
   Naming: SUIT (PascalCase components, camelCase descendants, is-/u- prefixes)
   Theme: streaming-dark-orange · Units: clamp · Vars: fluid · Reset: preflight
   ========================================================================== */

/* ---------- Reset (tailwind-preflight style) ---------- */
*, *::before, *::after { box-sizing: border-box; border: 0 solid; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; line-height: 1.5; tab-size: 4; }
body { min-height: 100%; line-height: inherit; -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; }
a { color: inherit; text-decoration: inherit; }
img, svg, video { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; background: transparent; }
button { cursor: pointer; }
ul, ol { list-style: none; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- Fluid design tokens ---------- */
:root {
  /* palette (streaming-dark-orange) */
  --bg-primary: #141414;
  --bg-secondary: #1a1a1a;
  --bg-tertiary: #212121;
  --surface: #1d1d1d;
  --surface-2: #262626;
  --accent: #f47521;
  --accent-hover: #ff8533;
  --accent-glow: rgba(244, 117, 33, 0.30);
  --accent-soft: rgba(244, 117, 33, 0.14);
  --text-primary: #ffffff;
  --text-secondary: #d1d1d1;
  --text-muted: #9a9a9a;
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.16);

  /* type */
  --font-head: 'Sora', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;

  /* fluid spacing — modular 8px base, scaled with clamp */
  --space-1: clamp(0.5rem, 0.5rem + 0.2vw, 0.75rem);
  --space-2: clamp(0.75rem, 0.6rem + 0.6vw, 1rem);
  --space-3: clamp(1rem, 0.8rem + 1vw, 1.5rem);
  --space-4: clamp(1.5rem, 1.2rem + 1.4vw, 2rem);
  --space-5: clamp(2rem, 1.5rem + 2.4vw, 3rem);
  --space-section: clamp(3rem, 2rem + 5vw, 6rem);

  /* fluid font sizes (balanced scale) */
  --fs-h1: clamp(2rem, 1.4rem + 2.8vw, 2.6rem);
  --fs-h2: clamp(1.6rem, 1.25rem + 1.7vw, 2rem);
  --fs-h3: clamp(1.25rem, 1.1rem + 0.8vw, 1.5rem);
  --fs-h4: clamp(1.1rem, 1rem + 0.4vw, 1.25rem);
  --fs-body: clamp(1rem, 0.97rem + 0.15vw, 1.0625rem);
  --fs-small: clamp(0.8125rem, 0.8rem + 0.1vw, 0.875rem);

  /* misc */
  --radius: 12px;
  --radius-lg: 18px;
  --radius-pill: 999px;
  --container: 1140px;
  --shadow: 0 4px 20px rgba(0, 0, 0, 0.45);
  --shadow-sm: 0 4px 14px rgba(0, 0, 0, 0.30);
  --transition: 0.2s ease;
}

/* ---------- Base ---------- */
body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-primary);
  background: var(--bg-primary);
  line-height: 1.7;
  overflow-x: hidden;
}
h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.18; color: var(--text-primary); }
h1 { font-size: var(--fs-h1); font-weight: 800; }
h2 { font-size: var(--fs-h2); font-weight: 700; }
h3 { font-size: var(--fs-h3); font-weight: 600; }
h4 { font-size: var(--fs-h4); font-weight: 600; }
p { font-size: var(--fs-body); line-height: 1.75; }
strong { font-weight: 600; color: var(--text-primary); }

/* ---------- Utilities ---------- */
.u-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--space-3); }
.u-center { text-align: center; }

/* ---------- Buttons (gradient-border-btn, dark-adapted) ---------- */
.Btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: clamp(0.7rem, 0.6rem + 0.5vw, 0.9rem) clamp(1.2rem, 1rem + 0.8vw, 1.8rem);
  font-family: var(--font-head); font-weight: 600; font-size: var(--fs-small);
  letter-spacing: 0.02em; border-radius: 10px; transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);
}
.Btn:hover { transform: translateY(-2px); }
.Btn:active { transform: translateY(0); }
.Btn--primary {
  position: relative; color: var(--accent); border: 2px solid transparent;
  background-image:
    linear-gradient(var(--bg-secondary), var(--bg-secondary)),
    linear-gradient(135deg, var(--accent), var(--accent-hover));
  background-origin: border-box;
  background-clip: padding-box, border-box;
}
.Btn--primary:hover { color: var(--text-primary); box-shadow: 0 6px 20px var(--accent-glow); }
.Btn--ghost { color: var(--text-primary); border: 1px solid var(--border-strong); background: transparent; }
.Btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.Btn--block { width: 100%; }

/* ---------- Sections (modern-alternative) ---------- */
.Section { padding-block: var(--space-section); background: var(--bg-secondary); }
.Section--alt { background: var(--bg-tertiary); }
.Section-head { max-width: 720px; margin-inline: auto; margin-bottom: var(--space-5); text-align: center; }
.Section-kicker { font-family: var(--font-head); font-size: var(--fs-small); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--space-2); }
.Section-title { margin-bottom: var(--space-2); }
.Section-lead { color: var(--text-secondary); }
.section-divider { height: 1px; background: var(--border); max-width: 1100px; margin: 0 auto; }

/* ---------- Hero (asymmetric-diagonal + background-images) ---------- */
.Hero { position: relative; min-height: clamp(520px, 78vh, 760px); display: flex; align-items: center; background-size: cover; background-position: center; }
.Hero-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,10,10,0.85) 0%, rgba(10,10,10,0.55) 50%, rgba(10,10,10,0.25) 100%); }
.Hero-inner { position: relative; z-index: 1; width: 100%; }
.Hero-panel { max-width: 620px; padding: clamp(1.5rem, 1rem + 3vw, 3rem); background: linear-gradient(135deg, rgba(244,117,33,0.16), rgba(20,20,20,0.55)); border: 1px solid var(--border); border-radius: var(--radius-lg); backdrop-filter: blur(4px); clip-path: polygon(0 0, 100% 0, 96% 100%, 0 100%); }
.Hero-kicker { font-family: var(--font-head); font-size: var(--fs-small); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--space-2); }
.Hero-title { margin-bottom: var(--space-3); }
.Hero-sub { color: var(--text-secondary); font-size: clamp(1.05rem, 1rem + 0.4vw, 1.2rem); margin-bottom: var(--space-4); }
.Hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-4); }
.Hero-trust { display: flex; flex-wrap: wrap; gap: var(--space-3); padding-top: var(--space-3); border-top: 1px solid var(--border); }
.Hero-trust li { position: relative; padding-left: 1.4rem; font-size: var(--fs-small); color: var(--text-muted); }
.Hero-trust li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* ---------- Features (cards: icon-top-center) ---------- */
.Features-grid { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }
.Card {
  flex: 1 1 280px; max-width: 360px; text-align: center;
  padding: clamp(1.5rem, 1.2rem + 1vw, 2rem) var(--space-3);
  background: var(--surface); border: 1px solid var(--border); border-radius: 14px;
  box-shadow: var(--shadow-sm); transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.Card:hover { transform: translateY(-6px); border-color: var(--accent); box-shadow: 0 10px 28px rgba(0,0,0,0.5); }
.Card-icon { width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto var(--space-3); background: var(--accent-soft); color: var(--accent); }
.Card-icon svg { width: 28px; height: 28px; stroke: currentColor; stroke-width: 1.8; fill: none; }
.Card-title { margin-bottom: var(--space-2); }
.Card-text { color: var(--text-secondary); font-size: var(--fs-small); }

/* ---------- About ---------- */
.About-grid { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: center; }
.About-media { flex: 1 1 320px; }
.About-media img { width: 100%; border-radius: var(--radius-lg); border: 1px solid var(--border); object-fit: cover; aspect-ratio: 4/3; }
.About-body { flex: 1 1 360px; }
.About-stats { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-4); }
.Stat { flex: 1 1 130px; }
.Stat-num { font-family: var(--font-head); font-size: clamp(1.8rem, 1.4rem + 1.6vw, 2.4rem); font-weight: 800; color: var(--accent); }
.Stat-label { font-size: var(--fs-small); color: var(--text-muted); }

/* ---------- Prose (article / legal bodies) ---------- */
.Prose { max-width: 760px; margin-inline: auto; color: var(--text-secondary); }
.Prose > * + * { margin-top: var(--space-3); }
.Prose h2 { margin-top: var(--space-5); color: var(--text-primary); }
.Prose h3 { margin-top: var(--space-4); color: var(--text-primary); }
.Prose ul, .Prose ol { padding-left: 1.3rem; }
.Prose li { list-style: disc; margin-top: 0.4rem; }
.Prose ol li { list-style: decimal; }
.Prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.Prose strong { color: var(--text-primary); }

/* ---------- Posts ---------- */
.Posts-head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-5); }
.Posts-grid { display: flex; flex-wrap: wrap; gap: var(--space-4); }
.Post {
  display: flex; flex-direction: column; flex: 1 1 300px; max-width: 360px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: transform var(--transition), border-color var(--transition);
}
.Post:hover { transform: translateY(-5px); border-color: var(--accent); }
.Post-media { aspect-ratio: 16/10; background: var(--surface-2) center/cover no-repeat; }
.Post-body { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-3); flex: 1; }
.Post-meta { display: flex; gap: 0.75rem; font-size: var(--fs-small); color: var(--text-muted); }
.Post-cat { color: var(--accent); font-weight: 600; }
.Post-title { font-size: var(--fs-h4); }
.Post-excerpt { color: var(--text-secondary); font-size: var(--fs-small); flex: 1; }
.Post-more { color: var(--accent); font-weight: 600; font-size: var(--fs-small); }
.Post-more:hover { text-decoration: underline; }

/* ---------- Article (single post) ---------- */
.Article-hero { aspect-ratio: 21/9; background: var(--surface-2) center/cover no-repeat; border-radius: var(--radius-lg); margin-bottom: var(--space-4); }
.Article-head { max-width: 760px; margin: 0 auto var(--space-4); text-align: center; }
.Article-meta { display: flex; justify-content: center; gap: 0.75rem; font-size: var(--fs-small); color: var(--text-muted); margin-bottom: var(--space-2); }
.Article-title { margin-bottom: var(--space-2); }
.Article-back { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--accent); font-weight: 600; margin-top: var(--space-5); }
.Article-back:hover { text-decoration: underline; }
.Article-cta { max-width: 760px; margin: var(--space-5) auto 0; padding: var(--space-4); text-align: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); }

/* ---------- FAQ (gradient-accordion) ---------- */
.Faq-list { max-width: 800px; margin-inline: auto; }
.Faq-item { border: 1px solid var(--border); border-radius: 12px; margin-bottom: 0.6rem; transition: background var(--transition), border-color var(--transition); overflow: hidden; }
.Faq-item.is-open { background: linear-gradient(135deg, var(--accent-soft), transparent); border-color: var(--accent); }
.Faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 1rem; text-align: left; padding: 1.1rem 1.25rem; font-family: var(--font-head); font-weight: 600; color: var(--text-primary); }
.Faq-icon { flex-shrink: 0; transition: transform var(--transition); color: var(--accent); }
.Faq-item.is-open .Faq-icon { transform: rotate(45deg); }
.Faq-a { max-height: 0; overflow: hidden; transition: max-height var(--transition); }
.Faq-a > div { padding: 0 1.25rem 1.2rem; color: var(--text-secondary); font-size: var(--fs-small); }

/* ---------- Team ---------- */
.Team-grid { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: center; }
.Member { flex: 1 1 220px; max-width: 260px; text-align: center; }
.Member-photo { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: var(--radius-lg); border: 1px solid var(--border); margin-bottom: var(--space-2); }
.Member-name { font-family: var(--font-head); font-weight: 600; }
.Member-role { font-size: var(--fs-small); color: var(--accent); margin-bottom: 0.4rem; }
.Member-bio { font-size: var(--fs-small); color: var(--text-muted); }

/* ---------- Lead (footer-section) ---------- */
.Lead { background: var(--bg-tertiary); padding-block: var(--space-section); border-top: 1px solid var(--border); }
.Lead-inner { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: flex-start; }
.Lead-copy { flex: 1 1 320px; }
.Lead-title { margin-bottom: var(--space-2); }
.Lead-text { color: var(--text-secondary); margin-bottom: var(--space-3); }
.Lead-points { display: flex; flex-direction: column; gap: 0.5rem; }
.Lead-points li { position: relative; padding-left: 1.5rem; font-size: var(--fs-small); color: var(--text-muted); }
.Lead-points li::before { content: "\2713"; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.Lead-form { flex: 1 1 320px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); box-shadow: var(--shadow); }
.Lead-submit { margin-top: var(--space-2); width: 100%; }

/* ---------- Forms ---------- */
.Field { margin-bottom: var(--space-3); }
.Field label { display: block; font-size: var(--fs-small); font-weight: 500; color: var(--text-secondary); margin-bottom: 0.4rem; }
.Field input, .Field textarea, .Contact-form textarea {
  width: 100%; padding: 0.8rem 1rem; background: var(--bg-primary);
  border: 1px solid var(--border-strong); border-radius: 10px; color: var(--text-primary);
  transition: border-color var(--transition);
}
.Field input:focus, .Field textarea:focus { border-color: var(--accent); outline: none; }
.Field-check { display: flex; gap: 0.6rem; align-items: flex-start; font-size: var(--fs-small); color: var(--text-muted); margin-bottom: var(--space-3); }
.Field-check input { width: 18px; height: 18px; margin-top: 0.15rem; accent-color: var(--accent); flex-shrink: 0; }
.Field-check a { color: var(--accent); text-decoration: underline; }
.Form-note { margin-top: var(--space-2); font-size: var(--fs-small); padding: 0.6rem 0.9rem; border-radius: 8px; }
.Form-note.is-error { background: rgba(220,80,60,0.14); color: #ffb4a6; }
.Form-note.is-ok { background: var(--accent-soft); color: var(--accent-hover); }

/* ---------- Disclaimer note (subtle, minimal) ---------- */
.DisclaimerNote { font-size: var(--fs-small); color: var(--text-muted); text-align: center; padding-block: var(--space-3); }
.DisclaimerNote a { color: var(--text-secondary); text-decoration: underline; }

/* ---------- Contact ---------- */
.Contact-grid { display: flex; flex-wrap: wrap; gap: var(--space-5); }
.Contact-info { flex: 1 1 280px; }
.Contact-item { display: flex; gap: 0.75rem; align-items: flex-start; margin-bottom: var(--space-3); }
.Contact-item svg { width: 22px; height: 22px; color: var(--accent); flex-shrink: 0; stroke: currentColor; fill: none; stroke-width: 1.8; }
.Contact-item a { color: var(--text-secondary); }
.Contact-item a:hover { color: var(--accent); }
.Contact-form { flex: 1 1 360px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); }

/* ---------- Legal pages ---------- */
.Legal { padding-block: var(--space-section); }
.Legal-head { max-width: 760px; margin: 0 auto var(--space-4); }
.Legal-title { margin-bottom: var(--space-2); }
.Legal-updated { font-size: var(--fs-small); color: var(--text-muted); }

/* ---------- Footer (single-row-compact) ---------- */
.Footer { background: var(--bg-secondary); border-top: 1px solid var(--border); }
.Footer-top { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: space-between; padding-block: var(--space-5); }
.Footer-brand { flex: 1 1 200px; }
.Footer-tag { font-size: var(--fs-small); color: var(--text-muted); margin-top: var(--space-2); }
.Footer-links { flex: 2 1 360px; display: flex; flex-wrap: wrap; gap: 0.6rem 1.2rem; align-content: flex-start; }
.Footer-links a { font-size: var(--fs-small); color: var(--text-secondary); transition: color var(--transition); }
.Footer-links a:hover { color: var(--accent); }
.Footer-company { flex: 1 1 240px; font-style: normal; font-size: var(--fs-small); color: var(--text-muted); line-height: 1.9; }
.Footer-company a { color: var(--text-secondary); }
.Footer-company a:hover { color: var(--accent); }
.Footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 0.75rem; padding-block: var(--space-3); border-top: 1px solid var(--border); font-size: var(--fs-small); color: var(--text-muted); }
.Footer-mini a { color: var(--text-secondary); text-decoration: underline; }

/* ---------- Bottom nav (mobile_behavior: bottom-nav) ---------- */
.BottomNav { display: none; }
.BottomNav-item svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linejoin: round; stroke-linecap: round; }

/* ---------- Slide-in CTA panel ---------- */
.Panel { position: fixed; inset: 0; z-index: 1200; }
.Panel[hidden] { display: none; }
.Panel-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.6); opacity: 0; transition: opacity var(--transition); }
.Panel-card {
  position: absolute; top: 0; right: 0; width: min(420px, 92vw); height: 100%;
  background: var(--bg-secondary); border-left: 1px solid var(--border);
  padding: clamp(1.5rem, 1rem + 3vw, 2.5rem); overflow-y: auto;
  transform: translateX(100%); transition: transform 0.3s ease;
}
.Panel.is-open .Panel-overlay { opacity: 1; }
.Panel.is-open .Panel-card { transform: translateX(0); }
.Panel-close { position: absolute; top: 1rem; right: 1.1rem; font-size: 1.8rem; line-height: 1; color: var(--text-muted); }
.Panel-close:hover { color: var(--accent); }
.Panel-title { margin-bottom: var(--space-2); }
.Panel-text { color: var(--text-secondary); font-size: var(--fs-small); margin-bottom: var(--space-3); }

/* ==========================================================================
   Header / Nav — tab-navigation desktop styling
   (functional show/hide + slide-right panel handled by module CSS below)
   ========================================================================== */
.Header { position: sticky; top: 0; z-index: 1000; background: rgba(20,20,20,0.92); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border); }
.Header-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding-block: 0.85rem; }
.Header-logoImg { width: auto; height: 34px; }
.Nav-list { display: flex; align-items: center; gap: 0.25rem; }
.Nav-link { position: relative; display: inline-block; padding: 0.5rem 0.9rem; font-family: var(--font-head); font-weight: 500; font-size: var(--fs-small); letter-spacing: 0.02em; color: var(--text-secondary); transition: color var(--transition); }
.Nav-link::after { content: ""; position: absolute; left: 0.9rem; right: 0.9rem; bottom: 0.2rem; height: 2px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform var(--transition); }
.Nav-link:hover { color: var(--text-primary); }
.Nav-link:hover::after, .Nav-link.is-active::after { transform: scaleX(1); }
.Nav-link.is-active { color: var(--text-primary); }
.Nav-item--cta { margin-left: 0.5rem; }
.Nav-cta { font-size: var(--fs-small); }

/* ==========================================================================
   Mobile menu module — slide-right (functional, do not edit)
   Palette overridden to match site below.
   ========================================================================== */
[data-mm-header]{--mm-bg:#ffffff;--mm-text:#333333;--mm-primary:#2563eb;--mm-overlay-bg:rgba(0,0,0,0.5);--mm-transition:0.3s ease}[data-mm-header]{position:relative}[data-mm-toggle]{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}[data-mm-toggle] span{display:block;width:24px;height:2px;background:var(--mm-text);transition:var(--mm-transition)}[data-mm-menu]{position:fixed;top:0;right:0;width:280px;max-width:85vw;height:100vh;height:100dvh;background:var(--mm-bg);transform:translateX(100%);transition:transform var(--mm-transition);z-index:1100;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;padding:60px 24px 24px}[data-mm-menu].mm-open{transform:translateX(0)}[data-mm-menu] ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}[data-mm-menu] ul li a{display:block;padding:14px 0;color:var(--mm-text);text-decoration:none;font-size:16px;border-bottom:1px solid rgba(255,255,255,0.08);transition:color var(--mm-transition)}[data-mm-menu] ul li a:hover{color:var(--mm-primary)}[data-mm-close]{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--mm-text);padding:4px 8px}[data-mm-overlay]{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--mm-overlay-bg);opacity:0;visibility:hidden;transition:opacity var(--mm-transition),visibility var(--mm-transition);z-index:1050}[data-mm-overlay].mm-visible{opacity:1;visibility:visible}@media(min-width:768px){[data-mm-toggle]{display:none!important}[data-mm-menu]{position:static!important;width:auto!important;max-width:none!important;height:auto!important;background:transparent!important;transform:none!important;padding:0!important;overflow:visible!important;flex-direction:row!important}[data-mm-menu] ul{flex-direction:row;gap:0;align-items:center}[data-mm-menu] ul li a{padding:8px 16px;border-bottom:none;font-size:inherit}[data-mm-close]{display:none!important}[data-mm-overlay]{display:none!important}}@media(prefers-reduced-motion:reduce){[data-mm-menu],[data-mm-overlay],[data-mm-toggle] span{transition:none!important}}

/* Override mobile-menu palette to match site theme */
[data-mm-header]{
  --mm-bg: #181818;
  --mm-text: #d1d1d1;
  --mm-primary: #f47521;
  --mm-overlay-bg: rgba(0,0,0,0.7);
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 767px) {
  .Hero-panel { clip-path: none; max-width: 100%; }
  .Hero-overlay { background: linear-gradient(180deg, rgba(10,10,10,0.55), rgba(10,10,10,0.85)); }
  .Posts-head { flex-direction: column; align-items: flex-start; }
  .Footer-bottom { flex-direction: column; align-items: flex-start; }
  /* bottom-nav */
  body { padding-bottom: 64px; }
  .BottomNav {
    display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000;
    background: rgba(20,20,20,0.96); backdrop-filter: blur(8px); border-top: 1px solid var(--border);
  }
  .BottomNav-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 0.5rem 0; font-size: 0.7rem; color: var(--text-muted); transition: color var(--transition); }
  .BottomNav-item.is-active, .BottomNav-item:hover { color: var(--accent); }
}
