/* ============================================================
   Henner Lilge — Foto- & Videoproduktion
   Gemeinsames Stylesheet (lokal gehostete Schriften, DSGVO-sauber)
   ============================================================ */

/* ---- Lokale Schriften (kein Google-CDN, keine externen Aufrufe) ---- */
@font-face{
  font-family:"Bricolage Grotesque";
  src:url("bricolage-grotesque.woff2") format("woff2");
  font-weight:400 800;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Instrument Sans";
  src:url("instrument-sans.woff2") format("woff2");
  font-weight:400 600;font-style:normal;font-display:swap;
}

:root{
  --bg:#100C09;
  --bg-2:#1A1410;
  --bg-3:#241B14;
  --line:rgba(245,233,219,.10);
  --line-strong:rgba(245,233,219,.18);
  --ink:#F6EEE3;
  --muted:#A89A8B;
  --accent:#E27A4D;
  --accent-2:#F2994A;
  --accent-deep:#C2542A;
  --display:"Bricolage Grotesque",-apple-system,sans-serif;
  --body:"Instrument Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  --maxw:1200px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--bg);color:var(--ink);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(70% 50% at 80% -5%, rgba(226,122,77,.13), transparent 60%),
    radial-gradient(60% 40% at -5% 30%, rgba(194,84,42,.08), transparent 60%);
}
main,header,footer{position:relative;z-index:1}

/* ---------- HEADER ---------- */
header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);
  background:rgba(16,12,9,.55);border-bottom:1px solid transparent;transition:border-color .3s;
}
header.scrolled{border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:30px;width:auto;display:block}
.brand-name{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-.01em;line-height:1}
.navlinks{display:flex;gap:34px;align-items:center}
.navlinks a{font-size:15px;color:var(--muted);transition:color .2s}
.navlinks a:hover{color:var(--ink)}
.btn{
  font-family:var(--body);font-weight:600;font-size:15px;
  padding:11px 20px;border-radius:100px;cursor:pointer;border:0;
  transition:transform .15s ease, box-shadow .2s ease, background .2s;display:inline-block;
}
.btn-primary{background:var(--accent);color:#1a0f08;box-shadow:0 0 0 0 rgba(226,122,77,.4)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(226,122,77,.35)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.menu-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer}

/* ---------- HERO ---------- */
.hero{padding:88px 0 64px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:26px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(44px,6.4vw,82px);line-height:.98;letter-spacing:-.03em;margin-bottom:26px}
.hero h1 .accent{background:linear-gradient(120deg,var(--accent-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.hero p.lead{font-size:19px;color:var(--muted);max-width:46ch;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.play-link{display:inline-flex;align-items:center;gap:12px;font-weight:600;font-size:15px}
.play-link .pp{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;transition:.2s}
.play-link:hover .pp{border-color:var(--accent);background:var(--accent);color:#1a0f08;transform:scale(1.05)}

.phone{position:relative;aspect-ratio:9/16;border-radius:30px;background:linear-gradient(160deg,var(--bg-3),var(--bg-2));border:1px solid var(--line-strong);box-shadow:0 40px 80px -30px rgba(0,0,0,.8);overflow:hidden;max-width:300px;margin:0 auto;transform:rotate(2.5deg)}
.phone::after{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);width:78px;height:6px;border-radius:6px;background:rgba(0,0,0,.5);z-index:3}
.phone .reel-fill{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%, rgba(226,122,77,.25), transparent 55%),linear-gradient(200deg,#2a1e16,#140f0b);display:grid;place-items:center}
.phone .pbig{width:64px;height:64px;border-radius:50%;background:rgba(246,238,227,.12);backdrop-filter:blur(6px);border:1px solid rgba(246,238,227,.25);display:grid;place-items:center;color:var(--ink);transition:.25s}
.phone:hover .pbig{background:var(--accent);color:#1a0f08;transform:scale(1.08)}
.phone .tag{position:absolute;left:16px;bottom:18px;right:16px;z-index:2;font-size:13px;color:var(--ink)}
.phone .tag b{display:block;font-family:var(--display);font-size:16px;font-weight:600}
.phone .tag span{color:var(--muted)}

.marquee-wrap{margin-top:64px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:20px 0}
.marquee{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scrollx 34s linear infinite}
@media (prefers-reduced-motion:reduce){.marquee{animation:none;flex-wrap:wrap;white-space:normal;justify-content:center}}
.marquee span{font-family:var(--display);font-size:17px;font-weight:500;color:var(--muted);display:flex;align-items:center;gap:48px}
.marquee span::after{content:"•";color:var(--accent)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- SECTION SHELL ---------- */
section{padding:96px 0}
.sec-head{margin-bottom:48px;max-width:620px}
.sec-num{font-family:var(--display);font-size:14px;color:var(--accent);font-weight:600;letter-spacing:.1em}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,4vw,46px);line-height:1.04;letter-spacing:-.025em;margin:14px 0 16px}
.sec-head p{color:var(--muted);font-size:18px}

/* ---------- PORTFOLIO REELS ---------- */
.filter{display:flex;gap:10px;margin-bottom:36px;flex-wrap:wrap}
.filter button{font-family:var(--body);font-size:14px;font-weight:500;padding:9px 18px;border-radius:100px;cursor:pointer;background:var(--bg-2);border:1px solid var(--line);color:var(--muted);transition:.2s}
.filter button:hover{color:var(--ink);border-color:var(--line-strong)}
.filter button.active{background:var(--accent);border-color:var(--accent);color:#1a0f08}

.reels{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.reel{position:relative;aspect-ratio:9/16;border-radius:18px;overflow:hidden;border:1px solid var(--line);cursor:pointer;background:linear-gradient(200deg,#241a13,#130e0a);transition:transform .3s ease, border-color .3s}
.reel:hover{transform:translateY(-6px);border-color:var(--accent)}
.reel .grad{position:absolute;inset:0;opacity:.9}
.reel .reel-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;background:#130e0a}
.reel:nth-child(1) .grad{background:radial-gradient(110% 70% at 30% 10%,rgba(242,153,74,.4),transparent 60%),linear-gradient(200deg,#2c1d12,#120d09)}
.reel:nth-child(2) .grad{background:radial-gradient(110% 70% at 70% 20%,rgba(226,122,77,.4),transparent 60%),linear-gradient(200deg,#26201a,#0f0c09)}
.reel:nth-child(3) .grad{background:radial-gradient(110% 70% at 40% 0%,rgba(194,84,42,.45),transparent 60%),linear-gradient(200deg,#2a1812,#100b08)}
.reel:nth-child(4) .grad{background:radial-gradient(110% 70% at 60% 15%,rgba(242,153,74,.3),transparent 60%),linear-gradient(200deg,#231c16,#0f0b08)}
.reel:nth-child(5) .grad{background:radial-gradient(110% 70% at 35% 10%,rgba(226,122,77,.35),transparent 60%),linear-gradient(200deg,#2b1d13,#120d09)}
.reel:nth-child(6) .grad{background:radial-gradient(110% 70% at 65% 5%,rgba(242,153,74,.38),transparent 60%),linear-gradient(200deg,#251a12,#100c08)}
.reel:nth-child(7) .grad{background:radial-gradient(110% 70% at 45% 12%,rgba(194,84,42,.4),transparent 60%),linear-gradient(200deg,#291911,#0f0b08)}
.reel:nth-child(8) .grad{background:radial-gradient(110% 70% at 55% 8%,rgba(226,122,77,.32),transparent 60%),linear-gradient(200deg,#241c15,#100c08)}
.reel .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(16,12,9,.45);backdrop-filter:blur(4px);border:1px solid rgba(246,238,227,.3);display:grid;place-items:center;color:var(--ink);transition:.25s}
.reel:hover .play{background:var(--accent);color:#1a0f08;border-color:var(--accent)}
.reel .meta{position:absolute;left:14px;right:14px;bottom:14px;z-index:2}
.reel .meta b{font-family:var(--display);font-weight:600;font-size:15px;display:block}
.reel .meta span{font-size:12.5px;color:var(--muted)}
.reel .badge{position:absolute;top:12px;left:12px;z-index:2;font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;padding:5px 10px;border-radius:100px;background:rgba(16,12,9,.6);border:1px solid var(--line-strong);color:var(--accent)}

/* ---------- HERO PHONE VIDEO ---------- */
.phone-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}

/* ---------- FEATURED FILM (16:9) ---------- */
.film{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 30px 70px -34px rgba(0,0,0,.7)}
.film-video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#0d0a08}
.film-badge{position:absolute;top:14px;left:14px;z-index:2;font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:100px;background:rgba(16,12,9,.7);border:1px solid var(--line-strong);color:var(--accent);pointer-events:none}
.film-cap{color:var(--muted);font-size:15px;margin-top:14px}

/* ---------- REELS ROW ---------- */
.reels-row{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.reels-row .reel{flex:0 1 300px;max-width:100%}

/* ---------- SERVICES ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:linear-gradient(180deg,var(--bg-2),rgba(26,20,16,.4));border:1px solid var(--line);border-radius:20px;padding:30px;transition:border-color .3s, transform .3s}
.card:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.card .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:rgba(226,122,77,.12);color:var(--accent);margin-bottom:20px}
.card h3{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.01em;margin-bottom:10px}
.card p{color:var(--muted);font-size:15.5px}
.card.feature{border-color:rgba(226,122,77,.35);background:linear-gradient(180deg,rgba(226,122,77,.12),rgba(26,20,16,.3))}

/* ---------- PHOTO GALLERY (Masonry) ---------- */
.photos{column-count:3;column-gap:16px}
.photo{position:relative;break-inside:avoid;margin:0 0 16px;border-radius:16px;overflow:hidden;border:1px solid var(--line);display:block;transition:border-color .3s}
.photo:hover{border-color:var(--accent)}
.photo img{width:100%;display:block}
.photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,6,4,.6),transparent 38%);pointer-events:none}
.photo .lbl{position:absolute;left:14px;bottom:11px;z-index:2;font-size:13px;color:var(--ink);font-weight:600}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.about-photo{aspect-ratio:4/5;border-radius:22px;border:1px solid var(--line-strong);background:radial-gradient(90% 70% at 60% 10%,rgba(226,122,77,.25),transparent 60%),linear-gradient(180deg,#241a13,#120d09);position:relative;overflow:hidden}
.about-photo .ph-lbl{position:absolute;left:18px;bottom:18px;color:var(--muted);font-size:13px}
.about-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.about-text h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.6vw,42px);letter-spacing:-.025em;line-height:1.05;margin-bottom:22px}
.about-text p{color:var(--muted);font-size:17px;margin-bottom:18px}
.about-text p strong{color:var(--ink);font-weight:600}
.stats{display:flex;gap:40px;margin-top:30px;flex-wrap:wrap}
.stat b{font-family:var(--display);font-size:34px;font-weight:700;color:var(--accent);display:block;line-height:1}
.stat span{font-size:14px;color:var(--muted)}

/* ---------- CONTACT ---------- */
.contact{padding:64px 56px;text-align:center;position:relative;z-index:1}
.contact h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,4.4vw,52px);letter-spacing:-.03em;line-height:1.02;margin-bottom:18px;position:relative}
.contact p{color:var(--muted);font-size:19px;max-width:48ch;margin:0 auto 34px;position:relative}
.contact-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
.contact-phone{margin-top:22px;color:var(--muted);font-size:15px;position:relative}
.contact-phone a{color:var(--ink);font-weight:600}
.contact-phone a:hover{color:var(--accent)}
.btn-lg{padding:15px 30px;font-size:16px}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);padding:42px 0;margin-top:24px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-links{display:flex;gap:24px;font-size:14px;color:var(--muted)}
.foot-links a:hover{color:var(--accent)}
.foot-legal{font-size:13px;color:var(--muted)}
.foot-legal a:hover{color:var(--accent)}

/* ---------- LEGAL PAGES ---------- */
.legal{padding:64px 0 96px;max-width:760px}
.legal .back{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-bottom:32px}
.legal .back:hover{color:var(--accent)}
.legal h1{font-family:var(--display);font-weight:700;font-size:clamp(32px,4.4vw,46px);letter-spacing:-.025em;margin-bottom:10px}
.legal .updated{color:var(--muted);font-size:14px;margin-bottom:40px}
.legal h2{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-.01em;margin:36px 0 12px}
.legal h3{font-family:var(--display);font-weight:600;font-size:17px;margin:24px 0 8px}
.legal p{color:#cdbfae;margin-bottom:14px}
.legal a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.legal strong{color:var(--ink)}
.legal .note{background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;padding:18px 22px;margin:24px 0;color:var(--muted);font-size:15px}

/* ---------- LIQUID GLASS ---------- */
.glass{
  position:relative;z-index:1;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.035));
  backdrop-filter:blur(26px) saturate(165%);
  -webkit-backdrop-filter:blur(26px) saturate(165%);
  border:1px solid rgba(255,255,255,.16);
  border-radius:28px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.42),
    inset 0 -1px 1px rgba(0,0,0,.22),
    0 30px 70px -32px rgba(0,0,0,.75);
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;
  background:
    radial-gradient(130% 90% at 12% -12%, rgba(255,255,255,.22), transparent 46%),
    radial-gradient(90% 60% at 100% 0%, rgba(255,255,255,.10), transparent 55%);
  opacity:.85;
}
.glass > *{position:relative;z-index:1}
.about-glass{padding:52px}

/* farbiger Schimmer hinter dem Glas, den der Blur bricht */
#ueber, #kontakt{position:relative;overflow:hidden}
#ueber::before, #kontakt::before{
  content:"";position:absolute;z-index:0;pointer-events:none;
  width:560px;height:560px;border-radius:50%;filter:blur(100px);opacity:.55;
  background:radial-gradient(circle, rgba(242,153,74,.55), transparent 70%);
  animation:floatblob 16s ease-in-out infinite;
}
#ueber::before{top:-110px;right:-80px}
#kontakt::before{bottom:-150px;left:-60px;background:radial-gradient(circle, rgba(226,122,77,.5), transparent 70%);animation-delay:-6s}
@keyframes floatblob{0%,100%{transform:translate(0,0)}50%{transform:translate(-26px,28px)}}
@media (prefers-reduced-motion:reduce){#ueber::before,#kontakt::before{animation:none}}

/* Fallback, falls der Browser kein backdrop-filter kann */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .glass{background:rgba(28,22,17,.94)}
}

/* reveal animation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero .phone{transform:rotate(0);max-width:260px}
  .reels{grid-template-columns:repeat(2,1fr)}
  .services{grid-template-columns:1fr 1fr}
  .photos{column-count:2}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-glass{padding:34px}
  .navlinks{display:none}
  .menu-toggle{display:block}
  .contact{padding:48px 28px}
}
@media (max-width:560px){
  body{font-size:16px}
  .reels{grid-template-columns:1fr 1fr;gap:14px}
  .services{grid-template-columns:1fr}
  .photos{column-count:1}
  .reels-row .reel{flex:1 1 45%}
  .nav .btn{display:none}
  .stats{gap:26px}
  .brand-name{display:none}
}
