/* --- La Luso - kolory z informacji technicznych --- */
:root {
  --purple-dark: #522172;
  --purple-main: #63247D;
  --purple-light: #894C9C;
  --gold: #d6b981;
  --gold-mid: #a58658;
  --gold-light: #e8cb91;
  --gold-gradient: linear-gradient(180deg, #e8cb91 0%, #a58658 50%, #d6b981 100%);
  --white: #fff;
  --black: #1a1a1a;
  --font-body: "Quicksand", sans-serif;
  --font-display: "Quicksand", sans-serif;
  --font-script: "lindsey-signature", sans-serif;
}

img { border: none; }
a { text-decoration: none; }
a:hover, a:visited, a:focus { text-decoration: none; outline: none; }
a img { border: none; }
img { max-width: 100%; height: auto; display: block; }
b, strong { font-weight: 600; }
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; min-height: 100%; font-family: var(--font-body); font-size: 1rem; color: var(--black); }
html { font-size: clamp(0.9rem, 1vw + 0.1rem, 1.15rem); }
#wrapper { min-height: 100%; position: relative; }

/* Typography - Goldplay alternative: Plus Jakarta Sans, 20pt / 50pt line, justified */
.text-block { font-size: 1.25rem; line-height: 1.5; text-align: justify; }
.text-block p { margin: 0 0 1rem; }
.text-block p:last-child { margin-bottom: 0; }
.text-white { color: var(--white); }
.text-white a { color: var(--gold-light); }

.flex { display: flex; justify-content: space-between; flex-wrap: wrap; }
.flexStart { justify-content: flex-start; }
.flexEnd { justify-content: flex-end; }
.flexCenter { justify-content: center; }
.flexVcenter { align-items: center; }
.flexAround { justify-content: space-around; }
.flex-row { flex-direction: row; align-items: stretch; }

.box { max-width: 1620px; margin: 0 auto; padding: 0 20px; }
.alignRight { text-align: right; }
.alignCenter { text-align: center; }

ul.list { list-style: none; margin: 0; padding: 0 0 0 1rem; }
ul.list li { position: relative; padding-left: 0.5rem; margin-bottom: 0.35rem; }
ul.list li::before { content: "–"; position: absolute; left: -0.5rem; }

/* --- Topbar --- */
#topbar { z-index: 999; position: fixed; top: 0; left: 0; right: 0; padding: 1rem 0; transition: background 0.3s, padding 0.3s; }
#topbar.clearHeader { background: transparent; }
#topbar.fixedHeader { background: rgba(82, 33, 114, 0.97); padding: 0.5rem 0; }
#topbar .box.flex { align-items: center; flex-wrap: nowrap; }
#topbar .logo { width: 140px; }
#topbar .logo img { height: auto; max-height: 50px; }
#topbar.fixedHeader .logo { width: 110px; }
#topbar.fixedHeader .logo img { max-height: 40px; }
.lang-switch { font-size: 0.95rem; font-weight: 500; letter-spacing: 0.02em; }
.lang-switch a { color: var(--white) !important; }
.lang-switch .lang-active { opacity: 1; }
.lang-switch a:not(.lang-active) { opacity: 0.85; }
.lang-switch a:hover { opacity: 1 !important; }
.lang-sep { color: var(--white); opacity: 0.8; margin: 0 0.1rem; }
#topbar.clearHeader .lang-switch a, #topbar.clearHeader .lang-sep { color: var(--white) !important; text-shadow: 0 1px 2px rgba(0,0,0,0.3); }
#topbar.fixedHeader .lang-switch a, #topbar.fixedHeader .lang-sep { color: var(--white) !important; }

#menu ul { margin: 0; padding: 0; list-style: none; display: flex; align-items: center; gap: 2rem; font-size: 0.9rem; font-weight: 400; letter-spacing: 0.15em; }
#menu ul li { display: inline-block; }
#menu ul li a { color: var(--white) !important; padding: 0.5rem 0; white-space: nowrap; }
#menu ul li a:hover { color: var(--gold-light) !important; }
#topbar.clearHeader #menu ul li a { color: var(--white) !important; text-shadow: 0 1px 2px rgba(0,0,0,0.3); }

.mobile { display: none; }
#nav-icon { width: 40px; height: 27px; position: relative; cursor: pointer; }
#nav-icon span { display: block; position: absolute; height: 3px; width: 100%; background: var(--white); border-radius: 2px; left: 0; transition: 0.25s ease-in-out; }
#nav-icon span:nth-child(1) { top: 0; }
#nav-icon span:nth-child(2) { top: 10px; }
#nav-icon span:nth-child(3) { top: 20px; }
#nav-icon.open span:nth-child(1) { transform: rotate(45deg); top: 10px; }
#nav-icon.open span:nth-child(2) { opacity: 0; }
#nav-icon.open span:nth-child(3) { transform: rotate(-45deg); top: 10px; }

#mobile-menu { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: var(--purple-main); z-index: 998; padding-top: 80px; text-align: center; overflow: auto; }
#mobile-menu #menu ul { flex-direction: column; gap: 0; }
#mobile-menu #menu ul li { width: 100%; padding: 0.75rem; }
#mobile-menu #menu ul li a { color: var(--white) !important; font-size: 1.1rem; }

@media (max-width: 1020px) {
  .mobile { display: block; }
  .desktop { display: none; }
}

/* --- Hero (Sekcja 1) --- */
#header.hero { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; }
.hero-video { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.5) 100%); }
.hero-content { position: relative; z-index: 2; padding: 2rem; }
.hero-content-s1 { display: flex; align-items: center; justify-content: center; gap: 4rem; max-width: 1280px; margin: 0 auto; text-align: left; }
.hero-left { display: flex; flex-direction: column; align-items: flex-start; }
.hero-logo-img { }
.hero-logo-img img { max-height: clamp(280px, 38vw, 380px); width: auto; }
.hero-right { position: relative; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding-bottom: 3rem; }
.hero-events { font-family: var(--font-display); font-size: clamp(1.65rem, 3vw, 2.35rem); font-weight: 500; letter-spacing: 0.12em; color: var(--white); margin: 0; text-transform: uppercase; }
.hero-script-wrap { position: absolute; left: 60%; top: 40%; margin-top: 0.5rem; display: flex; align-items: center; gap: 0.5rem; white-space: nowrap; }
.hero-script-line { display: inline-block; width: 22px; height: 1px; background: rgba(255,255,255,0.7); flex-shrink: 0; }
.hero-script { font-family: var(--font-script); font-weight: 400; font-style: normal; font-size: clamp(1.75rem, 3.2vw, 2.6rem); color: var(--white); }
.hero-social { position: absolute; right: 2rem; bottom: 2.5rem; z-index: 2; display: flex; flex-direction: column; gap: 1rem; align-items: center; }
.hero-social img { height: 28px; width: auto; opacity: 0.95; }
.hero-social a:hover img { opacity: 1; }

/* --- Sections --- */
.section { padding: 4rem 0; }
.section-purple { background: var(--purple-main); color: var(--white); }
.section-white { background: var(--white); color: var(--black); }

.section-label { font-size: 1rem; font-weight: 600; letter-spacing: 0.15em; margin: 0 0 1.5rem; }
.section-label-right { text-align: right; }
.section-title { font-family: var(--font-body); font-size: clamp(1.8rem, 4vw, 2.5rem); font-weight: 500; margin: 0 0 2rem; letter-spacing: 0.02em; }
.section-title-white { color: var(--white); }
.section-title-dark { color: #000; }
.section-title-purple { color: var(--purple-main); }
.section-title-black { color: var(--black); }
.section-content { max-width: 900px; }
.section-cta { text-align: center; margin: 2rem 0 0; }

/* --- O NAS (Sekcja 2) --- */
.section-o-nas { position: relative; }
.section-o-nas-inner { position: relative; padding-top: 3rem; padding-bottom: 3rem; }
.section-heading { margin: 0 0 3rem 0; font-family: var(--font-body); font-size: clamp(2rem, 4.5vw, 3.25rem); font-weight: 500; letter-spacing: 0.2em; color:#D3D3D3; text-transform: uppercase; }
.section-o-nas-content { max-width: 720px; margin: 4rem auto 0; padding: 0 20px; text-align: left; color: var(--white); font-size: 1.05rem; line-height: 1.65; }
.section-o-nas-content p { margin: 0 0 1.25rem; }
.section-o-nas-content p:last-of-type { margin-bottom: 0; }
.section-o-nas-content strong { font-weight: 600; color: var(--white); }
.section-o-nas-cta {margin: 2.5rem auto 0; padding: 0 20px 0 5rem; text-align: left; }
.btn-o-nas { display: inline-block; padding: 0.85rem 2.25rem; font-size: 0.95rem; font-weight: 500; letter-spacing: 0.04em; color: #D3d3d3; border: 2px solid rgba(255, 255, 255, 0.85); border-radius: 6px; background: var(--purple-main); transition: background 0.3s, border-color 0.3s, color 0.3s; }
.btn-o-nas:hover { background: var(--purple-light); border-color: var(--white); color: var(--white); }

/* Buttons */
.btn { display: inline-block; padding: 0.75rem 2rem; font-family: var(--font-body); font-size: 0.95rem; font-weight: 600; letter-spacing: 0.05em; cursor: pointer; transition: all 0.3s; border: 2px solid; }
.btn-outline { color: var(--white); border-color: var(--white); background: transparent; }
.btn-outline:hover { background: var(--white); color: var(--purple-main); }
.btn-gold { color: var(--black); border-color: var(--gold); background: var(--gold-gradient); }
.btn-gold:hover { opacity: 0.95; transform: translateY(1px); }
.btn-img { display: inline-block; border: none; background: none; cursor: pointer; }
.btn-img img { max-height: 56px; width: auto; transition: opacity 0.3s; }
.btn-img:hover img { opacity: 0.9; }
.btn-submit img { max-height: 48px; }

/* --- O NAS --- */
#o-nas .text-block { max-width: 100%; }

/* --- Founder --- */
.founder { align-items: center; }
.founder .flex-row { gap: 3rem; align-items: center; }
.founder-text { flex: 1; min-width: 280px; }
.founder-text p {line-height:1.8; }
.founder-text .section-title { margin-bottom: 1.5rem; }
.founder-text .text-block { font-size: 1.1rem; }
.founder-photo-wrap { flex: 0 0 520px; max-width: 100%; }
.frame { position: relative; overflow: hidden; }
.frame img { width: 100%; height: auto; display: block; vertical-align: top; }
#zalozycielka .frame img {position:relative;z-index:5;}
#zalozycielka .frame {padding:40px 0px 40px 100px;}
.frame-gold.frame-right::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 150px; background: var(--gold-gradient); z-index: 1; }
.frame-gold.frame-left::before { content: ""; position: absolute; right: 0; top: 0; bottom: 0; width: 6px; background: var(--gold-gradient); z-index: 1; }
.frame-gold.frame-left::after { content: ""; position: absolute; bottom: 0; left: 0; width: 80px; height: 6px; background: var(--gold-gradient); z-index: 1; }
.frame-gold:not(.frame-right):not(.frame-left)::before { content: ""; position: absolute; inset: 0; border: 4px solid var(--gold); z-index: 1; pointer-events: none; }

/* --- Bar gold – liczniki --- */
.bar-gold { background: linear-gradient(90deg, #a58658 0%, #c4a574 40%, #d6b981 70%, #e8cb91 100%); padding: 2.5rem 0; }
.bar-gold-inner { display: flex; justify-content: space-between; align-items: stretch; gap: 1rem; flex-wrap: wrap; }
.bar-gold-col { flex: 1; min-width: 140px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 0.6rem; }
.bar-gold-num { font-family: var(--font-body); font-size: clamp(2rem, 4vw, 2.75rem); font-weight: 500; color: rgba(255, 255, 255, 0.98); letter-spacing: 0.02em; line-height: 1.2; }
.bar-gold-sep { display: block; width: 48px; max-width: 80%; height: 2px; background: rgba(255, 255, 255, 0.85); margin: 0.1rem 0; }
.bar-gold-label { font-family: var(--font-body); font-size: clamp(0.8rem, 1.2vw, 0.95rem); font-weight: 400; color: rgba(255, 255, 255, 0.95); line-height: 1.35; max-width: 120px; }

/* --- Nasze usługi (kafelki) --- */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 2.5rem; }
.service-tile { position: relative; aspect-ratio: 1; overflow: hidden; display: block; box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.service-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.service-tile:hover img { transform: scale(1.08); }
.service-tile-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.5rem; background: linear-gradient(transparent, rgba(0,0,0,0.65)); display: flex; flex-direction: column; align-items: flex-start; gap: 0.25rem; text-align: left; }
.service-tile-label { font-family: var(--font-body); font-size: 1.35rem; font-weight: 600; letter-spacing: 0.08em; color: var(--white); text-transform: uppercase; }
.service-tile-subtitle { font-family: var(--font-body); font-size: 0.9rem; font-weight: 400; color: rgba(255,255,255,0.95); }

/* --- Jak pracujemy --- */
.how-we-work { background: #522172; color: var(--white); position: relative; overflow: visible; }
.how-we-work .box { position: relative; }
.how-we-work .flex-row { gap: 3rem; align-items: stretch; }
.how-text { flex: 1; min-width: 280px; max-width: 48%; }
.how-heading-right { text-align: right; }
.how-text-content { max-width: 100%; font-size: 1.1rem; line-height: 1.8; }
.how-text-content p { margin: 0 0 1rem; }
.how-text-content p:last-child { margin-bottom: 0; }
.how-photo-wrap { position: relative; flex: 0 0 42%; max-width: 480px; padding-top: 80px; padding-bottom: 80px; }
.how-gold-bg { position: absolute; top: -4rem; left: -80px; right: 80px; bottom: 80px; background: var(--gold-gradient); z-index: 0; }
.how-slider-wrap { position: relative; z-index: 1; width: 100%; max-width: 100%; margin: 0 auto; padding: 0 12px; margin-bottom: -80px; }
.how-slider { width: 100%; }
.how-slider .slick-list { height: auto; }
.how-slider .slick-track { height: auto; }
.how-slider .slick-slide { height: auto; }
.how-slide { outline: none; position: relative; aspect-ratio: 1 / 2; overflow: hidden; width: 100%; }
.how-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.how-slider-wrap .slick-prev, .how-slider-wrap .slick-next { z-index: 3; width: 44px; height: 44px; top: 50%; transform: translateY(-50%); margin-top: 0; }
.how-slider-wrap .slick-prev { left: 16px; }
.how-slider-wrap .slick-next { right: 16px; }
.how-slider-wrap .slick-prev:before, .how-slider-wrap .slick-next:before { color: var(--white); opacity: 0.95; font-size: 28px; }
.how-slider-wrap .slick-dots { display: none !important; }
.how-gallery-zoom { position: absolute; bottom: 16px; right: 16px; z-index: 3; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.5); border-radius: 50%; color: var(--white); transition: background 0.3s; }
.how-gallery-zoom:hover { background: rgba(0,0,0,0.75); color: var(--white); }
.how-gallery-zoom svg { width: 22px; height: 22px; }

/* --- Eventy --- */
.eventy { background: #894C9C; color: var(--white); position: relative; overflow: visible; }
.eventy .box { position: relative; z-index: 1; }
.eventy .flex-row { gap: 3rem; align-items: stretch; }
.eventy-photo-wrap { position: relative; flex: 0 0 42%; max-width: 480px; padding-top: 80px; padding-bottom: 80px; order: 1; }
.eventy-gold-bg { position: absolute; top: 0; left: 0; bottom: 0; width: 42%; max-width: 560px; background: var(--gold-gradient); z-index: 0; }
.eventy-slider-wrap { position: relative; z-index: 1; width: 100%; max-width: 100%; margin: 0 auto; padding: 0 12px; margin-bottom: -80px; }
.eventy-slider { width: 100%; }
.eventy-slider .slick-list { height: auto; }
.eventy-slider .slick-track { height: auto; }
.eventy-slider .slick-slide { height: auto; }
.eventy-slide { outline: none; position: relative; aspect-ratio: 1 / 2; overflow: hidden; width: 100%; }
.eventy-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.eventy-slider-wrap .slick-prev, .eventy-slider-wrap .slick-next { z-index: 3; width: 44px; height: 44px; top: 50%; transform: translateY(-50%); margin-top: 0; }
.eventy-slider-wrap .slick-prev { left: 16px; }
.eventy-slider-wrap .slick-next { right: 16px; }
.eventy-slider-wrap .slick-prev:before, .eventy-slider-wrap .slick-next:before { color: var(--white); opacity: 0.95; font-size: 28px; }
.eventy-slider-wrap .slick-dots { display: none !important; }
.eventy-gallery-zoom { position: absolute; bottom: 16px; right: 16px; z-index: 3; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.5); border-radius: 50%; color: var(--white); transition: background 0.3s; }
.eventy-gallery-zoom:hover { background: rgba(0,0,0,0.75); color: var(--white); }
.eventy-gallery-zoom svg { width: 22px; height: 22px; }
.eventy-text { flex: 1; min-width: 280px; max-width: 58%; order: 2; }
.eventy-heading-right { text-align: right; color: #fff; }
.eventy-text-content { max-width: 100%; font-size: 1.1rem; line-height: 1.8; }
.eventy-text-content p { margin: 0 0 1rem; }
.eventy-text-content p:last-child { margin-bottom: 0; }
.eventy-text-content strong { font-weight: 600; color: var(--white); }

/* --- Catering --- */
.catering { position: relative; padding-bottom: 0; }
.catering .box { padding-bottom: 0; position: relative; z-index: 1; }
.catering-heading { margin-bottom: 2rem; }
.catering-top { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin-bottom: 0; align-items: start; }
.catering-text { font-size: 1.05rem; line-height: 1.65; color: var(--black); }
.catering-text p { margin: 0 0 1rem; text-align: justify; }
.catering-text p:last-of-type { margin-bottom: 0; }
.catering-list { padding-left: 1rem; margin: 0 0 1rem; }
.catering-list li { margin-bottom: 0.5rem; padding-left: 0.5rem; }

.catering-gold-bars { position: absolute; left: 53%; right: 10%; bottom: 0; z-index: 0; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; box-sizing: border-box;height:49%; }
.catering-gold-bar { background: linear-gradient(0deg, #a58658 0%, #c4a574 40%, #d6b981 70%, #e8cb91 100%); }
.catering-gallery-wrap { position: relative; width: 100%; padding: 3rem 0; margin-top: 3rem; overflow: hidden; z-index: 1; }
.catering-gallery-inner { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2rem; width: 100%; max-width: 100%; padding: 0 0px; margin: 0; align-items: stretch; box-sizing: border-box; }
.catering-gallery-item { aspect-ratio: 4 / 3; overflow: hidden; position: relative; }
.catering-gallery-item img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

/* --- Warsztaty --- */
.warsztaty { background: #522172; color: var(--white); }
.warsztaty .box { position: relative; }
.warsztaty-heading { text-align: center; margin-bottom: 2.5rem; }
.warsztaty-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.warsztaty-col { font-size: 1.05rem; line-height: 1.65; }
.warsztaty-col p { margin: 0 0 1rem; text-align: justify; }
.warsztaty-col p:last-of-type { margin-bottom: 0; }
.warsztaty-col .list { padding-left: 1rem; margin: 0 0 1rem; }
.warsztaty-col .list li { margin-bottom: 0.4rem; padding-left: 0.5rem; }
.warsztaty-col strong { font-weight: 600; }

.warsztaty-photo-wrap { position: relative; max-width: 900px; margin: 7rem auto 0 auto; }
.warsztaty-gold-bg { position: absolute; top: -3rem; left: -4rem; right: -4rem; bottom: 3rem; background: var(--gold-gradient); z-index: 0; clip-path: polygon(0 0, 100% 0, 100% 100%, 62% 100%, 50% 90%, 38% 100%, 0 100%); }
.warsztaty-photo-wrap img { position: relative; z-index: 1; width: 100%; height: auto; display: block; vertical-align: bottom; }

/* --- Testimonials (Opinie) --- */
.testimonials { background: #894C9C; position: relative; }
.testimonials .box { position: relative; z-index: 1; }
.testimonials .section-title { margin-bottom: 2rem; }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4rem; align-items: start; }
.testimonial-card { background: var(--white); color: var(--black); padding: 2rem 2rem 4rem 2rem; border-radius: 0; position: relative; }
.testimonial-quote { width: 4rem; height: auto; margin-bottom: 3rem; opacity: 0.8; margin-top:-3.5rem; display: block; margin-left: auto; margin-right: auto; }
.testimonial-card p { margin: 0 0 0.75rem; font-size: 1rem; line-height: 1.5; text-align: center; }
.testimonial-card p:last-child { margin-bottom: 0; }
.testimonial-author { margin-top: 1rem !important; font-weight: 600; text-align: center; font-size: 0.95rem; color: var(--black); }
.testimonials-gold-bar { position: absolute; bottom: 20%; left: 0; right: 0; height: 80px;  z-index: 0; background: linear-gradient(90deg, #a58658 0%, #c4a574 40%, #d6b981 70%, #e8cb91 100%); }

/* --- Contact form --- */
.contact { background: #894C9C; }
.contact .box { max-width: 700px; }
.contact .section-title { margin-bottom: 2rem; }
.contact-form { display: flex; flex-direction: column; gap: 1.5rem; align-items: center; }
.contact-label { color: var(--white); font-size: 1rem; font-weight: 400; width: 100%; max-width: 100%; text-align: center; display: block; margin-bottom: -0.25rem; }
.contact-form input, .contact-form textarea { width: 100%; max-width: 100%; padding: 1rem 1.5rem; font-family: var(--font-body); font-size: 1rem; border: none; border-radius: 999px; background: var(--white); color: var(--black); box-sizing: border-box; }
.contact-form textarea { border-radius: 1.5rem; min-height: 120px; resize: vertical; }
.contact-form input::placeholder, .contact-form textarea::placeholder { color: #888; }
.contact-submit { margin-top: 0.5rem; padding: 0.75rem 2rem; font-family: var(--font-body); font-size: 1rem; border: none; border-radius: 999px; background: var(--white); color: #894C9C; cursor: pointer; font-weight: 500; }

/* --- Footer --- */
.footer { background: #894C9C; color: var(--white); padding: 2.5rem 0; }
.footer-inner { display: flex; flex-direction: row; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 2rem; }
.footer-left { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.footer-logo { max-width: 100px; height: auto; margin: 0; }
.footer-contact { display: flex; flex-direction: row; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.footer-contact-item { color: var(--white); display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.95rem; font-weight: 300; text-decoration: none; }
.footer-contact-item:hover { color: var(--white); opacity: 0.9; }
.footer-contact img { width: 18px; height: 18px; opacity: 0.95; }
.footer-right { display: flex; flex-direction: column; align-items: flex-end; margin-left: auto; }
.footer-find-us { font-size: 0.85rem; font-weight: 300; letter-spacing: 0.1em; margin: 0 0 0.75rem; }
.footer-social { display: flex; gap: 1rem; }
.footer-social img { height: 24px; width: auto; filter: brightness(0) invert(1); }

/* Responsive */
@media (max-width: 1200px) {
  .founder-photo-wrap { flex: 0 0 320px; }
  .how-photo-wrap, .eventy-photo-wrap { flex: 0 0 360px; }
  .how-gold-bg {   left: -40px;  }
}

@media (max-width: 1020px) {
  .section { padding: 3rem 0; }
  .founder .flex-row, .how-we-work .flex-row, .eventy .flex-row { flex-direction: column; }
  .warsztaty-columns { grid-template-columns: 1fr; }
  .founder-photo-wrap, .how-photo-wrap, .eventy-photo-wrap { flex: none; width: 100%; max-width: 400px; margin: 0 auto; }
  .eventy-photo-wrap { order: 1; }
  .eventy-text { order: 2; }
  .services-grid { grid-template-columns: 1fr; }
  .catering-gallery-inner { gap: 8px; padding: 0 16px; }
  .catering-gallery-wrap { padding: 2rem 0; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .catering-top { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; text-align: center; }
  .footer-left { flex-direction: column; justify-content: center; }
  .footer-contact { justify-content: center; }
  .footer-right { margin-left: 0; align-items: center; }
  #topbar .box.flex {justify-content:flex-end;}
  .how-text {max-width:100%;}
  .how-gold-bg {  top: -1rem; }
  .eventy-gold-bg {display:none;}
  .eventy-text { max-width:100%;  }
  .catering-gold-bars {max-height:21rem;}
  .warsztaty-photo-wrap {max-width:calc(100% - 8rem);}
}

@media (max-width: 768px) {
  .hero-content-s1 { flex-direction: column; text-align: center; gap: 2rem; }
  .hero-left { align-items: center; }
  .hero-right { align-items: center; }
  .hero-right { padding-bottom: 0; }
  .hero-script-wrap { position: static; margin-top: 1rem; margin-left: 0; justify-content: center; }
  .hero-logo-img img { max-height: clamp(180px, 42vw, 260px); }
  .hero-events { font-size: clamp(1.35rem, 4.5vw, 1.75rem); }
  .hero-social { right: 1rem; bottom: 2rem; flex-direction: column; }
  .section-o-nas-heading { position: static; text-align: right; margin-bottom: 1rem; }
  .section-o-nas-content { margin-top: 0; }
  .bar-gold-col { min-width: 100px; }
  .section-title { font-size: 1.6rem; }
  .text-block { font-size: 1.1rem; }
}

.transition, .logo, .button, .service-tile img { transition: all 0.3s ease; }
