/* ==========================================================================
   rupp-honig.de  ·  Design-System
   Imkerei Florian & Patrick Rupp · Obersulm
   Gebaut von web-emotions.com
   ========================================================================== */

/* ---------- Fonts (selbst gehostet, datenschutzfreundlich) ---------------- */
@font-face{
  font-family:'Fraunces';
  src:url('../fonts/fraunces.woff2') format('woff2');
  font-weight:100 900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Inter';
  src:url('../fonts/inter.woff2') format('woff2');
  font-weight:100 900; font-style:normal; font-display:swap;
}

/* ---------- Tokens -------------------------------------------------------- */
:root{
  --ink:#1c1813;
  --ink-2:#3a332a;
  --ink-3:#6b6255;
  --paper:#faf5ec;
  --paper-2:#f2e9d8;
  --paper-3:#ece0c9;
  --card:#fffdf8;
  --honey:#c9961f;
  --honey-deep:#9a6f12;
  --honey-glow:#f4c64e;
  --violet:#6f6ea8;
  --line:rgba(28,24,19,.12);
  --line-2:rgba(28,24,19,.22);

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --container:1240px;
  --gap:clamp(1.4rem,3.2vw,2.6rem);
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 1px 2px rgba(28,24,19,.04),0 14px 40px -18px rgba(28,24,19,.30);
  --shadow-lg:0 30px 80px -30px rgba(28,24,19,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset --------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:clamp(1rem,.55vw + .9rem,1.12rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none;padding:0}
::selection{background:var(--honey-glow);color:var(--ink)}

/* ---------- Typo ---------------------------------------------------------- */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:540;
  line-height:1.04;
  letter-spacing:-.015em;
  font-optical-sizing:auto;
  color:var(--ink);
  text-wrap:balance;
}
.display{
  font-size:clamp(2.7rem,7vw,5.6rem);
  font-weight:560;
  line-height:.98;
}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.85rem)}
.lead{
  font-size:clamp(1.15rem,1.6vw,1.4rem);
  line-height:1.55;
  color:var(--ink-2);
  font-weight:400;
}
em,.it{font-style:italic}
.serif{font-family:var(--serif)}

/* ---------- Layout helpers ----------------------------------------------- */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-wide{width:min(100% - 1.6rem,1500px);margin-inline:auto}
.section{padding-block:clamp(4.5rem,9vw,8.5rem)}
.section-sm{padding-block:clamp(3rem,6vw,5rem)}
.stack>*+*{margin-top:1.1em}
.center{text-align:center}
.measure{max-width:64ch}
.measure-sm{max-width:48ch}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);
  font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--honey-deep);
  margin-bottom:1.1rem;
}
.eyebrow::before{
  content:"";width:26px;height:1px;background:var(--honey);opacity:.7;
}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--honey);opacity:.7}

/* ---------- Buttons ------------------------------------------------------- */
.btn{
  --bg:var(--ink);--fg:var(--paper);
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  letter-spacing:.01em;
  padding:.92rem 1.6rem;border-radius:100px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s;
  will-change:transform;
}
.btn svg{width:18px;height:18px;transition:transform .4s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 30px -14px rgba(28,24,19,.55)}
.btn:hover svg{transform:translateX(4px)}
.btn--honey{--bg:var(--honey);--fg:#1c1813}
.btn--honey:hover{--bg:var(--honey-glow)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border:1.5px solid var(--line-2)}
.btn--ghost:hover{--bg:var(--ink);--fg:var(--paper);border-color:var(--ink)}
.btn--light{--bg:rgba(255,255,255,.12);--fg:#fff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn--light:hover{--bg:#fff;--fg:var(--ink);border-color:#fff}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;color:var(--honey-deep);
  border-bottom:1.5px solid transparent;padding-bottom:2px;
  transition:gap .3s var(--ease),border-color .3s;
}
.link-arrow:hover{gap:.85rem;border-color:var(--honey)}

/* ---------- Honeycomb pattern -------------------------------------------- */
.hexbg{position:relative;isolation:isolate}
.hexbg::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100' viewBox='0 0 56 100'%3E%3Cg fill='none' stroke='%23c9961f' stroke-width='1.4'%3E%3Cpath d='M28 0L52 14v28L28 56 4 42V14z'/%3E%3Cpath d='M28 56l24 14v28M28 56L4 70v28'/%3E%3C/g%3E%3C/svg%3E");
  background-size:56px 100px;opacity:.05;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .5s var(--ease),box-shadow .5s,padding .5s var(--ease);
  padding:1.15rem 0;
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{position:relative;display:flex;align-items:center;z-index:2}
.brand img{height:48px;width:auto;transition:opacity .35s var(--ease)}
.brand .logo-dark{position:absolute;left:0;top:50%;transform:translateY(-50%);opacity:0}
.nav{display:flex;align-items:center;gap:2.2rem}
.nav a{
  font-size:.95rem;font-weight:500;color:var(--nav-fg,#fff);
  position:relative;padding:.3rem 0;transition:color .3s;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;
  background:var(--honey);transition:width .35s var(--ease);
}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--honey-glow)}
.header__cta{display:flex;align-items:center;gap:1.4rem}

/* Scrolled state */
.header.is-solid{
  background:rgba(250,245,236,.98);
  box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(28,24,19,.5);
  padding:.6rem 0;
  --nav-fg:var(--ink-2);
}
.header.is-solid .nav a:hover{color:var(--ink)}
.header.is-solid .brand .logo-light,
.header--light .brand .logo-light{opacity:0}
.header.is-solid .brand .logo-dark,
.header--light .brand .logo-dark{opacity:1}
.header.is-solid .btn--light{--bg:var(--honey);--fg:#1c1813;border-color:transparent;backdrop-filter:none}
.header.is-solid .btn--light:hover{--bg:var(--honey-glow)}
/* On light pages (no hero) header is permanently solid via .header--light */
.header--light{
  --nav-fg:var(--ink-2);
  background:rgba(250,245,236,.98);
  box-shadow:0 1px 0 var(--line);
}

.nav-toggle{display:none;width:46px;height:46px;border-radius:50%;align-items:center;justify-content:center;z-index:2}
.nav-toggle span{position:relative;width:22px;height:2px;background:var(--nav-fg,#fff);border-radius:2px;transition:.3s var(--ease)}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:inherit;border-radius:2px;transition:.3s var(--ease)}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}
.is-solid .nav-toggle span,.header--light .nav-toggle span{background:var(--ink)}
/* Auf hellen/soliden Headern: dezente Hinterlegung, damit der Button klar erkennbar ist */
.header.is-solid .nav-toggle,.header--light .nav-toggle{background:rgba(28,24,19,.06)}

@media (max-width:880px){
  .header__cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:0;background:var(--ink);
    display:flex;flex-direction:column;justify-content:center;gap:1.4rem;
    transform:translateX(100%);transition:transform .55s var(--ease);
    --nav-fg:#fff;
  }
  .nav a{font-family:var(--serif);font-size:2rem;color:#fff}
  .nav a[aria-current="page"]{color:var(--honey-glow)}
  body.menu-open{overflow:hidden}
  body.menu-open .nav{transform:translateX(0)}
  body.menu-open .nav-toggle span{background:transparent}
  body.menu-open .nav-toggle span::before{top:0;transform:rotate(45deg);background:#fff}
  body.menu-open .nav-toggle span::after{top:0;transform:rotate(-45deg);background:#fff}
  body.menu-open .nav-toggle{position:fixed;right:max(.8rem,calc((100vw - var(--container))/2));top:1rem}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,16,11,.55) 0%,rgba(20,16,11,0) 28%),
    linear-gradient(0deg,rgba(20,16,11,.86) 2%,rgba(20,16,11,.30) 42%,rgba(20,16,11,.18) 100%);
}
.hero__inner{padding-block:clamp(7rem,16vh,11rem) clamp(3rem,7vh,5rem);width:100%}
.hero__eyebrow{color:var(--honey-glow);margin-bottom:1.4rem}
.hero__eyebrow::before{background:var(--honey-glow)}
.hero h1{color:#fff;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero__lead{color:rgba(255,255,255,.9);max-width:46ch;margin-top:1.6rem;font-size:clamp(1.1rem,1.5vw,1.35rem);line-height:1.55}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__scroll{
  position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.75);
}
.hero__scroll .mouse{width:24px;height:38px;border:1.5px solid rgba(255,255,255,.6);border-radius:14px;position:relative}
.hero__scroll .mouse::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;border-radius:3px;background:#fff;transform:translateX(-50%);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}
/* Scroll-Indikator nur auf groesseren Screens (auf Mobil stoert er) */
@media (max-width:880px){.hero__scroll{display:none}}
/* Hero auf Mobil: weniger Text, staerkerer Scrim, Bild im Fokus */
@media (max-width:640px){
  .hero__lead{display:none}
  .hero h1{font-size:clamp(2.5rem,9vw,3.4rem)}
  .hero__inner{padding-block:6.5rem 2.6rem}
  .hero__eyebrow{margin-bottom:1rem;font-size:.7rem}
  .hero__actions{margin-top:1.8rem;gap:.8rem}
  .hero__media::after{
    background:
      linear-gradient(180deg,rgba(20,16,11,.5) 0%,rgba(20,16,11,0) 24%),
      linear-gradient(0deg,rgba(20,16,11,.94) 0%,rgba(20,16,11,.4) 46%,rgba(20,16,11,.12) 100%);
  }
}

/* Page hero (interior, kompakter) */
.pagehero{position:relative;color:#fff;isolation:isolate;display:flex;align-items:flex-end;min-height:62vh}
.pagehero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.pagehero__media img{width:100%;height:100%;object-fit:cover}
.pagehero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,16,11,.82),rgba(20,16,11,.15) 70%,rgba(20,16,11,.4))}
.pagehero__inner{padding-block:clamp(7rem,14vh,9rem) clamp(2.6rem,6vh,4rem)}
.pagehero h1{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);max-width:18ch}
.pagehero p{color:rgba(255,255,255,.88);max-width:52ch;margin-top:1.1rem;font-size:1.18rem}
.pagehero .eyebrow{color:var(--honey-glow)}
.pagehero .eyebrow::before{background:var(--honey-glow)}

/* ==========================================================================
   GENERIC SECTIONS
   ========================================================================== */
.sectionhead{max-width:60ch}
.sectionhead.center{margin-inline:auto;text-align:center}
.sectionhead .lead{margin-top:1.2rem}

/* Split: text + media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:-1}
.split__media{position:relative}
.split__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;object-fit:cover}
.split__media .badge{position:absolute}
@media (max-width:820px){.split{grid-template-columns:1fr}.split--reverse .split__media{order:0}}

/* Figure with caption frame */
.framed{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.framed img{width:100%;display:block}
.framed figcaption{
  position:absolute;left:0;bottom:0;right:0;padding:1.4rem 1.6rem;color:#fff;
  background:linear-gradient(0deg,rgba(20,16,11,.75),transparent);
  font-size:.92rem;
}

/* Stat / float badge */
.floatcard{
  position:absolute;background:var(--card);border-radius:16px;padding:1rem 1.3rem;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.85rem;
}
.floatcard .num{font-family:var(--serif);font-size:2rem;font-weight:580;color:var(--honey-deep);line-height:1}
.floatcard small{display:block;font-size:.8rem;color:var(--ink-3);letter-spacing:.02em}

/* ---------- Claim band ---------------------------------------------------- */
.claim{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.claim .hexbg::before{opacity:.06}
.claim__inner{padding-block:clamp(4rem,8vw,7rem);position:relative}
.claim blockquote{
  font-family:var(--serif);font-weight:500;line-height:1.12;
  font-size:clamp(1.8rem,4.4vw,3.4rem);letter-spacing:-.02em;
  max-width:24ch;color:var(--paper);
}
.claim blockquote .hl{color:var(--honey-glow);font-style:italic}
.claim cite{display:block;margin-top:1.6rem;font-family:var(--sans);font-style:normal;font-size:.95rem;letter-spacing:.04em;color:rgba(250,245,236,.65)}
/* Zweispaltiger Claim-Block (Text + CTAs), stapelt auf Mobil */
.claim__split{display:grid;gap:2rem;grid-template-columns:1.4fr 1fr;align-items:center}
@media (max-width:760px){.claim__split{grid-template-columns:1fr;gap:1.6rem}}

/* ==========================================================================
   CARDS
   ========================================================================== */
.grid{display:grid;gap:var(--gap)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){
  .grid-2,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}
  .grid-3{grid-template-columns:1fr}
}

/* Value card */
.vcard{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.8rem;transition:transform .5s var(--ease),box-shadow .5s,border-color .4s;
}
.vcard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.vcard .ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  background:var(--paper-2);color:var(--honey-deep);margin-bottom:1.2rem;
}
.vcard .ico svg{width:26px;height:26px}
.vcard h3{font-size:1.3rem;margin-bottom:.5rem}
.vcard p{color:var(--ink-2);font-size:1rem}

/* Sorten card */
.sortcard{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--card);
  border:1px solid var(--line);box-shadow:var(--shadow);
  transition:transform .55s var(--ease),box-shadow .55s;display:flex;flex-direction:column;
}
.sortcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.sortcard__img{aspect-ratio:4/5;overflow:hidden;background:var(--paper-2)}
.sortcard__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.sortcard:hover .sortcard__img img{transform:scale(1.05)}
.sortcard__body{padding:1.5rem 1.5rem 1.7rem}
.sortcard__body h3{font-size:1.45rem}
.sortcard .tag{
  display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--honey-deep);background:var(--paper-2);padding:.3rem .7rem;border-radius:100px;margin-bottom:.9rem;
}
.sortcard p{color:var(--ink-2);font-size:.98rem;margin-top:.4rem}
.sortcard .notes{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.1rem}
.sortcard .notes span{font-size:.8rem;color:var(--ink-3);background:var(--paper);border:1px solid var(--line);padding:.25rem .65rem;border-radius:100px}
/* Horizontale Sorten-Karte (Honig-Seite) */
.sortcard--row{flex-direction:row}
.sortcard--row .sortcard__img{flex:0 0 42%;aspect-ratio:auto}
.sortcard--row .sortcard__img img{height:100%}
@media (max-width:640px){
  /* Sorten 2-spaltig: kompakte, hochformatige Karten */
  .sortcard--row{flex-direction:column}
  .sortcard--row .sortcard__img{flex:auto;aspect-ratio:1/1}
  .sortcard__body{padding:.85rem .8rem 1.05rem}
  .sortcard__body h3{font-size:1.1rem}
  .sortcard .tag{font-size:.62rem;margin-bottom:.5rem;padding:.25rem .55rem}
  .sortcard p{font-size:.84rem;line-height:1.45}
  .sortcard .notes{gap:.3rem;margin-top:.7rem}
  .sortcard .notes span{font-size:.68rem;padding:.18rem .5rem}
  /* Werte-Karten kompakter */
  .vcard{padding:1.3rem 1.1rem}
  .vcard .ico{width:44px;height:44px;border-radius:11px;margin-bottom:.9rem}
  .vcard .ico svg{width:22px;height:22px}
  .vcard h3{font-size:1.12rem}
  .vcard p{font-size:.88rem}
}

/* Process steps */
.steps{counter-reset:step;display:grid;gap:1.4rem}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;
  padding:1.6rem 0;border-top:1px solid var(--line);
}
.step:last-child{border-bottom:1px solid var(--line)}
.step__n{
  counter-increment:step;font-family:var(--serif);font-size:1.1rem;font-weight:600;
  width:48px;height:48px;border-radius:50%;border:1.5px solid var(--honey);
  color:var(--honey-deep);display:grid;place-items:center;flex:none;
}
.step__n::before{content:"0" counter(step)}
.step h3{font-size:1.3rem;margin-bottom:.35rem}
.step p{color:var(--ink-2);font-size:1rem;max-width:60ch}

/* Valley list (Region) */
.valleys{display:grid;gap:0;border-top:1px solid var(--line-2)}
.valley{
  display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;
  padding:1.7rem .4rem;border-bottom:1px solid var(--line);
  transition:padding-left .4s var(--ease),background .4s;
}
.valley:hover{padding-left:1.2rem;background:linear-gradient(90deg,var(--paper-2),transparent)}
.valley__idx{font-family:var(--serif);font-size:1.05rem;color:var(--honey-deep)}
.valley h3{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:520}
.valley p{color:var(--ink-2);font-size:.98rem;margin-top:.2rem;max-width:54ch}
.valley__tag{font-size:.8rem;color:var(--ink-3);white-space:nowrap}
@media (max-width:640px){.valley{grid-template-columns:auto 1fr}.valley__tag{display:none}}

/* Gallery / mosaic */
.mosaic{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;grid-auto-flow:dense}
.mosaic figure{overflow:hidden;border-radius:14px;position:relative;background:var(--paper-2)}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.mosaic figure:hover img{transform:scale(1.06)}
.m-a{grid-column:span 7;aspect-ratio:16/10}
.m-b{grid-column:span 5;aspect-ratio:4/5}
.m-c{grid-column:span 5;aspect-ratio:4/5}
.m-d{grid-column:span 7;aspect-ratio:16/10}
.m-w{grid-column:span 12;aspect-ratio:32/9}
@media (max-width:720px){.mosaic{grid-template-columns:repeat(2,1fr)}.m-a,.m-b,.m-c,.m-d{grid-column:span 1;aspect-ratio:1/1}.m-w{grid-column:span 2;aspect-ratio:16/9}}

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contactgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
@media (max-width:860px){.contactgrid{grid-template-columns:1fr}}
.infocard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow)}
.infoitem{display:flex;gap:1.1rem;padding:1.15rem 0;border-bottom:1px solid var(--line)}
.infoitem:last-child{border-bottom:0}
.infoitem .ico{width:46px;height:46px;border-radius:12px;background:var(--paper-2);color:var(--honey-deep);display:grid;place-items:center;flex:none}
.infoitem .ico svg{width:22px;height:22px}
.infoitem h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-bottom:.2rem}
.infoitem a,.infoitem p{font-size:1.12rem;color:var(--ink);font-weight:500}
.infoitem a:hover{color:var(--honey-deep)}

/* Form */
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--ink-2);margin-bottom:.45rem}
.field input,.field textarea,.field select{
  width:100%;font:inherit;font-size:1rem;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--line-2);border-radius:12px;
  padding:.85rem 1rem;transition:border-color .3s,box-shadow .3s,background .3s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--honey);background:#fff;
  box-shadow:0 0 0 4px rgba(201,150,31,.14);
}
.field textarea{resize:vertical;min-height:130px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:520px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:.85rem;color:var(--ink-3);margin-top:.4rem}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer{background:var(--ink);color:rgba(250,245,236,.72);padding-block:clamp(3.5rem,6vw,5rem) 2rem;position:relative;overflow:hidden}
.footer .hexbg::before{opacity:.05}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;position:relative}
@media (max-width:760px){.footer__top{grid-template-columns:1fr;gap:2rem}}
.footer img.flogo{height:56px;width:auto;margin-bottom:1.2rem}
.footer p{font-size:.96rem;max-width:38ch}
.footer h5{font-family:var(--sans);color:#fff;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:600}
.footer ul a,.footer address a{color:rgba(250,245,236,.72);font-style:normal;line-height:2.1;transition:color .3s}
.footer ul a:hover,.footer address a:hover{color:var(--honey-glow)}
/* Agentur-Credit (web-emotions) */
.footer__agency{
  display:flex;align-items:center;justify-content:space-between;gap:1rem 2rem;flex-wrap:wrap;
  margin-top:2.8rem;padding:1.5rem 0;
  border-top:1px solid rgba(250,245,236,.14);
}
.footer__agency p{font-size:.95rem;line-height:1.55;color:rgba(250,245,236,.72);max-width:64ch;margin:0}
.footer__agency p a{color:var(--honey-glow);font-weight:600;border-bottom:1px solid rgba(244,198,78,.35);transition:border-color .3s}
.footer__agency p a:hover{border-color:var(--honey-glow)}
.we-cta{
  white-space:nowrap;display:inline-flex;align-items:center;gap:.45rem;flex:none;
  font-weight:600;font-size:.92rem;color:#fff;
  border:1px solid rgba(250,245,236,.32);border-radius:100px;padding:.6rem 1.2rem;
  transition:background .3s var(--ease),color .3s,border-color .3s,transform .3s var(--ease);
}
.we-cta:hover{background:var(--honey);color:var(--ink);border-color:var(--honey);transform:translateY(-2px)}

.footer__bottom{
  display:flex;flex-wrap:wrap;gap:.8rem 1.6rem;justify-content:space-between;align-items:center;
  margin-top:1.3rem;
  font-size:.85rem;color:rgba(250,245,236,.5);position:relative;
}
.footer__bottom .web-emotions a{color:rgba(250,245,236,.8);font-weight:600}
.footer__bottom .web-emotions a:hover{color:var(--honey-glow)}
.footer__bottom a:hover{color:var(--honey-glow)}
.web-emotions{color:rgba(250,245,236,.5)}
.web-emotions b{color:rgba(250,245,236,.8);font-weight:600}

/* ==========================================================================
   REVEAL ANIMATION
   ========================================================================== */
/* Scroll-Reveal bewusst deaktiviert – Inhalte sind sofort sichtbar (ruhige Scroll-Übergänge) */
[data-reveal]{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.hero__scroll .mouse::after{animation:none}}

/* ---------- Small utils --------------------------------------------------- */
.bg-paper2{background:var(--paper-2)}
.bg-paper3{background:var(--paper-3)}
.divider-drip{display:block;width:100%;height:40px;color:var(--paper)}
.pill{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.06em;color:var(--honey-deep);background:var(--paper-2);padding:.4rem .9rem;border-radius:100px}
.skip{position:absolute;left:-999px}
.skip:focus{left:1rem;top:1rem;z-index:200;background:#fff;color:var(--ink);padding:.6rem 1rem;border-radius:8px}
