/*
Theme Name: Michael Koch Bedachungen — Swiss Modernism
Theme URI: https://michael-koch-bedachungen-3.lead.bummeltech.com/
Author: bummeltech
Description: Individuelles Theme fuer Michael Koch Bedachungen. Swiss Modernism 2.0 — striktes 12-Spalten-Grid, Inter/Helvetica, modulare Sektionen, mathematische Abstaende, EINE ruhige Akzentfarbe (Dachziegel). Alle Inhalte im wp-admin pflegbar (Customizer, CPT slide, CPT service, Seiten, Menues).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: mkb
*/

/* =========================================================================
   DESIGN TOKENS — Swiss Modernism 2.0
   Neutrale Basis + EINE gedaempfte Akzentfarbe (Dachziegel-Rot).
   8px base unit, 12-Spalten-Grid, mathematische Abstaende.
   ========================================================================= */
:root{
  /* Grid & Spacing */
  --grid-columns: 12;
  --grid-gap: 1rem;              /* 16px */
  --base-unit: 8px;
  --container-max: 1360px;
  --gutter: clamp(1.25rem, 4vw, 4rem);

  /* Spacing scale (mathematisch, *8px) */
  --s-1: 8px;  --s-2: 16px; --s-3: 24px; --s-4: 32px;
  --s-5: 48px; --s-6: 64px; --s-7: 96px; --s-8: 128px; --s-9: 176px;

  /* Colors — natuerlich, gedaempft, WCAG-AA */
  --color-bg:      #FFFFFF;
  --color-surface: #FAF9F6;   /* off-white */
  --color-surface-2:#F1EEE8;  /* soft sand */
  --color-ink:     #14110F;   /* near-black warm */
  --color-text:    #1E1B18;
  --color-muted:   #6B655E;
  --color-border:  #E4E0D8;
  --color-line:    #D8D3C9;

  /* Single accent — Dachziegel (muted brick), harmoniert mit Branche */
  --accent:        #A8432A;
  --accent-dark:   #7E2F1C;
  --accent-tint:   #F5E9E4;

  /* Typography */
  --font-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --fw-regular: 400; --fw-medium: 500; --fw-semibold: 600; --fw-bold: 700; --fw-black: 800;

  --fs-display: clamp(2.6rem, 6.5vw, 5.4rem);
  --fs-h1: clamp(2.2rem, 5vw, 3.6rem);
  --fs-h2: clamp(1.7rem, 3.4vw, 2.6rem);
  --fs-h3: clamp(1.25rem, 2vw, 1.55rem);
  --fs-lead: clamp(1.05rem, 1.6vw, 1.3rem);
  --fs-body: 1.0625rem;
  --fs-small: 0.875rem;
  --fs-label: 0.75rem;

  /* Effects */
  --radius: 4px;
  --radius-lg: 8px;
  --shadow-sm: 0 1px 2px rgba(20,17,15,.06), 0 1px 1px rgba(20,17,15,.04);
  --shadow-md: 0 10px 30px -12px rgba(20,17,15,.18);
  --shadow-lg: 0 30px 60px -20px rgba(20,17,15,.26);
  --ease: cubic-bezier(.22,.61,.36,1);
  --dur: 220ms;

  --header-h: 76px;
}

/* =========================================================================
   RESET / BASE
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--font-primary);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--color-text);
  background:var(--color-bg);
  font-weight:var(--fw-regular);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1,"liga" 1,"calt" 1;
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,h4{ margin:0; line-height:1.08; letter-spacing:-.02em; font-weight:var(--fw-bold); color:var(--color-ink); }
p{ margin:0 0 1em; }
ul{ margin:0; padding:0; }

/* =========================================================================
   LAYOUT — 12-Spalten-Grid (strict)
   ========================================================================= */
.container{ width:100%; max-width:var(--container-max); margin-inline:auto; padding-inline:var(--gutter); }
.grid12{
  display:grid;
  grid-template-columns:repeat(var(--grid-columns), 1fr);
  gap:var(--grid-gap);
}
.section{ padding-block:var(--s-8); }
.section--tight{ padding-block:var(--s-7); }
.section--surface{ background:var(--color-surface); }
.section--ink{ background:var(--color-ink); color:#EFEBE4; }
.section--ink h1,.section--ink h2,.section--ink h3{ color:#fff; }

/* Section heading block */
.section-head{ grid-column:1 / -1; display:grid; grid-template-columns:repeat(12,1fr); gap:var(--grid-gap); align-items:end; margin-bottom:var(--s-6); }
.section-head .eyebrow{ grid-column:1 / -1; }
.section-head h2{ grid-column:1 / span 8; font-size:var(--fs-h2); }
.section-head .section-note{ grid-column:9 / span 4; color:var(--color-muted); font-size:var(--fs-small); align-self:end; }
@media (max-width:900px){
  .section-head h2{ grid-column:1 / -1; }
  .section-head .section-note{ grid-column:1 / -1; margin-top:var(--s-2); }
}

/* Eyebrow / kicker label — Swiss uppercase label */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:var(--fs-label); font-weight:var(--fw-semibold);
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent);
  margin-bottom:var(--s-3);
}
.eyebrow::before{ content:""; width:28px; height:2px; background:var(--accent); display:inline-block; }
.section--ink .eyebrow{ color:#E9A98F; }
.section--ink .eyebrow::before{ background:#E9A98F; }

.lead{ font-size:var(--fs-lead); color:var(--color-muted); line-height:1.55; }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{
  --btn-bg:var(--accent); --btn-fg:#fff;
  display:inline-flex; align-items:center; gap:.6em; cursor:pointer;
  padding:14px 26px; font-size:var(--fs-small); font-weight:var(--fw-semibold);
  letter-spacing:.04em; text-transform:uppercase;
  background:var(--btn-bg); color:var(--btn-fg);
  border:1px solid var(--btn-bg); border-radius:var(--radius);
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  will-change:transform;
}
.btn svg{ width:16px; height:16px; transition:transform var(--dur) var(--ease); }
.btn:hover{ background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn:hover svg{ transform:translateX(3px); }
.btn:focus-visible{ outline:3px solid var(--accent); outline-offset:3px; }
.btn--ghost{ --btn-bg:transparent; --btn-fg:var(--color-ink); border-color:var(--color-line); }
.btn--ghost:hover{ --btn-bg:var(--color-ink); border-color:var(--color-ink); color:#fff; }
.btn--light{ --btn-bg:#fff; --btn-fg:var(--color-ink); border-color:#fff; }
.btn--light:hover{ background:#EFEBE4; border-color:#EFEBE4; color:var(--color-ink); }

/* =========================================================================
   HEADER / NAVBAR — grosszuegig, sticky, Burger < 900px
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--color-border);
  transition:box-shadow var(--dur) var(--ease), background var(--dur) var(--ease);
}
.site-header.is-scrolled{ box-shadow:var(--shadow-sm); background:rgba(255,255,255,.94); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:var(--header-h); gap:var(--s-4); }
.brand{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.brand__mark{
  width:44px; height:44px; border-radius:var(--radius); background:var(--accent);
  display:grid; place-items:center; color:#fff; flex-shrink:0;
}
.brand__mark svg{ width:24px; height:24px; }
.brand__name{ display:flex; flex-direction:column; line-height:1.1; }
.brand__name b{ font-size:1.02rem; font-weight:var(--fw-bold); letter-spacing:-.01em; color:var(--color-ink); }
.brand__name span{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--color-muted); }

.nav__menu{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2.4rem); list-style:none; }
.nav__menu a{
  font-size:.94rem; font-weight:var(--fw-medium); color:var(--color-text);
  position:relative; padding:6px 0; letter-spacing:.01em; white-space:nowrap;
  transition:color var(--dur) var(--ease);
}
.nav__menu a::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--accent);
  transition:width var(--dur) var(--ease);
}
.nav__menu a:hover{ color:var(--accent); }
.nav__menu a:hover::after,.nav__menu .current-menu-item>a::after{ width:100%; }
.nav__menu .current-menu-item>a{ color:var(--color-ink); }
.nav__actions{ display:flex; align-items:center; gap:var(--s-3); flex-shrink:0; }
.nav__phone{ display:inline-flex; align-items:center; gap:.5em; font-weight:var(--fw-semibold); font-size:.94rem; white-space:nowrap; }
.nav__phone svg{ width:16px; height:16px; color:var(--accent); }
.nav__phone:hover{ color:var(--accent); }

.burger{
  display:none; width:46px; height:46px; border:1px solid var(--color-line);
  background:transparent; border-radius:var(--radius); cursor:pointer; padding:0;
  position:relative; flex-shrink:0;
}
.burger span{ position:absolute; left:12px; right:12px; height:2px; background:var(--color-ink); transition:transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.burger span:nth-child(1){ top:16px; } .burger span:nth-child(2){ top:22px; } .burger span:nth-child(3){ top:28px; }
body.nav-open .burger span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
body.nav-open .burger span:nth-child(2){ opacity:0; }
body.nav-open .burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* Mobile drawer */
.nav__overlay{ display:none; }
@media (max-width:900px){
  .nav__menu, .nav__phone{ display:none; }
  .burger{ display:block; }
  .nav__drawer{
    position:fixed; inset:var(--header-h) 0 0 auto; width:min(88vw,420px);
    background:var(--color-bg); border-left:1px solid var(--color-border);
    transform:translateX(100%); transition:transform 320ms var(--ease);
    z-index:99; padding:var(--s-5) var(--gutter); display:flex; flex-direction:column;
    gap:var(--s-2); overflow-y:auto; box-shadow:var(--shadow-lg);
  }
  body.nav-open .nav__drawer{ transform:translateX(0); }
  .nav__drawer ul{ list-style:none; display:flex; flex-direction:column; gap:var(--s-1); }
  .nav__drawer a{ display:block; padding:14px 4px; font-size:1.15rem; font-weight:var(--fw-medium); border-bottom:1px solid var(--color-border); }
  .nav__drawer a:hover{ color:var(--accent); }
  .nav__drawer .btn{ margin-top:var(--s-3); justify-content:center; }
  .nav__overlay{ display:block; position:fixed; inset:var(--header-h) 0 0 0; background:rgba(20,17,15,.4);
    opacity:0; visibility:hidden; transition:opacity var(--dur) var(--ease), visibility var(--dur); z-index:98; }
  body.nav-open .nav__overlay{ opacity:1; visibility:visible; }
  body.nav-open{ overflow:hidden; }
}
.nav__drawer{ }
@media (min-width:901px){ .nav__drawer{ display:contents; } .nav__drawer .nav__drawer-cta{ display:none; } }

/* =========================================================================
   HERO — Swiss split grid + Foto, subtiler Parallax
   ========================================================================= */
.hero{ position:relative; background:var(--color-surface); border-bottom:1px solid var(--color-border); overflow:hidden; }
.hero__grid{ align-items:stretch; min-height:min(84vh,780px); }
.hero__content{ grid-column:1 / span 6; display:flex; flex-direction:column; justify-content:center; padding-block:var(--s-8); padding-right:var(--s-5); }
.hero__media{ grid-column:7 / span 6; position:relative; }
.hero__media .hero__img-wrap{
  position:absolute; inset:0; overflow:hidden;
}
.hero__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; will-change:transform; }
.hero__badge{
  position:absolute; left:var(--s-4); bottom:var(--s-4); z-index:3;
  background:rgba(255,255,255,.9); backdrop-filter:blur(8px);
  border:1px solid var(--color-border); border-radius:var(--radius-lg);
  padding:16px 20px; box-shadow:var(--shadow-md); max-width:240px;
}
.hero__badge b{ display:block; font-size:1.9rem; color:var(--accent); letter-spacing:-.03em; }
.hero__badge span{ font-size:.8rem; color:var(--color-muted); }
.hero h1{ font-size:var(--fs-display); margin-bottom:var(--s-3); }
.hero h1 .accent{ color:var(--accent); }
.hero__sub{ font-size:var(--fs-lead); color:var(--color-muted); max-width:34ch; margin-bottom:var(--s-5); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:var(--s-2); margin-bottom:var(--s-5); }
.hero__meta{ display:flex; flex-wrap:wrap; gap:var(--s-4); border-top:1px solid var(--color-border); padding-top:var(--s-4); }
.hero__meta div b{ display:block; font-size:1.4rem; color:var(--color-ink); font-weight:var(--fw-bold); letter-spacing:-.02em; }
.hero__meta div span{ font-size:var(--fs-small); color:var(--color-muted); }
@media (max-width:1000px){
  .hero__content{ grid-column:1 / -1; padding-right:0; }
  .hero__media{ grid-column:1 / -1; min-height:52vh; }
  .hero__grid{ min-height:auto; }
}

/* =========================================================================
   MARQUEE / TRUST STRIP
   ========================================================================= */
.trust{ border-bottom:1px solid var(--color-border); background:var(--color-bg); }
.trust__inner{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--s-3) var(--s-6); padding-block:var(--s-4); }
.trust__label{ font-size:var(--fs-label); text-transform:uppercase; letter-spacing:.16em; color:var(--color-muted); font-weight:var(--fw-semibold); }
.trust__item{ display:flex; align-items:center; gap:.6em; font-weight:var(--fw-medium); color:var(--color-text); font-size:.95rem; }
.trust__item svg{ width:20px; height:20px; color:var(--accent); flex-shrink:0; }

/* =========================================================================
   SLIDER (CPT slide) — scroll-snap + auto-advance
   ========================================================================= */
.slider{ position:relative; }
.slider__track{
  display:flex; overflow-x:auto; scroll-snap-type:x mandatory; gap:var(--grid-gap);
  scrollbar-width:none; -ms-overflow-style:none;
}
.slider__track::-webkit-scrollbar{ display:none; }
.slide{
  position:relative; flex:0 0 100%; scroll-snap-align:center; min-height:min(70vh,620px);
  border-radius:var(--radius-lg); overflow:hidden; background:var(--color-ink);
}
.slide img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.72; }
.slide__overlay{ position:absolute; inset:0; background:linear-gradient(90deg, rgba(20,17,15,.78) 0%, rgba(20,17,15,.35) 55%, rgba(20,17,15,.05) 100%); }
.slide__body{ position:relative; z-index:2; max-width:640px; padding:clamp(2rem,5vw,4.5rem); color:#fff; height:100%; display:flex; flex-direction:column; justify-content:center; }
.slide__body .eyebrow{ color:#E9A98F; }
.slide__body .eyebrow::before{ background:#E9A98F; }
.slide__body h3{ font-size:var(--fs-h1); color:#fff; margin-bottom:var(--s-2); }
.slide__body p{ font-size:var(--fs-lead); color:rgba(255,255,255,.86); max-width:46ch; }
.slider__controls{ display:flex; align-items:center; justify-content:space-between; margin-top:var(--s-3); gap:var(--s-3); }
.slider__dots{ display:flex; gap:8px; }
.slider__dots button{ width:36px; height:4px; border:none; padding:0; background:var(--color-line); cursor:pointer; border-radius:2px; transition:background var(--dur) var(--ease); }
.slider__dots button.is-active{ background:var(--accent); }
.slider__arrows{ display:flex; gap:8px; }
.slider__arrows button{ width:46px; height:46px; border:1px solid var(--color-line); background:var(--color-bg); border-radius:var(--radius); cursor:pointer; display:grid; place-items:center; transition:all var(--dur) var(--ease); }
.slider__arrows button:hover{ background:var(--color-ink); border-color:var(--color-ink); color:#fff; }
.slider__arrows svg{ width:18px; height:18px; }

/* =========================================================================
   SERVICES (CPT service) — Bento-ish modular grid, hover-tilt 3D
   ========================================================================= */
.services__grid{ grid-column:1 / -1; }
.service-card{
  grid-column:span 4; background:var(--color-bg); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); padding:var(--s-5); position:relative; overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transform-style:preserve-3d; will-change:transform;
}
.service-card::before{ content:""; position:absolute; left:0; top:0; width:100%; height:3px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--dur) var(--ease); }
.service-card:hover{ box-shadow:var(--shadow-lg); border-color:var(--color-line); }
.service-card:hover::before{ transform:scaleX(1); }
.service-card__num{ font-size:var(--fs-small); font-weight:var(--fw-semibold); color:var(--color-muted); letter-spacing:.1em; }
.service-card__icon{ width:52px; height:52px; border-radius:var(--radius); background:var(--accent-tint); color:var(--accent); display:grid; place-items:center; margin:var(--s-3) 0 var(--s-4); transform:translateZ(30px); }
.service-card__icon svg{ width:26px; height:26px; }
.service-card h3{ font-size:var(--fs-h3); margin-bottom:var(--s-2); transform:translateZ(18px); }
.service-card p{ color:var(--color-muted); font-size:var(--fs-body); margin-bottom:var(--s-3); }
.service-card__link{ margin-top:auto; display:inline-flex; align-items:center; gap:.5em; font-weight:var(--fw-semibold); font-size:.92rem; color:var(--accent); letter-spacing:.02em; }
.service-card__link svg{ width:16px; height:16px; transition:transform var(--dur) var(--ease); }
.service-card:hover .service-card__link svg{ transform:translateX(4px); }
.service-card__media{ margin:calc(-1*var(--s-5)) calc(-1*var(--s-5)) var(--s-4); aspect-ratio:16/10; overflow:hidden; }
.service-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform 600ms var(--ease); }
.service-card:hover .service-card__media img{ transform:scale(1.06); }
@media (max-width:900px){ .service-card{ grid-column:span 6; } }
@media (max-width:640px){ .service-card{ grid-column:1 / -1; } }

/* Bento feature grid (varied spans) */
.bento{ grid-column:1 / -1; grid-auto-rows:minmax(180px,auto); }
.bento .tile{
  border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:var(--s-5);
  background:var(--color-bg); display:flex; flex-direction:column; justify-content:space-between;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.bento .tile:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tile--wide{ grid-column:span 8; } .tile--tall{ grid-column:span 4; grid-row:span 2; }
.tile--half{ grid-column:span 4; } .tile--third{ grid-column:span 4; }
.tile--dark{ background:var(--color-ink); color:#EFEBE4; }
.tile--dark h3{ color:#fff; }
.tile--accent{ background:var(--accent); color:#fff; } .tile--accent h3{ color:#fff; }
.tile__k{ font-size:clamp(2.4rem,4vw,3.4rem); font-weight:var(--fw-black); letter-spacing:-.04em; line-height:1; }
.tile h3{ font-size:var(--fs-h3); }
.tile p{ color:var(--color-muted); margin:0; }
.tile--dark p,.tile--accent p{ color:rgba(255,255,255,.82); }
.tile__media{ position:relative; overflow:hidden; padding:0; }
.tile__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
@media (max-width:900px){ .tile--wide,.tile--tall,.tile--half,.tile--third{ grid-column:1 / -1; grid-row:auto; } .tile--tall{ min-height:220px; } }

/* =========================================================================
   ABOUT / SPLIT
   ========================================================================= */
.split{ align-items:center; }
.split__media{ grid-column:1 / span 6; position:relative; }
.split__media .frame{ border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5; box-shadow:var(--shadow-lg); }
.split__media img{ width:100%; height:100%; object-fit:cover; }
.split__media .stat-chip{
  position:absolute; right:-16px; bottom:24px; background:var(--color-ink); color:#fff;
  padding:20px 24px; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); max-width:220px;
}
.split__media .stat-chip b{ display:block; font-size:2.2rem; letter-spacing:-.03em; color:#fff; }
.split__media .stat-chip span{ font-size:var(--fs-small); color:rgba(255,255,255,.75); }
.split__body{ grid-column:8 / span 5; }
.split__body h2{ font-size:var(--fs-h2); margin-bottom:var(--s-3); }
.split__body .checklist{ list-style:none; margin-top:var(--s-4); display:grid; gap:var(--s-2); }
.split__body .checklist li{ display:flex; gap:.7em; align-items:flex-start; }
.split__body .checklist svg{ width:22px; height:22px; color:var(--accent); flex-shrink:0; margin-top:2px; }
@media (max-width:1000px){
  .split__media{ grid-column:1 / -1; }
  .split__media .frame{ aspect-ratio:16/10; }
  .split__body{ grid-column:1 / -1; margin-top:var(--s-5); }
  .split__media .stat-chip{ right:16px; }
}

/* =========================================================================
   PROCESS / STEPS
   ========================================================================= */
.steps{ grid-column:1 / -1; counter-reset:step; }
.step{ grid-column:span 3; position:relative; padding-top:var(--s-4); border-top:2px solid var(--color-ink); }
.step__n{ font-size:var(--fs-small); font-weight:var(--fw-bold); letter-spacing:.1em; color:var(--accent); }
.step h3{ font-size:var(--fs-h3); margin:var(--s-2) 0; }
.step p{ color:var(--color-muted); margin:0; font-size:var(--fs-body); }
@media (max-width:900px){ .step{ grid-column:span 6; } }
@media (max-width:560px){ .step{ grid-column:1 / -1; } }

/* =========================================================================
   CTA BAND
   ========================================================================= */
.cta-band{ position:relative; overflow:hidden; }
.cta-band__grid{ align-items:center; }
.cta-band h2{ grid-column:1 / span 7; font-size:var(--fs-h1); color:#fff; }
.cta-band .cta-band__side{ grid-column:9 / span 4; display:flex; flex-direction:column; gap:var(--s-3); align-items:flex-start; }
.cta-band p{ color:rgba(255,255,255,.8); margin:0; }
@media (max-width:900px){ .cta-band h2,.cta-band .cta-band__side{ grid-column:1 / -1; } .cta-band .cta-band__side{ margin-top:var(--s-4); } }

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact__info{ grid-column:1 / span 5; }
.contact__form{ grid-column:7 / span 6; }
.contact__card{ display:flex; gap:var(--s-3); padding:var(--s-3) 0; border-bottom:1px solid var(--color-border); }
.contact__card:first-of-type{ border-top:1px solid var(--color-border); }
.contact__card svg{ width:24px; height:24px; color:var(--accent); flex-shrink:0; }
.contact__card b{ display:block; font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; color:var(--color-muted); margin-bottom:2px; }
.contact__card a,.contact__card span{ font-size:1.05rem; color:var(--color-ink); font-weight:var(--fw-medium); }
.contact__card a:hover{ color:var(--accent); }
@media (max-width:1000px){ .contact__info,.contact__form{ grid-column:1 / -1; } .contact__form{ margin-top:var(--s-5); } }

/* Contact form 7 / generic form styling */
.form-wrap{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:var(--s-5); }
.form-wrap p{ margin:0 0 var(--s-2); }
.form-wrap label{ display:block; font-size:var(--fs-small); font-weight:var(--fw-semibold); margin-bottom:6px; color:var(--color-ink); }
.wpcf7-form-control-wrap{ display:block; }
input[type=text],input[type=email],input[type=tel],input[type=url],textarea,select{
  width:100%; padding:12px 14px; font-family:inherit; font-size:1rem; color:var(--color-ink);
  background:var(--color-bg); border:1px solid var(--color-line); border-radius:var(--radius);
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
input:focus,textarea:focus,select:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-tint); }
textarea{ min-height:130px; resize:vertical; }
.wpcf7-submit,.form-wrap button[type=submit]{
  cursor:pointer; padding:14px 28px; background:var(--accent); color:#fff; border:none;
  border-radius:var(--radius); font-weight:var(--fw-semibold); text-transform:uppercase; letter-spacing:.04em;
  transition:background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.wpcf7-submit:hover{ background:var(--accent-dark); transform:translateY(-2px); }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{ background:var(--color-ink); color:#C9C3BA; padding-block:var(--s-8) var(--s-5); }
.site-footer a{ color:#C9C3BA; transition:color var(--dur) var(--ease); }
.site-footer a:hover{ color:#fff; }
.footer__grid{ }
.footer__brand{ grid-column:1 / span 4; }
.footer__brand .brand__name b{ color:#fff; } .footer__brand .brand__name span{ color:#8C857B; }
.footer__brand p{ margin-top:var(--s-3); color:#948D83; max-width:36ch; }
.footer__col{ grid-column:span 2; }
.footer__col:nth-of-type(2){ grid-column:6 / span 2; }
.footer__col h4{ color:#fff; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; margin-bottom:var(--s-3); }
.footer__col ul{ list-style:none; display:grid; gap:10px; font-size:.95rem; }
.footer__contact{ grid-column:10 / span 3; }
.footer__contact h4{ color:#fff; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; margin-bottom:var(--s-3); }
.footer__contact p{ margin:0 0 8px; font-size:.95rem; }
.footer__bottom{ margin-top:var(--s-7); padding-top:var(--s-4); border-top:1px solid rgba(255,255,255,.1); display:flex; flex-wrap:wrap; gap:var(--s-2) var(--s-4); justify-content:space-between; font-size:var(--fs-small); color:#8C857B; }
.footer__bottom a:hover{ color:#fff; }
@media (max-width:900px){
  .footer__brand,.footer__col,.footer__contact{ grid-column:1 / -1 !important; }
  .footer__col{ margin-top:var(--s-3); }
}

/* =========================================================================
   GENERIC PAGE / GUTENBERG CONTENT
   ========================================================================= */
.page-hero{ background:var(--color-surface); border-bottom:1px solid var(--color-border); padding-block:var(--s-8) var(--s-7); }
.page-hero .container{ }
.page-hero .breadcrumb{ font-size:var(--fs-small); color:var(--color-muted); margin-bottom:var(--s-3); }
.page-hero .breadcrumb a:hover{ color:var(--accent); }
.page-hero h1{ font-size:var(--fs-h1); max-width:20ch; }
.page-hero p{ margin-top:var(--s-3); max-width:60ch; color:var(--color-muted); font-size:var(--fs-lead); }
.entry{ padding-block:var(--s-7); }
.entry__body{ grid-column:2 / span 8; }
@media (max-width:900px){ .entry__body{ grid-column:1 / -1; } }
.entry__body h2{ font-size:var(--fs-h2); margin:var(--s-6) 0 var(--s-2); }
.entry__body h3{ font-size:var(--fs-h3); margin:var(--s-5) 0 var(--s-2); }
.entry__body p{ margin:0 0 var(--s-3); }
.entry__body ul,.entry__body ol{ margin:0 0 var(--s-4) 1.2em; display:grid; gap:.5em; }
.entry__body ul li{ list-style:none; position:relative; padding-left:1.6em; }
.entry__body ul li::before{ content:""; position:absolute; left:0; top:.62em; width:9px; height:9px; background:var(--accent); border-radius:2px; }
.entry__body ol{ list-style:decimal; }
.entry__body img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-md); margin:var(--s-4) 0; }
.entry__body .wp-block-columns{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-5); align-items:center; margin:var(--s-5) 0; }
.entry__body .wp-block-column{ min-width:0; }
@media (max-width:700px){ .entry__body .wp-block-columns{ grid-template-columns:1fr; } }
.entry__body .wp-block-group{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:var(--s-5); margin:var(--s-4) 0; }
.entry__body .wp-block-group.has-accent{ background:var(--accent-tint); border-color:#E2C7BC; }
.entry__body .wp-block-separator{ border:none; border-top:1px solid var(--color-border); margin:var(--s-6) 0; }
.entry__body .wp-block-quote{ border-left:3px solid var(--accent); padding-left:var(--s-3); margin:var(--s-5) 0; font-size:var(--fs-lead); color:var(--color-ink); font-style:normal; }
.entry__body figure{ margin:var(--s-4) 0; }
.entry__body .wp-block-buttons{ display:flex; gap:var(--s-2); flex-wrap:wrap; margin:var(--s-4) 0; }
.entry__body .wp-block-button__link{ background:var(--accent); color:#fff; padding:14px 26px; border-radius:var(--radius); font-weight:var(--fw-semibold); text-transform:uppercase; font-size:var(--fs-small); letter-spacing:.04em; display:inline-block; }
.entry__body .wp-block-button__link:hover{ background:var(--accent-dark); }

/* Service/page detail cross-links */
.subpage-links{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:var(--grid-gap); }
.subpage-links a{ border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:var(--s-4); background:var(--color-bg); transition:all var(--dur) var(--ease); display:flex; align-items:center; justify-content:space-between; gap:var(--s-2); font-weight:var(--fw-semibold); }
.subpage-links a:hover{ border-color:var(--accent); color:var(--accent); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.subpage-links svg{ width:18px; height:18px; }

/* =========================================================================
   SCROLL REVEAL
   ========================================================================= */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity 640ms var(--ease), transform 640ms var(--ease); }
[data-reveal].is-visible{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:80ms; }
[data-reveal][data-delay="2"]{ transition-delay:160ms; }
[data-reveal][data-delay="3"]{ transition-delay:240ms; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
  .hero__media img{ transform:none !important; }
  *{ scroll-behavior:auto !important; }
}

/* Utilities */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.visually-hidden{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.skip-link{ position:absolute; left:-999px; top:0; background:var(--accent); color:#fff; padding:10px 16px; z-index:1000; }
.skip-link:focus{ left:8px; top:8px; }
