/* Navigo Deutschland — v1 Very Pro / Executive
   Tone: corporate, sober, dense, premium. Avoid staffing-agency look. */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --black:#000;
  --ink:#0a0a0a;
  --ink-2:#1d1d1d;
  --grey-100:#f5f4f1;
  --grey-200:#e9e6e0;
  --grey-300:#cfcbc4;
  --grey-500:#6b6862;
  --grey-700:#3a3a36;
  --red:#dd0000;
  --gold:#ffce00;
  --bg:#fafaf7;
  --serif:"Cormorant Garamond", "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --container:1200px;
  --container-narrow:880px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--ink);margin:0 0 .5em;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(40px,5.4vw,68px);font-weight:500}
h2{font-size:clamp(30px,3.6vw,46px);font-weight:500}
h3{font-size:22px;font-weight:600}
h4{font-size:17px;font-weight:600;font-family:var(--sans);letter-spacing:.02em}
p{margin:0 0 1em}
.lead{font-size:19px;line-height:1.65;color:var(--grey-700);font-weight:300}
.eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:2.4px;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:18px;display:inline-block}
.eyebrow.dark{color:var(--ink)}
.eyebrow.light{color:rgba(255,255,255,.75)}
.divider{width:48px;height:1px;background:var(--red);margin:24px 0}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 32px}
section{padding:96px 0}
section.tight{padding:64px 0}
.section-head{max-width:760px;margin-bottom:56px}
.section-head.center{margin-inline:auto;text-align:center}
.grid{display:grid;gap:32px}

/* ---------- Top stripe / Header ---------- */
.top-stripe{height:3px;display:flex}
.top-stripe>span{flex:1}
.top-stripe>span:nth-child(1){background:#000}
.top-stripe>span:nth-child(2){background:var(--red)}
.top-stripe>span:nth-child(3){background:var(--gold)}

.site-header{position:sticky;top:0;z-index:50;background:rgba(250,250,247,.92);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--grey-200)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:104px}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:74px;width:auto}
.brand-text{font-family:var(--serif);font-size:13.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--grey-700);display:none}
@media (min-width:1080px){.brand-text{display:block}}
@media (max-width:520px){.brand img{height:60px}.site-header .container{height:84px}}

/* Language switcher (dropdown) — far right, separated from menu */
.lang-switch{position:relative;margin-left:16px;padding-left:16px;border-left:1px solid var(--grey-300)}
.lang-current{display:inline-flex;align-items:center;gap:7px;padding:9px 13px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-700);background:transparent;border:1px solid var(--grey-300);border-radius:0;cursor:pointer;transition:all .15s ease}
.lang-current:hover{border-color:var(--ink);color:var(--ink)}
.lang-current .chev{font-size:9px;transition:transform .15s ease}
.lang-switch:hover .lang-current .chev,.lang-switch.open .lang-current .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:150px;background:#fff;border:1px solid var(--grey-200);box-shadow:0 16px 40px rgba(0,0,0,.10);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .15s ease,transform .15s ease,visibility .15s ease;z-index:60}
.lang-switch:hover .lang-menu,.lang-switch:focus-within .lang-menu,.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu a{display:block;padding:11px 16px;font-size:13.5px;color:var(--ink);font-weight:500;border-bottom:1px solid var(--grey-200)}
.lang-menu a:last-child{border-bottom:0}
.lang-menu a:hover{background:var(--grey-100);color:var(--red)}
.lang-menu a.active{color:var(--red);font-weight:700}
/* Flags next to languages */
.lang-current::before,.lang-menu a::before{content:"";flex:0 0 auto;width:22px;height:15px;background-size:cover;background-position:center;border:1px solid rgba(0,0,0,.12);border-radius:2px}
.lang-menu a{display:flex;align-items:center;gap:10px}
.lang-menu a:nth-child(1)::before,.lang-switch.lang-de .lang-current::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 5 3'%3E%3Crect width='5' height='1' y='0' fill='%23000000'/%3E%3Crect width='5' height='1' y='1' fill='%23DD0000'/%3E%3Crect width='5' height='1' y='2' fill='%23FFCE00'/%3E%3C/svg%3E")}
.lang-menu a:nth-child(2)::before,.lang-switch.lang-en .lang-current::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3Crect width='60' height='30' fill='%23012169'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23ffffff' stroke-width='6'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23C8102E' stroke-width='4'/%3E%3Crect x='25' width='10' height='30' fill='%23ffffff'/%3E%3Crect y='10' width='60' height='10' fill='%23ffffff'/%3E%3Crect x='27' width='6' height='30' fill='%23C8102E'/%3E%3Crect y='12' width='60' height='6' fill='%23C8102E'/%3E%3C/svg%3E")}
.lang-menu a:nth-child(3)::before,.lang-switch.lang-fr .lang-current::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 3 2'%3E%3Crect width='3' height='2' fill='%23ffffff'/%3E%3Crect width='1' height='2' x='0' fill='%23002654'/%3E%3Crect width='1' height='2' x='2' fill='%23CE1126'/%3E%3C/svg%3E")}
@media (max-width:960px){.lang-switch{margin:8px 32px 12px;padding-left:0;border-left:0}.lang-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--grey-100);display:none;margin-top:8px}.lang-switch.open .lang-menu{display:block}.lang-current{width:100%;justify-content:space-between}}

.nav{display:flex;align-items:center;gap:0}
.nav>li{list-style:none;position:relative}
.nav>li>a:not(.btn),.nav>li>button:not(.lang-current){
  display:inline-flex;align-items:center;gap:6px;padding:28px 13px;white-space:nowrap;
  font-size:13.5px;letter-spacing:.03em;color:var(--ink);font-weight:500;
  background:transparent;border:none;border-bottom:2px solid transparent;transition:border-color .15s ease,color .15s ease;
}
.nav>li>a:not(.btn):hover,.nav>li>button:not(.lang-current):hover,.nav>li.has-dropdown:hover>button{color:var(--red);border-bottom-color:var(--red)}
.nav>li>a.active:not(.btn){border-bottom-color:var(--ink)}
.nav-cta{margin-left:10px}

/* Dropdown */
.has-dropdown{position:relative}
.dropdown-panel{
  position:absolute;left:50%;top:100%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--grey-200);min-width:280px;
  box-shadow:0 24px 48px rgba(0,0,0,.08);
  opacity:0;visibility:hidden;transition:opacity .15s ease,transform .15s ease,visibility .15s ease;
  z-index:60;
}
.has-dropdown:hover .dropdown-panel,.has-dropdown:focus-within .dropdown-panel{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown-panel a{
  display:flex;flex-direction:column;gap:4px;padding:18px 22px;border-bottom:1px solid var(--grey-200);
  font-size:14px;color:var(--ink);font-weight:600;
}
.dropdown-panel a:last-child{border-bottom:none}
.dropdown-panel a small{display:block;font-weight:400;color:var(--grey-500);font-size:12.5px}
.dropdown-panel a:hover{background:var(--grey-100);color:var(--red)}

.menu-toggle{display:none;background:transparent;border:0;padding:8px;cursor:pointer}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:transform .2s}
@media (max-width:960px){
  .menu-toggle{display:block}
  .nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:#fff;border-bottom:1px solid var(--grey-200);max-height:0;overflow:hidden;transition:max-height .25s ease}
  .nav.open{max-height:520px}
  .nav>li>a,.nav>li>button{padding:18px 32px;width:100%;justify-content:space-between;border-bottom:1px solid var(--grey-200)}
  .nav-cta{margin:18px 32px;width:calc(100% - 64px)}
  .dropdown-panel{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;background:var(--grey-100);min-width:0;display:none}
  .has-dropdown.open .dropdown-panel{display:block}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;
  padding:14px 26px;font-size:13.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid transparent;border-radius:0;transition:all .15s ease;cursor:pointer;
}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:var(--red);border-color:var(--red)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--ink);border-color:#fff}
.btn-light:hover{background:var(--gold);border-color:var(--gold)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-link{padding:0;border:0;background:transparent;color:var(--ink);font-weight:600;font-size:13.5px;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--ink);padding-bottom:4px}
.btn-link:hover{color:var(--red);border-bottom-color:var(--red)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:0;background:var(--ink);color:#fff;overflow:hidden;min-height:760px;display:flex;align-items:center}
.hero::before{
  content:"";position:absolute;inset:0;
  background:url("../img/hero-team.jpg") center/cover no-repeat;
  opacity:.55;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.55) 45%,rgba(0,0,0,.35) 100%);
}
.hero .container{position:relative;z-index:2;padding-top:120px;padding-bottom:120px}
.hero h1{color:#fff;max-width:14ch}
.hero h1 em{font-style:normal;color:var(--gold);font-weight:500}
.hero .lead{color:rgba(255,255,255,.86);max-width:60ch;margin-top:24px;font-size:20px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:40px}
.hero-meta{position:absolute;right:32px;bottom:32px;z-index:2;color:rgba(255,255,255,.6);font-size:11.5px;letter-spacing:2px;text-transform:uppercase}
.hero-side-rule{position:absolute;left:32px;top:50%;transform:translateY(-50%);z-index:2;display:none}
@media (min-width:1240px){.hero-side-rule{display:block}}
.hero-side-rule .num{font-family:var(--serif);font-size:120px;color:rgba(255,255,255,.07);line-height:1;font-weight:400}

/* ---------- Section Warum (3 trust pillars) ---------- */
.warum{background:var(--bg)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px;border-top:1px solid var(--grey-300);border-left:1px solid var(--grey-300)}
.pillar{padding:40px 32px;border-right:1px solid var(--grey-300);border-bottom:1px solid var(--grey-300);background:#fff}
.pillar .num{font-family:var(--serif);font-size:18px;color:var(--red);font-weight:600;letter-spacing:1px;margin-bottom:18px}
.pillar h3{margin-bottom:12px;font-family:var(--serif);font-size:24px}
.pillar p{color:var(--grey-700);font-size:14.5px;margin:0}
@media (max-width:880px){.pillars{grid-template-columns:1fr}}

/* ---------- Alles aus einer Hand ---------- */
.alles{background:var(--ink);color:#fff}
.alles h2{color:#fff}
.alles .lead{color:rgba(255,255,255,.78)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;margin-top:56px;background:rgba(255,255,255,.12)}
.service-cell{background:var(--ink);padding:32px 28px;display:flex;flex-direction:column;gap:14px;transition:background .2s ease}
.service-cell:hover{background:var(--ink-2)}
.service-cell .icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--gold);border:1px solid rgba(255,206,0,.4)}
.service-cell h4{color:#fff;margin:0;font-size:15px;letter-spacing:.04em;text-transform:uppercase}
.service-cell p{color:rgba(255,255,255,.6);font-size:13.5px;margin:0;line-height:1.55}

/* ---------- Split sections (Unternehmen / Fachkräfte) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:520px}
.split>.media{background:#222 center/cover no-repeat}
.split>.content{padding:88px 64px;display:flex;flex-direction:column;justify-content:center;max-width:640px}
.split-unternehmen .content{background:var(--bg)}
.split-unternehmen .media{background-image:linear-gradient(rgba(0,0,0,.30),rgba(0,0,0,.45)),url("https://images.unsplash.com/photo-1521737711867-e3b97375f902?w=1400&q=80&auto=format&fit=crop"),linear-gradient(135deg,#2a2a2a,#000);background-position:center;background-size:cover}
.split-fachkraefte{direction:rtl}
.split-fachkraefte>*{direction:ltr}
.split-fachkraefte .content{background:#fff}
.split-fachkraefte .media{background-image:linear-gradient(rgba(221,0,0,.20),rgba(0,0,0,.45)),url("https://images.unsplash.com/photo-1521791136064-7986c2920216?w=1400&q=80&auto=format&fit=crop"),linear-gradient(135deg,#3a1010,#000);background-position:center;background-size:cover}
.split .content h2{font-size:38px}
.split .content ul{list-style:none;padding:0;margin:24px 0 32px;color:var(--grey-700)}
.split .content ul li{padding:10px 0 10px 28px;position:relative;border-bottom:1px solid var(--grey-200);font-size:15px}
.split .content ul li:last-child{border-bottom:0}
.split .content ul li::before{content:"";position:absolute;left:0;top:18px;width:14px;height:1px;background:var(--red)}
@media (max-width:960px){
  .split{grid-template-columns:1fr;min-height:0}
  .split>.media{min-height:320px}
  .split>.content{padding:56px 32px}
}

/* ---------- Über Uns synthese ---------- */
.about-syn{background:var(--bg);position:relative}
.about-syn .container{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center}
.about-syn .photo{aspect-ratio:4/5;background-image:url("https://images.unsplash.com/photo-1522202176988-66273c2fd55f?w=900&q=80&auto=format&fit=crop"),linear-gradient(135deg,#444,#222);background-size:cover;background-position:center;filter:grayscale(.3) contrast(1.04);position:relative}
.about-syn .photo::after{content:"";position:absolute;left:-16px;bottom:-16px;width:80px;height:80px;background:var(--gold);z-index:-1}
.about-syn blockquote{font-family:var(--serif);font-size:26px;line-height:1.4;color:var(--ink);font-style:italic;margin:0 0 24px;font-weight:500}
@media (max-width:960px){.about-syn .container{grid-template-columns:1fr;gap:40px}}

/* ---------- Vision band ---------- */
.vision{background:linear-gradient(135deg,var(--ink) 0%,#1a1a1a 100%);color:#fff;position:relative;overflow:hidden}
.vision::before{content:"";position:absolute;right:-100px;top:-100px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,206,0,.18) 0%,transparent 70%)}
.vision::after{content:"";position:absolute;left:-80px;bottom:-80px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(221,0,0,.15) 0%,transparent 70%)}
.vision .container{position:relative;z-index:2}
.vision h2{color:#fff;max-width:18ch}
.vision .lead{color:rgba(255,255,255,.8);max-width:64ch}

/* ---------- Kontakt section on home ---------- */
.kontakt-home{background:var(--grey-100)}
.kontakt-home .container{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.kontakt-card{background:#fff;padding:48px;border-top:3px solid var(--red)}
.kontakt-card h3{font-family:var(--serif);font-size:26px;margin-bottom:8px}
.kontakt-list{list-style:none;padding:0;margin:24px 0 0}
.kontakt-list li{padding:14px 0;border-bottom:1px solid var(--grey-200);display:flex;justify-content:space-between;font-size:14.5px;gap:16px;flex-wrap:wrap}
.kontakt-list li:last-child{border-bottom:0}
.kontakt-list li span:first-child{color:var(--grey-500);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
.kontakt-list li a{color:var(--ink);font-weight:500}
.kontakt-list li a:hover{color:var(--red)}
@media (max-width:880px){.kontakt-home .container{grid-template-columns:1fr;gap:32px}}

/* ---------- Form ---------- */
.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label{display:block;font-size:11.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--grey-500);font-weight:600;margin-bottom:8px}
.form .req{color:var(--red);margin-left:4px}
.form input,.form textarea,.form select{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--grey-300);
  padding:10px 0;font-family:var(--sans);font-size:15px;color:var(--ink);
  outline:0;transition:border-color .15s ease;
}
.form input:focus,.form textarea:focus,.form select:focus{border-bottom-color:var(--ink)}
.form textarea{resize:vertical;min-height:140px}
.form .consent{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--grey-700);line-height:1.5;margin-top:6px}
.form .consent input[type="checkbox"]{margin-top:3px;flex:0 0 auto;accent-color:var(--red)}
.form .consent a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.form .submit-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:8px}
.form .legal-note{font-size:12px;color:var(--grey-500);margin-top:8px;line-height:1.5}
.form .error{display:none;font-size:12px;color:var(--red);margin-top:6px;font-weight:500}
.form .field.error input,.form .field.error textarea{border-bottom-color:var(--red)}
.form .field.error .error{display:block}
.form-success{padding:32px;background:#fff;border-left:3px solid var(--gold);font-size:15px;display:none}
.form-success.show{display:block}
.form-success.show + .form{display:none}
@media (max-width:680px){.form .row{grid-template-columns:1fr}}

/* ---------- Page header (inner pages) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:120px 0 80px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(221,0,0,.18) 0%,transparent 50%)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(36px,4.6vw,56px);margin-bottom:16px}
.page-hero .lead{color:rgba(255,255,255,.78);max-width:64ch}
.crumbs{font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:20px}
.crumbs a{color:rgba(255,255,255,.7)}
.crumbs a:hover{color:var(--gold)}
.crumbs span{margin:0 8px;color:rgba(255,255,255,.3)}

/* ---------- Service detail list (Leistungen sub-pages) ---------- */
.service-detail{padding:96px 0;background:var(--bg)}
.service-detail .row{display:grid;grid-template-columns:1fr 2fr;gap:64px;padding:48px 0;border-bottom:1px solid var(--grey-200);align-items:start}
.service-detail .row:last-child{border-bottom:0}
.service-detail .row .num{font-family:var(--serif);font-size:48px;color:var(--red);line-height:1;font-weight:500}
.service-detail .row h3{font-size:28px;margin-bottom:12px}
.service-detail .row p{color:var(--grey-700);margin:0 0 12px}
.service-detail .row .label{font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--grey-500);font-weight:600;margin-bottom:6px}
@media (max-width:860px){.service-detail .row{grid-template-columns:1fr;gap:16px}}

/* ---------- About page ---------- */
.about-page-intro{background:var(--bg);padding:96px 0}
.about-page-intro .container-narrow p{font-size:17.5px;color:var(--grey-700);line-height:1.7}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px;margin-top:56px}
.value{padding:32px;background:#fff;border-top:2px solid var(--ink);transition:border-color .2s ease}
.value:hover{border-top-color:var(--red)}
.value h4{font-family:var(--serif);font-size:22px;text-transform:none;letter-spacing:0;margin-bottom:8px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:72px 0 24px}
.site-footer .container{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer h5{color:#fff;font-family:var(--sans);font-size:11.5px;letter-spacing:2px;text-transform:uppercase;margin:0 0 18px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{padding:6px 0;font-size:14px}
.site-footer ul li a:hover{color:var(--gold)}
.site-footer .brand-block img{height:36px;width:auto;filter:invert(1) brightness(2)}
.site-footer .brand-block p{font-size:13.5px;color:rgba(255,255,255,.5);margin-top:18px;max-width:32ch;line-height:1.6}
.site-footer .legal{padding-top:24px;font-size:12px;color:rgba(255,255,255,.4);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
.site-footer .legal a{color:rgba(255,255,255,.55)}
.site-footer .legal a:hover{color:#fff}
@media (max-width:860px){.site-footer .container{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.site-footer .container{grid-template-columns:1fr}}

/* ---------- Legal pages ---------- */
.legal-page{padding:80px 0;background:var(--bg)}
.legal-page h2{font-size:26px;margin-top:48px;margin-bottom:16px;font-family:var(--serif)}
.legal-page h3{font-size:18px;margin-top:32px;margin-bottom:8px;font-family:var(--sans);font-weight:600}
.legal-page p,.legal-page li{font-size:14.5px;color:var(--grey-700);line-height:1.7}
.legal-page ul{padding-left:20px}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}
.hide-mobile{display:none}
@media (min-width:768px){.hide-mobile{display:initial}}
