body { margin: 0; padding: 0; background-color: #F9F8F4; color: #4A3F35; font-family: 'Inter', sans-serif; -webkit-font-smoothing: antialiased; }
        h1, h2, h3, h4, h5, h6 { font-family: 'Playfair Display', serif; }
        .botanical-line { background-image: url("data:image/svg+xml,%3Csvg width='100' height='20' viewBox='0 0 100 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 10C20 10 30 0 50 0C70 0 80 20 100 20' stroke='%237A8B76' stroke-width='0.5' fill='none'/%3E%3C/svg%3E"); background-repeat: repeat-x; background-position: center; }
        .masonry-grid { column-count: 1; column-gap: 1.5rem; }
        @media (min-width: 768px) { .masonry-grid { column-count: 2; } }
        @media (min-width: 1024px) { .masonry-grid { column-count: 3; } }
        .masonry-item { break-inside: avoid; margin-bottom: 1.5rem; }

        html { scroll-behavior: smooth; }
        img { display: block; }
        .reveal { opacity: 0; transform: translateY(24px); transition: opacity .85s ease, transform .85s cubic-bezier(.2,.8,.2,1); transition-delay: var(--delay, 0ms); }
        .reveal.is-visible { opacity: 1; transform: translateY(0); }
        .float-soft { animation: floatSoft 7s ease-in-out infinite; }
        .pulse-soft { animation: pulseSoft 3s ease-in-out infinite; }
        .gallery-card { filter: grayscale(22%) brightness(.72) saturate(.75); transform: translateZ(0); transition: filter .55s ease, transform .65s cubic-bezier(.2,.8,.2,1), box-shadow .55s ease; }
        .gallery-card:hover { filter: grayscale(0%) brightness(1) saturate(1); transform: translateY(-6px) scale(1.025); box-shadow: 0 24px 60px -24px rgba(74,63,53,.35); }
        .gallery-card img { transition: transform .75s cubic-bezier(.2,.8,.2,1); }
        .gallery-card:hover img { transform: scale(1.075); }
        .map-frame { min-height: 440px; }
        .map-frame iframe { width: 100%; height: 100%; min-height: 440px; border: 0; }
        @keyframes floatSoft { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
        @keyframes pulseSoft { 0%,100% { box-shadow: 0 0 0 0 rgba(122,139,118,.22); } 50% { box-shadow: 0 0 0 12px rgba(122,139,118,0); } }


        #o-mnie .about-photo-frame img {
            width: 100%;
            height: 100%;
            display: block;
            object-fit: cover;
            object-position: center center;
            image-rendering: auto;
            transform: translateZ(0);
        }
        #o-mnie .about-document-frame {
            background: #fffdfa;
            border: 1px solid rgba(122,139,118,.12);
        }
        #o-mnie .about-document-frame img {
            width: 100%;
            height: 100%;
            display: block;
            object-fit: contain;
            object-position: center center;
            padding: 18px;
            background: #fffdfa;
            image-rendering: auto;
            filter: contrast(1.04) saturate(1.02);
            transform: translateZ(0);
        }


        #o-mnie .about-layout {
            display: grid;
            grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr);
            gap: clamp(2.5rem, 6vw, 5rem);
            align-items: center;
        }
        #o-mnie .about-visual {
            display: grid;
            gap: 1rem;
            align-content: start;
        }
        #o-mnie .about-photo-frame--main {
            height: min(560px, 64vw);
            min-height: 420px;
            border: 1px solid rgba(122,139,118,.12);
            background: #EFECE5;
        }
        #o-mnie .about-content {
            max-width: 660px;
        }
        #o-mnie .about-inline-cta {
            display: inline-flex;
            align-items: center;
            gap: .65rem;
            margin-top: 2rem;
            padding: .92rem 1.25rem;
            border-radius: 999px;
            background: #4A5B46;
            color: #F9F8F4;
            font-weight: 700;
            font-size: .92rem;
            transition: background .25s ease, transform .25s ease;
        }
        #o-mnie .about-inline-cta:hover {
            background: #7A8B76;
            transform: translateY(-1px);
        }
        #o-mnie .about-cert-card {
            display: grid;
            grid-template-columns: auto minmax(0, 1fr) auto;
            align-items: center;
            gap: 1rem;
            width: 100%;
            padding: 1.05rem 1.15rem;
            border-radius: 24px;
            background: #F9F8F4;
            border: 1px solid rgba(122,139,118,.14);
            box-shadow: 0 18px 54px -36px rgba(74,63,53,.28);
            color: #4A3F35;
            text-align: left;
            cursor: zoom-in;
            transition: border-color .25s ease, transform .25s ease, box-shadow .25s ease;
        }
        #o-mnie .about-cert-card:hover {
            border-color: rgba(122,139,118,.34);
            transform: translateY(-2px);
            box-shadow: 0 22px 60px -38px rgba(74,63,53,.38);
        }
        #o-mnie .about-cert-card:focus-visible {
            outline: 3px solid rgba(122,139,118,.45);
            outline-offset: 4px;
        }
        #o-mnie .about-cert-card__icon,
        #o-mnie .about-cert-card__action,
        #o-mnie .about-proof-card__icon {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 46px;
            height: 46px;
            border-radius: 16px;
            background: #EFECE5;
            color: #7A8B76;
            flex: 0 0 auto;
        }
        #o-mnie .about-cert-card__content {
            display: grid;
            gap: .2rem;
        }
        #o-mnie .about-cert-card__title {
            color: #4A5B46;
            font-family: 'Playfair Display', serif;
            font-size: 1.15rem;
            line-height: 1.2;
        }
        #o-mnie .about-cert-card__text {
            color: #8B7D6B;
            font-size: .86rem;
            line-height: 1.45;
        }
        #o-mnie .about-cert-card__action {
            width: 40px;
            height: 40px;
            border-radius: 999px;
            background: #4A5B46;
            color: #F9F8F4;
        }
        #o-mnie .about-proof-grid {
            display: grid;
            grid-template-columns: minmax(0, 1.04fr) minmax(0, .96fr);
            gap: 1.25rem;
            margin-top: clamp(2rem, 5vw, 4rem);
            align-items: start;
        }
        #o-mnie .about-proof-card {
            border-radius: 30px;
            background: #F9F8F4;
            border: 1px solid rgba(122,139,118,.13);
            box-shadow: 0 18px 54px -36px rgba(74,63,53,.28);
            padding: clamp(1.15rem, 2.4vw, 1.65rem);
        }
        #o-mnie .about-proof-card__head {
            display: flex;
            align-items: center;
            gap: .9rem;
            margin-bottom: 1.15rem;
        }
        #o-mnie .about-proof-card__head h3 {
            margin: 0;
            color: #4A5B46;
            font-size: clamp(1.25rem, 2vw, 1.55rem);
            line-height: 1.15;
        }
        #o-mnie .about-credentials-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: .85rem;
        }
        #o-mnie .about-credential-item {
            min-height: 100%;
            border-radius: 22px;
            background: rgba(239,236,229,.45);
            border: 1px solid rgba(122,139,118,.1);
            padding: 1rem;
        }
        #o-mnie .about-credential-item h4 {
            margin: 0 0 .55rem;
            color: #4A5B46;
            font-size: 1.02rem;
            line-height: 1.2;
        }
        #o-mnie .about-credential-item p {
            margin: 0;
            color: #8B7D6B;
            font-size: .86rem;
            line-height: 1.55;
        }
        #o-mnie .about-course-tags {
            display: flex;
            flex-wrap: wrap;
            gap: .65rem;
            margin: 0;
            padding: 0;
            list-style: none;
        }
        #o-mnie .about-course-tags li {
            display: inline-flex;
            align-items: center;
            border-radius: 999px;
            background: rgba(239,236,229,.55);
            border: 1px solid rgba(122,139,118,.1);
            color: #8B7D6B;
            font-size: .86rem;
            line-height: 1.35;
            padding: .62rem .85rem;
        }
        @media (max-width: 1023px) {
            #o-mnie .about-layout,
            #o-mnie .about-proof-grid {
                grid-template-columns: 1fr;
            }
            #o-mnie .about-content {
                max-width: none;
            }
            #o-mnie .about-photo-frame--main {
                height: 460px;
                min-height: 360px;
            }
        }
        @media (max-width: 760px) {
            #o-mnie .about-credentials-grid {
                grid-template-columns: 1fr;
            }
        }
        @media (max-width: 640px) {
            #o-mnie .about-photo-frame--main {
                height: 340px;
                min-height: 320px;
                border-radius: 28px;
            }
            #o-mnie .about-cert-card {
                grid-template-columns: auto minmax(0, 1fr);
            }
            #o-mnie .about-cert-card__action {
                display: none;
            }
            #o-mnie .about-proof-card {
                border-radius: 24px;
            }
            #o-mnie .about-course-tags li {
                width: 100%;
                border-radius: 18px;
            }
        }


        .brand-logo-lockup {
            display: inline-flex;
            align-items: center;
            gap: 0.75rem;
        }
        .brand-logo-mark {
            width: clamp(76px, 6vw, 90px);
            height: clamp(76px, 6vw, 90px);
            display: block;
            object-fit: contain;
            flex: 0 0 auto;
            border-radius: 999px;
        }
        footer .brand-logo-mark {
            width: clamp(86px, 7vw, 102px);
            height: clamp(86px, 7vw, 102px);
            filter: drop-shadow(0 8px 18px rgba(0,0,0,.14));
        }
        .hero-photo-frame {
            max-width: 520px;
            margin-left: auto;
        }
        @media (max-width: 1023px) {
            .hero-photo-frame {
                max-width: none;
                margin-left: 0;
            }
        }
        #o-mnie .about-document-frame {
            position: relative;
            cursor: zoom-in;
            appearance: none;
            width: 100%;
            text-align: inherit;
        }
        #o-mnie .about-document-frame:focus-visible {
            outline: 3px solid rgba(122,139,118,.45);
            outline-offset: 4px;
        }
        #o-mnie .about-document-frame__hint {
            position: absolute;
            right: 0.85rem;
            bottom: 0.85rem;
            z-index: 2;
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
            padding: 0.55rem 0.75rem;
            border-radius: 999px;
            background: rgba(74,91,70,.92);
            color: #F9F8F4;
            font-size: 0.72rem;
            font-weight: 700;
            line-height: 1;
            opacity: 0;
            transform: translateY(6px);
            transition: opacity .25s ease, transform .25s ease;
            pointer-events: none;
        }
        #o-mnie .about-document-frame:hover .about-document-frame__hint,
        #o-mnie .about-document-frame:focus-visible .about-document-frame__hint {
            opacity: 1;
            transform: translateY(0);
        }
        .cert-modal {
            position: fixed;
            inset: 0;
            z-index: 100;
            display: grid;
            place-items: center;
            padding: clamp(1rem, 3vw, 2rem);
            background: rgba(35, 31, 28, .72);
            backdrop-filter: blur(10px);
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
            transition: opacity .25s ease, visibility .25s ease;
        }
        .cert-modal.is-open {
            opacity: 1;
            visibility: visible;
            pointer-events: auto;
        }
        .cert-modal__dialog {
            position: relative;
            width: min(1120px, 100%);
            max-height: min(86vh, 900px);
            border-radius: 28px;
            background: #fffdfa;
            border: 1px solid rgba(239,236,229,.8);
            box-shadow: 0 36px 90px -26px rgba(0,0,0,.45);
            overflow: hidden;
            transform: translateY(12px) scale(.98);
            transition: transform .25s ease;
        }
        .cert-modal.is-open .cert-modal__dialog {
            transform: translateY(0) scale(1);
        }
        .cert-modal__img {
            width: 100%;
            max-height: min(86vh, 900px);
            display: block;
            object-fit: contain;
            background: #fffdfa;
            padding: clamp(0.75rem, 2vw, 1.5rem);
        }
        .cert-modal__close {
            position: absolute;
            top: 1rem;
            right: 1rem;
            z-index: 2;
            width: 42px;
            height: 42px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: rgba(74,91,70,.94);
            color: #F9F8F4;
            border: 1px solid rgba(249,248,244,.2);
            box-shadow: 0 12px 24px -14px rgba(0,0,0,.4);
            transition: transform .2s ease, background .2s ease;
        }
        .cert-modal__close:hover {
            background: #7A8B76;
            transform: translateY(-1px);
        }
        body.cert-modal-open {
            overflow: hidden;
        }


        .sunvit-gallery-orbit {
            position: relative;
            min-height: 780px;
            display: grid;
            place-items: center;
            padding: clamp(3rem, 8vw, 5rem) 0;
            overflow: hidden;
        }
        .sunvit-gallery-panel {
            position: relative;
            z-index: 1;
            width: min(520px, calc(100% - 2rem));
            min-height: 560px;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            text-align: center;
            padding: clamp(2rem, 5vw, 4rem);
            background: #4A5B46;
            color: #F9F8F4;
            box-shadow: 0 34px 90px -54px rgba(74,63,53,.55);
        }
        .sunvit-gallery-panel p {
            max-width: 360px;
            margin: 0;
            color: rgba(249,248,244,.74);
            font-weight: 300;
            line-height: 1.7;
        }
        .sunvit-gallery-marquee {
            position: absolute;
            left: 50%;
            z-index: 3;
            width: 100vw;
            transform: translateX(-50%);
            overflow: hidden;
            mask-image: linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%);
        }
        .sunvit-gallery-marquee--top {
            top: 65.5%;
        }
        .sunvit-gallery-marquee--bottom {
            top: 34.5%;
        }
        .sunvit-gallery-track {
            display: flex;
            width: max-content;
            gap: 1rem;
            animation: sunvitGalleryScroll 72s linear infinite;
            will-change: transform;
        }
        .sunvit-gallery-marquee--bottom .sunvit-gallery-track {
            animation-name: sunvitGalleryScrollReverse;
            animation-duration: 82s;
        }
        .sunvit-gallery-marquee:hover .sunvit-gallery-track,
        .sunvit-gallery-marquee:focus-within .sunvit-gallery-track {
            animation-play-state: paused;
        }
        .sunvit-gallery-group {
            display: flex;
            gap: 1rem;
            padding-right: 1rem;
        }
        .sunvit-gallery-orbit__card {
            position: relative;
            width: clamp(300px, 26vw, 390px);
            height: clamp(185px, 16vw, 225px);
            flex: 0 0 auto;
            margin: 0;
            overflow: hidden;
            background: #EFECE5;
            box-shadow: 0 22px 54px -30px rgba(74,63,53,.55);
            isolation: isolate;
        }
        .sunvit-gallery-orbit__card::after {
            content: '';
            position: absolute;
            inset: 0;
            z-index: 1;
            background: linear-gradient(180deg, rgba(249,248,244,0) 24%, rgba(74,63,53,.12) 56%, rgba(74,63,53,.78) 100%);
            pointer-events: none;
        }
        .sunvit-gallery-orbit__card img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            filter: saturate(.92) contrast(.97);
            transform: scale(1.01);
            transition: transform .75s cubic-bezier(.2,.8,.2,1), filter .55s ease;
        }
        .sunvit-gallery-orbit__card:hover img {
            transform: scale(1.075);
            filter: saturate(1.08) contrast(1.02);
        }
        .sunvit-gallery-orbit__card figcaption {
            position: absolute;
            left: 1rem;
            right: 1rem;
            bottom: .85rem;
            z-index: 2;
            color: #F9F8F4;
            font-family: 'Playfair Display', serif;
            font-size: clamp(1.08rem, 1.55vw, 1.32rem);
            line-height: 1.15;
            text-shadow: 0 2px 18px rgba(0,0,0,.24);
        }
        @keyframes sunvitGalleryScroll {
            from { transform: translateX(0); }
            to { transform: translateX(calc(-50% - .5rem)); }
        }
        @keyframes sunvitGalleryScrollReverse {
            from { transform: translateX(calc(-50% - .5rem)); }
            to { transform: translateX(0); }
        }
        @media (max-width: 1023px) {
            .sunvit-gallery-orbit {
                min-height: 720px;
            }
            .sunvit-gallery-panel {
                min-height: 520px;
            }
            .sunvit-gallery-marquee--top { top: 65.5%; }
            .sunvit-gallery-marquee--bottom { top: 35.5%; }
        }
        @media (max-width: 640px) {
            .sunvit-gallery-orbit {
                min-height: 650px;
                padding: 2.5rem 0;
            }
            .sunvit-gallery-panel {
                width: calc(100% - 2rem);
                min-height: 460px;
                padding: 2rem 1.4rem;
            }
            .sunvit-gallery-orbit__card {
                width: 280px;
                height: 170px;
            }
            .sunvit-gallery-marquee {
                mask-image: linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%);
            }
            .sunvit-gallery-marquee--top { top: 65.5%; }
            .sunvit-gallery-marquee--bottom { top: 35.5%; }
        }

        .contact-panel { border-radius: 40px; background: #F9F8F4; border: 1px solid rgba(122,139,118,.14); box-shadow: 0 24px 70px -38px rgba(74,63,53,.35); padding: clamp(1rem, 2vw, 1.35rem); }
        .route-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.35rem; }
        .model-kicker { display: block; color: #7A8B76; text-transform: uppercase; letter-spacing: .16em; font-size: .72rem; font-weight: 700; margin-bottom: .35rem; }
        .route-head h3 { color: #4A5B46; font-size: clamp(1.8rem, 3vw, 2.55rem); line-height: 1; margin: 0; }
        .route-open { white-space: nowrap; border: 1px solid rgba(122,139,118,.22); color: #4A5B46; border-radius: 999px; padding: .75rem 1rem; font-size: .85rem; font-weight: 600; transition: background .25s ease, color .25s ease, transform .25s ease; }
        .route-open:hover { background: #4A5B46; color: #F9F8F4; transform: translateY(-1px); }
        .route-form { display: grid; gap: 1rem; margin-bottom: 1.25rem; }
        .field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
        .route-form label { display: block; color: #8B7D6B; font-size: .78rem; font-weight: 700; margin-bottom: .35rem; }
        .route-form input { width: 100%; border: 1px solid rgba(122,139,118,.18); background: #fffdfa; border-radius: 18px; padding: .9rem 1rem; color: #4A3F35; outline: none; transition: border-color .25s ease, box-shadow .25s ease; }
        .route-form input:focus { border-color: rgba(122,139,118,.62); box-shadow: 0 0 0 4px rgba(122,139,118,.12); }
        .route-form .btn { justify-self: start; display: inline-flex; align-items: center; gap: .65rem; border-radius: 999px; background: #4A5B46; color: #F9F8F4; padding: .95rem 1.35rem; font-weight: 700; transition: transform .25s ease, background .25s ease; }
        .route-form .btn:hover { background: #7A8B76; transform: translateY(-1px); }
        .route-status { color: #8B7D6B; font-size: .86rem; min-height: 1.2rem; }
        .route-map-shell { overflow: hidden; border-radius: 32px; min-height: 420px; background: #EFECE5; border: 1px solid rgba(122,139,118,.12); }
        .route-map-shell iframe { width: 100%; min-height: 420px; height: 100%; border: 0; display: block; filter: saturate(.86) contrast(.96); }


        .workshop-photo {
            position: relative;
            min-height: 520px;
            overflow: hidden;
            border-radius: 40px;
            background: #EFECE5;
            border: 1px solid rgba(122,139,118,.14);
            box-shadow: 0 24px 70px -38px rgba(74,63,53,.35);
        }
        .workshop-photo img {
            width: 100%;
            height: 100%;
            min-height: 520px;
            object-fit: cover;
            object-position: center center;
            filter: saturate(.94) contrast(.98);
        }
        .workshop-photo__badge {
            position: absolute;
            left: 1.25rem;
            right: 1.25rem;
            bottom: 1.25rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: .7rem;
            padding: .9rem 1rem;
            border-radius: 999px;
            background: rgba(249,248,244,.92);
            color: #4A5B46;
            font-size: .9rem;
            font-weight: 700;
            box-shadow: 0 16px 36px -24px rgba(74,63,53,.45);
            backdrop-filter: blur(10px);
        }
        @media (max-width: 1023px) {
            .workshop-photo,
            .workshop-photo img { min-height: 420px; }
        }
        @media (max-width: 640px) {
            .workshop-photo { border-radius: 28px; min-height: 340px; }
            .workshop-photo img { min-height: 340px; }
            .workshop-photo__badge { border-radius: 22px; flex-wrap: wrap; text-align: center; }
        }

        @media (max-width: 640px) { .field-grid { grid-template-columns: 1fr; } .route-head { flex-direction: column; } .contact-panel { border-radius: 28px; } }



        .visit-calculator {
            max-width: 940px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: minmax(0, 1.02fr) minmax(300px, .78fr);
            gap: 1.15rem;
            align-items: start;
        }
        .visit-calculator__form,
        .visit-calculator__result,
        .pricing-mini {
            border-radius: 28px;
            background: #F9F8F4;
            border: 1px solid rgba(122,139,118,.13);
            box-shadow: 0 18px 54px -36px rgba(74,63,53,.28);
        }
        .visit-calculator__form {
            display: grid;
            gap: .9rem;
            padding: clamp(1rem, 2vw, 1.4rem);
            align-self: start;
            transition: padding .28s ease, box-shadow .28s ease;
        }
        .calculator-field {
            display: grid;
            gap: .55rem;
            margin: 0;
            padding: 0;
            border: 0;
        }
        .calculator-field label,
        .calculator-field legend {
            color: #4A5B46;
            font-size: .78rem;
            font-weight: 800;
            letter-spacing: .08em;
            text-transform: uppercase;
        }
        .calculator-field select {
            width: 100%;
            min-height: 52px;
            border: 1px solid rgba(122,139,118,.18);
            background: #fffdfa;
            border-radius: 16px;
            padding: 0 .95rem;
            color: #4A3F35;
            font: inherit;
            font-weight: 700;
            outline: none;
            transition: border-color .25s ease, box-shadow .25s ease;
        }
        .calculator-field select:focus {
            border-color: rgba(122,139,118,.62);
            box-shadow: 0 0 0 4px rgba(122,139,118,.12);
        }
        .calculator-options {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: .62rem;
        }
        .calculator-option {
            position: relative;
            display: flex;
            align-items: center;
            min-height: 58px;
            padding: .78rem .9rem;
            border-radius: 16px;
            border: 1px solid rgba(122,139,118,.16);
            background: rgba(239,236,229,.36);
            color: #4A3F35;
            font-size: .82rem;
            font-weight: 800;
            letter-spacing: .045em;
            text-transform: uppercase;
            cursor: pointer;
            transition: background .25s ease, border-color .25s ease, transform .25s ease;
        }
        .calculator-option:hover {
            transform: translateY(-1px);
            border-color: rgba(122,139,118,.32);
        }
        .calculator-option input {
            position: absolute;
            opacity: 0;
            pointer-events: none;
        }
        .calculator-option:has(input:checked) {
            background: #4A5B46;
            border-color: #4A5B46;
            color: #F9F8F4;
        }
        .calculator-location {
            display: grid;
            max-height: 0;
            margin-top: -.9rem;
            opacity: 0;
            overflow: hidden;
            transform: translateY(-8px);
            pointer-events: none;
            transition: max-height .34s cubic-bezier(.2,.8,.2,1), opacity .24s ease, transform .34s cubic-bezier(.2,.8,.2,1), margin .34s cubic-bezier(.2,.8,.2,1);
        }
        .calculator-location.is-visible {
            max-height: 150px;
            margin-top: 0;
            opacity: 1;
            transform: translateY(0);
            pointer-events: auto;
        }
        .visit-calculator__result {
            position: relative;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            gap: 1.05rem;
            padding: clamp(1.15rem, 2.2vw, 1.65rem);
            overflow: hidden;
        }
        .visit-calculator__result::before {
            content: '';
            position: absolute;
            top: -3.4rem;
            right: -3.4rem;
            width: 9.5rem;
            height: 9.5rem;
            border-radius: 999px;
            background: rgba(122,139,118,.12);
        }
        .result-kicker {
            position: relative;
            z-index: 1;
            color: #7A8B76;
            text-transform: uppercase;
            letter-spacing: .16em;
            font-size: .68rem;
            font-weight: 800;
        }
        .result-price {
            position: relative;
            z-index: 1;
            color: #4A5B46;
            font-family: 'Playfair Display', serif;
            font-size: clamp(1.75rem, 3.4vw, 2.45rem);
            line-height: .95;
            font-weight: 600;
        }
        .result-note {
            position: relative;
            z-index: 1;
            margin: 0;
            color: #8B7D6B;
            font-size: .88rem;
            line-height: 1.5;
        }
        .result-summary {
            position: relative;
            z-index: 1;
            display: grid;
            gap: .62rem;
            padding-top: .95rem;
            border-top: 1px solid rgba(122,139,118,.14);
        }
        .result-summary div {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            align-items: baseline;
        }
        .result-summary span {
            color: #8B7D6B;
            font-size: .78rem;
        }
        .result-summary strong {
            color: #4A5B46;
            text-align: right;
            font-size: .86rem;
        }
        .result-cta {
            position: relative;
            z-index: 1;
            display: inline-flex;
            justify-content: center;
            align-items: center;
            width: 100%;
            padding: .82rem 1.1rem;
            border-radius: 999px;
            background: #4A5B46;
            color: #F9F8F4;
            font-weight: 750;
            font-size: .92rem;
            transition: background .25s ease, transform .25s ease;
        }
        .result-cta:hover {
            background: #7A8B76;
            transform: translateY(-1px);
        }
        .pricing-mini {
            max-width: 940px;
            margin-left: auto;
            margin-right: auto;
            padding: .85rem clamp(.9rem, 2.4vw, 1.25rem);
        }
        .pricing-mini summary {
            cursor: pointer;
            color: #4A5B46;
            font-family: 'Playfair Display', serif;
            font-size: clamp(1.1rem, 1.7vw, 1.42rem);
            font-weight: 600;
            list-style-position: outside;
            padding: .65rem .25rem;
        }
        .pricing-mini__list {
            display: grid;
            gap: .65rem;
            margin-top: .75rem;
        }
        .pricing-mini__list div {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 1rem;
            align-items: baseline;
            padding: .72rem 0;
            border-top: 1px solid rgba(122,139,118,.12);
        }
        .pricing-mini__list span {
            color: #4A3F35;
            font-weight: 700;
            line-height: 1.45;
        }
        .pricing-mini__list strong {
            color: #4A5B46;
            text-align: right;
            white-space: nowrap;
        }
        .pricing-mini__note {
            margin: 1rem 0 .35rem;
            color: #8B7D6B;
            font-size: .84rem;
            line-height: 1.5;
        }
        @media (max-width: 900px) {
            .visit-calculator { grid-template-columns: 1fr; }
        }
        @media (max-width: 640px) {
            .calculator-options { grid-template-columns: 1fr; }
            .visit-calculator__form,
            .visit-calculator__result,
            .pricing-mini { border-radius: 24px; }
            .result-summary div,
            .pricing-mini__list div { grid-template-columns: 1fr; }
            .result-summary strong,
            .pricing-mini__list strong { text-align: left; }
        }


        @media (prefers-reduced-motion: reduce) {
            html { scroll-behavior: auto; }
            *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
            .reveal { opacity: 1; transform: none; }
            .sunvit-gallery-track { animation: none !important; transform: none !important; }
        }

/* Mobile landing cleanup - SunVit */
.mobile-menu-panel {
    display: none;
}
.mobile-menu-toggle {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    align-items: center;
    justify-content: center;
    background: rgba(239,236,229,.72);
    border: 1px solid rgba(122,139,118,.16);
}
body.mobile-menu-open {
    overflow: hidden;
}

@media (max-width: 1023px) {
    header .h-28 {
        height: 72px;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    main.pt-28 {
        padding-top: 72px;
    }
    .brand-logo-mark {
        width: 58px;
        height: 58px;
    }
    .mobile-menu-toggle {
        display: inline-flex;
    }
    .mobile-menu-panel {
        position: fixed;
        left: 1rem;
        right: 1rem;
        top: 82px;
        z-index: 60;
        display: grid;
        gap: .35rem;
        padding: .85rem;
        border-radius: 26px;
        background: rgba(249,248,244,.96);
        border: 1px solid rgba(122,139,118,.18);
        box-shadow: 0 24px 70px -38px rgba(74,63,53,.42);
        backdrop-filter: blur(18px);
        opacity: 0;
        visibility: hidden;
        transform: translateY(-10px) scale(.98);
        pointer-events: none;
        transition: opacity .22s ease, visibility .22s ease, transform .22s ease;
    }
    .mobile-menu-panel.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0) scale(1);
        pointer-events: auto;
    }
    .mobile-menu-panel a {
        display: flex;
        align-items: center;
        min-height: 46px;
        padding: .72rem 1rem;
        border-radius: 18px;
        color: #4A5B46;
        font-size: .95rem;
        font-weight: 750;
    }
    .mobile-menu-panel a:hover,
    .mobile-menu-panel a:focus-visible {
        background: rgba(122,139,118,.1);
    }
    .mobile-menu-panel__cta {
        justify-content: center;
        margin-top: .25rem;
        background: #4A5B46;
        color: #F9F8F4 !important;
    }
}

@media (max-width: 768px) {
    section {
        scroll-margin-top: 78px;
    }
    #hero,
    #o-mnie,
    #oferta,
    #warsztaty,
    #galeria,
    #cennik,
    #kontakt {
        padding-top: 72px;
        padding-bottom: 72px;
    }
    #hero {
        min-height: auto;
    }
    #hero .py-20 {
        padding-top: 3.5rem;
        padding-bottom: 2rem;
    }
    #hero .gap-16,
    #kontakt .gap-16,
    #warsztaty .gap-16 {
        gap: 2rem;
    }
    #hero h1,
    #kontakt h2 {
        font-size: clamp(2.45rem, 13vw, 3.35rem);
        line-height: 1.04;
        margin-bottom: 1.15rem;
    }
    #hero p,
    #kontakt > div > div > div:first-child > p,
    #warsztaty .space-y-6 p:nth-child(2),
    #o-mnie .about-content .space-y-6 p:nth-child(3) {
        display: none;
    }
    #hero .inline-flex {
        margin-bottom: 1.35rem;
    }
    #hero .flex-col.sm\:flex-row {
        gap: .75rem;
    }
    #hero .flex-col.sm\:flex-row a {
        padding: .92rem 1.15rem;
    }
    .hero-photo-frame {
        height: 360px !important;
        border-radius: 28px !important;
        margin-top: .5rem;
    }
    #hero .absolute.-bottom-8 {
        display: none;
    }
    #trust-strip {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
    #trust-strip .grid {
        gap: 0;
    }
    #trust-strip h3 {
        font-size: 1rem;
    }
    #trust-strip i {
        font-size: 1.2rem;
        margin-bottom: .55rem;
    }
    #o-mnie .about-layout {
        gap: 1.6rem;
    }
    #o-mnie .about-content h2,
    #oferta h2,
    #warsztaty h2,
    #galeria h2,
    #cennik h2 {
        font-size: clamp(2.15rem, 10vw, 2.75rem);
        line-height: 1.08;
        margin-bottom: 1.15rem;
    }
    #o-mnie .about-content .space-y-6,
    #warsztaty .space-y-6 {
        gap: 1rem;
    }
    #o-mnie .about-inline-cta {
        width: 100%;
        justify-content: center;
    }
    #o-mnie .about-photo-frame--main {
        height: 310px;
        min-height: 310px;
    }
    #o-mnie .about-proof-grid {
        margin-top: 1rem;
        gap: .85rem;
    }
    #o-mnie .about-proof-card {
        padding: 1rem;
    }
    #o-mnie .about-credential-item,
    #o-mnie .about-course-tags li {
        padding: .82rem .9rem;
    }
    #oferta .mb-20,
    #cennik .mb-12 {
        margin-bottom: 2rem;
    }
    #oferta .grid.md\:grid-cols-2 {
        gap: .85rem;
        margin-bottom: 1.25rem;
    }
    #oferta .grid.md\:grid-cols-2 > div {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: .85rem;
        align-items: start;
        padding: 1rem;
        border-radius: 24px;
    }
    #oferta .grid.md\:grid-cols-2 > div > div:first-child {
        width: 44px;
        height: 44px;
        margin-bottom: 0;
        border-radius: 15px;
    }
    #oferta .grid.md\:grid-cols-2 h3 {
        font-size: 1.2rem;
        margin-bottom: .35rem;
    }
    #oferta .grid.md\:grid-cols-2 p {
        font-size: .84rem;
    }
    #oferta .bg-brand-ivory.rounded-\[32px\] {
        padding: 1.1rem;
        border-radius: 26px;
    }
    #oferta .flex.flex-wrap.justify-center.gap-4 {
        justify-content: flex-start;
        gap: .55rem;
        max-height: 190px;
        overflow: hidden;
        -webkit-mask-image: linear-gradient(180deg, #000 76%, transparent 100%);
        mask-image: linear-gradient(180deg, #000 76%, transparent 100%);
    }
    #oferta .inline-flex.items-center.gap-3.px-6.py-3 {
        padding: .58rem .75rem;
        font-size: .8rem;
    }
    .workshop-photo,
    .workshop-photo img {
        min-height: 315px;
    }
    .workshop-photo__badge {
        left: .85rem;
        right: .85rem;
        bottom: .85rem;
        font-size: .82rem;
    }
    .sunvit-gallery-orbit {
        min-height: 560px;
        padding: 1.75rem 0;
    }
    .sunvit-gallery-panel {
        width: calc(100% - 2rem);
        min-height: 395px;
        padding: 1.5rem 1.15rem;
        justify-content: flex-start;
        padding-top: 2rem;
    }
    .sunvit-gallery-panel p {
        display: none;
    }
    .sunvit-gallery-orbit__card {
        width: 238px;
        height: 148px;
    }
    .sunvit-gallery-orbit__card figcaption {
        font-size: 1rem;
        left: .75rem;
        right: .75rem;
        bottom: .65rem;
    }
    .sunvit-gallery-marquee--top {
        top: 36%;
    }
    .sunvit-gallery-marquee--bottom {
        top: 58%;
    }
    .sunvit-gallery-track,
    .sunvit-gallery-marquee--bottom .sunvit-gallery-track {
        animation-duration: 64s;
    }
    .visit-calculator {
        gap: .85rem;
    }
    .visit-calculator__form,
    .visit-calculator__result,
    .pricing-mini {
        border-radius: 24px;
    }
    .calculator-field select,
    .calculator-option {
        min-height: 54px;
    }
    .result-price {
        font-size: 2.15rem;
    }
    .pricing-mini__list {
        max-height: 330px;
        overflow: auto;
        padding-right: .2rem;
    }
    #kontakt .space-y-8 {
        display: grid;
        gap: .85rem;
        margin-bottom: 1.5rem;
    }
    #kontakt .space-y-8 > div {
        gap: .85rem;
        padding: .95rem;
        border-radius: 22px;
        background: #F9F8F4;
        border: 1px solid rgba(122,139,118,.13);
        box-shadow: 0 18px 54px -42px rgba(74,63,53,.28);
    }
    #kontakt .w-16.h-16 {
        width: 46px;
        height: 46px;
        border-radius: 16px;
    }
    #kontakt h4 {
        font-size: 1.15rem;
    }
    #kontakt a[href^="mailto"] {
        font-size: .95rem;
        word-break: break-word;
    }
    .contact-panel {
        padding: .9rem;
    }
    .route-map-shell,
    .route-map-shell iframe {
        min-height: 300px;
    }
    footer {
        padding-top: 3rem !important;
        padding-bottom: 2rem !important;
    }
    footer .grid {
        gap: 2rem;
        margin-bottom: 2.5rem;
    }
}

@media (max-width: 390px) {
    #hero h1,
    #kontakt h2 {
        font-size: 2.35rem;
    }
    .hero-photo-frame {
        height: 320px !important;
    }
    .sunvit-gallery-orbit__card {
        width: 220px;
        height: 140px;
    }
    .mobile-menu-panel {
        left: .75rem;
        right: .75rem;
    }
}

/* Ticket: mobile hero order + gallery spacing/text */
.hero-actions--mobile {
    display: none !important;
}

.gallery-section-intro {
    position: relative;
    z-index: 5;
    width: min(760px, calc(100% - 2rem));
    margin: 0 auto clamp(1.25rem, 3vw, 2rem);
    text-align: center;
}
.gallery-section-intro span {
    display: block;
    margin-bottom: .7rem;
    color: #7A8B76;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
}
.gallery-section-intro h2 {
    margin: 0 0 .85rem;
    color: #4A5B46;
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.25rem, 4vw, 3.35rem);
    line-height: 1.05;
    font-weight: 500;
}
.gallery-section-intro p {
    max-width: 560px;
    margin: 0 auto;
    color: #8B7D6B;
    font-weight: 300;
    line-height: 1.75;
}

@media (max-width: 768px) {
    #hero {
        padding-top: 1rem !important;
        padding-bottom: 3rem !important;
    }
    #hero .max-w-7xl {
        display: flex !important;
        flex-direction: column;
        gap: 1.15rem !important;
        padding-top: .35rem !important;
        padding-bottom: 1.5rem !important;
    }
    #hero .max-w-2xl {
        width: 100%;
    }
    #hero .inline-flex {
        margin-bottom: 1rem !important;
    }
    #hero h1 {
        margin-bottom: 0 !important;
    }
    #hero .max-w-7xl > .relative {
        width: 100%;
        margin-top: .25rem;
    }
    .hero-actions--desktop {
        display: none !important;
    }
    .hero-actions--mobile {
        display: flex !important;
        width: 100%;
        margin-top: .15rem;
    }
    .hero-actions--mobile a {
        width: 100%;
        min-height: 56px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .gallery-section-intro {
        width: calc(100% - 2rem);
        margin-bottom: .75rem;
    }
    .gallery-section-intro h2 {
        font-size: clamp(2.05rem, 10vw, 2.75rem);
        line-height: 1.08;
    }
    .gallery-section-intro p {
        font-size: .95rem;
        line-height: 1.65;
    }
    .sunvit-gallery-orbit {
        min-height: 650px !important;
        padding: 1.5rem 0 2rem !important;
    }
    .sunvit-gallery-panel {
        min-height: 500px !important;
        justify-content: center !important;
        padding: 1.7rem 1.2rem !important;
    }
    .sunvit-gallery-orbit__card {
        width: 280px !important;
        height: 170px !important;
    }
    .sunvit-gallery-group,
    .sunvit-gallery-track {
        gap: 1rem !important;
    }
    .sunvit-gallery-marquee--top {
        top: 31% !important;
    }
    .sunvit-gallery-marquee--bottom {
        top: 64% !important;
    }
}

@media (max-width: 390px) {
    .sunvit-gallery-orbit__card {
        width: 260px !important;
        height: 160px !important;
    }
    .sunvit-gallery-orbit {
        min-height: 630px !important;
    }
}


/* Ticket: gallery image refresh + payment methods */
.payment-methods-card {
    max-width: 940px;
    margin: 1rem auto 0;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border-radius: 24px;
    background: rgba(239,236,229,.55);
    border: 1px solid rgba(122,139,118,.16);
    box-shadow: 0 18px 54px -42px rgba(74,63,53,.26);
}
.payment-methods-card__icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    background: #4A5B46;
    color: #F9F8F4;
}
.payment-methods-card__kicker {
    display: block;
    margin-bottom: .25rem;
    color: #7A8B76;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.payment-methods-card p {
    margin: 0;
    color: #4A5B46;
    font-weight: 800;
    line-height: 1.45;
}
@media (max-width: 640px) {
    .payment-methods-card {
        align-items: flex-start;
        border-radius: 22px;
        padding: .95rem;
    }
    .payment-methods-card__icon {
        width: 44px;
        height: 44px;
        border-radius: 15px;
    }
}


/* Ticket: hero logo docking transition */
.header-logo {
    opacity: 0;
    visibility: hidden;
    transform: scale(.72) translateY(-4px);
    pointer-events: none;
    transition: opacity .35s ease, visibility .35s ease, transform .35s cubic-bezier(.2,.8,.2,1);
}

#header.header--scrolled .header-logo {
    opacity: 1;
    visibility: visible;
    transform: scale(1) translateY(0);
    pointer-events: auto;
}

.hero-logo-frame {
    display: grid;
    place-items: center;
    background: radial-gradient(circle at 50% 42%, rgba(249,248,244,.96) 0%, rgba(239,236,229,.86) 48%, rgba(239,236,229,.62) 100%);
    transition: opacity .4s ease, transform .45s cubic-bezier(.2,.8,.2,1), filter .4s ease;
}

.hero-logo-image {
    width: min(82%, 430px);
    height: auto;
    max-height: 86%;
    object-fit: contain;
    filter: drop-shadow(0 20px 34px rgba(74,63,53,.12));
    transition: transform .45s cubic-bezier(.2,.8,.2,1), opacity .35s ease;
}

#hero.hero-logo-is-docked .hero-logo-frame {
    opacity: .18;
    transform: scale(.96);
    filter: blur(1px);
}

#hero.hero-logo-is-docked .hero-logo-image {
    transform: scale(.82);
    opacity: .35;
}

#o-mnie .about-photo-frame--main img[src$="sandra.png"] {
    object-position: center 18%;
}

@media (max-width: 768px) {
    .hero-logo-image {
        width: min(82%, 310px);
    }

    .hero-logo-frame {
        min-height: 320px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .header-logo,
    .hero-logo-frame,
    .hero-logo-image {
        transition: none;
    }
}

.hero-logo-frame.float-soft {
    animation: none;
}
