/* =========================================================================
   cutsbymaus — Sophia Maus | UGC · Foto · Video · Schnitt
   Design: Editorial Premium × Bold-Akzent · girly × elegant
   Fonts: Fraunces (Headlines) + Plus Jakarta Sans (Body)
   Signature: View-Count-Pill + 9:16-Reel-Frame
   ========================================================================= */

/* Schrift wie auf Sophias eigener Seite: Montserrat (geometrische Bold-Sans + Bold-Italic) */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,600;1,700;1,800;1,900&family=Caveat:wght@600;700&display=swap');

/* ---------- Design-Tokens (alle Werte begruendet in design-dna.md) ---------- */
:root{
  --cream:#FBF6F2;          /* warmes Off-White, Haupt-BG */
  --blush:#F6E7E3;          /* sanftes Blush, Wechsel-BG */
  --blush-deep:#EFD7D2;     /* tieferes Blush fuer Karten/Verlaeufe */
  --accent:#B86B7C;         /* elegantes Dusty-Rose */
  --accent-rgb:184,107,124;
  --accent-dark:#9E5468;    /* dunkleres Rose fuer Hover */
  --terra:#C07A4F;          /* Terrakotta (ihr Halstuch), sparsam */
  --ink:#2C2025;            /* warmes Espresso-Plum statt #000 */
  --ink-soft:#5A4A4E;       /* warmes Mauve-Grau, Body */
  --plum-dark:#2A2024;      /* dunkler Plum-BG */
  --plum-soft:#3A2F34;      /* etwas heller fuer Karten auf Plum */

  --font-head:'Montserrat',system-ui,sans-serif;
  --font-body:'Montserrat',system-ui,sans-serif;
  --font-hand:'Caveat',cursive;

  --ease:cubic-bezier(0.34,1.28,0.64,1);   /* soft-bounce */
  --ease-soft:cubic-bezier(0.4,0,0.2,1);
  --section-y:clamp(96px,11vw,168px);
  --container:1240px;
  --radius:2px;            /* eckig, kein Pill */
  --radius-img:6px;
}

/* ---------- Reset & Basis ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink-soft);
  line-height:1.65;
  font-size:clamp(16px,1.05vw,17px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:rgba(var(--accent-rgb),.22);color:var(--ink)}

/* ---------- Typografie ---------- */
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.08;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.7rem,6.4vw,5rem);font-weight:800;text-wrap:balance;letter-spacing:-.03em}
h2{font-size:clamp(2rem,4.2vw,3.3rem);text-wrap:balance}
h3{font-size:clamp(1.25rem,2.1vw,1.6rem);font-weight:700}
p{text-wrap:pretty}
.lead{font-size:clamp(1.1rem,1.6vw,1.3rem);color:rgba(44,32,37,.78);line-height:1.6}

.kicker{
  font-family:var(--font-body);font-weight:600;font-size:.78rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;margin-bottom:1.1rem;
}
.kicker::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
section{padding-block:var(--section-y);position:relative}
.narrow{max-width:62ch}

/* ---------- Buttons (eckig + Hairline-Detail) ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:1rem 1.7rem;border-radius:var(--radius);
  background:var(--accent);color:#fff;
  transition:background .35s var(--ease-soft),transform .35s var(--ease),box-shadow .35s var(--ease-soft);
  box-shadow:0 2px 0 rgba(var(--accent-rgb),.3);
}
.btn:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 22px rgba(var(--accent-rgb),.32)}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1px rgba(44,32,37,.25)}
.btn--ghost:hover{background:transparent;box-shadow:inset 0 0 0 1px var(--accent);color:var(--accent)}
.btn--light{background:#fff;color:var(--ink);box-shadow:none}
.btn--light:hover{background:var(--blush)}
.btn-micro{font-size:.82rem;color:rgba(44,32,37,.5);margin-top:.7rem;font-weight:500}
.on-dark .btn-micro{color:rgba(255,255,255,.55)}

/* ---------- Signature: View-Count-Pill ---------- */
.viewpill{
  display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--font-body);font-weight:600;font-size:.8rem;
  padding:.4em .8em;border-radius:100px;
  background:rgba(255,255,255,.85);color:var(--ink);
  backdrop-filter:blur(4px);box-shadow:0 4px 14px rgba(44,32,37,.12);
}
.viewpill svg{width:1.05em;height:1.05em;opacity:.7}
.viewpill--terra{background:var(--terra);color:#fff}
.viewpill--accent{background:var(--accent);color:#fff}

/* ---------- KEINE Scroll-Reveal-Animation (bewusst statisch, kein Hover-Lag) ---------- */
.reveal{opacity:1;transform:none}

/* =========================================================================
   NAV — solid Hairline, warm
   ========================================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(20px,5vw,40px);
  background:rgba(251,246,242,0);border-bottom:1px solid transparent;
  transition:background .4s var(--ease-soft),border-color .4s,padding .4s;
}
.nav.scrolled{background:rgba(251,246,242,.92);border-bottom:1px solid rgba(44,32,37,.08);padding-block:.7rem}
.nav__logo{font-family:var(--font-head);font-weight:600;font-size:1.35rem;color:var(--ink);letter-spacing:-.02em}
.nav__logo span{color:var(--accent)}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{font-weight:500;font-size:.92rem;color:rgba(44,32,37,.72);transition:color .3s}
.nav__links a:hover{color:var(--accent)}
.nav__cta{padding:.7rem 1.3rem;font-size:.9rem}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:101}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================================
   HERO — Tom-Kova: Text links, Foto rechts full-bleed + Fade
   ========================================================================= */
.hero{
  min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;
  padding-block:0;gap:0;overflow:hidden;
}
.hero__text{padding:7rem clamp(20px,5vw,40px) 4rem clamp(20px,7vw,90px);max-width:680px;justify-self:end;position:relative;z-index:2}
.hero h1{margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:900}
.hero__sub{font-size:clamp(1.05rem,1.5vw,1.25rem);color:rgba(44,32,37,.74);max-width:46ch;margin-bottom:2.2rem}
.hero__loc{display:inline-flex;align-items:center;gap:.5em;font-size:.85rem;font-weight:600;letter-spacing:.04em;color:rgba(44,32,37,.55);margin-top:2.4rem}
.hero__loc svg{width:1.05em;height:1.05em;color:var(--accent)}
.hero__media{position:relative;height:100vh;min-height:600px}
/* Saubere Kante: Bild links auf transparent maskieren -> Creme scheint durch, kein grauer Streifen */
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 18%;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 42%);
  mask-image:linear-gradient(90deg,transparent 0,#000 42%);}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:3;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(44,32,37,.45);display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scroll::after{content:"";width:1px;height:38px;background:linear-gradient(var(--accent),transparent);animation:scrolldown 2s var(--ease-soft) infinite}
@keyframes scrolldown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================================
   REICHWEITEN-STRIP — dunkler Plum, Counter, View-Pills (Wow #1)
   ========================================================================= */
.reach{background:var(--plum-dark);color:#fff;text-align:center}
.reach .kicker{color:rgba(255,255,255,.6)}
.reach .kicker::before{background:rgba(255,255,255,.4)}
.reach h2{color:#fff;margin-bottom:.6rem}
.reach__intro{color:rgba(255,255,255,.6);max-width:48ch;margin:0 auto 3.5rem}
.reach__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.5rem,4vw,3rem)}
.reach__stat{position:relative}
.reach__num{font-family:var(--font-head);font-weight:600;font-size:clamp(2.6rem,5vw,4rem);color:#fff;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.reach__num span{color:var(--accent)}
.reach__label{margin-top:.7rem;font-size:.85rem;letter-spacing:.05em;color:rgba(255,255,255,.6);text-transform:uppercase;font-weight:600}
.reach__grid .reach__stat:not(:last-child)::after{content:"";position:absolute;right:calc(-1*clamp(.75rem,2vw,1.5rem));top:15%;height:70%;width:1px;background:rgba(255,255,255,.12)}

/* =========================================================================
   ÜBER MICH — Editorial, Blush-BG, Freisteller-Foto
   ========================================================================= */
.about{background:var(--blush)}
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.about__media{position:relative;max-width:440px;width:100%}
.about__media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:var(--radius-img);display:block;position:relative;z-index:2}
.about__media .viewpill{position:absolute;z-index:3;bottom:1.1rem;right:1.1rem}
.about__body h2{margin-bottom:1.6rem}
.about__block{margin-bottom:1.7rem;max-width:54ch}
.about__block h4{font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.about__block p{color:rgba(44,32,37,.74)}

/* =========================================================================
   LEISTUNGEN — asymmetrische Cards mit Reel-Frame-Visual
   ========================================================================= */
.services .head{max-width:60ch;margin-bottom:clamp(2.5rem,5vw,4rem)}
.services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.svc{
  position:relative;border-radius:14px;overflow:hidden;
  background:var(--blush);padding:2.5rem;min-height:260px;display:flex;flex-direction:column;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease-soft),background .4s var(--ease-soft),color .4s var(--ease-soft);
  border:1px solid rgba(44,32,37,.06);
}
.svc:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(var(--accent-rgb),.22);background:var(--accent);color:#fff}
.svc:hover .svc__icon,.svc:hover h3{color:#fff}
.svc:hover p{color:rgba(255,255,255,.88)}
.svc:hover .svc__num{color:rgba(255,255,255,.32)}
/* grosse Hintergrund-Nummer als Designelement */
.svc__num{position:absolute;top:1.2rem;right:1.6rem;font-family:var(--font-head);font-size:3.4rem;font-weight:900;color:rgba(var(--accent-rgb),.16);letter-spacing:-.03em;line-height:1;transition:color .4s}
.svc--feat{background:linear-gradient(150deg,var(--accent),var(--accent-dark));color:#fff}
.svc--feat .svc__num{color:rgba(255,255,255,.26)}
.svc--feat p{color:rgba(255,255,255,.88)}
.svc--feat h3,.svc--feat .svc__icon{color:#fff}
.svc--feat:hover{transform:translateY(-6px);background:linear-gradient(150deg,var(--accent-dark),var(--accent))}
.svc__icon{width:38px;height:38px;color:var(--accent);margin-bottom:auto}
.svc h3{margin:1.4rem 0 .6rem;position:relative;z-index:1}
.svc p{font-size:.96rem;color:rgba(44,32,37,.72);position:relative;z-index:1}
.svc--feat .svc__icon{color:#fff}

/* =========================================================================
   FÜR WEN — Editorial-Liste mit Hover-Nummer (Wow #2)
   ========================================================================= */
.fowen .head{margin-bottom:clamp(2rem,4vw,3.5rem);max-width:60ch}
.fowen__list{border-top:1px solid rgba(44,32,37,.12)}
.fowen__row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;
  padding:clamp(1.4rem,3vw,2.2rem) 0;border-bottom:1px solid rgba(44,32,37,.12);
  transition:padding-left .45s var(--ease),background .45s var(--ease-soft);position:relative;
}
.fowen__row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.fowen__row:hover{padding-left:1.6rem}
.fowen__row:hover::before{transform:scaleY(1)}
.fowen__idx{font-family:var(--font-head);font-size:1.1rem;color:rgba(44,32,37,.25);font-weight:600;transition:color .4s}
.fowen__row:hover .fowen__idx{color:var(--accent)}
.fowen__row h3{font-size:clamp(1.4rem,2.6vw,2rem)}
.fowen__row p{color:rgba(44,32,37,.66);font-size:.96rem;max-width:42ch}
.fowen__tag{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);white-space:nowrap}

/* =========================================================================
   VIDEOGRAPHY — horizontale Reel-Galerie (Centerpiece)
   ========================================================================= */
.reels .head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}
.reels__scroll{
  display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:.5rem clamp(20px,5vw,40px) 1.5rem;margin-inline:calc(-1*clamp(20px,5vw,40px));
  scrollbar-width:thin;scrollbar-color:var(--accent) transparent;
}
.reels__scroll::-webkit-scrollbar{height:6px}
.reels__scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:100px}
.reels__scroll::-webkit-scrollbar-track{background:rgba(44,32,37,.08)}
.reel{
  flex:0 0 auto;width:clamp(220px,24vw,278px);aspect-ratio:9/16;scroll-snap-align:start;
  position:relative;border-radius:10px;overflow:hidden;background:var(--blush-deep);
  border:1px solid rgba(44,32,37,.08);cursor:pointer;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease-soft);
}
.reel:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(44,32,37,.18)}
.reel__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.reel__ph svg{width:44px;height:44px;color:#fff;opacity:.92;filter:drop-shadow(0 2px 8px rgba(0,0,0,.25))}
.reel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reel__grad{position:absolute;inset:0;background:linear-gradient(0deg,rgba(42,32,36,.6) 0%,transparent 42%,rgba(42,32,36,.18))}
.reel__cat{position:absolute;top:.9rem;left:.9rem;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(42,32,36,.4);backdrop-filter:blur(4px);padding:.35em .7em;border-radius:100px}
.reel .viewpill{position:absolute;bottom:.9rem;left:.9rem}
.reels__hint{font-size:.8rem;color:rgba(44,32,37,.45);margin-top:1rem;display:flex;align-items:center;gap:.5em}

/* =========================================================================
   PHOTOGRAPHY — Masonry
   ========================================================================= */
.photo{background:var(--blush)}
.photo .head{margin-bottom:clamp(2rem,4vw,3.2rem)}
.masonry{columns:4;column-gap:1rem}
.masonry figure{break-inside:avoid;margin-bottom:1rem;border-radius:var(--radius-img);overflow:hidden;border:1px solid rgba(44,32,37,.06);background:var(--blush-deep)}
.masonry figure img{width:100%;display:block;transition:transform .7s var(--ease-soft)}
.masonry figure:hover img{transform:scale(1.04)}

/* =========================================================================
   DESIGN / EDITS — Cards
   ========================================================================= */
.work .head{margin-bottom:clamp(2rem,4vw,3.2rem)}
.work__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.work__card{aspect-ratio:4/5;border-radius:var(--radius-img);overflow:hidden;position:relative;background:var(--blush-deep);border:1px solid rgba(44,32,37,.06);transition:transform .5s var(--ease),box-shadow .5s var(--ease-soft)}
.work__card:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(44,32,37,.12)}
.work__card img{width:100%;height:100%;object-fit:cover;display:block}

/* =========================================================================
   TESTIMONIALS — Quote-Cards
   ========================================================================= */
.testi .head{text-align:center;max-width:50ch;margin:0 auto clamp(2.5rem,5vw,3.5rem)}
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{background:#fff;border:1px solid rgba(44,32,37,.07);border-radius:var(--radius-img);padding:2.2rem;display:flex;flex-direction:column;gap:1.2rem;transition:transform .5s var(--ease),box-shadow .5s var(--ease-soft)}
.quote:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(44,32,37,.09)}
.quote__mark{font-family:var(--font-head);font-size:3rem;line-height:.5;color:var(--accent);height:1.4rem}
.quote p{color:rgba(44,32,37,.82);font-size:1rem}
.quote__by{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.quote__av{width:42px;height:42px;border-radius:100px;background:var(--blush-deep);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:600;color:var(--accent)}
.quote__by b{display:block;color:var(--ink);font-size:.92rem}
.quote__by small{color:rgba(44,32,37,.5);font-size:.82rem}

/* =========================================================================
   PROZESS — nummerierte Timeline
   ========================================================================= */
.process .head{margin-bottom:clamp(2.5rem,5vw,4rem);max-width:54ch}
.timeline{max-width:660px;margin-inline:auto;position:relative}
.tl-step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.6rem;padding-bottom:2.6rem}
.tl-step:last-child{padding-bottom:0}
.tl-marker{position:relative;display:flex;justify-content:center}
.tl-marker span{width:54px;height:54px;border-radius:100px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:1.05rem;z-index:2;flex:0 0 auto}
.tl-step:not(:last-child) .tl-marker::after{content:"";position:absolute;top:54px;bottom:-2.6rem;left:50%;transform:translateX(-50%);width:2px;background:linear-gradient(var(--accent),rgba(var(--accent-rgb),.18))}
.tl-content{padding-top:.7rem}
.tl-content h3{font-size:1.3rem;margin-bottom:.4rem}
.tl-content p{font-size:.96rem;color:rgba(44,32,37,.7);max-width:48ch}

/* =========================================================================
   FINALER CTA + FORMULAR — dunkler Plum (Wow #3)
   ========================================================================= */
.cta{background:var(--plum-dark);color:#fff;position:relative;overflow:hidden}
.cta__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.cta .kicker{color:rgba(255,255,255,.6)}
.cta .kicker::before{background:rgba(255,255,255,.4)}
.cta h2{color:#fff;font-style:italic;font-weight:800;margin-bottom:1.3rem}
.cta__sub{color:rgba(255,255,255,.65);max-width:42ch;margin-bottom:2rem}
.cta__contact{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.cta__contact a{display:inline-flex;align-items:center;gap:.7em;color:rgba(255,255,255,.85);font-weight:500;transition:color .3s}
.cta__contact a:hover{color:var(--accent)}
.cta__contact svg{width:1.15em;height:1.15em;color:var(--accent)}
/* Formular */
.form{background:var(--plum-soft);border-radius:10px;padding:clamp(1.6rem,3vw,2.4rem)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.7);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border-radius:var(--radius);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  color:#fff;font-family:inherit;font-size:.95rem;transition:border-color .3s,background .3s;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.4)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:rgba(255,255,255,.1)}
.field select option{color:var(--ink)}
.field textarea{resize:vertical;min-height:96px}
.form .btn{width:100%;justify-content:center;margin-top:.4rem}
.form__note{font-size:.78rem;color:rgba(255,255,255,.5);text-align:center;margin-top:.9rem}
.form__ok{display:none;text-align:center;padding:2rem 0;color:#fff}
.form__ok.show{display:block}
.form__ok svg{width:48px;height:48px;color:var(--accent);margin:0 auto 1rem}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{background:var(--plum-dark);color:rgba(255,255,255,.6);padding-block:2.5rem;border-top:1px solid rgba(255,255,255,.08)}
.footer__in{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;font-size:.85rem}
.footer__logo{font-family:var(--font-head);font-size:1.3rem;color:#fff}
.footer__logo span{color:var(--accent)}
.footer__links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer__links a:hover{color:var(--accent)}
.footer__badge a{color:rgba(255,255,255,.75)}
.footer__badge a:hover{color:var(--accent)}

/* =========================================================================
   STICKY MOBILE CTA-BAR
   ========================================================================= */
.mbar{display:none}

/* ---------- Reel-Play-Badge (auf echten Covern) ---------- */
.reel__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:100px;background:rgba(255,255,255,.22);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2;opacity:.92;transition:transform .4s var(--ease),background .4s var(--ease-soft)}
.reel__play svg{width:22px;height:22px;color:#fff;margin-left:2px}
.reel:hover .reel__play{transform:translate(-50%,-50%) scale(1.12);background:var(--accent)}

/* ---------- Foto-Collage + Design-Band (echte Inhalte) ---------- */
.photo__collage,.work__band{border-radius:var(--radius-img);overflow:hidden;border:1px solid rgba(44,32,37,.07);box-shadow:0 14px 40px rgba(44,32,37,.08);background:var(--blush-deep)}
.photo__collage img,.work__band img{width:100%;display:block}

/* ---------- Testimonials: echte WhatsApp-Screenshots, horizontaler Scroller ---------- */
.testi__scroll{display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.5rem clamp(20px,5vw,40px) 1.5rem;margin-inline:calc(-1*clamp(20px,5vw,40px));scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.testi__scroll::-webkit-scrollbar{height:6px}
.testi__scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:100px}
.testi__scroll::-webkit-scrollbar-track{background:rgba(44,32,37,.08)}
.tshot{flex:0 0 auto;width:clamp(238px,26vw,296px);scroll-snap-align:start;border-radius:14px;overflow:hidden;border:1px solid rgba(44,32,37,.08);box-shadow:0 10px 30px rgba(44,32,37,.1);background:#fff;transition:transform .5s var(--ease)}
.tshot:hover{transform:translateY(-5px)}
.tshot img{width:100%;display:block}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1024px){
  .masonry{columns:3}
  .work__grid{grid-template-columns:repeat(3,1fr)}
  .reach__grid{gap:1.2rem}
  .reach__num{font-size:clamp(2.2rem,6vw,3rem)}
}
@media (max-width:860px){
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;justify-content:center;
    background:var(--cream);padding:3rem;gap:1.8rem;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:-20px 0 60px rgba(44,32,37,.15)
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:1.1rem}
  .nav__burger{display:flex}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__text{order:2;padding:3rem clamp(20px,6vw,40px) 4rem;justify-self:stretch;max-width:none;text-align:left}
  .hero__media{order:1;height:74vh;min-height:480px}
  .hero__media::before{background:linear-gradient(0deg,var(--cream) 0%,transparent 30%)}
  .hero__scroll{display:none}
  .about__grid{grid-template-columns:1fr;gap:2.5rem}
  .about__media{max-width:380px}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .svc,.svc--feat,.svc--sm{grid-column:span 1!important}
  .cta__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr);gap:2rem}
  .testi__grid{grid-template-columns:1fr;max-width:480px;margin-inline:auto}
  .chats{grid-template-columns:1fr;max-width:520px}
  .fowen__row{grid-template-columns:auto 1fr;gap:1rem}
  .fowen__tag{display:none}
  .mbar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;
    padding:.7rem 1rem;background:rgba(251,246,242,.95);backdrop-filter:blur(8px);
    border-top:1px solid rgba(44,32,37,.1);gap:.8rem;align-items:center;
    transform:translateY(110%);transition:transform .4s var(--ease)
  }
  .mbar.show{transform:translateY(0)}
  .mbar .btn{flex:1;justify-content:center;padding:.85rem}
  .mbar a:first-child{font-weight:600;color:var(--ink);font-size:.9rem;white-space:nowrap}
}
@media (max-width:560px){
  .masonry{columns:2;column-gap:.8rem}
  .masonry figure{margin-bottom:.8rem}
  .work__grid{grid-template-columns:repeat(2,1fr)}
  .reach__grid{grid-template-columns:repeat(2,1fr);gap:2.2rem 1rem}
  .reach__grid .reach__stat::after{display:none}
  .services__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .cta__contact{margin-top:.5rem}
}
