/* ═══════════════════════════════════════════════════════════
   EURO Küchencenter Giebelhausen — Neues Design 2026
   Bordeaux-Rot · Schwarz · Weiß · Grau
   Keine Buttons — Designelemente: Linien, Flächen, Typografie
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --r: #B81C30;
  --r-d: #8B1524;
  --r-s: #fef0f2;
  --bk: #0a0a0a;
  --tx: #1a1a1a;
  --txm: #4a4a4a;
  --txl: #6b7280;
  --g1: #f5f5f7;
  --g2: #e8e8ec;
  --bd: #e5e7eb;
  --w: #fff;
  --rds: 12px;
  --rds-lg: 20px;
  --sh: 0 4px 20px rgba(0,0,0,0.06);
  --sh-lg: 0 12px 48px rgba(0,0,0,0.10);
  --t: 0.3s cubic-bezier(0.4,0,0.2,1);
  --max: 1200px;
  --font: 'Inter', system-ui, -apple-system, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);background:var(--w);color:var(--tx);
  line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-sm{padding:3rem 0}
.section-alt{background:var(--g1)}
.section-dark{background:var(--bk);color:var(--w)}
.center{text-align:center}

/* ── Typografie ─────────────────────────── */
.label{
  font-size:0.72rem;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--r);
  margin-bottom:0.5rem;display:block;
}
h2{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:800;letter-spacing:-0.03em;color:var(--bk)}
h3{font-size:1.15rem;font-weight:700}
p{color:var(--txm)}

/* ── Design-Element: Rote Linie (kein Button!) ── */
.rule-r{
  width:40px;height:3px;background:var(--r);border:none;
  margin:1rem 0;
}
.rule-r.center{margin-left:auto;margin-right:auto}

/* ── Design-Element: Karte mit rotem Rand ── */
.card{
  background:var(--w);border:1px solid var(--bd);
  border-radius:var(--rds);padding:1.5rem;
  transition:var(--t);
}
.card:hover{
  border-color:var(--r);box-shadow:var(--sh);
}
.card-linked{cursor:pointer}
.card-linked:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}

/* ── Design-Element: Rote Kante links ── */
.edge-r{
  border-left:3px solid var(--r);padding-left:1rem;
}

/* ── NAVIGATION ─────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0.85rem 0;transition:var(--t);background:transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--bd);
  box-shadow:0 1px 2px rgba(0,0,0,0.04);
}
.nav .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:0.15rem}
.nav-links a{
  padding:0.4rem 0.85rem;border-radius:8px;
  font-size:0.85rem;font-weight:500;color:var(--txl);
  transition:var(--t);
}
.nav-links a:hover{color:var(--bk);background:var(--g1)}
.nav-links a.active{
  color:var(--r);font-weight:600;
  border-bottom:2px solid var(--r);
  border-radius:0;padding-bottom:0.3rem;
}
.menu-btn{display:none;background:none;border:none;font-size:1.3rem;cursor:pointer}

/* ── PAGE HEADER ────────────────────────── */
.page-head{
  padding:9rem 0 3.5rem;
  background:var(--g1);
  border-bottom:1px solid var(--bd);
}
.page-head .label{text-align:center}
.page-head h1{
  text-align:center;font-size:clamp(2rem,4vw,3rem);
  font-weight:900;letter-spacing:-0.04em;color:var(--bk);
}
.page-head .subtitle{
  text-align:center;max-width:560px;margin:1rem auto 0;
  color:var(--txl);font-size:1.05rem;
}

/* ── HERO (Home) ────────────────────────── */
.hero{
  position:relative;min-height:90vh;
  display:flex;align-items:center;
  padding:8rem 0 5rem;overflow:hidden;
  background:linear-gradient(180deg,var(--w)0%,var(--g1)100%);
}
.hero .container{position:relative;z-index:2}
.hero h1{
  font-size:clamp(2.2rem,5vw,3.4rem);font-weight:900;
  letter-spacing:-0.04em;line-height:1.15;color:var(--bk);margin-bottom:1rem;
}
.hero h1 em{font-style:normal;color:var(--r)}
.hero-sub{font-size:1.1rem;color:var(--txl);max-width:500px;margin-bottom:0.5rem}
.hero-accent{
  position:absolute;top:15%;right:-5%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,var(--r-s)0%,transparent 60%);
  pointer-events:none;
}

/* ── KACHELN / GALLERY ──────────────────── */
.gallery{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-top:2rem;
}
@media(max-width:700px){.gallery{grid-template-columns:repeat(2,1fr);gap:1rem}}
@media(max-width:450px){.gallery{grid-template-columns:1fr}}
.gallery-item{
  display:flex;flex-direction:column;
  border-radius:var(--rds);overflow:hidden;
  border:1px solid var(--bd);transition:var(--t);
  background:var(--w);position:relative;
}
.gallery-item:hover{
  transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,0,0,0.08);
  border-color:var(--r);
}
.gallery-img{
  aspect-ratio:16/10;display:flex;align-items:center;
  justify-content:center;font-size:2.8rem;background:#e5e7eb;
}
.gallery-body{
  padding:1rem 1.15rem 1.15rem;
  display:flex;flex-direction:column;gap:0.35rem;flex:1;
}
.gallery-body h4{font-size:1rem;font-weight:700;color:#111}
.gallery-body p{font-size:0.82rem;color:#4b5563}
.gallery-link{
  display:inline-flex;align-items:center;gap:0.25rem;
  font-size:0.82rem;font-weight:600;color:var(--r);
  margin-top:auto;padding-top:0.5rem;
}
.gallery-item:hover .gallery-link{text-decoration:underline}
.gallery-tag{
  position:absolute;top:0.75rem;left:0.75rem;
  background:var(--r);color:var(--w);
  padding:0.2rem 0.7rem;border-radius:100px;
  font-size:0.68rem;font-weight:600;z-index:2;
}

/* ── SERVICE-LISTE ──────────────────────── */
.svc-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:0.75rem;margin-top:2rem;
}
@media(max-width:700px){.svc-list{grid-template-columns:1fr}}
.svc-item{
  display:flex;align-items:flex-start;gap:0.85rem;
  padding:1.25rem;background:var(--w);
  border-radius:var(--rds);border:1px solid var(--bd);
  transition:var(--t);
}
.svc-item:hover{border-color:var(--r);box-shadow:var(--sh)}
.svc-num{
  width:28px;height:28px;border-radius:50%;
  background:var(--r-s);color:var(--r);
  display:flex;align-items:center;justify-content:center;
  font-size:0.82rem;font-weight:700;flex-shrink:0;
}
.svc-item h4{font-size:0.9rem;font-weight:600;margin-bottom:0.15rem}
.svc-item p{font-size:0.8rem;color:var(--txl)}

/* ── KONTAKT ────────────────────────────── */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:2.5rem;margin-top:2rem;
}
@media(max-width:700px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  background:var(--w);border:1px solid var(--bd);
  border-radius:var(--rds);padding:2rem;
}
.contact-card h3{margin-bottom:1rem}
.contact-card dt{
  font-weight:600;color:var(--bk);
  margin-top:0.75rem;font-size:0.88rem;
}
.contact-card dd{color:var(--txl);font-size:0.88rem}
.contact-card a{color:var(--r)}
.contact-card a:hover{text-decoration:underline}
.map-wrap{
  border-radius:var(--rds);overflow:hidden;
  border:1px solid var(--bd);
}
.map-wrap iframe{
  width:100%;height:100%;min-height:320px;border:0;
}

/* ── DETAIL-PAGE ────────────────────────── */
.detail-grid{
  display:grid;grid-template-columns:1.3fr 1fr;
  gap:2.5rem;margin-top:1.5rem;
}
@media(max-width:900px){.detail-grid{grid-template-columns:1fr}}
.slider-main{
  position:relative;border-radius:var(--rds-lg);overflow:hidden;
  background:var(--g1);border:1px solid var(--bd);
  aspect-ratio:4/3;
}
.slide{
  position:absolute;inset:0;opacity:0;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;transition:opacity 0.4s ease;
}
.slide.active{opacity:1}
.slider-thumbs{display:flex;gap:0.5rem;margin-top:0.75rem;flex-wrap:wrap}
.slider-thumb{
  width:72px;aspect-ratio:1;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;border:2px solid var(--bd);
  cursor:pointer;transition:var(--t);background:var(--w);
}
.slider-thumb.active{border-color:var(--r)}
.slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,0.9);border:1px solid var(--bd);
  cursor:pointer;z-index:5;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:var(--t);
}
.slider-arrow:hover{background:var(--w)}
.slider-arrow.prev{left:0.75rem}.slider-arrow.next{right:0.75rem}
.detail-info h1{font-size:1.6rem;font-weight:800;letter-spacing:-0.02em;color:var(--bk)}
.detail-sub{
  color:var(--r);font-weight:600;font-size:0.82rem;
  text-transform:uppercase;letter-spacing:0.05em;margin-bottom:1.25rem;
}
.detail-spec{margin-bottom:1.25rem}
.detail-spec h4{
  font-size:0.72rem;font-weight:700;letter-spacing:0.06em;
  text-transform:uppercase;color:var(--txl);margin-bottom:0.4rem;
}
.tags{display:flex;flex-wrap:wrap;gap:0.35rem}
.tag{
  background:var(--g1);padding:0.3rem 0.8rem;
  border-radius:100px;font-size:0.78rem;
}
.detail-nav{
  display:flex;justify-content:space-between;
  margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--bd);
}

/* ── BENTO ──────────────────────────────── */
.bento{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1rem;margin-top:2rem;
}
@media(max-width:900px){.bento{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.bento{grid-template-columns:1fr}}
.bento-card{
  background:var(--w);border:1px solid var(--bd);
  border-radius:var(--rds);padding:1.5rem;
  transition:var(--t);display:flex;flex-direction:column;
}
.bento-card.linked{cursor:pointer}
.bento-card.linked:hover{
  transform:translateY(-3px);box-shadow:var(--sh-lg);
  border-color:var(--r);
}
.bento-lg{grid-column:span 2;grid-row:span 2}
.bento-wide{grid-column:span 2}
.bento-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--r-s);display:flex;
  align-items:center;justify-content:center;
  font-size:1.1rem;margin-bottom:0.75rem;
}
.bento-card h4{font-size:1rem;font-weight:700;margin-bottom:0.2rem}
.bento-card p{font-size:0.84rem;color:var(--txl);flex:1}

/* ── STATS ──────────────────────────────── */
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2rem;max-width:700px;margin:2rem auto 0;
}
@media(max-width:640px){.stats{grid-template-columns:1fr}}
.stat{text-align:center}
.stat-num{font-size:2.4rem;font-weight:900;color:var(--r);line-height:1}
.stat-desc{font-size:0.85rem;color:var(--txl);margin-top:0.4rem}

/* ── PARTNER ────────────────────────────── */
.partner-section{display:flex;flex-direction:column;gap:4rem;margin-top:2rem}
.partner-block{
  display:flex;flex-direction:column;
  padding:2rem;border:1px solid var(--bd);
  border-radius:var(--rds-lg);background:var(--w);
  transition:var(--t);
}
.partner-block:hover{border-color:var(--r);box-shadow:var(--sh)}
.partner-logo-area{
  display:flex;align-items:center;justify-content:center;
  height:64px;margin-bottom:1rem;
}
.partner-logo-area img{max-height:48px;max-width:200px;object-fit:contain}
.partner-block h3{
  text-align:center;font-size:1.3rem;font-weight:800;
  letter-spacing:-0.02em;color:var(--bk);margin-bottom:0.75rem;
}
.partner-bubbles{
  display:flex;flex-wrap:wrap;gap:0.4rem;
  justify-content:center;margin-bottom:1rem;
}
.partner-bubble{
  background:var(--r-s);color:var(--r);
  padding:0.25rem 0.8rem;border-radius:100px;
  font-size:0.75rem;font-weight:600;
  white-space:nowrap;
}
.partner-block > p{
  text-align:center;font-size:0.9rem;color:var(--txm);
  max-width:620px;margin:0 auto 0.75rem;
}
.partner-weblink{
  text-align:center;margin-bottom:1.25rem;
}
.partner-weblink a{
  color:var(--r);font-size:0.85rem;font-weight:600;
  transition:var(--t);
}
.partner-weblink a:hover{text-decoration:underline}

/* ── PARTNER-SLIDER (In-Card) ── */
.partner-slider-wrap{
  position:relative;margin-top:0.5rem;
}
.partner-slider{
  display:flex;gap:0.5rem;overflow-x:auto;
  scroll-behavior:smooth;padding-bottom:0.5rem;
  -ms-overflow-style:none;scrollbar-width:none;
}
.partner-slider::-webkit-scrollbar{display:none}
.partner-slide{
  width:160px;height:110px;flex-shrink:0;
  border-radius:var(--rds);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;background:var(--g1);
  cursor:pointer;transition:var(--t);
}
.partner-slide:hover{border-color:var(--r);transform:scale(1.03)}
.partner-slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.9);border:1px solid var(--bd);
  cursor:pointer;z-index:5;font-size:0.9rem;
  display:none;align-items:center;justify-content:center;
  transition:var(--t);
}
@media(min-width:701px){
  .partner-slider-arrow{display:flex}
}
.partner-slider-arrow:hover{background:var(--w);border-color:var(--r)}
.partner-slider-arrow.prev{left:-0.75rem}
.partner-slider-arrow.next{right:-0.75rem}

/* ── SOCIAL LINKS ───────────────────────── */
.social-links{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}
.social-link{
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--bd);display:flex;
  align-items:center;justify-content:center;
  font-size:1.1rem;transition:var(--t);color:var(--txl);
}
.social-link:hover{border-color:var(--r);color:var(--r);transform:translateY(-2px)}

/* ── LANDING PAGE ───────────────────────── */
.landing{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bk);color:var(--w);text-align:center;
}
.landing-logo{height:70px;width:auto;margin:0 auto 1.5rem}
.landing h1{color:var(--w);font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:0.5rem}
.landing p{color:rgba(255,255,255,0.5);margin-bottom:2rem}
.landing-link{
  display:inline-flex;align-items:center;gap:0.5rem;
  color:var(--r);font-weight:600;font-size:1.1rem;
  border-bottom:2px solid var(--r);
  padding-bottom:0.2rem;transition:var(--t);
}
.landing-link:hover{color:var(--w);border-color:var(--w)}
.landing .social-links{margin-top:2.5rem}
.landing .social-link{
  border-color:rgba(255,255,255,0.15);color:rgba(255,255,255,0.4);
}
.landing .social-link:hover{border-color:var(--r);color:var(--r)}

/* ── ÜBER UNS ───────────────────────────── */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  align-items:center;margin-top:2rem;
}
@media(max-width:700px){.about-grid{grid-template-columns:1fr}}
.about-visual{
  aspect-ratio:4/3;border-radius:var(--rds-lg);
  background:var(--g1);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;
}
.about-text h2{margin-bottom:1rem}
.about-text p{margin-bottom:0.75rem;font-size:0.95rem}

/* ── LEISTUNGEN (neue Service-Seite) ───── */
.leistung-block{
  margin-bottom:3rem;
}
.leistung-block h3{
  font-size:1.2rem;font-weight:700;margin-bottom:1rem;
  padding-bottom:0.5rem;border-bottom:1px solid var(--bd);
}
.leistung-block .svc-list{margin-top:1rem}

/* ── FOOTER ─────────────────────────────── */
.footer{
  background:var(--bk);color:rgba(255,255,255,0.55);
  padding:3rem 0 1.25rem;font-size:0.82rem;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:2rem;margin-bottom:1.5rem;
}
.footer-brand{display:flex;flex-direction:column;gap:0.6rem}
.footer-brand img{height:32px;width:auto;max-width:200px;object-fit:contain;opacity:0.9}
.footer-brand p{color:rgba(255,255,255,0.4);font-size:0.8rem;line-height:1.5;margin:0}
.footer-brand .footer-address{
  color:rgba(255,255,255,0.6);font-size:0.8rem;line-height:1.6;
}
.footer h5{
  color:var(--w);font-size:0.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.06em;
  margin-bottom:0.75rem;
}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0.35rem}
.footer a{color:rgba(255,255,255,0.45);font-size:0.82rem;transition:var(--t)}
.footer a:hover{color:var(--r)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.06);
  padding-top:1rem;text-align:center;
  font-size:0.7rem;color:rgba(255,255,255,0.3);
}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}

/* ── LEGAL ──────────────────────────────── */
.legal{max-width:720px;margin:0 auto}
.legal h3{margin:1.5rem 0 0.5rem;font-size:1.05rem}
.legal p,.legal li{font-size:0.88rem;color:var(--txm);margin-bottom:0.4rem}
.legal ul{padding-left:1.25rem;list-style:disc}

/* ── DESIGN-Element: Trennstrich ────────── */
.hr{
  width:100%;height:1px;background:var(--bd);border:none;
  margin:2rem 0;
}

/* ── RESPONSIVE ─────────────────────────── */
@media(max-width:640px){
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;
    top:100%;left:0;right:0;background:var(--w);
    padding:1rem;border-bottom:1px solid var(--bd);
    box-shadow:var(--sh-lg);gap:0.25rem;
  }
  .menu-btn{display:block}
}

/* ── REFERENZEN ─────────────────────────── */
.rating-hero{
  display:flex;flex-direction:column;align-items:center;
  gap:0.5rem;margin-top:1rem;padding:2rem 0 0;
}
.rating-big{
  font-size:3rem;font-weight:900;color:var(--bk);
  line-height:1;display:flex;align-items:center;gap:0.5rem;
}
.rating-stars{color:var(--r);font-size:2rem;letter-spacing:0.15em}
.rating-count{color:var(--txl);font-size:0.95rem}
.reviews-list{
  display:flex;flex-direction:column;gap:1.5rem;
  margin-top:2rem;max-width:720px;margin-left:auto;margin-right:auto;
}
.review-card{
  background:var(--w);border:1px solid var(--bd);
  border-radius:var(--rds-lg);padding:1.75rem;
  transition:var(--t);
}
.review-card:hover{border-color:var(--r);box-shadow:var(--sh)}
.review-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:0.75rem;gap:1rem;
}
.review-author{font-weight:700;font-size:0.95rem;color:var(--bk)}
.review-date{font-size:0.78rem;color:var(--txl);white-space:nowrap}
.review-stars{color:var(--r);font-size:0.85rem;letter-spacing:0.1em;margin-top:0.15rem}
.review-text{font-size:0.92rem;color:var(--txm);line-height:1.7;font-style:italic}
.review-text::before{content:'\201E'}
.review-text::after{content:'\201C'}
.review-card.featured{border-color:var(--r);background:var(--r-s)}



.lightbox{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:75vh;border-radius:var(--rds-lg);object-fit:contain}
.lightbox-close{color:var(--w);font-size:2.5rem;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:var(--t);position:absolute;top:1rem;right:1rem;z-index:3100}
.lightbox-close:hover{color:var(--r)}
.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:92vw}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.15);border:none;color:var(--w);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.lightbox-nav:hover{background:rgba(255,255,255,0.3)}
.lightbox-nav.prev{left:1rem}
.lightbox-nav.next{right:1rem}
.lightbox-thumbs{display:flex;gap:0.5rem;overflow-x:auto;max-width:92vw;padding:0.5rem 0}
.lightbox-thumb{width:80px;height:60px;border-radius:8px;object-fit:cover;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:var(--t);opacity:0.5}
.lightbox-thumb:hover{opacity:0.8;border-color:rgba(255,255,255,0.4)}
.lightbox-thumb.active{opacity:1;border-color:var(--r)}


/* MASONRY */
.masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:700px){.masonry{grid-template-columns:repeat(2,1fr)}}
@media(max-width:450px){.masonry{grid-template-columns:1fr}}
.masonry-item{aspect-ratio:4/3;border-radius:var(--rds);overflow:hidden;border:1px solid var(--bd);cursor:pointer;transition:var(--t)}
.masonry-item:hover{transform:scale(1.03);box-shadow:var(--sh-lg)}
.masonry-item img{width:100%;height:100%;object-fit:cover;display:block}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:75vh;border-radius:var(--rds-lg);object-fit:contain}
.lightbox-close{position:absolute;top:1rem;right:1rem;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.1);border:none;color:var(--w);font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t);z-index:3100}
.lightbox-close:hover{background:var(--r)}
.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:92vw}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.15);border:none;color:var(--w);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.lightbox-nav:hover{background:rgba(255,255,255,0.3)}
.lightbox-nav.prev{left:1rem}
.lightbox-nav.next{right:1rem}
.lightbox-thumbs{display:flex;gap:0.5rem;overflow-x:auto;max-width:92vw;padding:0.5rem 0}
.lightbox-thumb{width:80px;height:60px;border-radius:8px;object-fit:cover;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:var(--t);opacity:0.5}
.lightbox-thumb:hover{opacity:0.8;border-color:rgba(255,255,255,0.4)}
.lightbox-thumb.active{opacity:1;border-color:var(--r)}




@media(max-width:600px){
  
  
}
@media(max-width:600px){
  
  
}

.lightbox-close-simple:hover,.lightbox-close-simple:active{background:rgba(255,255,255,0.25)}
.masonry.partner-inline{display:grid;grid-template-columns:repeat(4,120px);gap:0.5rem;justify-content:center;margin-top:1rem}
.masonry.partner-inline .masonry-item{width:120px;height:80px;flex-shrink:0;opacity:0.85;background-size:cover;background-position:center;aspect-ratio:auto}
@media(max-width:600px){.masonry.partner-inline{display:flex;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start}.masonry.partner-inline .masonry-item{width:90px;height:60px}}