/* =========================================================
   MINK Orthopädieschuhtechnik — Design System
   Premium, warm, vertrauenswürdig. Marke: Grün (Logo #18C52B).
   ========================================================= */

/* ---------- Fonts (selbstgehostet, DSGVO) ---------- */
@font-face{
  font-family:"Fraunces";
  src:url("../fonts/Fraunces.woff2") format("woff2");
  font-weight:300 800; font-display:swap; font-style:normal;
}
@font-face{
  font-family:"Manrope";
  src:url("../fonts/Manrope.woff2") format("woff2");
  font-weight:300 800; font-display:swap; font-style:normal;
}

/* ---------- Tokens ---------- */
:root{
  --green:#18a531;          /* Marken-Grün, etwas edler als Logo */
  --green-bright:#22c43e;
  --green-deep:#0c6a22;
  --green-ink:#0c2417;      /* sehr dunkles Tannengrün */
  --ink:#13211a;
  --text:#283a31;
  --muted:#5d7167;
  --cream:#f6f9f3;
  --cream-2:#eef3ea;
  --sage:#e3ece0;
  --line:#dde6d9;
  --white:#ffffff;
  --brass:#b08a2e;          /* nur sparsam: Jubiläum/Seit 1925 */

  --maxw:1240px;
  --gap:clamp(1rem,3vw,2rem);
  --radius:18px;
  --radius-lg:28px;
  --radius-sm:12px;

  --shadow-sm:0 2px 10px rgba(12,36,23,.06);
  --shadow:0 18px 50px -20px rgba(12,36,23,.30);
  --shadow-lg:0 40px 90px -30px rgba(12,36,23,.45);

  --ease:cubic-bezier(.22,.61,.36,1);
  --fast:.25s var(--ease);
  --slow:.7s var(--ease);

  --h1:clamp(2.4rem,6vw,4.6rem);
  --h2:clamp(1.9rem,4vw,3.1rem);
  --h3:clamp(1.25rem,2.2vw,1.7rem);

  --font-serif:"Fraunces",Georgia,"Times New Roman",serif;
  --font-sans:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:clip}
body{
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  font-size:17px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
:focus-visible{outline:3px solid var(--green);outline-offset:3px;border-radius:4px}

h1,h2,h3,h4{font-family:var(--font-serif);color:var(--ink);line-height:1.08;font-weight:600;letter-spacing:-.01em}
h1{font-size:var(--h1)}
h2{font-size:var(--h2)}
h3{font-size:var(--h3)}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.4rem)}
.section{padding:clamp(3.5rem,8vw,7rem) 0}
.section--tight{padding:clamp(2.5rem,5vw,4rem) 0}
.center{text-align:center}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--muted);line-height:1.75}

.kicker{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-sans);font-weight:700;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--green-deep);
}
.kicker::before{content:"";width:30px;height:2px;background:var(--green);display:inline-block;border-radius:2px}
.kicker--center{justify-content:center}
.kicker--light{color:#9ce8ab}
.kicker--light::before{background:var(--green-bright)}

.eyebrow-mark{color:var(--green)}

/* ---------- Buttons ---------- */
.btn{
  --c:var(--white);
  display:inline-flex;align-items:center;gap:.6rem;
  font-weight:700;font-size:.95rem;letter-spacing:.01em;
  padding:.95rem 1.6rem;border-radius:100px;
  transition:transform var(--fast),box-shadow var(--fast),background var(--fast),color var(--fast);
  will-change:transform;
}
.btn svg{width:18px;height:18px}
.btn--primary{
  background:linear-gradient(135deg,var(--green-bright),var(--green-deep));
  color:#fff;box-shadow:0 12px 28px -10px rgba(12,106,34,.7);
}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 20px 38px -12px rgba(12,106,34,.75)}
.btn--ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn--ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}
.btn--dark{background:var(--green-ink);color:#fff}
.btn--dark:hover{transform:translateY(-3px);background:#11331f}
.btn--outline{border:1.5px solid var(--line);color:var(--ink);background:#fff}
.btn--outline:hover{border-color:var(--green);color:var(--green-deep);transform:translateY(-3px)}
.btn--lg{padding:1.1rem 2rem;font-size:1.02rem}

.arrow-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--green-deep)}
.arrow-link svg{width:18px;height:18px;transition:transform var(--fast)}
.arrow-link:hover svg{transform:translateX(5px)}

/* =========================================================
   TOPBAR + HEADER
   ========================================================= */
.topbar{
  background:var(--green-ink);color:#cfe9d5;
  font-size:.82rem;font-weight:500;
}
.topbar .container{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;align-items:center;justify-content:center;padding-block:.5rem}
.topbar a{color:#cfe9d5;display:inline-flex;align-items:center;gap:.4rem;transition:color var(--fast)}
.topbar a:hover{color:#fff}
.topbar .sep{opacity:.35}
.topbar svg{width:14px;height:14px;opacity:.8}

.site-header{
  position:sticky;top:0;z-index:60;
  transition:background var(--fast),box-shadow var(--fast),padding var(--fast);
  background:rgba(246,249,243,.96);backdrop-filter:saturate(1.4) blur(12px);box-shadow:0 4px 24px -16px rgba(12,36,23,.45);
}
.site-header .bar{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding-block:clamp(.7rem,1.4vw,1.05rem);
}
.brand{display:flex;align-items:center;gap:.7rem;z-index:2}
.brand img{height:clamp(40px,5vw,56px);width:auto;transition:filter var(--fast)}
/* Over hero: header transparent, logo on dark needs to stay visible (logo is green on transparent → fine on dark) */
.site-header.over-hero{background:rgba(246,249,243,.96)}
.site-header.over-hero .nav-link{color:var(--ink)}
.site-header.scrolled{
  background:rgba(246,249,243,.92);
  backdrop-filter:saturate(1.4) blur(12px);
  box-shadow:0 6px 30px -18px rgba(12,36,23,.5);
}

/* Primary nav */
.nav{display:flex;align-items:center;gap:clamp(.4rem,1.4vw,1.6rem)}
.nav-list{display:flex;align-items:center;gap:clamp(.2rem,1vw,.6rem)}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:.35rem;
  font-weight:700;font-size:.86rem;letter-spacing:.05em;text-transform:uppercase;
  color:var(--ink);padding:.7rem .8rem;border-radius:10px;
  transition:color var(--fast),background var(--fast);
}
.nav-link:hover,.nav-item.active>.nav-link{color:var(--green-deep)}
.nav-link .chev{width:14px;height:14px;transition:transform var(--fast)}
.nav-item.has-mega:hover .nav-link .chev{transform:rotate(180deg)}
.nav-link.is-current::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.35rem;height:2px;background:var(--green);border-radius:2px}

/* Mega dropdown (CSS hover) */
.mega{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(12px);
  min-width:640px;max-width:92vw;
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);border:1px solid var(--line);
  padding:1.4rem;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .28s var(--ease),transform .28s var(--ease),visibility .28s;
  z-index:80;
}
.nav-item.has-mega::after{content:"";position:absolute;top:100%;left:0;right:0;height:22px} /* hover bridge */
.nav-item.has-mega:hover .mega,.nav-item.has-mega:focus-within .mega{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(10px);
}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}
.mega-item{
  display:flex;gap:.85rem;align-items:flex-start;
  padding:.7rem .8rem;border-radius:14px;transition:background var(--fast),transform var(--fast);
}
.mega-item:hover{background:var(--cream-2)}
.mega-ic{
  flex:0 0 40px;height:40px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,#e8f7ec,#d4efdb);color:var(--green-deep);
}
.mega-ic svg{width:21px;height:21px}
.mega-tx b{display:block;font-size:.95rem;color:var(--ink);font-weight:700;line-height:1.2}
.mega-tx span{display:block;font-size:.8rem;color:var(--muted);margin-top:.15rem;line-height:1.35}
.mega-foot{
  margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.mega-foot span{font-size:.9rem;color:var(--muted)}

.header-cta{display:flex;align-items:center;gap:.8rem}
.header-cta .btn{padding:.7rem 1.25rem;font-size:.85rem}

/* Burger */
.burger{display:none;width:46px;height:46px;border-radius:12px;flex-direction:column;gap:5px;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform var(--fast),opacity var(--fast)}
.over-hero .burger{background:#fff;border-color:var(--line)}
.over-hero .burger span{background:var(--ink)}

/* Mobile drawer */
.mnav{position:fixed;inset:0;z-index:90;visibility:hidden;pointer-events:none}
.mnav-overlay{position:absolute;inset:0;background:rgba(12,36,23,.5);opacity:0;transition:opacity var(--fast)}
.mnav-panel{
  position:absolute;top:0;right:0;height:100%;width:min(86vw,400px);
  background:var(--cream);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;padding:1.3rem;overflow-y:auto;
}
.mnav.open{visibility:visible;pointer-events:auto}
.mnav.open .mnav-overlay{opacity:1}
.mnav.open .mnav-panel{transform:translateX(0)}
.mnav-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.mnav-head img{height:42px}
.mnav-close{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:1.4rem;color:var(--ink);display:grid;place-items:center}
.mnav a.mlink{display:block;padding:.85rem .4rem;font-weight:700;font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--line);letter-spacing:.02em}
.macc{border-bottom:1px solid var(--line)}
.macc-head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.85rem .4rem;font-weight:700;font-size:1.05rem;color:var(--ink)}
.macc-head svg{width:18px;height:18px;transition:transform var(--fast)}
.macc.open .macc-head svg{transform:rotate(180deg)}
.macc-body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.macc-body a{display:block;padding:.6rem .4rem .6rem 1.1rem;color:var(--muted);font-weight:600;font-size:.97rem}
.macc-body a:hover{color:var(--green-deep)}
.mnav-cta{margin-top:1.4rem;display:grid;gap:.7rem}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:clamp(560px,90vh,880px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero--sub{min-height:clamp(420px,62vh,620px)}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:kenburns 18s var(--ease) infinite alternate}
@keyframes kenburns{from{transform:scale(1.04) translateY(0)}to{transform:scale(1.13) translateY(-2%)}}
.hero-overlay{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(8,28,18,.86) 0%,rgba(8,28,18,.62) 42%,rgba(8,28,18,.28) 100%);
}
.hero-overlay::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,28,18,.7),transparent 45%)}
.hero-inner{padding-block:clamp(5rem,12vh,8rem);max-width:780px}
.hero .kicker{color:#9ce8ab;margin-bottom:1.3rem}
.hero .kicker::before{background:var(--green-bright)}
.hero h1{color:#fff;font-weight:600;margin-bottom:1.4rem;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{font-style:italic;color:#a9ecb6;font-weight:500}
.hero-sub-txt{font-size:clamp(1.05rem,1.8vw,1.3rem);color:#e3f1e6;max-width:60ch;margin-bottom:2.2rem;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem}
.hero-badge{
  position:absolute;right:clamp(1rem,5vw,4rem);bottom:clamp(1rem,5vw,3rem);z-index:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:clamp(110px,15vw,160px);height:clamp(110px,15vw,160px);border-radius:50%;
  background:rgba(12,36,23,.55);border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px);
  text-align:center;color:#fff;
}
.hero-badge b{font-family:var(--font-serif);font-size:clamp(1.7rem,3vw,2.3rem);line-height:1;color:#a9ecb6}
.hero-badge span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.4rem;opacity:.85}
.scroll-cue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:1;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-cue .mouse{width:22px;height:36px;border:2px solid rgba(255,255,255,.6);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:7px;background:#fff;border-radius:2px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;top:6px}30%{opacity:1}60%{opacity:1;top:16px}100%{opacity:0;top:18px}}

/* Sub-page hero */
.hero--sub .hero-overlay{background:linear-gradient(105deg,rgba(8,28,18,.85),rgba(8,28,18,.5))}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.82rem;color:#bfe0c6;margin-bottom:1rem}
.breadcrumb a:hover{color:#fff}
.breadcrumb svg{width:13px;height:13px;opacity:.6}

/* =========================================================
   GENERIC SECTIONS
   ========================================================= */
.section-head{max-width:720px;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head.center{margin-inline:auto}
.section-head .kicker{margin-bottom:1rem}
.section-head p{margin-top:1rem}

/* Editorial alternating row */
.media-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,4rem);align-items:center}
.media-row+.media-row{margin-top:clamp(3rem,7vw,6rem)}
.media-row.flip .media-row-text{order:2}
.media-row.flip .media-row-media{order:1}
.media-row-text h2{margin-bottom:1.1rem}
.media-row-text p{margin-bottom:1rem;color:var(--text)}
.media-row-text p:last-child{margin-bottom:0}
.media-row-media{position:relative}
.media-row-media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.media-row-media .frame{position:absolute;inset:0;border-radius:var(--radius-lg);pointer-events:none;border:1px solid rgba(255,255,255,.4)}
.media-row-media.stack img+img{margin-top:1rem}

.feature-block{padding:clamp(2rem,4vw,3rem) 0;border-bottom:1px solid var(--line)}
.feature-block:last-child{border-bottom:none}

/* prose */
.prose h2{font-size:clamp(1.4rem,2.4vw,1.9rem);margin:2.2rem 0 .9rem}
.prose h3{font-size:clamp(1.15rem,2vw,1.4rem);margin:1.6rem 0 .6rem}
.prose h4{font-size:1.05rem;margin:1.3rem 0 .4rem;font-family:var(--font-sans);font-weight:800;color:var(--ink)}
.prose h5{font-size:.95rem;margin:1rem 0 .3rem;font-family:var(--font-sans);font-weight:800;color:var(--green-deep)}
.prose p{margin-bottom:1rem;color:var(--text)}
.prose strong{color:var(--ink);font-weight:700}
.prose a{color:var(--green-deep);font-weight:600;text-decoration:underline;text-underline-offset:3px;overflow-wrap:anywhere}
.prose ul{margin:.5rem 0 1.2rem;padding-left:0}
.prose li{position:relative;padding-left:1.6rem;margin-bottom:.5rem}
.prose li::before{content:"";position:absolute;left:0;top:.7em;width:7px;height:7px;border-radius:2px;background:var(--green);transform:rotate(45deg)}
.prose-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,3.2rem);box-shadow:var(--shadow-sm);max-width:900px;margin-inline:auto}

/* =========================================================
   CARDS — Leistungen grid
   ========================================================= */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:clamp(1rem,2vw,1.6rem)}
.card{
  position:relative;display:flex;flex-direction:column;
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform var(--fast),box-shadow var(--fast);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-img{aspect-ratio:16/11;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-img img{transform:scale(1.07)}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,28,18,.35),transparent 55%)}
.card-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.18rem;margin-bottom:.5rem}
.card-body p{font-size:.92rem;color:var(--muted);margin-bottom:1rem;flex:1}
.card .arrow-link{font-size:.86rem;text-transform:uppercase;letter-spacing:.05em}
.card-num{position:absolute;top:1rem;left:1rem;z-index:2;width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.92);color:var(--green-deep);font-weight:800;font-size:.85rem;display:grid;place-items:center}

/* =========================================================
   GALLERY + LIGHTBOX
   ========================================================= */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery figure{position:relative;border-radius:var(--radius);overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow-sm);background:#fff}
.gallery img{aspect-ratio:1/1;object-fit:cover;width:100%;transition:transform .6s var(--ease)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figure::after{content:"";position:absolute;inset:0;background:rgba(12,36,23,0);transition:background var(--fast)}
.gallery figure:hover::after{background:rgba(12,36,23,.12)}

.lightbox{position:fixed;inset:0;z-index:120;background:rgba(8,20,13,.92);display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity var(--fast)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px;box-shadow:var(--shadow-lg)}
.lightbox-close{position:absolute;top:1.3rem;right:1.5rem;color:#fff;font-size:2rem;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.3);display:grid;place-items:center}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2rem;width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;transition:background var(--fast)}
.lightbox-nav:hover{background:rgba(255,255,255,.15)}
.lb-prev{left:1.3rem}.lb-next{right:1.3rem}

/* =========================================================
   DARK BAND (Heritage / stats)
   ========================================================= */
.band{position:relative;background:var(--green-ink);color:#e7f3e9;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 80% at 85% 10%,rgba(34,196,62,.18),transparent 60%),
  radial-gradient(50% 60% at 10% 90%,rgba(34,196,62,.12),transparent 60%);}
.band .container{position:relative}
.band h2{color:#fff}
.band .lead{color:#bfe0c6}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:.5rem}
.stat{text-align:center;padding:1.4rem 1rem;border-radius:var(--radius);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.stat b{display:block;font-family:var(--font-serif);font-size:clamp(2rem,4vw,3rem);color:#a9ecb6;line-height:1}
.stat span{display:block;margin-top:.5rem;font-size:.85rem;letter-spacing:.06em;color:#bfe0c6}

/* =========================================================
   MARKEN / PARTNER LOGOS
   ========================================================= */
.marken{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1.6rem,5vw,3.5rem)}
.marken img{height:clamp(34px,5vw,52px);width:auto;opacity:.55;filter:grayscale(1);transition:opacity var(--fast),filter var(--fast)}
.marken img:hover{opacity:1;filter:grayscale(0)}

/* =========================================================
   ACTUELLES / NEWS
   ========================================================= */
.news{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.2rem,3vw,2rem)}
.news-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform var(--fast),box-shadow var(--fast)}
.news-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.news-card .ph{aspect-ratio:16/10;overflow:hidden}
.news-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.news-card:hover .ph img{transform:scale(1.06)}
.news-card .bd{padding:1.5rem 1.6rem 1.8rem}
.news-tag{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-deep);font-weight:800}
.news-card h3{margin:.6rem 0 .6rem;font-size:1.25rem}
.news-card p{color:var(--muted);font-size:.95rem}

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:start}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-sm)}
.info-row{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:none}
.info-ic{flex:0 0 44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#e8f7ec,#d4efdb);color:var(--green-deep);display:grid;place-items:center}
.info-ic svg{width:21px;height:21px}
.info-row b{display:block;color:var(--ink);font-weight:700;font-size:.95rem;margin-bottom:.15rem}
.info-row span,.info-row a{color:var(--muted);font-size:.95rem;line-height:1.55}
.info-row a:hover{color:var(--green-deep)}

.form{display:grid;gap:1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{display:block;font-size:.85rem;font-weight:700;color:var(--ink);margin-bottom:.35rem}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:.97rem;color:var(--text);background:var(--cream);transition:border var(--fast),background var(--fast);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green);background:#fff}
.form .check{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--muted)}
.form .check input{margin-top:.25rem}
.map-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-top:1.5rem;aspect-ratio:16/9;
  background:
    radial-gradient(circle at 30% 40%,rgba(34,196,62,.10),transparent 45%),
    radial-gradient(circle at 75% 70%,rgba(34,196,62,.08),transparent 45%),
    linear-gradient(0deg,var(--sage),var(--cream-2));
}
.map-wrap::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:38px 38px;mask-image:radial-gradient(circle at 50% 45%,#000,transparent 75%)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.92)}
.map-cta{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;text-align:center;padding:1rem;color:var(--text);transition:background var(--fast)}
.map-cta:hover{background:rgba(255,255,255,.25)}
.map-cta .map-pin{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--green-bright),var(--green-deep));color:#fff;display:grid;place-items:center;box-shadow:0 12px 26px -8px rgba(12,106,34,.7);margin-bottom:.5rem}
.map-cta .map-pin svg{width:26px;height:26px}
.map-cta b{font-family:var(--font-serif);font-size:1.1rem;color:var(--ink)}
.map-cta>span{font-size:.92rem;color:var(--muted)}
.map-cta .map-load-btn{margin-top:.7rem;display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:#fff;background:var(--green-deep);padding:.6rem 1.1rem;border-radius:100px;font-size:.9rem}
.map-cta .map-load-btn svg{width:16px;height:16px}
.map-cta small{margin-top:.5rem;font-size:.72rem;color:var(--muted);opacity:.8}
.map-open{position:absolute;bottom:.9rem;right:.9rem;z-index:3;display:inline-flex;align-items:center;gap:.4rem;background:#fff;color:var(--green-deep);font-weight:700;font-size:.82rem;padding:.5rem .9rem;border-radius:100px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.map-open svg{width:15px;height:15px}
.map-open:hover{color:var(--green-bright)}

/* =========================================================
   CTA strip
   ========================================================= */
.cta{position:relative;border-radius:var(--radius-lg);overflow:hidden;color:#fff;padding:clamp(2.4rem,5vw,4rem);background:linear-gradient(120deg,var(--green-deep),var(--green-ink))}
.cta::after{content:"";position:absolute;inset:0;background:radial-gradient(50% 120% at 90% 10%,rgba(34,196,62,.3),transparent 60%)}
.cta>*{position:relative}
.cta h2{color:#fff;max-width:18ch}
.cta p{color:#cfe9d5;margin:.9rem 0 1.6rem;max-width:55ch}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--green-ink);color:#bcd6c2;padding-top:clamp(3rem,6vw,5rem)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2rem}
.footer h4{color:#fff;font-family:var(--font-sans);font-weight:800;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-brand img{height:54px;margin-bottom:1rem;filter:brightness(0) invert(1) }
.footer-brand p{font-size:.92rem;line-height:1.7;color:#a9c4af;max-width:34ch}
.footer-col a,.footer-col p{display:block;color:#bcd6c2;font-size:.92rem;padding:.3rem 0;transition:color var(--fast)}
.footer-col a:hover{color:#fff}
.footer-contact a,.footer-contact p{display:flex;gap:.6rem;align-items:flex-start;color:#bcd6c2;font-size:.92rem;padding:.3rem 0}
.footer-contact svg{width:16px;height:16px;margin-top:.2rem;color:#7fcf91;flex:0 0 16px}
.footer-bottom{margin-top:clamp(2rem,4vw,3rem);border-top:1px solid rgba(255,255,255,.1);padding:1.4rem 0;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:.82rem;color:#8fae96}
.footer-legal{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer-legal a{font-size:.82rem;color:#8fae96}
.footer-legal a:hover{color:#fff}

/* =========================================================
   WHATSAPP / FAB phone
   ========================================================= */
.fab{position:fixed;right:1.2rem;bottom:1.2rem;z-index:70;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--green-bright),var(--green-deep));color:#fff;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(12,106,34,.7);transition:transform var(--fast)}
.fab:hover{transform:scale(1.08)}
.fab svg{width:26px;height:26px}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1040px){
  .nav-list,.header-cta .btn--phone{display:none}
  .burger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  body{font-size:16px}
  .topbar .container{font-size:.74rem;gap:.2rem .8rem}
  .topbar .hide-sm{display:none}
  .media-row{grid-template-columns:1fr}
  .media-row.flip .media-row-text{order:1}
  .media-row.flip .media-row-media{order:2}
  .media-row-media img{aspect-ratio:16/11}
  .contact-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .hero-badge{width:96px;height:96px}
  .cta{padding:2rem 1.4rem}
}
/* Parallax/heavy effects only on capable devices */
@media (hover:hover) and (pointer:fine){
  .hero-bg img{will-change:transform}
}
@media (hover:none){
  .hero-bg img{animation:none;transform:scale(1.04)}
}

/* =========================================================
   COOKIE CONSENT
   ========================================================= */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;transform:translateY(115%);transition:transform .45s var(--ease);padding-bottom:env(safe-area-inset-bottom)}
.cookie-banner.show{transform:none}
.cookie-inner{max-width:var(--maxw);margin:0 auto 1rem;margin-inline:clamp(.8rem,3vw,2rem);background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.1rem 1.3rem;display:flex;gap:1.2rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cookie-tx b{font-family:var(--font-serif);font-size:1.08rem;color:var(--ink)}
.cookie-tx p{font-size:.85rem;color:var(--muted);margin-top:.25rem;line-height:1.55;max-width:62ch}
.cookie-tx a{color:var(--green-deep);text-decoration:underline;text-underline-offset:2px}
.cookie-btns{display:flex;gap:.7rem;flex-shrink:0}
.cookie-btns .btn{padding:.7rem 1.25rem;font-size:.85rem}
#cookieSettingsLink{cursor:pointer}
@media (max-width:680px){
  .cookie-inner{flex-direction:column;align-items:stretch;gap:.9rem}
  .cookie-btns .btn{flex:1;justify-content:center}
}
