/* Navigo Deutschland — v3 User Friendly / Warm Human
   Tone: warm, accessible, gradient-rich, big rounded shapes, photo-forward. */

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

:root{
  --black:#181818;
  --ink:#1f1c1a;
  --ink-2:#2f2a26;
  --warm:#5a4f47;
  --warm-2:#857a72;
  --cream:#fff9ef;
  --cream-2:#fff3dc;
  --beige:#f7efe1;
  --bg:#fffbf4;
  --surface:#ffffff;
  --line:#ece3d2;
  --red:#dd0000;
  --red-2:#ff3f3f;
  --red-soft:#ffe4e4;
  --gold:#ffce00;
  --gold-2:#ffb700;
  --gold-soft:#fff3c2;
  --grad-warm:linear-gradient(135deg,#dd0000 0%,#ff6a00 50%,#ffce00 100%);
  --grad-soft:linear-gradient(135deg,#ffe4e4 0%,#fff3c2 100%);
  --display:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --container:1180px;
  --container-narrow:780px;
  --radius:18px;
  --radius-lg:28px;
  --radius-pill:999px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.04);
  --shadow:0 10px 30px rgba(20,15,10,.07),0 2px 6px rgba(20,15,10,.04);
  --shadow-warm:0 16px 40px rgba(221,0,0,.10),0 4px 12px rgba(221,0,0,.06);
  --shadow-lg:0 24px 60px rgba(20,15,10,.10),0 8px 24px rgba(20,15,10,.06);
}

*,*::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:16.5px;line-height:1.7;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(--display);color:var(--ink);margin:0 0 .5em;line-height:1.15;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(44px,6vw,76px);letter-spacing:-.035em;font-weight:800}
h2{font-size:clamp(32px,4vw,52px);letter-spacing:-.03em}
h3{font-size:24px}
h4{font-size:18px}
p{margin:0 0 1em}
.lead{font-size:20px;line-height:1.65;color:var(--warm);font-weight:400}
.eyebrow{font-family:var(--display);font-size:13.5px;letter-spacing:.04em;color:var(--red);font-weight:700;margin-bottom:18px;display:inline-flex;align-items:center;gap:10px;background:var(--red-soft);padding:8px 16px;border-radius:var(--radius-pill);text-transform:none}
.eyebrow.gold{background:var(--gold-soft);color:#7a5a00}
.eyebrow.light{background:rgba(255,255,255,.18);color:#fff}
.gradient-text{background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 24px}
section{padding:96px 0}
section.tight{padding:64px 0}
.section-head{max-width:680px;margin-bottom:48px}
.section-head.center{margin-inline:auto;text-align:center}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,251,244,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:108px}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:78px;width:auto}
.brand-text{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--warm-2);display:none;font-weight:600}
@media (min-width:1080px){.brand-text{display:block}}
@media (max-width:520px){.brand img{height:64px}.site-header .container{height:88px}}

/* Language switcher (dropdown) — far right, separated from menu */
.lang-switch{position:relative;margin-left:22px;padding-left:22px;border-left:1px solid var(--line)}
.lang-current{display:inline-flex;align-items:center;gap:7px;padding:10px 15px;font-size:13.5px;font-weight:700;color:var(--warm);background:var(--cream-2);border:1px solid transparent;border-radius:var(--radius-pill);cursor:pointer;transition:all .15s ease}
.lang-current:hover{background:#fff;border-color:var(--line);color:var(--ink);box-shadow:var(--shadow-sm)}
.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% + 8px);min-width:165px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s ease,transform .18s ease,visibility .18s 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:14.5px;color:var(--ink);font-weight:600;border-radius:12px}
.lang-menu a:hover{background:var(--cream-2);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:4px}
.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 16px 12px;padding-left:0;border-left:0}.lang-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--cream-2);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:4px;list-style:none;padding:0;margin:0}
.nav>li{position:relative}
.nav>li>a:not(.btn),.nav>li>button:not(.lang-current){
  display:inline-flex;align-items:center;gap:6px;padding:10px 16px;white-space:nowrap;
  font-size:15px;color:var(--ink);font-weight:600;
  background:transparent;border:none;border-radius:var(--radius-pill);transition:background .15s ease,color .15s ease;
}
.nav>li>a:not(.btn):hover,.nav>li>button:not(.lang-current):hover{background:var(--cream-2)}
.nav>li>a.active:not(.btn){background:var(--red);color:#fff}
.nav-cta{margin-left:12px}

/* Dropdown */
.has-dropdown{position:relative}
.dropdown-panel{
  position:absolute;left:50%;top:calc(100% + 8px);transform:translateX(-50%) translateY(-6px);
  background:#fff;min-width:340px;border-radius:var(--radius-lg);padding:14px;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);
  opacity:0;visibility:hidden;transition:opacity .18s ease,transform .18s ease,visibility .18s 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:2px;padding:14px 18px;border-radius:14px;
  font-size:15px;color:var(--ink);font-weight:700;
}
.dropdown-panel a small{display:block;font-weight:400;color:var(--warm-2);font-size:13px;margin-top:2px}
.dropdown-panel a:hover{background:var(--cream-2);color:var(--red)}

.menu-toggle{display:none;background:transparent;border:0;padding:8px;cursor:pointer}
.menu-toggle span{display:block;width:24px;height:2.5px;background:var(--ink);margin:5px 0;border-radius:2px}
@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(--line);max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 16px;gap:0}
  .nav.open{max-height:600px;padding:8px 16px}
  .nav>li>a,.nav>li>button{padding:16px 18px;width:100%;justify-content:space-between;border-radius:14px}
  .nav-cta{margin:14px 16px;width:calc(100% - 32px)}
  .dropdown-panel{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;background:var(--cream-2);min-width:0;display:none;padding:8px}
  .has-dropdown.open .dropdown-panel{display:block}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;
  padding:15px 26px;font-size:15px;font-weight:700;letter-spacing:-.005em;
  border:2px solid transparent;border-radius:var(--radius-pill);transition:all .2s ease;cursor:pointer;font-family:var(--display);
}
.btn-primary{background:var(--grad-warm);color:#fff;box-shadow:var(--shadow-warm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 50px rgba(221,0,0,.18)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-outline{background:#fff;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-soft{background:#fff;color:var(--red);border-color:var(--red-soft)}
.btn-soft:hover{background:var(--red-soft)}
.btn-ghost-light{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.28)}
.btn-whatsapp{background:#25d366;color:#fff}
.btn-whatsapp:hover{background:#1fb957;transform:translateY(-2px)}
.btn-link{padding:0;background:transparent;color:var(--red);font-weight:700;font-size:15px;border:0;display:inline-flex;align-items:center;gap:8px;border-radius:0}
.btn-link:hover{color:var(--red-2);gap:12px}

/* ---------- Hero ---------- */
.hero{padding:64px 0 96px;background:linear-gradient(180deg,var(--cream) 0%,var(--bg) 100%);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:0;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(255,206,0,.20) 0%,transparent 60%);z-index:0}
.hero::after{content:"";position:absolute;bottom:-300px;left:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(221,0,0,.10) 0%,transparent 60%);z-index:0}
.hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.hero h1{max-width:14ch}
.hero .lead{margin-top:24px;max-width:54ch;font-size:21px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.hero-trust{display:flex;align-items:center;gap:16px;margin-top:40px;color:var(--warm);font-size:14.5px;flex-wrap:wrap}
.hero-trust .dots{display:inline-flex}
.hero-trust .dots span{width:34px;height:34px;border-radius:50%;background:var(--cream-2);border:3px solid #fff;display:inline-block;margin-left:-8px;background-size:cover}
.hero-trust .dots span:first-child{margin-left:0;background:var(--gold)}
.hero-trust .dots span:nth-child(2){background:var(--red)}
.hero-trust .dots span:nth-child(3){background:var(--ink)}
.hero-visual{position:relative;width:100%;justify-self:end;max-width:560px}
.hero-visual .frame{aspect-ratio:1/1.15;border-radius:var(--radius-lg);overflow:hidden;position:relative;box-shadow:var(--shadow-lg)}
.hero-visual .frame img{width:100%;height:100%;object-fit:cover}
.hero-visual .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(221,0,0,.08) 100%)}
.hero-visual .floating{position:absolute;background:#fff;border-radius:18px;padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;max-width:240px}
.hero-visual .floating-1{top:24px;left:-30px;animation:float 6s ease-in-out infinite}
.hero-visual .floating-2{bottom:60px;right:-30px;animation:float 6s ease-in-out infinite 3s}
.hero-visual .floating .emoji{width:42px;height:42px;background:var(--gold-soft);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex:0 0 auto}
.hero-visual .floating-2 .emoji{background:var(--red-soft)}
.hero-visual .floating strong{display:block;font-size:14px;color:var(--ink);font-weight:700;line-height:1.2}
.hero-visual .floating small{display:block;font-size:12px;color:var(--warm-2);margin-top:2px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media (max-width:960px){
  .hero .container{grid-template-columns:1fr;gap:48px}
  .hero-visual{justify-self:center;max-width:480px}
  .hero-visual .frame{aspect-ratio:4/3}
}

/* ---------- Warum (3 cards) ---------- */
.warum{background:#fff}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.pillar{background:var(--cream);border-radius:var(--radius-lg);padding:36px;transition:all .25s ease;border:1px solid transparent}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold)}
.pillar:nth-child(2){background:var(--red-soft)}
.pillar:nth-child(3){background:var(--gold-soft)}
.pillar .ico{width:52px;height:52px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.pillar h3{margin-bottom:12px}
.pillar p{color:var(--warm);font-size:15px;margin:0;line-height:1.65}
@media (max-width:880px){.pillars{grid-template-columns:1fr}}

/* ---------- Alles aus einer Hand ---------- */
.alles{background:var(--beige)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:48px}
.service-cell{background:#fff;border-radius:var(--radius);padding:24px;transition:all .25s ease;display:flex;flex-direction:column;gap:10px;cursor:default}
.service-cell:hover{transform:translateY(-3px);box-shadow:var(--shadow);background:linear-gradient(180deg,#fff 0%,var(--cream) 100%)}
.service-cell .icon{width:48px;height:48px;border-radius:14px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:8px}
.service-cell h4{margin:0;font-size:16.5px}
.service-cell p{color:var(--warm);font-size:14px;margin:0;line-height:1.55}

/* ---------- Split sections (warm) ---------- */
.split{padding:96px 0}
.split.unternehmen{background:#fff}
.split.fachkraefte{background:var(--cream)}
.split .container{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.reverse .container>*:first-child{order:2}
.split .media{aspect-ratio:5/4;background:#222 center/cover no-repeat;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.split .media::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(221,0,0,.08) 100%)}
.split.unternehmen .media{background-image:url("https://images.unsplash.com/photo-1521737711867-e3b97375f902?w=1400&q=80&auto=format&fit=crop"),linear-gradient(135deg,var(--cream-2),var(--gold-soft));background-size:cover;background-position:center}
.split.fachkraefte .media{background-image:url("https://images.unsplash.com/photo-1521791136064-7986c2920216?w=1400&q=80&auto=format&fit=crop"),linear-gradient(135deg,var(--red-soft),var(--gold-soft));background-size:cover;background-position:center}
.split .content h2{margin-bottom:18px}
.split .content ul{list-style:none;padding:0;margin:24px 0 32px;display:grid;gap:14px}
.split .content ul li{display:flex;gap:14px;align-items:flex-start;color:var(--ink);font-size:16px}
.split .content ul li::before{content:"✓";flex:0 0 32px;width:32px;height:32px;background:var(--grad-warm);color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
@media (max-width:960px){.split .container{grid-template-columns:1fr;gap:40px}.split.reverse .container>*:first-child{order:0}}

/* ---------- About synthese ---------- */
.about-syn{background:#fff;position:relative}
.about-syn .container{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center}
.about-syn .photo-wrap{position:relative;aspect-ratio:4/5}
.about-syn .photo-wrap .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,var(--cream-2),var(--gold-soft));background-size:cover;background-position:center;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.about-syn .photo-wrap .deco{position:absolute;width:100%;height:100%;border-radius:var(--radius-lg);top:24px;left:24px;background:var(--grad-warm);z-index:-1}
.about-syn blockquote{font-family:var(--display);font-size:28px;line-height:1.35;color:var(--ink);margin:0 0 20px;font-weight:700;letter-spacing:-.02em}
.about-syn blockquote::before{content:"„";font-size:64px;color:var(--red);line-height:1;display:block;margin-bottom:-20px}
@media (max-width:960px){.about-syn .container{grid-template-columns:1fr;gap:40px}.about-syn .photo-wrap{max-width:400px;margin:0 auto}}

/* ---------- Vision ---------- */
.vision{background:var(--grad-warm);color:#fff;position:relative;overflow:hidden}
.vision::before{content:"";position:absolute;top:-150px;right:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18) 0%,transparent 70%)}
.vision::after{content:"";position:absolute;bottom:-200px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(0,0,0,.18) 0%,transparent 70%)}
.vision .container{position:relative;z-index:2}
.vision h2{color:#fff}
.vision .lead{color:rgba(255,255,255,.92);max-width:64ch}
.vision .eyebrow{background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(8px)}

/* ---------- Kontakt home ---------- */
.kontakt-home{background:var(--beige)}
.kontakt-home .container{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.kontakt-card{background:#fff;border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow)}
.kontakt-card h3{margin-bottom:6px}
.kontakt-list{list-style:none;padding:0;margin:24px 0 0}
.kontakt-list li{padding:14px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;font-size:15px;gap:12px;flex-wrap:wrap;align-items:center}
.kontakt-list li:last-child{border-bottom:0}
.kontakt-list li span:first-child{color:var(--warm-2);font-size:12.5px;letter-spacing:.06em;font-weight:700;text-transform:uppercase}
.kontakt-list li a{color:var(--ink);font-weight:700}
.kontakt-list li a:hover{color:var(--red)}
@media (max-width:880px){.kontakt-home .container{grid-template-columns:1fr;gap:40px}}

/* ---------- Form ---------- */
.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label{display:block;font-size:13.5px;color:var(--ink);font-weight:700;margin-bottom:8px}
.form .req{color:var(--red);margin-left:3px}
.form input,.form textarea,.form select{
  width:100%;background:#fff;border:2px solid var(--line);border-radius:14px;
  padding:14px 16px;font-family:var(--sans);font-size:15.5px;color:var(--ink);
  outline:0;transition:border-color .15s ease,box-shadow .15s ease;
}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.form textarea{resize:vertical;min-height:140px}
.form .consent{display:flex;gap:14px;align-items:flex-start;font-size:14px;color:var(--warm);line-height:1.55;margin-top:4px;background:var(--cream);border:2px solid var(--line);border-radius:14px;padding:16px}
.form .consent input[type="checkbox"]{margin-top:3px;flex:0 0 auto;accent-color:var(--red);width:20px;height:20px}
.form .consent a{color:var(--red);text-decoration:underline;text-underline-offset:3px;font-weight:700}
.form .submit-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px}
.form .legal-note{font-size:13px;color:var(--warm-2);line-height:1.55}
.form .error{display:none;font-size:13px;color:var(--red);margin-top:6px;font-weight:600}
.form .field.error input,.form .field.error textarea{border-color:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.form .field.error .error{display:block}
.form-success{padding:28px;background:var(--gold-soft);border-radius:var(--radius);font-size:16px;display:none;margin-bottom:24px;border:2px solid var(--gold)}
.form-success.show{display:block}
.form-success.show + .form{display:none}
@media (max-width:680px){.form .row{grid-template-columns:1fr}}

/* ---------- Page hero ---------- */
.page-hero{background:linear-gradient(180deg,var(--cream) 0%,var(--bg) 100%);padding:96px 0 64px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-100px;right:-100px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,206,0,.20) 0%,transparent 60%)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{max-width:18ch;font-size:clamp(40px,5vw,64px)}
.page-hero .lead{max-width:62ch;margin-top:14px}
.crumbs{font-size:13.5px;color:var(--warm-2);margin-bottom:20px;font-weight:600}
.crumbs a{color:var(--warm-2)}
.crumbs a:hover{color:var(--red)}
.crumbs span{margin:0 8px;color:var(--line)}

/* ---------- Service detail ---------- */
.service-detail{padding:96px 0;background:#fff}
.service-detail .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.service-card{background:var(--cream);border-radius:var(--radius-lg);padding:36px;transition:all .25s ease;display:flex;flex-direction:column}
.service-card:nth-child(odd){background:var(--cream-2)}
.service-card:nth-child(3n){background:var(--red-soft)}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.service-card .num{font-family:var(--display);font-size:13px;color:var(--red);font-weight:800;margin-bottom:14px;letter-spacing:.05em}
.service-card h3{font-size:22px;margin-bottom:10px}
.service-card p{color:var(--warm);font-size:15px;margin:0 0 10px;line-height:1.65}
.service-card .icon{width:56px;height:56px;background:#fff;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:20px;box-shadow:var(--shadow-sm)}

/* ---------- About page ---------- */
.about-page-intro{padding:96px 0;background:#fff}
.about-page-intro p{font-size:18px;color:var(--warm);line-height:1.75}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:48px}
.value{padding:32px;background:#fff;border-radius:var(--radius);transition:all .25s ease;border:2px solid var(--line)}
.value:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}
.value .emoji{font-size:36px;margin-bottom:12px;display:block}
.value h4{margin-bottom:8px}

/* ---------- Floating WhatsApp ---------- */
.float-whatsapp{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(37,211,102,.35);z-index:100;transition:transform .2s ease}
.float-whatsapp:hover{transform:scale(1.1)}
.float-whatsapp svg{width:30px;height:30px;fill:currentColor}

/* ---------- 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(--display);font-size:13px;letter-spacing:.06em;margin:0 0 16px;font-weight:700;text-transform:uppercase}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{padding:6px 0;font-size:14.5px}
.site-footer ul li a:hover{color:var(--gold)}
.site-footer .brand-block img{height:38px;width:auto;filter:invert(1) brightness(2)}
.site-footer .brand-block p{font-size:14px;margin-top:18px;max-width:32ch;line-height:1.65}
.site-footer .legal{padding-top:24px;font-size:13px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
.site-footer .legal a{color:rgba(255,255,255,.7)}
.site-footer .legal a:hover{color:var(--gold)}
@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:#fff}
.legal-page h2{font-size:26px;margin-top:48px;margin-bottom:14px}
.legal-page h3{font-size:18px;margin-top:32px;margin-bottom:8px;font-weight:700}
.legal-page p,.legal-page li{font-size:15.5px;color:var(--warm);line-height:1.75}
.legal-page ul{padding-left:20px}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}
