/* ═══════════════════════════════════════════════════════════════
   CMS TEMPLATE — styles.css
   Theming via CSS custom properties on body[data-theme][data-dark]
   ════════════════════════════════════════════════════════════════ */

/* ── Google Fonts ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700;800&family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ── Base Tokens ──────────────────────────────────────────────── */
:root {
  --font:         'Barlow', sans-serif;
  --font-display: 'Barlow Condensed', sans-serif;
  --radius:       10px;
  --radius-sm:    6px;
  --radius-lg:    16px;
  --max-w:        1200px;
  --header-h:     68px;
  --dur:          200ms;
  --ease:         cubic-bezier(0.16,1,0.3,1);
  --shadow-sm:    0 1px 4px rgba(0,0,0,0.08);
  --shadow-md:    0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg:    0 8px 32px rgba(0,0,0,0.14);
}

/* ── Color Themes ─────────────────────────────────────────────── */
body { --clr-primary:#283582; --clr-primary-dk:#162060; --clr-primary-lt:#eef1fc; --clr-accent:#FFDD07; --clr-accent-text:#162060; }
body[data-theme="forest"]   { --clr-primary:#1a6b45; --clr-primary-dk:#0f3a24; --clr-primary-lt:#e6f4ed; --clr-accent:#4ade80; --clr-accent-text:#0f3a24; }
body[data-theme="slate"]    { --clr-primary:#334155; --clr-primary-dk:#1e293b; --clr-primary-lt:#f1f5f9; --clr-accent:#f59e0b; --clr-accent-text:#1c2740; }
body[data-theme="burgundy"] { --clr-primary:#831843; --clr-primary-dk:#4a0726; --clr-primary-lt:#fdf2f8; --clr-accent:#fbbf24; --clr-accent-text:#451a03; }
body[data-theme="teal"]     { --clr-primary:#0f766e; --clr-primary-dk:#134e4a; --clr-primary-lt:#f0fdfb; --clr-accent:#f97316; --clr-accent-text:#431407; }
body[data-theme="indigo"]   { --clr-primary:#4338ca; --clr-primary-dk:#312e81; --clr-primary-lt:#eef2ff; --clr-accent:#fbbf24; --clr-accent-text:#1e1b4b; }

/* ── Light Mode (default) ─────────────────────────────────────── */
body { --clr-bg:#ffffff; --clr-bg-subtle:#f7f8fb; --clr-bg-card:#ffffff; --clr-fg:#1c1f2e; --clr-fg-muted:#5c6180; --clr-fg-subtle:#9da4bc; --clr-border:#e2e5ef; --clr-border-strong:#c4c8d8; }

/* ── Dark Mode ────────────────────────────────────────────────── */
body[data-dark="true"] {
  --clr-bg:#0f1117; --clr-bg-subtle:#1a1d2e; --clr-bg-card:#252836;
  --clr-fg:#e8eaf6; --clr-fg-muted:#8892b0; --clr-fg-subtle:#5c6180;
  --clr-border:#2e3245; --clr-border-strong:#454a62;
  --shadow-sm: 0 1px 4px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.35);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.45);
}

/* ── Reset & Base ─────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--clr-bg); color:var(--clr-fg); -webkit-font-smoothing:antialiased; transition:background var(--dur), color var(--dur); }
img { max-width:100%; display:block; }
a { color:var(--clr-primary); text-decoration:none; }
a:hover { text-decoration:underline; }
address { font-style:normal; }
::-webkit-scrollbar { width:6px; } ::-webkit-scrollbar-track { background:var(--clr-bg-subtle); } ::-webkit-scrollbar-thumb { background:var(--clr-border-strong); border-radius:3px; }

/* ── Layout ───────────────────────────────────────────────────── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 32px; }
.container--narrow { max-width:780px; }
.section { padding:64px 0; }
.section--white   { background:var(--clr-bg); }
.section--subtle  { background:var(--clr-bg-subtle); }
.section--primary { background:var(--clr-primary); }
.section--dark    { background:#0f1117; }
.section--accent  { background:var(--clr-accent); }
.page-wrap { min-height:70vh; }

/* ── Topbar ───────────────────────────────────────────────────── */
.topbar { background:var(--clr-primary-dk); padding:5px 0; }
.topbar-inner { max-width:var(--max-w); margin:0 auto; padding:0 32px; display:flex; align-items:center; justify-content:space-between; }
.topbar-tagline { font-size:12px; color:rgba(255,255,255,0.5); }
.topbar-actions { display:flex; gap:16px; }
.topbar-link { font-size:12px; color:rgba(255,255,255,0.7); background:none; border:none; cursor:pointer; font-family:var(--font); text-decoration:none; transition:color var(--dur); }
.topbar-link:hover { color:#fff; text-decoration:none; }

/* ── Header ───────────────────────────────────────────────────── */
.site-header { position:sticky; top:0; z-index:200; background:var(--clr-bg); border-bottom:1px solid var(--clr-border); transition:box-shadow var(--dur), background var(--dur); }
.site-header.scrolled { box-shadow:var(--shadow-md); }
.header-inner { max-width:var(--max-w); margin:0 auto; padding:0 32px; height:var(--header-h); display:flex; align-items:center; gap:16px; }
.logo { cursor:pointer; flex-shrink:0; }
.logo-img { height:42px; }
.logo-placeholder { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--clr-primary); letter-spacing:-0.02em; }
.main-nav { display:flex; align-items:center; gap:2px; flex:1; }
.nav-link { background:none; border:none; cursor:pointer; font-family:var(--font); font-size:14px; font-weight:500; color:var(--clr-fg-muted); padding:8px 13px; border-radius:var(--radius-sm); transition:all var(--dur); white-space:nowrap; }
.nav-link:hover { color:var(--clr-fg); background:var(--clr-bg-subtle); }
.nav-link.active { color:var(--clr-primary); background:var(--clr-primary-lt); font-weight:700; }
.header-phone { display:flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:var(--clr-primary); white-space:nowrap; text-decoration:none; margin-left:auto; }
.header-phone:hover { text-decoration:underline; }
.burger { display:none; flex-direction:column; gap:4px; background:none; border:none; cursor:pointer; padding:6px; }
.burger span { width:22px; height:2px; background:var(--clr-fg); border-radius:2px; display:block; }

/* ── Footer ───────────────────────────────────────────────────── */
.site-footer { background:var(--clr-primary-dk); color:rgba(255,255,255,0.65); }
.footer-upper { max-width:var(--max-w); margin:0 auto; padding:56px 32px 40px; display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px; }
.footer-logo { height:36px; margin-bottom:14px; }
.footer-logo-placeholder { font-family:var(--font-display); font-size:20px; font-weight:700; color:#fff; margin-bottom:14px; }
.footer-tagline { font-size:13px; line-height:1.65; color:rgba(255,255,255,0.5); max-width:280px; margin-bottom:16px; }
.footer-address { font-size:13px; color:rgba(255,255,255,0.45); line-height:1.7; margin-bottom:4px; }
.footer-contact-line { font-size:13px; color:rgba(255,255,255,0.45); margin-top:4px; }
.footer-col-head { font-size:11px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--clr-accent); margin-bottom:14px; }
.footer-col-links { display:flex; flex-direction:column; gap:9px; }
.footer-link { background:none; border:none; text-align:left; cursor:pointer; font-family:var(--font); font-size:13px; color:rgba(255,255,255,0.55); padding:0; transition:color var(--dur); }
.footer-link:hover { color:#fff; }
.footer-lower { max-width:var(--max-w); margin:0 auto; padding:18px 32px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; border-top:1px solid rgba(255,255,255,0.08); font-size:12px; color:rgba(255,255,255,0.3); }
.footer-legal { display:flex; gap:18px; }
.footer-legal-link { font-size:12px; color:rgba(255,255,255,0.38); text-decoration:none; }
.footer-legal-link:hover { color:rgba(255,255,255,0.7); text-decoration:underline; }

/* ── Hero ─────────────────────────────────────────────────────── */
.hero { position:relative; min-height:520px; display:flex; align-items:center; overflow:hidden; background-color:var(--clr-primary); background-size:cover; background-position:center; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(90deg,rgba(0,0,0,0.72) 0%,rgba(0,0,0,0.38) 70%,rgba(0,0,0,0.1) 100%); }
.hero-inner { position:relative; max-width:var(--max-w); margin:0 auto; padding:80px 32px; width:100%; }
.hero-content { max-width:620px; }
.hero-eyebrow { display:inline-block; font-size:11px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--clr-accent); border:1px solid rgba(255,255,255,0.2); border-radius:var(--radius-sm); padding:5px 12px; margin-bottom:18px; background:rgba(255,255,255,0.06); }
.hero-title { font-family:var(--font-display); font-size:clamp(38px,5vw,68px); font-weight:700; line-height:1.06; letter-spacing:-0.02em; color:#fff; margin-bottom:18px; white-space:pre-line; }
.hero-sub { font-size:17px; line-height:1.65; color:rgba(255,255,255,0.78); margin-bottom:32px; max-width:500px; }
.hero-btns { display:flex; gap:12px; flex-wrap:wrap; }

/* ── Section Heading ──────────────────────────────────────────── */
.section-heading { margin-bottom:36px; display:flex; flex-direction:column; gap:8px; }
.section-heading--center { align-items:center; text-align:center; }
.section-overline { font-size:11px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--clr-fg-subtle); }
.section--primary .section-overline,
.section--dark .section-overline { color:rgba(255,255,255,0.5); }
.section--accent .section-overline { color:var(--clr-accent-text); opacity:0.6; }
.section-title { font-family:var(--font-display); font-size:clamp(26px,3vw,40px); font-weight:700; color:var(--clr-fg); letter-spacing:-0.02em; line-height:1.1; }
.section--primary .section-title,
.section--dark .section-title { color:#fff; }
.section--accent .section-title { color:var(--clr-accent-text); }
.section-sub { font-size:16px; color:var(--clr-fg-muted); line-height:1.65; max-width:600px; }
.section--primary .section-sub { color:rgba(255,255,255,0.7); }

/* ── Buttons ──────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; font-family:var(--font); font-size:14px; font-weight:600; border:none; border-radius:var(--radius); cursor:pointer; transition:all var(--dur) var(--ease); white-space:nowrap; text-decoration:none; }
.btn--full { width:100%; }
.btn--primary { background:var(--clr-primary); color:#fff; padding:11px 24px; }
.btn--primary:hover { background:var(--clr-primary-dk); transform:translateY(-1px); }
.btn--outline { background:transparent; color:var(--clr-primary); border:1.5px solid var(--clr-primary); padding:10px 22px; }
.btn--outline:hover { background:var(--clr-primary-lt); }
.btn--ghost { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.35); padding:10px 22px; }
.btn--ghost:hover { background:rgba(255,255,255,0.12); }
.btn--accent { background:var(--clr-accent); color:var(--clr-accent-text); padding:11px 24px; }
.btn--accent:hover { opacity:0.9; transform:translateY(-1px); }
.btn--white { background:#fff; color:var(--clr-primary); padding:11px 24px; }
.btn--white:hover { background:var(--clr-primary-lt); }

/* ── Badge ────────────────────────────────────────────────────── */
.badge { display:inline-block; font-size:11px; font-weight:700; padding:3px 10px; border-radius:999px; letter-spacing:0.04em; background:var(--clr-primary-lt); color:var(--clr-primary); }

/* ── Post Card ────────────────────────────────────────────────── */
.posts-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.posts-grid--wide { grid-template-columns:repeat(3,1fr); }
.post-card { background:var(--clr-bg-card); border-radius:var(--radius); border:1px solid var(--clr-border); overflow:hidden; cursor:pointer; transition:all var(--dur) var(--ease); display:flex; flex-direction:column; }
.post-card--featured { grid-column:1/-1; flex-direction:row; min-height:280px; }
.post-card--hovered { box-shadow:var(--shadow-lg); transform:translateY(-3px); border-color:var(--clr-border-strong); }
.post-card-img-wrap { position:relative; overflow:hidden; flex-shrink:0; }
.post-card:not(.post-card--featured) .post-card-img-wrap { height:180px; }
.post-card--featured .post-card-img-wrap { width:420px; }
.post-card-img { width:100%; height:100%; object-fit:cover; transition:transform 400ms var(--ease); }
.post-card--hovered .post-card-img { transform:scale(1.04); }
.post-card-tag { position:absolute; top:12px; left:12px; font-size:10px; font-weight:700; padding:3px 9px; border-radius:4px; background:var(--clr-primary); color:#fff; letter-spacing:0.04em; }
.post-card-tag--inline { font-size:10px; font-weight:700; padding:2px 8px; border-radius:4px; background:var(--clr-primary-lt); color:var(--clr-primary); }
.post-card-body { padding:20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.post-card-meta { display:flex; align-items:center; gap:8px; }
.post-card-date { font-size:12px; color:var(--clr-fg-subtle); }
.post-card-title { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--clr-fg); line-height:1.25; }
.post-card--featured .post-card-title { font-size:28px; }
.post-card-excerpt { font-size:14px; color:var(--clr-fg-muted); line-height:1.65; flex:1; }
.post-card-cta { font-size:13px; font-weight:700; color:var(--clr-primary); margin-top:4px; }

/* ── Video Cards ──────────────────────────────────────────────── */
.videos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.video-card { background:#1a1d2e; border-radius:var(--radius); overflow:hidden; cursor:pointer; border:1px solid rgba(255,255,255,0.07); transition:transform var(--dur); }
.video-card:hover { transform:translateY(-2px); }
.video-card-thumb { position:relative; height:170px; overflow:hidden; }
.video-card-img { width:100%; height:100%; object-fit:cover; transition:opacity var(--dur); }
.video-card-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.video-play-btn { width:50px; height:50px; border-radius:50%; background:var(--clr-accent); display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--clr-accent-text); padding-left:3px; box-shadow:0 4px 16px rgba(0,0,0,0.3); }
.video-playing { font-size:13px; font-weight:700; color:var(--clr-accent); }
.video-duration { position:absolute; bottom:8px; right:8px; background:rgba(0,0,0,0.75); color:#fff; font-size:11px; font-weight:700; padding:2px 7px; border-radius:4px; }
.video-card-body { padding:14px 16px; }
.video-tag { font-size:10px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--clr-accent); display:block; margin-bottom:6px; }
.video-title { font-family:var(--font-display); font-size:16px; font-weight:700; color:#fff; line-height:1.3; margin-bottom:4px; }
.video-sub { font-size:12px; color:rgba(255,255,255,0.45); }

/* ── Services ─────────────────────────────────────────────────── */
.services-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:24px; }
.service-strip-item { padding:24px; border-radius:var(--radius); background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.service-strip-icon { font-size:28px; margin-bottom:10px; }
.service-strip-title { font-family:var(--font-display); font-size:18px; font-weight:700; color:#fff; margin-bottom:6px; }
.service-strip-desc { font-size:13px; color:rgba(255,255,255,0.65); line-height:1.6; }
.services-strip-cta { text-align:center; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:40px; }
.service-card { background:var(--clr-bg-card); border-radius:var(--radius); border:1px solid var(--clr-border); padding:28px; box-shadow:var(--shadow-sm); transition:all var(--dur); }
.service-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); border-color:var(--clr-border-strong); }
.service-card-icon { font-size:32px; margin-bottom:14px; }
.service-card-title { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--clr-fg); margin-bottom:8px; }
.service-card-desc { font-size:14px; color:var(--clr-fg-muted); line-height:1.65; margin-bottom:14px; }
.service-card-link { background:none; border:none; font-family:var(--font); font-size:13px; font-weight:700; color:var(--clr-primary); cursor:pointer; padding:0; }
.services-cta-box { background:var(--clr-primary-lt); border:1px solid var(--clr-border); border-radius:var(--radius-lg); padding:32px 40px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.services-cta-box h3 { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--clr-fg); margin-bottom:4px; }
.services-cta-box p { font-size:14px; color:var(--clr-fg-muted); }

/* ── Events List ──────────────────────────────────────────────── */
.events-list { display:flex; flex-direction:column; gap:12px; }
.event-row { display:flex; gap:20px; align-items:flex-start; background:var(--clr-bg-card); border-radius:var(--radius); border:1px solid var(--clr-border); padding:18px 20px; }
.event-row-date { display:flex; flex-direction:column; align-items:center; min-width:48px; background:var(--clr-primary-lt); border-radius:var(--radius-sm); padding:8px 4px; flex-shrink:0; }
.event-row-day { font-family:var(--font-display); font-size:26px; font-weight:800; color:var(--clr-primary); line-height:1; }
.event-row-month { font-size:11px; font-weight:700; text-transform:uppercase; color:var(--clr-fg-subtle); letter-spacing:0.06em; margin-top:2px; }
.event-row-body { flex:1; }
.event-row-title { font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--clr-fg); margin:4px 0; }
.event-row-meta { font-size:12px; color:var(--clr-fg-subtle); }
.event-tag { display:inline-block; font-size:10px; font-weight:700; padding:2px 8px; border-radius:4px; letter-spacing:0.04em; background:var(--clr-primary-lt); color:var(--clr-primary); }
.event-tag--webinar   { background:#dbeafe; color:#1d4ed8; }
.event-tag--workshop  { background:#fef3c7; color:#b45309; }
.event-tag--messe     { background:#fdf4ff; color:#7e22ce; }
.event-tag--versammlung{ background:#f0fdf4; color:#15803d; }
.event-tag--schulung  { background:#fff7ed; color:#c2410c; }

/* ── Calendar ─────────────────────────────────────────────────── */
.calendar-wrap { display:grid; grid-template-columns:1fr 340px; gap:28px; align-items:start; }
.calendar { background:var(--clr-bg-card); border-radius:var(--radius-lg); border:1px solid var(--clr-border); padding:24px; box-shadow:var(--shadow-sm); }
.cal-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cal-month { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--clr-fg); }
.cal-nav { background:none; border:1px solid var(--clr-border); border-radius:var(--radius-sm); width:32px; height:32px; cursor:pointer; font-size:16px; color:var(--clr-fg-muted); display:flex; align-items:center; justify-content:center; transition:all var(--dur); }
.cal-nav:hover { background:var(--clr-bg-subtle); color:var(--clr-fg); }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; }
.cal-dow { font-size:11px; font-weight:700; color:var(--clr-fg-subtle); text-align:center; padding:6px 0; text-transform:uppercase; letter-spacing:0.04em; }
.cal-cell { border-radius:var(--radius-sm); padding:6px 4px 4px; min-height:52px; cursor:pointer; display:flex; flex-direction:column; align-items:center; gap:3px; transition:background var(--dur); border:1px solid transparent; }
.cal-cell:not(.cal-cell--empty):hover { background:var(--clr-bg-subtle); }
.cal-cell--empty { cursor:default; }
.cal-cell--today .cal-day-num { background:var(--clr-primary); color:#fff; border-radius:50%; width:26px; height:26px; display:flex; align-items:center; justify-content:center; }
.cal-cell--selected { background:var(--clr-primary-lt) !important; border-color:var(--clr-primary); }
.cal-cell--has-events .cal-day-num { font-weight:700; color:var(--clr-primary); }
.cal-day-num { font-size:13px; font-weight:500; color:var(--clr-fg); width:26px; height:26px; display:flex; align-items:center; justify-content:center; }
.cal-dot-row { display:flex; gap:2px; }
.cal-dot { width:5px; height:5px; border-radius:50%; background:var(--clr-accent); border:1px solid var(--clr-primary); }
.cal-sidebar { background:var(--clr-bg-card); border-radius:var(--radius-lg); border:1px solid var(--clr-border); padding:20px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:12px; }
.cal-sidebar-head { font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--clr-fg); padding-bottom:10px; border-bottom:1px solid var(--clr-border); margin-bottom:4px; }
.cal-event-item { padding:12px; border-radius:var(--radius-sm); background:var(--clr-bg-subtle); cursor:pointer; transition:background var(--dur); border:1px solid var(--clr-border); }
.cal-event-item:hover { background:var(--clr-primary-lt); border-color:var(--clr-primary); }
.cal-event-title { font-size:14px; font-weight:600; color:var(--clr-fg); margin:5px 0 3px; line-height:1.3; }
.cal-event-time, .cal-event-loc { font-size:12px; color:var(--clr-fg-subtle); }
.cal-no-events { color:var(--clr-fg-subtle); font-size:14px; text-align:center; padding:20px 0; }

/* ── Page Header ──────────────────────────────────────────────── */
.page-header { background:var(--clr-primary); padding:40px 0; }
.page-header-title { font-family:var(--font-display); font-size:clamp(28px,4vw,48px); font-weight:700; color:#fff; letter-spacing:-0.02em; margin:12px 0 8px; }
.page-header-sub { font-size:16px; color:rgba(255,255,255,0.7); max-width:560px; }
.breadcrumb { font-size:13px; color:rgba(255,255,255,0.5); }
.breadcrumb span { cursor:pointer; }
.breadcrumb span:hover { color:#fff; text-decoration:underline; }
.breadcrumb span:not(:last-child)::after { content:' › '; }

/* ── Filter Bar ───────────────────────────────────────────────── */
.filter-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.filter-btn { background:var(--clr-bg-card); border:1.5px solid var(--clr-border); border-radius:999px; padding:7px 18px; font-family:var(--font); font-size:13px; font-weight:500; color:var(--clr-fg-muted); cursor:pointer; transition:all var(--dur); }
.filter-btn:hover { border-color:var(--clr-primary); color:var(--clr-primary); }
.filter-btn.active { background:var(--clr-primary); border-color:var(--clr-primary); color:#fff; font-weight:700; }

/* ── Post Detail ──────────────────────────────────────────────── */
.post-meta-row { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.post-date { font-size:13px; color:var(--clr-fg-subtle); }
.post-detail-title { font-family:var(--font-display); font-size:clamp(26px,4vw,44px); font-weight:700; color:var(--clr-fg); line-height:1.1; letter-spacing:-0.02em; margin-bottom:24px; }
.post-detail-img { width:100%; height:360px; object-fit:cover; border-radius:var(--radius); margin-bottom:28px; }
.post-detail-body { display:flex; flex-direction:column; gap:18px; }
.post-detail-body p { font-size:16px; line-height:1.75; color:var(--clr-fg-muted); }
.post-detail-footer { margin-top:40px; padding-top:24px; border-top:1px solid var(--clr-border); }

/* ── Contact ──────────────────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:40px; }
.contact-info-title { font-family:var(--font-display); font-size:24px; font-weight:700; color:var(--clr-fg); margin-bottom:24px; }
.contact-info-block { margin-bottom:18px; }
.contact-info-label { font-size:11px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--clr-fg-subtle); margin-bottom:4px; }
.contact-info-val { font-size:15px; color:var(--clr-fg); line-height:1.5; }
.contact-info-link { color:var(--clr-primary); text-decoration:none; }
.contact-info-link:hover { text-decoration:underline; }
.map-placeholder { background:var(--clr-bg-subtle); border:1px solid var(--clr-border); border-radius:var(--radius); height:200px; display:flex; align-items:center; justify-content:center; margin-top:24px; }
.map-placeholder-inner { font-size:14px; color:var(--clr-fg-subtle); text-align:center; }
.contact-form-title { font-family:var(--font-display); font-size:24px; font-weight:700; color:var(--clr-fg); margin-bottom:20px; }
.form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.form-label { font-size:13px; font-weight:600; color:var(--clr-fg); }
.form-req { color:#ef4444; margin-left:3px; }
.form-input { font-family:var(--font); font-size:14px; color:var(--clr-fg); background:var(--clr-bg-card); border:1.5px solid var(--clr-border-strong); border-radius:var(--radius-sm); padding:10px 14px; width:100%; outline:none; transition:border-color var(--dur), box-shadow var(--dur); }
.form-input:focus { border-color:var(--clr-primary); box-shadow:0 0 0 3px rgba(var(--clr-primary),0.1); }
.form-input--error { border-color:#ef4444; }
.form-error { font-size:12px; color:#ef4444; }
.form-textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-privacy { font-size:12px; color:var(--clr-fg-subtle); margin-bottom:14px; }
.form-privacy a { color:var(--clr-primary); }
.form-success { text-align:center; padding:48px 24px; display:flex; flex-direction:column; align-items:center; gap:14px; }
.form-success-icon { width:56px; height:56px; border-radius:50%; background:var(--clr-primary-lt); color:var(--clr-primary); font-size:24px; font-weight:700; display:flex; align-items:center; justify-content:center; }
.form-success h3 { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--clr-fg); }
.form-success p { font-size:15px; color:var(--clr-fg-muted); }

/* ── About ────────────────────────────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.about-title { font-family:var(--font-display); font-size:28px; font-weight:700; color:var(--clr-fg); margin-bottom:16px; }
.about-text p { font-size:15px; color:var(--clr-fg-muted); line-height:1.75; margin-bottom:16px; }
.about-sub-title { font-family:var(--font-display); font-size:20px; font-weight:700; color:var(--clr-fg); margin:24px 0 12px; }
.about-values { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.about-value-item { font-size:14px; color:var(--clr-fg-muted); padding:10px 14px; background:var(--clr-bg-subtle); border-radius:var(--radius-sm); border-left:3px solid var(--clr-primary); }
.about-img { width:100%; border-radius:var(--radius-lg); object-fit:cover; height:320px; margin-bottom:20px; }
.about-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.about-stat { background:var(--clr-primary-lt); border-radius:var(--radius); padding:16px; text-align:center; }
.about-stat-num { font-family:var(--font-display); font-size:28px; font-weight:800; color:var(--clr-primary); line-height:1; }
.about-stat-label { font-size:12px; color:var(--clr-fg-muted); margin-top:4px; }

/* ── CTA Banner ───────────────────────────────────────────────── */
.cta-banner { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.cta-banner-title { font-family:var(--font-display); font-size:32px; font-weight:700; color:var(--clr-accent-text); margin-bottom:6px; }
.cta-banner-sub { font-size:15px; color:var(--clr-accent-text); opacity:0.75; }
.cta-banner-btns { display:flex; gap:12px; flex-shrink:0; }

/* ── Modal ────────────────────────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.55); z-index:400; display:flex; align-items:center; justify-content:center; padding:20px; }
.modal { background:var(--clr-bg-card); border-radius:var(--radius-lg); padding:32px; max-width:480px; width:100%; position:relative; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:10px; }
.modal-close { position:absolute; top:14px; right:14px; background:var(--clr-bg-subtle); border:none; width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:14px; color:var(--clr-fg-muted); display:flex; align-items:center; justify-content:center; }
.modal-title { font-family:var(--font-display); font-size:22px; font-weight:700; color:var(--clr-fg); margin-top:4px; }
.modal-meta { font-size:14px; color:var(--clr-fg-muted); }
.modal-desc { font-size:14px; color:var(--clr-fg-muted); line-height:1.65; margin-bottom:8px; }
