:root{ --font-barlow-sc: "Barlow Semi Condensed", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; } @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Thin.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Thin.ttf") format("truetype");font-weight:100;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraLight.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraLight.ttf") format("truetype");font-weight:200;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Light.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Regular.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Medium.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-SemiBold.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Bold.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraBold.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraBold.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Black.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Black.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ThinItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ThinItalic.ttf") format("truetype");font-weight:100;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraLightItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraLightItalic.ttf") format("truetype");font-weight:200;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-LightItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-LightItalic.ttf") format("truetype");font-weight:300;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Italic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-Italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-MediumItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-MediumItalic.ttf") format("truetype");font-weight:500;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-SemiBoldItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-SemiBoldItalic.ttf") format("truetype");font-weight:600;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-BoldItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-BoldItalic.ttf") format("truetype");font-weight:700;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraBoldItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-ExtraBoldItalic.ttf") format("truetype");font-weight:800;font-style:italic;font-display:swap} @font-face{font-family:"Barlow Semi Condensed";src:url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-BlackItalic.woff2") format("woff2"), url("/assets/fonts/barlow-semi-condensed/BarlowSemiCondensed-BlackItalic.ttf") format("truetype");font-weight:900;font-style:italic;font-display:swap} body{ font-family:var(--font-barlow-sc); font-weight:400; font-synthesis-weight: none; font-synthesis-style: none; } h1,h2,h3{ font-weight:600; } em,i{ font-style:italic; } :root { --primary-color: #744900; --secondary-color: #8b7355; --accent-color: #d4af37; --light-bg: #f8f6f3; --white: #ffffff; --text-dark: #2c2416; --text-light: #6b6b6b; --transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); --font-sans: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; --font-display: "Barlow Semi Condensed"; } * { margin: 0; padding: 0; box-sizing: border-box; } html { scroll-behavior: smooth; } body{ font-family: var(--font-sans); color: var(--text-dark); line-height: 1.6; overflow-x: hidden; font-weight: 400; font-synthesis-weight: none; font-synthesis-style: none; } h1,h2,h3{ font-family: 'Arial'; font-weight: 100; letter-spacing: 0.1em; line-height: 1.15; } .container { max-width: 100vw; margin: 0 auto; padding: 0 40px; } .navbar { position: fixed; top: 0; width: 100%; background: transparent; z-index: 1000; transition: var(--transition); padding: 25px 0; } .navbar.scrolled { background: rgba(255, 255, 255, 0.98); box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1); padding: 15px 0; } .nav-container { max-width: 1800px; margin: 0 auto; padding: 0 40px; display: flex; justify-content: space-between; align-items: center; } .logo h1 { font-size:1.75rem; color: var(--white); letter-spacing: 3px; margin: 0; transition: var(--transition); } .navbar.scrolled .logo h1 { color: var(--primary-color); } .logo-subtitle { display: block; font-size:0.6875rem; letter-spacing: 4px; color: var(--accent-color); margin-top: -5px; } .nav-menu { display: flex; list-style: none; gap: 45px; } .nav-menu a { text-decoration: none; color: var(--white); font-size:0.875rem; font-weight: 400; letter-spacing: 1px; position: relative; transition: var(--transition); } .navbar.scrolled .nav-menu a { color: var(--text-dark); } .nav-menu a::after { content: ''; position: absolute; bottom: -5px; left: 0; width: 0; height: 1px; background: var(--accent-color); transition: var(--transition); } .nav-menu a:hover::after { width: 100%; } .menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; } .menu-toggle span { width: 25px; height: 2px; background: var(--white); transition: var(--transition); } .navbar.scrolled .menu-toggle span { background: var(--primary-color); } 

/* Wyłącz przewijanie poziome */
html, body {
    overflow-x: hidden;
    width: 100%;
}

/* Zapewnij poprawne działanie na różnych elementach */
* {
    max-width: 100%;
}

.creations { padding: 60px 0; background: var(--light-bg); } 
.section-header { text-align: center; margin-bottom: 80px; } 
.gallery {
    width: 100%;
    height: 600px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.gallery-item {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 20px;
}

.gallery-item img {
    width: 70%;
    height: 20%;
    object-fit: cover;
}
@media (max-width: 992px) {
    .gallery {
        grid-template-columns: repeat(2, 1fr);
        height: 1000px;
    }
}

@media (max-width: 600px) {
    .gallery {
        grid-template-columns: 1fr;
    }
}

.gallery-image { height: 200px; overflow: hidden; } 
.gallery-image .image-placeholder { transition: var(--transition); } 
.gallery-item:hover .image-placeholder { transform: scale(1.1); } 
.gallery-info { padding: 10px; background: var(--white); text-align: center; transition: var(--transition); } 
.gallery-item:hover .gallery-info { background: var(--primary-color); } 
.gallery-item:hover .gallery-info h3, 
.gallery-item:hover 
.gallery-info p { color: var(--white); } 
.gallery-info h3 { font-size:1.5rem; color: var(--primary-color); margin-bottom: 10px; transition: var(--transition); } 
.gallery-info p { font-size:0.875rem; color: var(--text-light); transition: var(--transition); } 

.news { padding: 20px 0; background: var(--white); } .news-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 40px; } .news-item { background: var(--light-bg); overflow: hidden; transition: var(--transition); border-radius: 8px; } .news-item:hover { transform: translateY(-10px); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1); } .news-image { height: 250px; overflow: hidden; } .news-content { padding: 30px; } .news-content h3 { font-size:1.375rem; color: var(--primary-color); margin-bottom: 15px; } .news-content p { font-size:0.875rem; color: var(--text-light); margin-bottom: 20px; line-height: 1.7; } .news-link { color: var(--accent-color); text-decoration: none; font-size:0.875rem; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; transition: var(--transition); position: relative; } .news-link::after { content: '→'; margin-left: 5px; transition: var(--transition); } .news-link:hover { color: var(--primary-color); } .news-link:hover::after { transform: translateX(5px); } .contact .contact-content { display: grid; gap: clamp(24px, 3vw, 40px); } @media (min-width: 992px) { .contact .contact-content { grid-template-columns: 1fr 1fr; grid-template-rows: auto 1fr; grid-template-areas: "info map" "form map"; align-items: start; } .contact .contact-info { grid-area: info; } .contact .contact-form-wrapper { grid-area: form; } .contact .contact-map { grid-area: map; min-height: 620px; height: 90%; } } @media (max-width: 991.98px) { .contact .contact-content { grid-template-columns: 1fr; grid-template-areas: "info" "form" "map"; } .contact .contact-map { min-height: 1105px; } } .contact-info { padding: 1.5rem 0; } .contact-details { display: flex; flex-direction: column; gap: 1.5rem; margin-top: 2rem; } .contact-item { display: flex; align-items: flex-start; gap: 1rem; } .contact-icon { font-size: 1.25rem; margin-top: 0.25rem; flex-shrink: 0; } .contact-item h3 { margin: 0 0 0.25rem 0; font-size: 1.1rem; color: var(--text-primary, #333); } .contact-item address, .contact-item p { margin: 0; font-style: normal; line-height: 1.5; color: var(--text-secondary, #666); } .contact-item a { color: inherit; text-decoration: none; transition: color 0.3s ease; } .contact-item a:hover { color: var(--primary-color, #d4a574); } .contact-form-wrapper { padding: 1.5rem 0; } .form-card { background: var(--background-light, #f8f8f8); padding: 2rem; border-radius: 16px; box-shadow: 0 4px 20px rgba(0,0,0,0.08); } .form-card h3 { margin: 0 0 1.5rem 0; font-size: 1.5rem; color: var(--text-primary, #333); } .form-group { margin-bottom: 1.25rem; } .contact-form input, .contact-form textarea { width: 100%; padding: 0.875rem 1rem; border: 2px solid var(--border-color, #e0e0e0); border-radius: 8px; font-size: 1rem; transition: all 0.3s ease; background: white; } .contact-form input:focus, .contact-form textarea:focus { outline: none; border-color: var(--primary-color, #d4a574); box-shadow: 0 0 0 3px rgba(212, 165, 116, 0.1); } .contact-form textarea { resize: vertical; min-height: 120px; font-family: inherit; } .btn-primary { width: 100%; padding: 1rem 2rem; background: var(--primary-color, #d4a574); color: white; border: none; border-radius: 8px; font-size: 1rem; font-weight: 600; cursor: pointer; transition: all 0.3s ease; } .btn-primary:hover { background: var(--primary-dark, #b58a5c); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(212, 165, 116, 0.3); } .contact-map { position: relative; border-radius: 16px; overflow: hidden; min-height: 1105px; } .contact-map::before { content: ""; position: absolute; inset: 0; background: rgba(112, 66, 20, 0.1); mix-blend-mode: multiply; pointer-events: none; z-index: 1000; border-radius: 16px; } .contact-map::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(135deg, rgba(0,0,0,0.03) 0%, transparent 50%); mix-blend-mode: multiply; } .leaflet-container { width: 100%; height: 100%; filter: sepia(0.5) saturate(0.8) hue-rotate(-10deg); } @media (min-width: 992px) { .contact .contact-content { grid-template-columns: 1.1fr 0.9fr; grid-template-areas: "info map" "form map"; align-items: start; } .contact .contact-info { grid-area: info; } .contact .contact-form-wrapper { grid-area: form; } .contact .contact-map { grid-area: map; min-height: 520px; } } @media (max-width: 991.98px) { .contact .contact-content > * { width: 100%; } .contact .contact-map { min-height: 360px; } } .contact .contact-map { position: relative; border-radius: 16px; overflow: hidden; box-shadow: 0 8px 28px rgba(0,0,0,.25); isolation: isolate; min-height: 1105px; } .contact .contact-map::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(to bottom right, rgba(0,0,0,.08), rgba(0,0,0,0)); mix-blend-mode: multiply; } .leaflet-container { width: 100%; height: 100%; } .footer { background: var(--primary-color); color: var(--white); padding: 80px 0 30px; } .footer-content { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 60px; margin-bottom: 50px; } .footer-logo h2 { font-size:2rem; letter-spacing: 3px; margin-bottom: 5px; } .footer-logo span { display: block; font-size:0.75rem; letter-spacing: 4px; color: white; margin-bottom: 15px; } .footer-logo p { font-size:0.875rem; color: rgb(255, 255, 255); margin-bottom: 20px; line-height: 1.6; } .footer-links h4, .footer-social h4, .footer-contact h4, .footer-newsletter h4 { font-size:1rem; margin-bottom: 20px; color: var(--accent-color); position: relative; } .footer-links h4::after, .footer-social h4::after, .footer-contact h4::after, .footer-newsletter h4::after { content: ''; position: absolute; left: 0; bottom: -8px; width: 30px; height: 2px; background: var(--accent-color); } .footer-links ul { list-style: none; } .footer-links a { color: rgba(255, 255, 255, 0.7); text-decoration: none; font-size:0.875rem; line-height: 2.2; transition: var(--transition); display: flex; align-items: center; } .footer-links a:hover { color: var(--accent-color); transform: translateX(5px); } .footer-links a::before { content: '›'; margin-right: 8px; color: var(--accent-color); opacity: 0; transition: var(--transition); } .footer-links a:hover::before { opacity: 1; } .social-icons { display: flex; gap: 15px; margin-bottom: 25px; } .social-icons a { width: 40px; height: 40px; border: 1px solid rgba(255, 255, 255, 0.3); display: flex; align-items: center; justify-content: center; color: var(--white); text-decoration: none; font-size:0.875rem; transition: var(--transition); border-radius: 50%; } .social-icons a:hover { background: var(--accent-color); border-color: var(--accent-color); color: var(--primary-color); transform: translateY(-3px); } .footer-contact p { font-size:0.875rem; color: var(--light-gray); margin-bottom: 15px; display: flex; align-items: flex-start; } .footer-contact i { color: var(--accent-color); margin-right: 10px; min-width: 16px; } .footer-newsletter p { font-size:0.875rem; color: var(--light-gray); margin-bottom: 20px; line-height: 1.6; } .newsletter-form { display: flex; flex-direction: column; gap: 12px; } .newsletter-form input { padding: 12px 15px; background: var(--secondary-color); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 4px; color: var(--white); font-size:0.875rem; transition: var(--transition); } .newsletter-form input:focus { outline: none; border-color: var(--accent-color); } .newsletter-form button { padding: 12px 20px; background: var(--accent-color); color: var(--primary-color); border: none; border-radius: 4px; font-weight: bold; cursor: pointer; transition: var(--transition); display: flex; align-items: center; justify-content: center; } .newsletter-form button:hover { background: #e6c035; transform: translateY(-2px); } .footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 30px; border-top: 1px solid rgba(255, 255, 255, 0.1); flex-wrap: wrap; gap: 15px; } .footer-bottom p { font-size:0.8125rem; color: rgba(255, 255, 255, 0.5); } .footer-bottom-links { display: flex; gap: 20px; } .footer-bottom-links a { color: rgba(255, 255, 255, 0.5); text-decoration: none; font-size:0.8125rem; transition: var(--transition); } .footer-bottom-links a:hover { color: var(--accent-color); } .go-up-btn { position: fixed; bottom: 30px; right: 30px; width: 50px; height: 50px; background: var(--accent-color); color: var(--primary-color); border: none; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 20px; transition: var(--transition); opacity: 0; visibility: hidden; z-index: 1000; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); } .go-up-btn.visible { opacity: 1; visibility: visible; } .go-up-btn:hover { background: #e6c035; transform: translateY(-3px); box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3); } .offers { padding: 50px 0; background: var(--white); } .offers .section-header { margin-bottom: 60px; } .offers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 30px; } .offer-card { background: var(--light-bg); border-radius: 12px; padding: 24px 24px 28px; box-shadow: 0 12px 32px rgba(0, 0, 0, 0.06); border: 1px solid rgba(139, 115, 85, 0.15); display: flex; flex-direction: column; gap: 8px; position: relative; overflow: hidden; transition: var(--transition); } .offer-card::before { content: ''; position: absolute; inset: 0; opacity: 0; background: radial-gradient(circle at top left, rgba(212, 175, 55, 0.26), transparent 52%); transition: var(--transition); } .offer-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0, 0, 0, 0.08); } .offer-card:hover::before { opacity: 1; } .offer-card h3 { font-size:1.25rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--primary-color); margin-bottom: 4px; } .offer-card p { font-size:0.875rem; color: var(--text-light); margin: 0; } .offer-time { font-size:0.75rem; text-transform: uppercase; letter-spacing: 0.16em; color: var(--secondary-color); margin-top: 4px; } .offer-price, .offer-price-extra { font-size:1.25rem; font-weight: 600; color: var(--accent-color); margin-top: 10px; } .offer-note { font-size:0.75rem; color: var(--text-light); margin-top: 8px; } .offer-highlight { background: var(--primary-color); color: var(--white); border-color: rgba(255, 255, 255, 0.25); } .offer-highlight h3, .offer-highlight p, .offer-highlight .offer-price-extra { color: var(--white); } .business-pricing { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px; margin: 10px 0 32px; } .price-card { background: #fff; border-radius: 10px; padding: 20px 22px; border: 1px solid rgba(139, 115, 85, 0.18); box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06); transition: var(--transition); } .price-card:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(0, 0, 0, 0.08); } .price-card h4 { font-size:1.125rem; color: var(--primary-color); margin-bottom: 6px; } .price-main { font-size:1.25rem; color: var(--accent-color); font-weight: 600; margin-bottom: 4px; } .price-note { font-size:0.8125rem; color: var(--text-light); } .business-contact { font-size:0.875rem; color: var(--text-light); margin: 20px 0; } .business-contact a { color: var(--accent-color); text-decoration: none; border-bottom: 1px solid rgba(212, 175, 55, 0.4); padding-bottom: 1px; } .business-contact a:hover { color: var(--primary-color); border-color: var(--primary-color); } @media (max-width: 768px) { .offers { padding: 70px 0; } } @media (max-width: 992px) { .footer-content { grid-template-columns: 1fr 1fr; gap: 40px; } } @media (max-width: 768px) { .footer-content { grid-template-columns: 1fr; gap: 30px; } .footer-bottom { flex-direction: column; text-align: center; } .footer-bottom-links { justify-content: center; } } @keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } @keyframes scrollDown { 0%, 100% { transform: translateY(0); opacity: 0; } 50% { opacity: 1; } } @media (max-width: 1024px) { .container { padding: 0 30px; } .nav-container { padding: 0 30px; } .hero-title { font-size: 70px; } .section-title { font-size: 42px; } .about-content, .contact-content, .business-content { grid-template-columns: 1fr; gap: 50px; } .footer-content { grid-template-columns: 1fr; gap: 40px; } .values-grid { grid-template-columns: 1fr; } } @media (max-width: 768px) { .menu-toggle { display: flex; z-index: 1001; } .nav-menu { position: fixed; top: 0; right: -100%; width: 70%; height: 100vh; background: var(--primary-color); flex-direction: column; padding: 100px 40px; gap: 30px; transition: var(--transition); } .nav-menu.active { right: 0; } .nav-menu a { color: var(--white); font-size:1.125rem; } .hero-title { font-size: 50px; } .hero-title span { font-size: 24px; } .section-title { font-size: 36px; } .gallery { grid-template-columns: 1fr; } .contact-form-wrapper { padding: 30px; } .news-grid { grid-template-columns: 1fr; } .about-conclusion { padding: 30px 20px; } .value-item { padding: 20px; } } @media (max-width: 480px) { .container { padding: 0 20px; } .nav-container { padding: 0 20px; } .hero-title { font-size: 38px; letter-spacing: 4px; } .hero-title span { font-size: 18px; letter-spacing: 6px; } .section-title { font-size: 32px; } .btn-primary { padding: 15px 35px; font-size:0.75rem; } 

.menu-item { flex-direction: column; gap: 15px; } 
.menu-item-price { margin-left: 0; } .values-title { font-size: 24px; } .about-conclusion h3 { font-size: 20px; } .service-item h3 { font-size: 18px; } .news-content { padding: 20px; } .news-content h3 { font-size: 18px; } } .hero { transform: none !important; will-change: auto; } section { scroll-margin-top: 90px; } @media (min-width: 769px) and (max-width: 1199.98px) { .menu-toggle { display: flex; z-index: 1100; } .nav-menu { position: fixed; top: 0; right: -100%; width: min(88vw, 420px); height: 100dvh; background: var(--primary-color); flex-direction: column; justify-content: flex-start; align-items: flex-start; padding: 96px 32px 32px; gap: 22px; transition: var(--transition); box-shadow: -12px 0 32px rgba(0,0,0,.25); } .nav-menu.active { right: 0; } .nav-menu a { color: var(--white); font-size:1rem; } .navbar.scrolled .nav-menu a { color: var(--white); } .navbar { padding: 18px 0; } .hero { min-height: 82dvh; } .hero-title { font-size: clamp(44px, 7vw, 68px); letter-spacing: clamp(2px, .6vw, 6px); line-height: 1.1; } .hero-title span { font-size: clamp(18px, 2.4vw, 28px); letter-spacing: clamp(4px, 1vw, 10px); } .scroll-indicator { display: none; } .about-content, .business-content { grid-template-columns: 1fr; gap: 36px; } .about-image, .business-image { height: auto; } .gallery { grid-template-columns: repeat(2, minmax(260px, 1fr)); } .gallery-image { height: clamp(240px, 36vw, 360px); } .contact .contact-map { min-height: clamp(460px, 60dvh, 680px); } .leaflet-container { height: 100%; min-height: inherit; } .menu-toggle span { transition: transform .25s ease, opacity .25s ease, background-color .25s ease; } .menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); } .menu-toggle.active span:nth-child(2) { opacity: 0; } .menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); } } body.lock { overflow: hidden; } .hero { position: relative; width: 100%; height: 100vh; min-height: 480px; max-height: 900px; overflow: hidden; } .hero-video { position: relative; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; z-index: 1; } .hero-overlay { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.25); z-index: 2; } .scroll-indicator { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 3; } .scroll-indicator span { display: block; width: 2px; height: 32px; border-radius: 999px; background: #fff; opacity: 0.8; } @media (max-width: 768px) { .hero { height: 90vh; min-height: 380px; } .scroll-indicator { bottom: 16px; } } @media (max-height: 700px) { .hero { height: 100vh; min-height: 360px; } } @media (min-width: 1600px) { .hero-video { object-position: center center; } } .btn-primary { display: inline-block; padding: 18px 45px; background: var(--accent-color); color: var(--primary-color); text-decoration: none; font-size:0.8125rem; letter-spacing: 2px; font-weight: 500; text-transform: uppercase; border: 2px solid var(--accent-color); transition: var(--transition); position: relative; overflow: hidden; } .btn-primary::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: var(--white); transition: var(--transition); z-index: -1; } .btn-primary:hover::before { left: 0; } .btn-primary:hover { color: var(--primary-color); border-color: var(--white); } .scroll-indicator { position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%); z-index: 2; } .scroll-indicator span { display: block; width: 1px; height: 60px; background: linear-gradient(to bottom, transparent, var(--accent-color)); animation: scrollDown 2s infinite; } .loyalty-section { padding: 70px 0 40px; background: var(--white); border-bottom: 1px solid rgba(139, 115, 85, 0.18); } .loyalty-card { max-width: 80wv; margin: 0 auto; padding: 26px 32px; background: var(--light-bg); border-radius: 10px; border: 1px solid rgba(139, 115, 85, 0.18); box-shadow: 0 12px 32px rgba(0, 0, 0, 0.06); display: flex; flex-direction: column; gap: 18px; } .loyalty-header { text-align: center; } .loyalty-title { font-family: var(--font-sans); font-size:1.25rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--primary-color); margin-bottom: 6px; } .loyalty-subtitle { font-size:0.875rem; color: var(--text-light); } .loyalty-perks { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 4px; } .loyalty-perk { flex: 1 1 170px; max-width: 210px; min-width: 150px; padding: 10px 16px; border-radius: 999px; background: rgba(255, 255, 255, 0.9); border: 1px solid rgba(139, 115, 85, 0.2); display: flex; align-items: center; justify-content: center; gap: 8px; transition: var(--transition); } .loyalty-perk:hover { background: #f1ebe1; transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06); } .perk-icon { font-size: 18px; line-height: 1; } .perk-text { font-size:0.8125rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-dark); white-space: nowrap; } .loyalty-cta { margin-top: 4px; text-align: center; font-size:0.75rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--secondary-color); } @media (max-width: 992px) { .loyalty-card { padding: 22px 22px; } .loyalty-title { font-size:1.125rem; letter-spacing: 0.18em; } } @media (max-width: 768px) { .loyalty-section { padding: 50px 0 30px; } .loyalty-card { padding: 20px 18px; border-radius: 8px; } .loyalty-perks { gap: 10px; } .loyalty-perk { flex: 1 1 45%; max-width: none; } .perk-text { font-size:0.75rem; letter-spacing: 0.1em; } } @media (max-width: 480px) { .loyalty-perk { flex: 1 1 100%; justify-content: center; } .loyalty-card { padding: 18px 14px; } .loyalty-title { font-size:1rem; letter-spacing: 0.16em; } } .about { padding: 120px 0; background: var(--white); } .about-content { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; } .section-label { display: inline-block; color: var(--accent-color); font-size:0.75rem; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 20px; font-weight: 500; } .section-title { font-size:3.25rem; color: var(--primary-color); margin-bottom: 30px; line-height: 1.2; } .about-text p { font-size:1rem; color: var(--text-light); margin-bottom: 20px; line-height: 1.8; } .values-section { margin: 50px 0; } .values-title { font-size:1.75rem; color: var(--primary-color); margin-bottom: 30px; } .values-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 30px; } .value-item { padding: 30px; background: var(--light-bg); border-radius: 5px; transition: var(--transition); position: relative; overflow: hidden; } .value-item::before { content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--accent-color); transform: scaleY(0); transition: var(--transition); } .value-item:hover::before { transform: scaleY(1); } .value-item:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1); } .value-item h4 { font-size:1.25rem; color: var(--primary-color); margin-bottom: 15px; } .value-item p { font-size:0.875rem; color: var(--text-light); line-height: 1.7; } .about-conclusion { margin-top: 50px; padding: 40px; background: var(--light-bg); text-align: center; border-radius: 5px; position: relative; overflow: hidden; } .about-conclusion::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: linear-gradient(to right, var(--primary-color), var(--accent-color)); } .about-conclusion h3 { font-size:1.5rem; color: var(--primary-color); margin-bottom: 20px; } .about-conclusion p { font-size:1rem; color: var(--text-light); max-width: 700px; margin: 0 auto; } .about-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; margin-top: 50px; } .feature-item h3 { font-size:1.25rem; color: var(--primary-color); margin-bottom: 10px; } .feature-item p { font-size:0.875rem; color: var(--text-light); } .about-image { height: 1024px; border-radius: 8px; overflow: hidden; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); } .image-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--secondary-color), var(--accent-color)); position: relative; overflow: hidden; } .image-placeholder img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition); } .about-image:hover .image-placeholder img { transform: scale(1.05); } .menu { padding: 70px 0; background: var(--white); } .menu .section-header { text-align: center; margin-bottom: 40px; } .menu-subtitle { margin-top: 10px; font-size:0.875rem; color: var(--text-light); } .menu-categories { display: flex; justify-content: center; gap: 8px; margin-bottom: 30px; flex-wrap: wrap; } .category-btn { padding: 8px 18px; background: #fff; border: 1px solid rgba(139, 115, 85, 0.3); border-radius: 999px; font-size:0.6875rem; letter-spacing: 0.14em; text-transform: uppercase; cursor: pointer; color: var(--text-dark); transition: var(--transition); } .category-btn:hover { border-color: var(--accent-color); } .category-btn.active { background: var(--text-dark); border-color: var(--text-dark); color: #fff; } 
.menu-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 18px; } 
.menu-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; box-shadow: 0 4px 14px rgba(0, 0, 0, 0.03); transition: var(--transition); } 
.menu-item:hover { box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06); transform: translateY(-1px); } 
.menu-item-main { flex: 1 1 auto; min-width: 0; } 
.menu-item-name { padding: 15px; font-size:0.75rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-dark); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } 
.menu-item-price { font-size:0.8125rem; font-weight: 600; color: var(--accent-color); white-space: nowrap; margin-left: 8px; } 
.menu-item-wide { grid-column: 1 / -1; border-radius: 12px; background: #f8f2e8; align-items: flex-start; padding: 14px 20px 16px; } 
.menu-item-wide .menu-item-name { font-size:0.8125rem; } 
.menu-item-desc { font-size:0.75rem; color: var(--text-light); margin-top: 6px; } 
.menu-item-allergens { font-size:0.6875rem; color: var(--text-light); margin-top: 4px; opacity: 0.9; } @media (max-width: 900px) { .menu-grid { grid-template-columns: 1fr; } 
.menu-item { border-radius: 12px; } 
.menu-item-name { white-space: normal; } } 

.business { padding: 110px 0; background: #fdf9f3; } 
.business .section-header { text-align: center; margin-bottom: 36px; } .business-hero { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.2fr); gap: 28px; align-items: stretch; margin-bottom: 40px; } .business-hero-image .image-placeholder { border-radius: 22px; overflow: hidden; height: 100%; } .business-hero-image img { width: 100%; height: 100%; object-fit: cover; } .business-hero-text { background: #ffffff; border-radius: 22px; padding: 26px 26px 24px; box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06); border: 1px solid rgba(139, 115, 85, 0.12); display: flex; flex-direction: column; gap: 14px; } .business-lead { font-size:0.875rem; color: var(--text-light); } .business-tags { display: flex; flex-wrap: wrap; gap: 8px; } .business-tags span { padding: 5px 11px; border-radius: 999px; font-size:0.6875rem; letter-spacing: 0.12em; text-transform: uppercase; background: #f7efe3; color: var(--primary-color); } .business-bullets { margin: 6px 0 0; padding-left: 18px; font-size:0.8125rem; color: var(--text-light); } .business-bullets li + li { margin-top: 4px; } .business-packages { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 20px; margin-bottom: 26px; } .business-package { background: #fff; border-radius: 18px; padding: 20px 20px 22px; border: 1px solid rgba(139, 115, 85, 0.14); box-shadow: 0 10px 30px rgba(0,0,0,0.05); transition: transform 0.25s ease, box-shadow 0.25s ease; } .business-package:hover { transform: translateY(-3px); box-shadow: 0 16px 38px rgba(0,0,0,0.08); } .business-package h3 { font-size:0.9375rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--primary-color); margin-bottom: 6px; } .business-package-desc { font-size:0.8125rem; color: var(--text-light); margin-bottom: 8px; } .business-package-price { font-size:1.125rem; font-weight: 600; color: var(--accent-color); } .business-package-note { font-size:0.75rem; color: var(--text-light); } .business-cta { text-align: center; font-size:0.8125rem; color: var(--text-light); margin-top: 6px; } .business-cta a { color: var(--accent-color); text-decoration: none; border-bottom: 1px solid rgba(212, 175, 55, 0.45); } .business-cta a:hover { color: var(--primary-color); border-color: var(--primary-color); } .business-cta .btn-primary { margin-top: 12px; } @media (max-width: 900px) { .business { padding: 80px 0; } .business-hero { grid-template-columns: 1fr; } .business-hero-text { padding: 20px 18px; border-radius: 18px; } }

/* Scroll reveal animations */
@media (prefers-reduced-motion: no-preference) {
  .reveal-section {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
    will-change: opacity, transform;
  }
  .reveal-section.in-view {
    opacity: 1;
    transform: translateY(0);
  }
}
/* === PREMIUM ANIMATIONS === */

.reveal-section {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.9s ease, transform 0.9s ease;
}

.reveal-section.in-view {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Zoom dla zdjęć */
.img-zoom {
    overflow: hidden;
    position: relative;
}

.img-zoom img {
    transform: scale(1);
    transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.img-zoom:hover img {
    transform: scale(1.12);
}

/* Subtelny glowy złoty border */
.gallery-item::after,
.news-item::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 8px;
    pointer-events: none;
    box-shadow: 0 0 0 rgba(212, 175, 55, 0);
    transition: box-shadow .6s ease;
}

.gallery-item:hover::after,
.news-item:hover::after {
    box-shadow: 0 0 25px rgba(212, 175, 55, 0.45);
}

/* Delikatny shift na hover */
.gallery-item,
.news-item {
    transition: transform .6s cubic-bezier(.22,1,.36,1);
}

.gallery-item:hover,
.news-item:hover {
    transform: translateY(-12px);
}
/* GOLD SHIMMER */
@keyframes goldShimmer {
    0% { opacity: 0; transform: translateX(-100%); }
    50% { opacity: 0.45; }
    100% { opacity: 0; transform: translateX(200%); }
}

.gallery-item:hover .image-placeholder::before,
.news-item:hover .image-placeholder::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg,
        transparent 0%,
        rgba(255,255,255,0.55) 45%,
        transparent 100%);
    animation: goldShimmer 1.2s ease;
    pointer-events: none;
}

/* Kontener dla trzech kolumn */
.business-hero {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr; /* 3 równe kolumny */
    gap: 2rem; /* Odstęp między kolumnami */
    align-items: start; /* Wyrównanie do góry */
    margin-bottom: 3rem;
}

/* Pojedyncza kolumna */
.business-column {
    display: flex;
    flex-direction: column;
    gap: 1.5rem; /* Odstęp między elementami w kolumnie */
}

/* Stylizacja obrazków - teraz jednakowa dla obu */
.business-column .image-placeholder {
    position: relative;
    overflow: hidden;
    border-radius: 25px;
    aspect-ratio: 1 / 1; /* KWADRAT - kluczowe dla równych wymiarów! */
}

.business-column .image-placeholder img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Obrazek wypełni kwadrat bez deformacji */
    transition: transform 0.3s ease;
}

/* Efekt hover (jeśli jest klasa img-zoom) */
.img-zoom:hover img {
    transform: scale(1.05);
}

/* Reszta stylów - dostosuj według potrzeb */
.business-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.business-tags span {
    background: #f0f0f0;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.875rem;
}

.business-bullets {
    list-style: none;
    padding: 0;
}

.business-bullets li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.5rem;
}

.business-bullets li:before {
    content: "•";
    position: absolute;
    left: 0;
    color: #d4a574; /* Lub inny kolor akcentu */
}

/* Responsywność */
@media (max-width: 768px) {
    .business-hero {
        grid-template-columns: 1fr; /* Jedna kolumna na mobile */
        gap: 1.5rem;
    }
    
    .business-column .image-placeholder {
        aspect-ratio: 16 / 9; /* Inny proporcja na mobile jeśli wolisz */
    }
}

/* ======= NEWS SINGLE PAGE ======= */
.news-single {
  font-family: "Montserrat", sans-serif;
  color: #2a2a2a;
}

/* HERO */
.news-hero {
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  color: #fff;
  text-align: center;
}
.news-hero .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
}
.news-hero .container {
  position: relative;
  padding: 4rem 1rem;
}
.news-hero .news-title {
  font-size: 2.8rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: #fff;
}
.news-hero .news-date {
  font-size: 1rem;
  opacity: 0.85;
}

/* TREŚĆ */
.news-content {
  max-width: 900px;
  margin: 4rem auto;
  font-size: 1.1rem;
  line-height: 1.7;
}
.news-content p {
  margin-bottom: 1.2rem;
}
.news-content .back-link {
  margin-top: 2.5rem;
  text-align: center;
}
.news-content .btn-gold {
  background: #c39a50;
  color: #fff;
  padding: 0.75rem 1.8rem;
  border-radius: 4px;
  text-decoration: none;
  transition: 0.2s ease;
}
.news-content .btn-gold:hover {
  background: #b1873f;
}

/* POWIĄZANE ARTYKUŁY */
.related-news {
  background: #faf8f5;
  padding: 4rem 0;
}
.related-news .section-title {
  text-align: center;
  font-size: 2rem;
  color: #b1873f;
  margin-bottom: 2rem;
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
}
.related-item {
  text-decoration: none;
  color: inherit;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  transition: 0.3s;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.related-item:hover {
  transform: translateY(-4px);
}
.related-thumb {
  height: 180px;
  background-size: cover;
  background-position: center;
}
.related-info {
  padding: 1rem 1.2rem;
}
.related-info h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: #2a2a2a;
  margin-bottom: 0.3rem;
}
.related-date {
  font-size: 0.9rem;
  color: #888;
}

/* ===== MOBILE FIX – GALLERY FLOW ===== */
/* =====================================================
   MOBILE (≤ 768px)
   ===================================================== */
@media (max-width: 768px) {

  /* ---------- CONTACT ---------- */
  .form-card {
    padding: 1.5rem;
  }

  .contact-details {
    gap: 1.25rem;
    margin-top: 1.5rem;
  }

  .contact-item {
    gap: 0.875rem;
  }

  /* ---------- GALLERY (MOBILE SLIDER) ---------- */
  .gallery {
    display: flex;
    flex-wrap: nowrap;
    max-width: 350px;

    gap: 16px;
    padding: 0 16px 24px;

    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;

    height: auto !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .gallery-item {
    flex: 0 0 85%;
    scroll-snap-align: start;
    min-width: 333px;
  }

  /* Hide scrollbar (WebKit) */
  .gallery::-webkit-scrollbar {
    display: none;
  }
}

/* =====================================================
   CONTACT – DESKTOP & GLOBAL
   ===================================================== */
.contact .contact-content {
  display: grid;
  gap: clamp(16px, 2vw, 28px);
}

