/* DeineFotobox.at – gemeinsames Design für Unterseiten */
:root{
  --bg:#0e0a1f;
  --bg-2:#161030;
  --bg-3:#1e1740;
  --card:rgba(255,255,255,.045);
  --card-border:rgba(255,255,255,.09);
  --text:#f4f1ff;
  --muted:#b6aed6;
  --pink:#ff4d8d;
  --violet:#8b5cf6;
  --gold:#ffc24d;
  --cyan:#37d6e8;
  --grad:linear-gradient(100deg,var(--pink),var(--violet) 55%,var(--cyan));
  --radius:22px;
  --shadow:0 20px 60px rgba(0,0,0,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',-apple-system,'Helvetica Neue',Arial,system-ui,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
::selection{background:var(--pink);color:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
section{position:relative;padding:80px 0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--grad);border-radius:2px}
h1,h2,h3{line-height:1.15;font-weight:800}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem);margin-bottom:16px}
.sub{color:var(--muted);font-size:1.06rem;max-width:680px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* Buttons & Chips */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:999px;font-weight:700;font-size:1rem;cursor:pointer;border:none;transition:transform .25s,box-shadow .25s}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 30px rgba(255,77,141,.35)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 16px 40px rgba(139,92,246,.5)}
.btn-ghost{background:rgba(255,255,255,.07);color:var(--text);border:1px solid var(--card-border);backdrop-filter:blur(8px)}
.btn-ghost:hover{transform:translateY(-3px);background:rgba(255,255,255,.12)}
.chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.06);border:1px solid var(--card-border);padding:8px 16px;border-radius:999px;font-size:.88rem;font-weight:600;color:var(--text)}

/* Nav */
nav.site{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s;padding:18px 0}
nav.site.scrolled{background:rgba(14,10,31,.85);backdrop-filter:blur(16px);box-shadow:0 6px 30px rgba(0,0,0,.35);padding:10px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.15rem}
.nav-logo img{height:52px;width:auto}
.nav-links{display:flex;gap:26px;font-weight:600;font-size:.95rem}
.nav-links a{color:var(--muted);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--grad);transition:width .25s;border-radius:2px}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{font-weight:700;color:var(--gold);font-size:.95rem}
.nav-burger{display:none;background:none;border:none;color:#fff;font-size:1.7rem;cursor:pointer}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(14,10,31,.97);z-index:99;padding:110px 32px;flex-direction:column;gap:22px;font-size:1.3rem;font-weight:700}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--text)}

/* Seiten-Hero */
.page-hero{padding:170px 0 70px;background:
  radial-gradient(900px 500px at 85% -10%,rgba(139,92,246,.28),transparent 60%),
  radial-gradient(700px 500px at -10% 40%,rgba(255,77,141,.18),transparent 60%),var(--bg)}
.page-hero .badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);border:1px solid var(--card-border);padding:8px 18px;border-radius:999px;font-size:.88rem;font-weight:600;color:var(--muted);margin-bottom:22px;backdrop-filter:blur(8px)}
.page-hero .badge .dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 10px #4ade80;animation:pulse 1.8s infinite}
@keyframes pulse{50%{opacity:.4}}
.page-hero h1{font-size:clamp(2rem,4.6vw,3.2rem);margin-bottom:18px;max-width:850px}
.page-hero p.lead{color:var(--muted);font-size:1.15rem;max-width:660px;margin-bottom:30px}
.page-hero .ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.page-hero .chips{display:flex;gap:10px;flex-wrap:wrap}
.page-hero .chip strong{color:var(--gold)}

/* Karten-Raster */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.feat{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);padding:30px;transition:transform .3s,border-color .3s,background .3s}
.feat:hover{transform:translateY(-6px);border-color:rgba(139,92,246,.5);background:rgba(139,92,246,.08)}
.feat .ico{width:54px;height:54px;border-radius:16px;background:var(--grad);display:grid;place-items:center;font-size:1.5rem;margin-bottom:18px;box-shadow:0 8px 24px rgba(255,77,141,.35)}
.feat h3{font-size:1.12rem;margin-bottom:8px}
.feat p{color:var(--muted);font-size:.95rem}

/* Info-Spalten (Ort-Seiten) */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.info{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);padding:28px}
.info h3{font-size:1.05rem;margin-bottom:14px;color:var(--gold)}
.info ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.info li{display:flex;gap:10px;font-size:.95rem;color:var(--muted)}
.info li::before{content:"✓";color:var(--gold);font-weight:900}
.info p{color:var(--muted);font-size:.95rem}
.tag-list{display:flex;flex-wrap:wrap;gap:9px}
.tag-list span{background:rgba(255,255,255,.06);border:1px solid var(--card-border);padding:6px 14px;border-radius:999px;font-size:.86rem;font-weight:600;color:var(--muted)}

/* CTA-Band */
.cta-band{background:var(--grad);border-radius:32px;padding:56px 44px;text-align:center;position:relative;overflow:hidden;box-shadow:0 30px 80px rgba(139,92,246,.4)}
.cta-band h2{font-size:clamp(1.7rem,3.6vw,2.4rem)}
.cta-band p{color:rgba(255,255,255,.85);font-size:1.1rem;margin:12px auto 26px;max-width:560px}
.cta-band .btn{background:#fff;color:var(--bg);font-size:1.05rem;padding:16px 34px}
.cta-band .btn:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 18px 45px rgba(0,0,0,.3)}
.cta-band::before,.cta-band::after{content:"📸";position:absolute;font-size:5rem;opacity:.16}
.cta-band::before{top:-14px;left:4%;transform:rotate(-15deg)}
.cta-band::after{bottom:-18px;right:4%;transform:rotate(12deg)}

/* FAQ Akkordeon */
.faq-group{margin-top:44px}
.faq-group h2{margin-bottom:6px}
.faq-group .eyebrow{margin-bottom:8px}
details.faq{background:var(--card);border:1px solid var(--card-border);border-radius:18px;margin-top:14px;overflow:hidden;transition:border-color .25s}
details.faq:hover{border-color:rgba(255,77,141,.4)}
details.faq[open]{border-color:rgba(139,92,246,.55);background:rgba(139,92,246,.07)}
details.faq summary{cursor:pointer;padding:20px 56px 20px 24px;font-weight:700;font-size:1.02rem;list-style:none;position:relative}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-weight:900;font-size:1.1rem;transition:transform .3s}
details.faq[open] summary::after{content:"–";transform:translateY(-50%) rotate(180deg)}
details.faq .answer{padding:0 24px 22px;color:var(--muted);font-size:.97rem}

/* Layout-Galerie */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.gallery a{border-radius:14px;overflow:hidden;border:1px solid var(--card-border);background:var(--card);transition:transform .3s,box-shadow .3s;display:block}
.gallery a:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 40px rgba(255,77,141,.3);z-index:2}
.gallery img{width:100%;aspect-ratio:3/2;object-fit:cover}
.gallery-more{text-align:center;margin-top:36px}

/* Orte-Übersicht */
.orte-region{margin-top:44px}
.orte-region h2{display:flex;align-items:center;gap:12px}
.orte-region h2 .em{font-size:1.6rem}
.orte-chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.orte-chips a{background:var(--card);border:1px solid var(--card-border);padding:11px 22px;border-radius:999px;font-weight:600;font-size:.95rem;color:var(--muted);transition:all .25s}
.orte-chips a:hover{background:var(--grad);color:#fff;border-color:transparent;transform:translateY(-3px);box-shadow:0 10px 26px rgba(255,77,141,.35)}
.orte-chips a.all{border-style:dashed;color:var(--gold);border-color:rgba(255,194,77,.5)}

/* Rechtstexte */
.legal{max-width:780px}
.legal h2{margin-top:44px;font-size:1.35rem}
.legal p{color:var(--muted);margin-top:12px}
.legal strong{color:var(--text)}
.legal a{color:var(--pink);text-decoration:underline}
.legal .note{background:rgba(255,194,77,.08);border:1px solid rgba(255,194,77,.35);border-left:4px solid var(--gold);border-radius:0 14px 14px 0;padding:16px 20px;margin-top:28px;color:var(--muted);font-size:.93rem}

/* Footer */
footer{background:var(--bg-2);border-top:1px solid var(--card-border);padding:70px 0 36px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;margin-bottom:48px}
.footer-grid h4{font-size:1rem;margin-bottom:16px;color:var(--gold)}
.footer-grid p,.footer-grid a{color:var(--muted);font-size:.95rem;display:block;margin-bottom:8px;transition:color .2s}
.footer-grid a:hover{color:#fff}
.footer-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;margin-bottom:14px}
.footer-logo img{height:64px;width:auto}
.footer-bottom{border-top:1px solid var(--card-border);padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--muted);font-size:.9rem;flex-wrap:wrap}
.to-top{width:46px;height:46px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-size:1.2rem;transition:transform .25s;box-shadow:0 8px 22px rgba(255,77,141,.35)}
.to-top:hover{transform:translateY(-5px)}

/* Scroll-Reveal */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

/* Responsive */
@media(max-width:1020px){
  .cards-3,.info-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  section{padding:60px 0}
  .nav-links,.nav-phone{display:none}
  .nav-burger{display:block}
  .cards-3,.info-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .page-hero{padding-top:130px}
  .cta-band{padding:44px 24px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
