:root {
    --bg      : #07070a;
    --panel   : #0f1016;
    --panel2  : #0b0c10;
    --soft    : rgba(255, 255, 255, .06);
    --textSoft: rgba(255, 255, 255, .72);
    --accent  : #e11d2e;
    /* vermelho */
    --accent2 : #ff3b4a;
    --border  : rgba(255, 255, 255, .10);
    --shadow  : 0 10px 30px rgba(0, 0, 0, .45);
    --radius  : 18px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body.bg-app {
    background: radial-gradient(1200px 600px at 70% 10%, rgba(225, 29, 46, .15), transparent 60%),
        radial-gradient(900px 500px at 10% 30%, rgba(255, 59, 74, .07), transparent 55%),
        var(--bg);
    font-family: "Space Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

.fw-900 {
    font-weight: 900;
}

.text-accent {
    color: var(--accent) !important;
}



.py-6 {
    padding-top   : 5rem;
    padding-bottom: 5rem;
}

.section {
    position              : relative;
    content-visibility    : auto;
    contain-intrinsic-size: 1px 920px;
}

.section h3 {
    font-size   : clamp(1.6rem, 2.5vw, 2.45rem);
    line-height : 1;
    margin-left : auto;
    margin-right: auto;
    font-weight : 500;
}

.section p.text {
    margin-left : auto;
    margin-right: auto;
    font-size   : 1rem;
    color       : var(--textSoft) !important;
}


footer {
    border-color          : #c4c8cb24 !important;
    content-visibility    : auto;
    contain-intrinsic-size: 1px 320px;
}

.bg-soft {
    background: linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, .01));
}

/* Navbar */
.nav-glass {
    background     : rgba(0, 0, 0, .35);
    backdrop-filter: blur(10px);
    border-bottom  : 1px solid rgba(255, 255, 255, .06);
}

.navbar .nav-link {
    color    : rgba(255, 255, 255, .75);
    font-size: .95rem;
}

.navbar .menu-dots-toggler {
    margin-left: auto;
    height     : 40px;
    width      : 40px;
    border     : 0;
    color      : #fff;
    line-height: 0;
    box-shadow : none !important;
}

.navbar .menu-dots-toggler .menu-dots-icon {
    display      : inline-block;
    width        : 6px;
    height       : 6px;
    border-radius: 50%;
    background   : rgb(255 255 255 / 100%);
    box-shadow   : 0 -9px 0 rgba(255, 255, 255, .95), 0 9px 0 rgb(255 255 255);
}

.logotopo img {
    height: 40px;
}

.navbar .nav-link:hover,
.navbar .nav-link.active {
    color: #fff;
}

.btn-accent {
    --bs-btn-bg                : var(--accent);
    --bs-btn-border-color      : transparent;
    --bs-btn-hover-bg          : var(--accent2);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-color             : #fff;
    box-shadow                 : 0 10px 20px rgba(225, 29, 46, .22);
    font-size                  : 1rem;
}

.btn-accent2 {
    --bs-btn-color: #fff;
    box-shadow    : 0 10px 20px rgba(225, 29, 46, .22);
    font-size     : 1rem;
    border        : 1px solid #ffffff6b;
    cursor        : pointer;
}


.btn-accent3 {
    background-color: #fff;
    box-shadow      : 0 10px 20px rgba(225, 29, 46, .22);
    font-size       : 1rem;
    cursor          : pointer;
    color           : #444;
}

.btn-accent2:hover {
    border-color: #fff;
}

.btn-filter {
    background   : rgba(255, 255, 255, .06);
    border       : 1px solid rgba(255, 255, 255, .08);
    color        : rgba(255, 255, 255, .78);
    border-radius: 999px;
    padding      : .45rem .9rem;
    flex         : 0 0 auto;
    white-space  : nowrap;
}

.btn-filter:hover {
    color       : #fff;
    border-color: rgba(255, 255, 255, .16);
}

.btn-filter.active {
    background  : rgba(225, 29, 46, .18);
    border-color: rgba(225, 29, 46, .35);
    color       : #fff;
}

[data-portfolio-filters] {
    position                  : sticky;
    display                   : flex;
    flex-wrap                 : nowrap !important;
    overflow-x                : auto;
    overflow-y                : hidden;
    -webkit-overflow-scrolling: touch;
    top                       : var(--portfolio-filters-sticky-top, 64px);
    z-index                   : 15;
    padding                   : .65rem .75rem;
    border                    : 1px solid rgba(255, 255, 255, .1);
    border-radius             : 14px;
    background                : rgba(9, 9, 14, .82);
    backdrop-filter           : blur(8px);
}

.hero h1 {
    line-height: 1 !important;
    font-size  : calc(1.2rem + 2.5vw) !important;
    font-weight: 600 !important;
}

.hero-bg {
    position           : absolute;
    inset              : 0;
    background-size    : cover;
    background-position: center;
    filter             : saturate(1.05) contrast(1.05);
}

.hero-video-bg {
    position      : absolute;
    inset         : 0;
    overflow      : hidden;
    pointer-events: none;
    z-index       : 0;
}

.hero-video-frame {
    position  : absolute;
    top       : 50%;
    left      : 50%;
    width     : 100vw;
    height    : 56.25vw;
    min-width : 177.78vh;
    min-height: 100vh;
    transform : translate(-50%, -50%);
}

.hero-video-frame iframe {
    width  : 100%;
    height : 100%;
    border : 0;
    display: block;
    opacity: .88;
    filter : saturate(1.02) contrast(1.04);
}

.hero-overlay {
    position: absolute;
    inset   : 0;
    background: radial-gradient(600px 900px at 65% 45%, rgba(0, 0, 0, 0), rgba(0, 0, 0, .8) 80%),
        linear-gradient(20deg, rgba(0, 0, 0, .15), rgba(0, 0, 0, .0));
}

#reels-pg .hero-bg {
    background-image     : url('/imagens/Mockup.jpg');
    background-attachment: fixed;
}

#reels-pg .hero-overlay {
    background: linear-gradient(90deg, rgba(7, 7, 10, .88) 8%, rgba(7, 7, 10, .52) 48%, rgba(7, 7, 10, .76) 100%), radial-gradient(760px 420px at 78% 50%, rgba(255, 138, 60, .14), #00000094 72%);
}

.chip {
    display       : inline-flex;
    align-items   : center;
    gap           : .5rem;
    font-size     : .75rem;
    font-weight   : 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding       : .35rem .75rem;
    border-radius : 999px;
    border        : 1px solid rgba(225, 29, 46, .35);
    background    : rgb(225 29 46 / 26%);
    color         : rgba(255, 255, 255, .88);
    margin-bottom : 1rem;
}

.events-hero-proof {
    display    : flex;
    flex-wrap  : wrap;
    align-items: center;
    gap        : .45rem .7rem;
    margin-top : 1rem;
    max-width  : 42rem;
    font-size  : .92rem;
    line-height: 1.5;
    color      : rgba(255, 255, 255, .76);
    text-align : center;
}

/* Scroll indicator */
.scroll-indicator {
    position       : absolute;
    left           : 50%;
    bottom         : -21px;
    transform      : translateX(-50%);
    width          : 26px;
    height         : 42px;
    border         : 1px solid rgba(255, 255, 255, .22);
    border-radius  : 999px;
    display        : flex;
    justify-content: center;
    align-items    : flex-start;
    padding-top    : 8px;
    opacity        : .8;
}

.scroll-indicator span {
    width        : 5px;
    height       : 5px;
    background   : rgba(255, 255, 255, .8);
    border-radius: 50%;
    animation    : scrollDot 1.2s infinite;
}

@keyframes scrollDot {
    0% {
        transform: translateY(0);
        opacity  : .9;
    }

    70% {
        transform: translateY(16px);
        opacity  : .3;
    }

    100% {
        transform: translateY(0);
        opacity  : .9;
    }
}

/* Floating Whats */
.float-whats {
    position       : fixed;
    right          : 18px;
    bottom         : 18px;
    z-index        : 50;
    display        : flex;
    align-items    : center;
    gap            : .5rem;
    padding        : .6rem .85rem;
    border-radius  : 999px;
    background     : rgba(15, 16, 22, .85);
    border         : 1px solid rgba(255, 255, 255, .10);
    color          : #fff;
    text-decoration: none;
    box-shadow     : var(--shadow);
    transition     : opacity .25s ease, transform .25s ease, background .25s ease;
}

.float-whats i {
    font-size: 1.15rem;
    color    : #25D366;
}

.float-whats span {
    font-size: .9rem;
    color    : rgba(255, 255, 255, .85);
}

.float-whats.is-hidden-mobile {
    opacity       : 0;
    transform     : translateY(16px);
    pointer-events: none;
}

/* Home categories */
.home-categories {
    margin-top: -3rem;
    padding   : 0 0 2rem;
    position  : relative;
    z-index   : 6;
}

.home-categories-grid {
    display              : grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap                  : .9rem;
}

.home-category-link {
    display        : flex;
    align-items    : center;
    gap            : .8rem;
    min-height     : 74px;
    padding        : 1rem 1.1rem;
    border         : 1px solid rgba(255, 255, 255, .12);
    border-radius  : 16px;
    background     : linear-gradient(180deg, rgba(15, 16, 22, .92), rgba(8, 9, 14, .85));
    color          : #fff;
    text-decoration: none;
    box-shadow     : 0 14px 28px rgba(0, 0, 0, .28);
    transition     : transform .2s ease, border-color .2s ease, background .2s ease;
}

.home-category-link:hover,
.home-category-link:focus-visible {
    transform   : translateY(-2px);
    border-color: rgba(225, 29, 46, .4);
    background  : linear-gradient(180deg, rgba(225, 29, 46, .18), rgba(8, 9, 14, .9));
    color       : #fff;
}

.home-category-icon {
    width        : 42px;
    height       : 42px;
    border-radius: 12px;
    display      : grid;
    place-items  : center;
    background   : rgba(225, 29, 46, .16);
    border       : 1px solid rgba(225, 29, 46, .3);
    color        : #fff;
    font-size    : 1.15rem;
    flex         : 0 0 42px;
}

.home-category-title {
    font-weight   : 700;
    font-size     : 1rem;
    letter-spacing: .02em;
    text-transform: uppercase;
}

/* Home reels highlight */
.home-reels-highlight {
    position     : relative;
    overflow     : hidden;
    padding      : 5.25rem 0;
    border-top   : 1px solid rgba(255, 255, 255, .08);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    isolation    : isolate;
}

.home-reels-highlight::before {
    content              : "";
    position             : absolute;
    inset                : 0;
    z-index              : 1;
    background-image     : url(../imagens/Mockup.jpg);
    background-attachment: fixed;
    background-size      : cover;
    /* background        :
        radial-gradient(850px 420px at 50% 50%, rgba(225, 29, 46, .24), transparent 70%),
        linear-gradient(180deg, rgba(6, 6, 10, .86), rgba(6, 6, 10, .92)); */
}

.home-reels-highlight::after {
    content   : "";
    position  : absolute;
    inset     : 0;
    z-index   : 2;
    background: linear-gradient(180deg, rgba(5, 5, 9, .56), rgba(5, 5, 9, .78));
    top       : 0;
    bottom    : 0;
    height    : 100%;
}

.home-reels-content {
    position  : relative;
    z-index   : 3;
    max-width : 1100px;
    margin    : 0 auto;
    text-align: center;
}

.home-reels-title {
    font-size  : clamp(1.7rem, 4vw, 2.5rem);
    line-height: 1.12;
}

.home-reels-title-mark {
    display      : inline-block;
    padding      : .08em .35em;
    border-radius: 8px;
    background   : var(--accent);
    color        : #fff;
}

.home-reels-actions {
    display        : inline-flex;
    align-items    : center;
    justify-content: center;
    flex-wrap      : wrap;
    gap            : .8rem;
    padding        : .75rem;
    border-radius  : 18px;
    background     : rgba(0, 0, 0, .42);
    border         : 1px solid rgba(255, 255, 255, .1);
    box-shadow     : 0 14px 30px rgba(0, 0, 0, .42);
}

@media (max-width: 991.98px) {
    .home-reels-highlight {
        padding: 4.3rem 0;
    }

    .home-reels-title {
        max-width: 820px;
        margin   : 0 auto;
    }
}

@media (max-width: 767.98px) {
    .home-reels-highlight {
        padding: 3.5rem 0;
    }

    .home-reels-highlight::before {
        background-attachment: scroll;
        background-size      : cover;
    }

    .home-reels-actions {
        width        : 100%;
        max-width    : 420px;
        margin       : 0 auto;
        border-radius: 14px;
    }

    .home-reels-actions .btn {
        width: 100%;
    }
}

/* Panels */
.panel {
    background   : linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .02));
    border       : 1px solid rgba(255, 255, 255, .08);
    border-radius: var(--radius);
    padding      : 1.75rem;
    box-shadow   : var(--shadow);
}

.panel-outline {
    border-color: rgb(60 12 12);
}

.info-triad {
    display              : grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap                  : 1rem;
}

.info-triad-card {
    position  : relative;
    min-height: 100%;
    padding   : 1.35rem;
    overflow  : hidden;
}

.info-triad-card::before {
    content       : "";
    position      : absolute;
    top           : -50px;
    right         : -48px;
    width         : 130px;
    height        : 130px;
    border-radius : 50%;
    background    : radial-gradient(circle, rgba(225, 29, 46, .18), transparent 68%);
    pointer-events: none;
}

.info-triad-card h2 {
    position   : relative;
    line-height: 1.1;
}

.info-triad-list {
    position  : relative;
    display   : grid;
    gap       : .6rem;
    list-style: none;
    margin    : 0;
    padding   : 0;
}

.info-triad-list li {
    display      : flex;
    align-items  : flex-start;
    gap          : .7rem;
    padding      : .72rem .82rem;
    border-radius: 14px;
    background   : rgba(255, 255, 255, .03);
    border       : 1px solid rgba(255, 255, 255, .08);
    line-height  : 1.3;
}

.info-triad-list i,
.info-step-index {
    width        : 24px;
    height       : 24px;
    flex         : 0 0 24px;
    display      : inline-grid;
    place-items  : center;
    border-radius: 999px;
    color        : #fff;
    font-size    : .92rem;
    background   : linear-gradient(135deg, rgba(225, 29, 46, .95), rgba(255, 122, 89, .75));
    box-shadow   : 0 8px 16px rgba(225, 29, 46, .16);
    font-style   : normal;
    font-weight  : 800;
    line-height  : 1;
    margin-top   : 1px;
}

.info-triad-list span:last-child {
    color: rgba(255, 255, 255, .92);
}

.media-card img {
    box-shadow: var(--shadow);
}

.badge-500 {
    position: absolute;
    left    : 16px;
    bottom  : 16px;
}

.badge-500-inner {
    background   : rgba(225, 29, 46, .92);
    border       : 1px solid rgba(255, 255, 255, .20);
    border-radius: 16px;
    padding      : .9rem 1rem;
    box-shadow   : 0 18px 40px rgba(225, 29, 46, .20);
}

/* Icon lines */
.icon-line {
    display    : flex;
    gap        : .9rem;
    align-items: flex-start;
}

.icon-line i {
    color     : var(--accent);
    font-size : 1.15rem;
    margin-top: 2px;
}

.service-line {
    display    : flex;
    gap        : .9rem;
    align-items: flex-start;
    text-align : left;
}

.service-line .icon {
    width        : 42px;
    height       : 42px;
    display      : grid;
    place-items  : center;
    border-radius: 14px;
    background   : rgba(225, 29, 46, .14);
    border       : 1px solid rgba(225, 29, 46, .20);
}

.service-line .icon i {
    color     : #fff;
    width     : 32px !important;
    text-align: center;
}

@media (max-width: 991.98px) {
    .info-triad {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .info-triad {
        grid-template-columns: minmax(0, 1fr);
    }

    .info-triad-card {
        padding: 1.2rem;
    }
}

/* Side media cover */
.media-cover {
    min-height         : 360px;
    background-size    : cover;
    background-position: center;
    position           : relative;
}

.media-cover-overlay {
    position: absolute;
    inset   : 0;
    background: radial-gradient(600px 400px at 65% 35%, rgba(225, 29, 46, .10), rgba(0, 0, 0, .85) 60%),
        linear-gradient(180deg, rgba(0, 0, 0, .25), rgba(0, 0, 0, .75));
}

.media-cover-content {
    position: absolute;
    left    : 0;
    right   : 0;
    bottom  : 0;
    padding : 2rem;
}

.services-carousel,
.events-deliverables-carousel {
    border-radius: 18px;
    overflow     : hidden;
    aspect-ratio : 16 / 14;
    background   : rgba(255, 255, 255, .03);
    border       : 1px solid rgba(255, 255, 255, .08);
}

#como-trabalhamos-casamentos .services-carousel {
    aspect-ratio: 16 / 16;
}

#eventsDeliverablesCarousel {
    aspect-ratio: 16 / 10;
}

.services-carousel .carousel-inner,
.services-carousel .carousel-item,
.events-deliverables-carousel .carousel-inner,
.events-deliverables-carousel .carousel-item {
    height: 100%;
}

.services-carousel .carousel-item img,
.events-deliverables-carousel .carousel-item img {
    width     : 100%;
    height    : 100%;
    object-fit: cover;
}

.services-carousel .carousel-control-prev,
.services-carousel .carousel-control-next,
.events-deliverables-carousel .carousel-control-prev,
.events-deliverables-carousel .carousel-control-next {
    width: 14%;
}

.services-carousel .carousel-control-prev-icon,
.services-carousel .carousel-control-next-icon,
.events-deliverables-carousel .carousel-control-prev-icon,
.events-deliverables-carousel .carousel-control-next-icon {
    width           : 2rem;
    height          : 2rem;
    border-radius   : 999px;
    background-color: rgba(8, 8, 12, .42);
    background-size : 60%;
}

.wedding-highlight-carousel,
.wedding-highlight-carousel .carousel-inner,
.wedding-highlight-carousel .carousel-item {
    height    : 100%;
    min-height: 360px;
}

.wedding-highlight-carousel .carousel-item img {
    width     : 100%;
    height    : 100%;
    object-fit: cover;
}

/* Portfolio cards */
.work-card {
    position       : relative;
    display        : block;
    border-radius  : 18px;
    overflow       : hidden;
    border         : 1px solid rgba(255, 255, 255, .10);
    background     : rgba(0, 0, 0, .2);
    box-shadow     : var(--shadow);
    text-decoration: none;
    transform      : translateY(0);
    transition     : transform .18s ease, border-color .18s ease;
}

.work-card:hover {
    transform   : translateY(-4px);
    border-color: rgba(225, 29, 46, .25);
}

.work-card img {
    width     : 100%;
    height    : 240px;
    object-fit: cover;
    filter    : contrast(1.05) saturate(1.05);
}

.portfolio-featured-card {
    background: #0d0f14;
}

.portfolio-featured-card img {
    height      : auto;
    min-height  : 240px;
    aspect-ratio: 16 / 9;
    display     : block;
}

.portfolio-featured-card .overlay-card-copy {
    padding    : 1.1rem;
    padding-top: 2.15rem;
}

.portfolio-featured-card .overlay-card-title {
    font-size: clamp(1.05rem, 1.4vw, 1.55rem);
}

.portfolio-featured-card .events-case-keywords {
    margin-top: .75rem;
}

.portfolio-featured-card .events-case-keywords span {
    font-size: .74rem;
}

[data-wedding-portfolio-grid] .events-case-item-featured {
    width       : 100%;
    aspect-ratio: 16 / 9;
    opacity     : .92;
}

.instagram-reels-page .reels-item {
    display: flex;
}

.instagram-reels-page .reels-item .events-case-item-reel {
    width       : 100%;
    aspect-ratio: 9 / 16;
    opacity     : .94;
}

.instagram-reels-page .reels-work-card img {
    height      : auto;
    aspect-ratio: auto;
    object-fit  : cover;
    display     : block;
}

.instagram-reels-page .reels-work-card .work-overlay,
.events-portfolio-showcase.is-portrait-showcase .reels-work-card .work-overlay {
    padding: 2rem;
}

.instagram-reels-page .reels-work-card .work-overlay h5,
.events-portfolio-showcase.is-portrait-showcase .reels-work-card .work-overlay h5,
#eventos-pg .reels-work-card .work-overlay h5 {
    font-size         : 1rem;
    color             : #fff;
    display           : -webkit-box;
    overflow          : hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.instagram-reels-page .reels-work-card .work-overlay small {
    display       : block;
    margin-top    : .35rem;
    font-size     : .78rem;
    line-height   : 1.2;
    letter-spacing: .04em;
    color         : rgba(255, 255, 255, .78);
}

#eventos-pg .reels-work-card .work-overlay small,
.events-portfolio-showcase.is-portrait-showcase .reels-work-card .work-overlay small {
    display       : block;
    margin-top    : .35rem;
    font-size     : .78rem;
    line-height   : 1.2;
    letter-spacing: .04em;
    color         : rgba(255, 255, 255, .78);
}

.events-case-feature {
    background: linear-gradient(180deg, rgba(13, 13, 18, .98), rgba(9, 10, 14, .92));
}

.events-portfolio-showcase {
    position         : relative;
    display          : flex;
    align-items      : center;
    overflow         : hidden;
    scroll-margin-top: 92px;
}

.events-portfolio-showcase-bg,
.events-portfolio-showcase-overlay {
    position: absolute;
    inset   : 0;
}

.events-portfolio-showcase-bg {
    display: none;
}

.events-portfolio-showcase-overlay {
    background:
        linear-gradient(180deg, rgba(6, 6, 10, .78) 0%, rgba(6, 6, 10, .48) 28%, rgba(6, 6, 10, .88) 100%),
        radial-gradient(760px 420px at 18% 24%, rgba(225, 29, 46, .24), transparent 66%),
        radial-gradient(920px 440px at 86% 74%, rgba(255, 255, 255, .06), transparent 68%);
}

.events-portfolio-showcase-shell {
    position      : relative;
    z-index       : 1;
    display       : flex;
    flex-direction: column;
    gap           : 2.4rem;
    padding-top   : 4.5rem;
    padding-bottom: 4.5rem;
}

.events-portfolio-showcase-copy {
    width     : 100%;
    margin    : 0 auto;
    max-width : 880px;
    text-align: center;
}

.events-portfolio-showcase-copy h2 {
    font-size   : clamp(2rem, 4vw, 3rem);
    line-height : 1;
    margin-left : auto;
    margin-right: auto;
}


.events-portfolio-showcase-stage {
    position: relative;
    padding : .35rem 0 .5rem;
}

.events-portfolio-showcase-head {
    position      : absolute;
    inset         : 0;
    z-index       : 3;
    pointer-events: none;
}

.events-portfolio-showcase-carousel {
    padding: 0;
}

.events-portfolio-showcase-carousel.owl-carousel {
    display: block;
}

.events-portfolio-showcase-carousel .owl-stage-outer {
    overflow: visible;
}

.events-portfolio-showcase-carousel .owl-stage {
    display    : flex;
    align-items: stretch;
}

.events-portfolio-showcase-carousel .owl-item {
    display    : flex;
    align-items: stretch;
}

.events-portfolio-showcase-carousel.owl-theme .owl-nav,
.events-portfolio-showcase-carousel.owl-theme .owl-dots {
    display: none;
}

.events-portfolio-showcase .events-case-item-featured {
    width  : min(66vw, 520px);
    opacity: .92;
}

.events-portfolio-showcase .events-case-item-reel {
    width       : min(18vw, 220px);
    aspect-ratio: 9 / 16;
    opacity     : .94;
}

.events-portfolio-showcase.is-portrait-showcase .events-case-item-reel {
    width       : min(22vw, 260px);
    aspect-ratio: 9 / 16;
}

.events-portfolio-showcase.is-portrait-showcase .reels-work-card {
    border       : 1px solid rgba(255, 255, 255, .10);
    border-radius: 22px;
    background   : rgba(0, 0, 0, .2);
}

.events-portfolio-showcase.is-portrait-showcase .reels-work-card img {
    height      : 100%;
    aspect-ratio: 9 / 16;
    object-fit  : cover;
    display     : block;
}

.events-portfolio-showcase.is-portrait-showcase .reels-work-card .work-overlay h5 {
    color: #fff;
}

.events-deliverables-section {
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.events-deliverables-layout {
    display              : grid;
    grid-template-columns: minmax(280px, .85fr) minmax(0, 1.4fr);
    gap                  : 1.15rem;
    align-items          : stretch;
}

.events-deliverables-intro {
    display        : flex;
    flex-direction : column;
    justify-content: flex-start;
    gap            : 1.1rem;
    min-height     : 100%;
    background     : linear-gradient(180deg, rgba(12, 12, 17, .96), rgba(9, 10, 14, .9));
    padding        : 1.75rem;
}

.events-deliverables-carousel {
    margin-left : -1.75rem;
    margin-right: -1.75rem;
    margin-top  : -1.75rem;
}

.events-deliverables-intro h2 {
    color      : #fff;
    line-height: 1.02;
    max-width  : 14ch;
}

.events-deliverables-grid {
    display              : grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap                  : 1rem;
}

.events-deliverable-card {
    min-height     : 100%;
    display        : flex;
    flex-direction : column;
    justify-content: flex-start;
    gap            : .3rem;
    padding        : 1.35rem;
    border-radius  : 22px;
    box-shadow     : 0 18px 40px rgba(0, 0, 0, .18);
}

.events-deliverable-card p {
    max-width: none;
}

.celebration-types-grid .events-deliverable-card {
    display              : grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items          : center;
    column-gap           : .85rem;
    row-gap              : .2rem;
}

.celebration-types-grid .events-mini-icon {
    margin-bottom: 0;
}

.celebration-types-grid .event-titulo {
    min-width: 0;
}

.events-case-shell {
    padding: 1.3rem;
}

.events-case-header {
    display              : grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
    gap                  : 1rem;
    align-items          : center;
    padding-bottom       : 1rem;
}

.events-case-header h3 {
    color    : #fff;
    font-size: clamp(1.6rem, 2.5vw, 2.45rem);
}

.events-case-carousel-wrap {
    position: relative;
}

.events-case-carousel-stage {
    padding: .35rem 0 .5rem;
}

.events-case-carousel-head {
    position      : absolute;
    inset         : 0;
    z-index       : 3;
    pointer-events: none;
}

.events-case-carousel-controls {
    display        : flex;
    justify-content: space-between;
    align-items    : center;
    gap            : .6rem;
    position       : absolute;
    inset          : 0;
    z-index        : 3;
    padding-inline : clamp(.35rem, 1vw, .9rem);
    left           : 0;
    right          : 0;
    pointer-events : none;
}

.events-case-carousel-btn {
    width         : 48px;
    height        : 48px;
    display       : grid;
    place-items   : center;
    border-radius : 999px;
    border        : 1px solid rgba(255, 255, 255, .1);
    background    : rgba(255, 255, 255, .04);
    color         : #fff;
    pointer-events: auto;
    box-shadow    : 0 12px 28px rgba(0, 0, 0, .22);
    transition    : background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.events-case-carousel-btn:hover,
.events-case-carousel-btn:focus-visible {
    background  : rgba(225, 29, 46, .18);
    border-color: rgba(225, 29, 46, .3);
    transform   : translateY(-1px);
    box-shadow  : 0 16px 34px rgba(0, 0, 0, .28);
}

.events-case-carousel {
    overflow-x                : auto;
    overflow-y                : hidden;
    scroll-snap-type          : x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width           : none;
}

.events-case-carousel::-webkit-scrollbar {
    display: none;
}

.events-case-carousel-owl {
    padding: 0;
}

.events-case-carousel-owl.owl-carousel {
    display: block;
}

.events-case-carousel-owl.owl-loaded {
    overflow        : visible;
    scroll-snap-type: none;
}

.events-case-carousel-owl:not(.owl-loaded) {
    display    : flex;
    gap        : 1rem;
    align-items: stretch;
}

.events-case-carousel-owl .owl-stage-outer {
    overflow: visible;
}

.events-case-carousel-owl .owl-stage {
    display    : flex;
    align-items: stretch;
}

.events-case-carousel-owl .owl-item {
    display    : flex;
    align-items: stretch;
}

.events-case-carousel-owl.owl-theme .owl-nav,
.events-case-carousel-owl.owl-theme .owl-dots {
    display: none;
}

.events-case-item {
    position            : relative;
    display             : block;
    overflow            : hidden;
    flex                : 0 0 auto;
    border-radius       : 22px;
    /* border           : 1px solid rgba(255, 255, 255, .08); */
    background          : #0d0f14;
    box-shadow          : 0 28px 70px rgba(0, 0, 0, .28);
    text-decoration     : none;
    scroll-snap-align   : start;
    transition          : transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.events-case-item img {
    width     : 100%;
    height    : 100%;
    display   : block;
    object-fit: cover;
    transform : scale(1.01);
}

.events-case-item-featured {
    width       : min(52vw, 620px);
    aspect-ratio: 16 / 9;
    opacity     : .6;
    cursor      : pointer;
}

.owl-item .events-case-item {
    opacity: .8;
    cursor : pointer;
}

.owl-item .events-case-item:hover {
    opacity: 1;
}

.events-case-item:hover,
.events-case-item:focus-visible {
    transform : translateY(-3px);
    box-shadow: 0 34px 82px rgba(0, 0, 0, .34);
    outline   : none;
}

.events-case-item-reel {
    width       : min(14vw, 180px);
    aspect-ratio: 9 / 16;
}

.events-case-item-overlay {
    position     : absolute;
    inset        : 0;
    /* background:
        linear-gradient(180deg, rgba(6, 6, 10, .02) 0%, rgba(6, 6, 10, .16) 38%, rgba(6, 6, 10, .82) 100%),
        radial-gradient(640px 280px at 80% 12%, rgba(225, 29, 46, .16), transparent 72%); */
}

.overlay-card-copy {
    position   : absolute;
    left       : 0;
    right      : 0;
    bottom     : 0;
    z-index    : 2;
    width      : 100%;
    padding    : 1.15rem;
    padding-top: 2rem;
    background : linear-gradient(0deg, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0) 100%);
}

.overlay-card-title {
    color      : #fff;
    line-height: 1.04;
    font-size  : clamp(1rem, 1.5vw, 1.75rem);
}

.overlay-card-tags,
.events-stage-tags {
    display   : flex;
    flex-wrap : wrap;
    gap       : .55rem;
    margin-top: 1rem;
    max-width : 500px;
}

.overlay-card-tags span,
.events-stage-tags span {
    padding        : .45rem .78rem;
    border-radius  : 999px;
    background     : rgba(255, 255, 255, .08);
    border         : 1px solid rgba(255, 255, 255, .12);
    color          : rgba(255, 255, 255, .95);
    font-size      : .82rem;
    line-height    : 1;
    backdrop-filter: blur(8px);
}

.overlay-card-copy h4 {
    font-size  : clamp(1.1rem, 1.6vw, 2rem);
    font-weight: 500;
}

.events-case-keywords {
    margin-top: .85rem;
    max-width : 560px;
}

.events-case-keywords span {
    font-size: .76rem;
}

.events-case-play {
    position       : absolute;
    top            : 1rem;
    left           : 1rem;
    z-index        : 3;
    width          : 42px;
    height         : 42px;
    display        : grid;
    place-items    : center;
    border-radius  : 50%;
    background     : rgba(8, 8, 12, .34);
    border         : 1px solid rgba(255, 255, 255, .12);
    backdrop-filter: blur(6px);
    color          : #fff;
    font-size      : 1rem;
    transition     : transform .18s ease, background .18s ease, border-color .18s ease;
}

.events-case-play.is-instagram {
    background: rgba(131, 58, 180, .18);
}

.events-case-play-sm {
    width    : 38px;
    height   : 38px;
    font-size: .92rem;
}

.events-case-item:hover .events-case-play,
.events-case-item:focus-visible .events-case-play {
    transform   : scale(1.04);
    background  : rgba(225, 29, 46, .18);
    border-color: rgba(225, 29, 46, .24);
}

.events-case-summary {
    display              : grid;
    grid-template-columns: minmax(0, auto) minmax(0, 1fr);
    gap                  : 1rem;
    align-items          : center;
    padding-top          : 1rem;
    border-top           : 1px solid rgba(255, 255, 255, .08);
}


.events-case-meta {
    display  : flex;
    flex-wrap: wrap;
    gap      : .55rem;
}

.events-case-meta span {
    display       : inline-flex;
    align-items   : center;
    padding       : .48rem .82rem;
    border-radius : 999px;
    border        : 1px solid rgba(255, 255, 255, .08);
    background    : rgba(255, 255, 255, .04);
    color         : rgba(255, 255, 255, .82);
    font-size     : .78rem;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.events-footer-cta-section {
    position: relative;
}

.events-success-case {
    position             : relative;
    min-height           : 280px;
    display              : grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items          : center;
    gap                  : 1.5rem;
    padding              : 2rem 2.1rem;
    overflow             : hidden;
    text-decoration      : none;
    color                : #fff;
    background-color     : #050608;
    background-image     : linear-gradient(90deg, rgba(0, 0, 0, .94) 0%, rgba(0, 0, 0, .9) 34%, rgba(0, 0, 0, .3) 62%, rgba(0, 0, 0, .05) 100%), var(--events-success-case-bg);
    background-size      : cover;
    background-position  : center;
    background-repeat    : no-repeat;
}

.events-success-case:hover,
.events-success-case:focus-visible {
    color: #fff;
}

.events-success-case-overlay {
    position      : absolute;
    inset         : 0;
    background    : radial-gradient(circle at 78% 18%, rgba(225, 29, 46, .14), transparent 24%);
    pointer-events: none;
}

.events-success-case-copy,
.events-success-case-action {
    position: relative;
    z-index : 1;
}

.events-success-case-copy {
    max-width   : 50%;
    /* display  : grid; */
    gap         : .9rem;
}

.events-success-case-copy h2 {
    font-size  : clamp(1.9rem, 4vw, 3.6rem);
    line-height: 1.06;
    max-width  : 14ch;
}


.events-footer-cta {
    display              : grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap                  : 1rem;
    align-items          : center;
    padding              : 1.5rem 1.65rem;
    background           : linear-gradient(180deg, rgba(18, 18, 24, .96), rgba(10, 10, 14, .92));
}

.events-footer-cta h2 {
    font-size  : clamp(1.45rem, 2.8vw, 2.3rem);
    line-height: 1;
}

@media (max-width: 767.98px) {
    .events-success-case {
        grid-template-columns: minmax(0, 1fr);
        min-height           : 420px;
        align-items          : end;
        align-content        : end;
        padding              : 1.4rem 1.1rem;
        gap                  : .75rem;
        text-align           : center;
        background-image     : linear-gradient(180deg, rgba(0, 0, 0, .82) 0%, rgba(0, 0, 0, .62) 100%), var(--events-success-case-bg-mobile, var(--events-success-case-bg));
        background-position  : center;
    }

    .events-success-case-copy {
        justify-items: center;
        max-width    : none;
    }

    .events-success-case-copy .chip {
        margin-bottom: 0;
    }

    .events-success-case-copy h2 {
        max-width: 11ch;
        font-size: clamp(1.8rem, 8vw, 2.8rem);
    }

    .events-success-case-action {
        width    : 100%;
        min-width: 0;
    }

    .events-footer-cta {
        grid-template-columns: minmax(0, 1fr);
        padding              : 1.1rem;
        text-align           : center;
    }

    .events-footer-cta .btn {
        width: 100%;
    }

    .float-whats {
        right          : 14px;
        bottom         : 30px;
        width          : 48px;
        height         : 48px;
        padding        : 0;
        border-radius  : 16px;
        justify-content: center;
        gap            : 0;
        background     : rgba(10, 11, 15, .9);
    }

    .float-whats span {
        display: none;
    }
}

.events-mini-icon {
    width        : 46px;
    height       : 46px;
    display      : grid;
    place-items  : center;
    margin-bottom: 1rem;
    border-radius: 14px;
    background   : rgba(225, 29, 46, .14);
    border       : 1px solid rgba(225, 29, 46, .20);
}

.events-mini-icon i {
    color    : #fff;
    font-size: 1.2rem;
}

@media (max-width: 991.98px) {
    .events-deliverables-layout {
        grid-template-columns: minmax(0, 1fr);
        background           : linear-gradient(180deg, rgba(12, 12, 17, .96), rgba(9, 10, 14, .9));
        border               : 1px solid rgba(225, 29, 46, .18);
        border-radius        : 1.5rem;
    }

    .events-deliverables-intro {
        background: transparent;
        border    : none;
    }

    .events-deliverables-intro h2 {
        max-width: 16ch;
    }

    .events-deliverables-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .events-case-header,
    .events-case-summary {
        grid-template-columns: minmax(0, 1fr);
    }

    .events-case-item-featured {
        width: min(70vw, 560px);
    }

    .events-case-item-reel {
        width: min(24vw, 170px);
    }

    .events-portfolio-showcase {
        min-height: auto;
    }

    .events-portfolio-showcase-shell {
        padding-top   : 5rem;
        padding-bottom: 4.5rem;
    }

    .events-portfolio-showcase-copy h2 {
        max-width: 13ch;
    }

    .events-portfolio-showcase .events-case-item-featured {
        width: min(76vw, 640px);
    }

    .events-portfolio-showcase .events-case-item-reel {
        width: min(26vw, 190px);
    }

    .events-portfolio-showcase.is-portrait-showcase .events-case-item-reel {
        width: min(30vw, 220px);
    }
}

@media (max-width: 767.98px) {
    .events-deliverables-grid {
        grid-template-columns: minmax(0, 1fr);
        padding              : 0 1rem 1rem;
        box-shadow           : none;
        gap                  : .75rem;
    }

    .events-deliverables-intro h2 {
        max-width    : none;
        margin-bottom: 0 !important;
    }

    .events-deliverables-intro {
        gap    : .9rem;
        padding: 1rem;
    }

    .events-deliverables-carousel {
        order       : 2;
        aspect-ratio: 16 / 11;
        margin      : 0;
    }

    .events-deliverable-card {
        display              : grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items          : start;
        column-gap           : .75rem;
        row-gap              : .3rem;
        padding              : .95rem 1rem;
        min-height           : auto;
        border-radius        : 16px;
        text-align           : left;
    }

    .events-deliverable-card .text-uppercase {
        margin-bottom: 0;
        font-size    : .68rem;
    }

    .events-deliverable-card h3 {
        margin-bottom: 0 !important;
        font-size    : .98rem;
    }

    .events-deliverable-card p {
        display    : block;
        grid-column: 2;
        font-size  : .84rem;
        line-height: 1.45;
    }

    .events-deliverable-card .events-mini-icon {
        width        : 40px;
        height       : 40px;
        margin-bottom: 0;
    }

    .events-deliverable-card .events-mini-icon i {
        font-size: 1rem;
    }

    .events-case-shell {
        padding: .9rem;
    }

    .events-case-carousel-controls {
        margin-bottom: .75rem;
    }

    .events-case-carousel-stage {
        padding: 0;
    }

    .events-case-item {
        border-radius: 18px;
    }

    .events-case-item-featured {
        width: min(82vw, 420px);
    }

    .events-case-item-reel {
        width: min(40vw, 158px);
    }

    .events-portfolio-showcase.is-portrait-showcase .reels-work-card .work-overlay {
        padding: .7rem;
    }

    .events-case-item-featured {
        scroll-snap-align: center;
    }

    .overlay-card-title {
        font-size: 1rem;
    }

    .events-case-summary {
        gap        : .75rem;
        padding-top: .9rem;
    }

    .events-case-meta {
        gap: .45rem;
    }

    .events-case-meta span {
        padding  : .38rem .68rem;
        font-size: .68rem;
    }

    .events-stage-tags span {
        padding  : .38rem .62rem;
        font-size: .7rem;
    }

    .events-portfolio-showcase-shell {
        gap           : 1.5rem;
        padding-top   : 2.75rem;
        padding-bottom: 1.5rem;
    }

    .events-portfolio-showcase-copy h2 {
        font-size: 1.95rem;
        max-width: none;
    }

    .events-portfolio-showcase-head {
        justify-content: flex-start;
        margin-bottom  : .75rem;
    }

    .events-portfolio-showcase-carousel {
        padding: 0;
    }

    .events-portfolio-showcase .events-case-item-featured {
        width: min(84vw, 430px);
    }

    .events-portfolio-showcase .owl-carousel.owl-drag .owl-item {
        opacity: .68;
    }

    .events-portfolio-showcase .owl-carousel.owl-drag .owl-item.active.center {
        opacity: 1;
    }

    .events-portfolio-showcase .events-case-item-reel {
        width: min(42vw, 172px);
    }

    .events-portfolio-showcase.is-portrait-showcase .events-case-item-reel {
        width: min(52vw, 210px);
    }

}


@media (min-width: 1200px) {
    .instagram-reels-page .reels-grid .reels-item {
        width    : 20%;
        flex     : 0 0 20%;
        max-width: 20%;
    }
}

.work-overlay {
    position  : absolute;
    left      : 0;
    right     : 0;
    bottom    : 0;
    padding   : 1rem;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .85));
    color     : #fff;
    text-align: center;
}

.work-overlay small {
    margin     : 0;
    line-height: 13px;
    display    : block;
}

.tag {
    position     : absolute;
    left         : 12px;
    top          : 12px;
    font-size    : .75rem;
    padding      : .25rem .55rem;
    border-radius: 999px;
    background   : rgba(225, 29, 46, .85);
    border       : 1px solid rgba(255, 255, 255, .16);
    color        : #fff;
}

/* Diagonal section */
.diagonal {
    background:
        repeating-linear-gradient(135deg,
            rgba(225, 29, 46, .20) 0px,
            rgba(225, 29, 46, .20) 1px,
            rgba(0, 0, 0, 0) 1px,
            rgba(0, 0, 0, 0) 9px),
        linear-gradient(180deg, rgba(255, 255, 255, .02), rgba(255, 255, 255, .01));
    border-top   : 1px solid rgba(255, 255, 255, .06);
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}

/* Clients */
.client-logo {
    border-radius : 14px;
    border        : 1px solid rgba(255, 255, 255, .10);
    background    : rgba(255, 255, 255, .04);
    display       : grid;
    place-items   : center;
    color         : rgba(255, 255, 255, .6);
    letter-spacing: .08em;
    font-size     : .75rem;
}

.client-logo img {
    /* max-height: 32px; */
    width    : auto;
    max-width: 85%;
}

/* Form */
.form-control-dark,
.form-control-dark:focus {
    background: rgba(255, 255, 255, .04);
    border    : 1px solid rgba(255, 255, 255, .10);
    color     : #fff;
}

.form-control-dark::placeholder {
    color: rgba(255, 255, 255, .40);
}

.form-select.form-control-dark {
    background-color: rgba(255, 255, 255, .04);
    border          : 1px solid rgba(255, 255, 255, .10);
    color           : #fff;
}

.form-label {
    color: rgba(255, 255, 255, .75);
}

/* Footer */
.footer {
    border-top: 1px solid rgba(255, 255, 255, .06);
    background: rgba(0, 0, 0, .35);
}

.footer .logofooter img {
    height: 50px;
}

.social {
    width          : 38px;
    height         : 38px;
    border-radius  : 12px;
    display        : grid;
    place-items    : center;
    background     : rgba(255, 255, 255, .05);
    border         : 1px solid rgba(255, 255, 255, .10);
    color          : #fff;
    text-decoration: none;
}

.social:hover {
    border-color: rgba(225, 29, 46, .25);
}

.link-soft {
    color          : rgba(255, 255, 255, .70);
    text-decoration: none;
}

.link-soft:hover {
    color: #fff;
}

/* Portfolio filtering */
.portfolio-item.hidden {
    display: none !important;
}

#contato .media-cover {
    position: relative;
    height  : 100%;
}


#contato .media-cover img {
    display   : block;
    width     : 100%;
    height    : 100%;
    min-width : 100%;
    min-height: 100%;
    object-fit: cover;
}

#contato .media-cover-content {
    position  : absolute;
    bottom    : 0;
    background: radial-gradient(600px 400px at 65% 35%, rgba(225, 29, 46, .10), rgba(0, 0, 0, .85) 60%), linear-gradient(180deg, rgba(0, 0, 0, .25), rgba(0, 0, 0, .75));
}

@media (max-width: 991.98px) {
    .home-categories {
        margin-top: 0;
        padding   : 1.25rem 0 1.5rem;
    }

    .home-categories-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-page .navbar .container {
        position: relative;
    }

    .home-page #navMain {
        position     : absolute;
        top          : calc(100% + .65rem);
        left         : 12px;
        right        : 12px;
        flex-basis   : auto;
        margin-top   : 0;
        padding      : .9rem 1rem;
        border       : 1px solid rgba(255, 255, 255, .08);
        border-radius: 14px;
        background   : rgba(9, 9, 14, .9);
        box-shadow   : 0 16px 40px rgba(0, 0, 0, .35);
    }

    .home-page #navMain .navbar-nav {
        width: 100%;
    }

    .home-page #navMain .d-flex {
        width     : 100%;
        margin-top: .7rem;
    }

    .footer {
        text-align: center;
    }

    .footer .logofooter {
        margin-left : auto;
        margin-right: auto;
        display     : block !important;
    }
}

@media (max-width: 767.98px) {
    .home-category-link {
        min-height: 68px;
    }
}

@media (max-width: 575.98px) {
    .home-categories-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

/* Wedding alt hero */
.wedding-alt-hero {
    position    : relative;
    min-height  : 100svh;
    overflow    : hidden;
    touch-action: pan-y;
}

.wedding-alt-track {
    position: absolute;
    inset   : 0;
}

.wedding-alt-slide {
    position      : absolute;
    inset         : 0;
    opacity       : 0;
    transform     : translate3d(0, 24px, 0) scale(1.02);
    transition    : opacity .68s cubic-bezier(.16, 1, .3, 1), transform .9s cubic-bezier(.16, 1, .3, 1);
    pointer-events: none;
    will-change   : transform, opacity;
}

.wedding-alt-slide::before {
    content               : "";
    position              : absolute;
    inset                 : 0;
    background-image      : var(--slide-bg);
    background-size       : cover;
    background-position   : center;
    /* filter             : blur(5px) saturate(1.08) contrast(1.04) brightness(.72); */
    transform             : scale(1.12);
    transition            : transform 1.25s cubic-bezier(.16, 1, .3, 1), filter .9s ease;
}

.wedding-alt-slide.is-active {
    opacity       : 1;
    transform     : translate3d(0, 0, 0) scale(1);
    pointer-events: auto;
}

.wedding-alt-slide.is-active::before {
    transform: scale(1.06);
}

.wedding-alt-slide.is-enter-from-right {
    opacity  : .001;
    transform: translate3d(92px, 0, 0) scale(1.015);
}

.wedding-alt-slide.is-enter-from-left {
    opacity  : .001;
    transform: translate3d(-92px, 0, 0) scale(1.015);
}

.wedding-alt-slide.is-exit-to-left {
    opacity  : 0;
    transform: translate3d(-92px, 0, 0) scale(1.03);
}

.wedding-alt-slide.is-exit-to-right {
    opacity  : 0;
    transform: translate3d(92px, 0, 0) scale(1.03);
}

.wedding-alt-overlay {
    position: absolute;
    inset   : 0;
    background:
        linear-gradient(96deg, rgba(7, 7, 10, .92) 12%, rgba(7, 7, 10, .56) 52%, rgba(7, 7, 10, .82) 100%),
        linear-gradient(180deg, rgba(4, 4, 6, .24) 0%, rgba(4, 4, 6, .56) 100%),
        radial-gradient(800px 420px at 78% 50%, rgba(255, 138, 60, .14), transparent 75%);
    z-index: 1;
}

.wedding-alt-content {
    position      : relative;
    z-index       : 3;
    min-height    : 100svh;
    display       : flex;
    align-items   : center;
    padding-top   : 80px;
    padding-bottom: 80px;
}

.wedding-alt-layout {
    width                : 100%;
    display              : grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 600px);
    gap                  : 2.2rem;
    align-items          : center;
}

.wedding-alt-copy {
    max-width: 700px;
}

.wedding-alt-copy.is-animating {
    animation: eventsHeroCopyIn .55s ease both;
}

@keyframes eventsHeroCopyIn {
    from {
        opacity  : 0;
        transform: translateY(14px);
    }

    to {
        opacity  : 1;
        transform: translateY(0);
    }
}

.wedding-alt-visual {
    justify-self  : end;
    width         : min(100%, 600px);
    align-self    : center;
    display       : flex;
    flex-direction: column;
    align-items   : center;
}

.wedding-alt-cover-card {
    width       : 100%;
    aspect-ratio: 16 / 9;
    opacity     : .92;
}

.wedding-alt-cover-card img {
    width       : 100%;
    height      : 100%;
    display     : block;
    aspect-ratio: 16 / 9;
    object-fit  : cover;
}

.wedding-alt-kicker {
    margin-bottom: 1.1rem;
}

.wedding-alt-title {
    margin     : 0;
    line-height: .96;
    font-size  : clamp(2.2rem, 4.4vw, 4rem);
}

.wedding-alt-title span {
    display    : block;
    text-shadow: 1px 1px 40px #000;
}

.wedding-alt-title .is-hidden {
    display: none;
}

.wedding-alt-description {
    max-width  : 58ch;
    margin-top : 1.35rem;
    font-size  : 1.02rem;
    line-height: 1.6;
}

.wedding-alt-cta {
    margin-top: 2.1rem;
}

.wedding-alt-side-nav {
    position      : absolute;
    left          : 50%;
    bottom        : 44px;
    z-index       : 5;
    transform     : translateX(-50%);
    display       : flex;
    flex-direction: row;
    gap           : .7rem;
}

.wedding-alt-side-nav button {
    width        : 12px;
    height       : 12px;
    border-radius: 50%;
    border       : 1px solid rgba(255, 255, 255, .44);
    background   : rgba(255, 255, 255, .12);
    padding      : 0;
}

.wedding-alt-side-nav button.is-active {
    background  : var(--accent);
    border-color: var(--accent);
}

.wedding-alt-hud {
    position: absolute;
    left    : 0;
    right   : 0;
    bottom  : 18px;
    z-index : 3;
}

.wedding-alt-controls {
    display        : flex;
    justify-content: space-between;
    align-items    : center;
    padding-bottom : 1.2rem;
}

.wedding-alt-control-left,
.wedding-alt-control-right {
    display    : flex;
    align-items: center;
    gap        : .9rem;
}

.wedding-alt-controls button {
    width          : 52px;
    height         : 52px;
    border-radius  : 999px;
    border         : 1px solid rgba(255, 255, 255, .12);
    padding        : 0;
    color          : #fff;
    background     : rgba(8, 8, 12, .42);
    backdrop-filter: blur(8px);
    font-size      : 1.1rem;
    line-height    : 1;
    transition     : color .2s ease, transform .2s ease, background .2s ease, border-color .2s ease;
}

.wedding-alt-controls button:hover {
    color       : #fff;
    background  : rgba(225, 29, 46, .2);
    border-color: rgba(225, 29, 46, .34);
    transform   : translateY(-1px);
}

@media (max-width: 991.98px) {

    .wedding-alt-content {
        padding-top   : 102px;
        padding-bottom: 138px;
    }

    .wedding-alt-layout {
        grid-template-columns: minmax(0, 1fr);
        gap                  : 1.5rem;
    }

    .wedding-alt-title {
        max-width: 620px;
        font-size: clamp(1.8rem, 6vw, 3rem);
    }

    .wedding-alt-visual {
        justify-self: start;
        width       : min(86vw, 580px);
    }

}

@media (max-width: 767.98px) {

    .wedding-alt-content {
        align-items   : flex-start;
        padding-top   : 130px;
        padding-bottom: 178px;
    }

    .wedding-alt-layout {
        justify-items: center;
        text-align   : center;
    }

    .wedding-alt-copy {
        max-width: 100%;
    }

    .wedding-alt-kicker {
        margin-bottom: .95rem;
    }

    .wedding-alt-description {
        max-width : 100%;
        font-size : .95rem;
        margin-top: .9rem;
    }

    .wedding-alt-cta {
        margin-top     : 1.45rem;
        justify-content: center;
    }

    .wedding-alt-visual {
        justify-self : center;
        width        : min(90vw, 520px);
        margin-inline: auto;
    }

    .wedding-alt-cover-title {
        text-align: center;
        font-size : .95rem;
        margin-top: .65rem;
    }

    .wedding-alt-side-nav {
        bottom: 104px;
        gap   : .52rem;
    }

    .wedding-alt-controls {
        padding-bottom: .9rem;
    }

    .wedding-alt-control-right {
        gap: .5rem;
    }

    .wedding-alt-hud {
        bottom: 78px;
    }

    .wedding-alt-controls button {
        width : 48px;
        height: 48px;
    }

}

/* Briefing page */
.briefing-page .panel.briefing-shell {
    max-width : 1040px;
    margin    : 0 auto;
    background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .02));
}

.briefing-top-logo {
    text-decoration: none;
    text-align     : center;
    display        : block;
    width          : 100%;
}

.briefing-top-logo img {
    width       : clamp(110px, 18vw, 160px);
    height      : auto;
    filter      : drop-shadow(0 8px 20px rgba(0, 0, 0, .35));
    display     : inline-block;
    margin-left : auto;
    margin-right: auto;
}

.briefing-page .form-control-dark,
.briefing-page .form-control-dark:focus,
.briefing-page .form-select.form-control-dark {
    background-color: #fff;
    border          : 1px solid rgba(0, 0, 0, .16);
    color           : #14171f;
}

.briefing-page .form-control-dark::placeholder {
    color: rgba(20, 23, 31, .52);
}

.briefing-faq .accordion-item {
    background   : rgba(255, 255, 255, .03);
    border       : 1px solid rgba(255, 255, 255, .10);
    border-radius: 12px;
    overflow     : hidden;
}

.briefing-faq .accordion-item+.accordion-item {
    margin-top: .65rem;
}

.briefing-faq .accordion-button {
    background : rgba(255, 255, 255, .02);
    color      : #fff;
    font-weight: 600;
    box-shadow : none;
}

.briefing-faq .accordion-button:not(.collapsed) {
    background: rgba(225, 29, 46, .12);
    color     : #fff;
}

.briefing-faq .accordion-button::after {
    filter: brightness(0) invert(1) opacity(.8);
}

.briefing-faq .accordion-body {
    color: rgba(255, 255, 255, .82);
}

.briefing-progress {
    height       : 9px;
    border-radius: 999px;
    background   : rgba(255, 255, 255, .08);
    overflow     : hidden;
}

.briefing-progress .progress-bar {
    background   : linear-gradient(90deg, var(--accent), var(--accent2));
    border-radius: 999px;
    transition   : width .25s ease;
}

.briefing-step {
    display      : none;
    border       : 1px solid rgba(255, 255, 255, .10);
    border-radius: 14px;
    padding      : 1.15rem;
    background   : rgba(7, 8, 12, .45);
}

.briefing-step.is-active {
    display: block;
}

.briefing-step-head {
    margin-bottom: .2rem;
}

.briefing-field.has-error .briefing-choice,
.briefing-field.has-error .form-control,
.briefing-field.has-error .form-select {
    border-color: rgba(220, 53, 69, .75) !important;
}

.briefing-choice-grid {
    display              : grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap                  : .55rem;
}

.briefing-choice-stack {
    display       : grid;
    gap           : .5rem;
    grid-auto-rows: minmax(0, auto);
}

.briefing-choice-columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.briefing-choice {
    position     : relative;
    display      : flex;
    align-items  : center;
    gap          : .55rem;
    border       : 1px solid rgba(255, 255, 255, .12);
    border-radius: 12px;
    padding      : .62rem .75rem;
    background   : rgba(255, 255, 255, .03);
    cursor       : pointer;
    transition   : border-color .2s ease, background-color .2s ease;
    color        : rgba(255, 255, 255, .92);
    line-height  : 1.25;
    font-size    : .94rem;
}

.briefing-choice input {
    accent-color: var(--accent);
    margin      : 0;
    flex-shrink : 0;
}

.briefing-choice:has(input:checked) {
    border-color: rgba(225, 29, 46, .62);
    background  : rgba(225, 29, 46, .15);
}

.briefing-review {
    border-top : 1px solid rgba(255, 255, 255, .09);
    padding-top: 1.1rem;
}

.briefing-review-grid {
    display              : grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap                  : .8rem;
}

.briefing-review-section {
    border       : 1px solid rgba(255, 255, 255, .10);
    border-radius: 12px;
    padding      : .85rem .9rem;
    background   : rgba(255, 255, 255, .03);
}

.briefing-review-list {
    display       : grid;
    gap           : .48rem;
    margin        : 0;
    padding       : 0;
    grid-auto-rows: minmax(0, auto);
}

.briefing-review-item {
    display              : grid;
    gap                  : .35rem;
    grid-template-columns: minmax(0, 1fr);
}

.briefing-review-item dt {
    color      : rgba(255, 255, 255, .62);
    font-size  : .78rem;
    line-height: 1.2;
    margin     : 0;
}

.briefing-review-item dd {
    color      : rgba(255, 255, 255, .95);
    font-size  : .9rem;
    line-height: 1.3;
    margin     : 0;
}

@media (max-width: 991.98px) {
    .briefing-review-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 575.98px) {
    .briefing-step {
        padding: .9rem;
    }

    .briefing-choice-columns {
        grid-template-columns: minmax(0, 1fr);
    }

    .briefing-choice {
        font-size: .9rem;
        padding  : .56rem .68rem;
    }

    .briefing-choice-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

/* Legenda de vídeo (Fancybox) */
.fancybox__caption .video-caption-title {
    font-size    : 1rem;
    font-weight  : 700;
    margin-bottom: .35rem;
}

.fancybox__caption .video-caption-link {
    color          : var(--accent2);
    text-decoration: underline;
    font-weight    : 600;
}

.fancybox__caption .video-caption-link:hover {
    color: #fff;
}

#eventos-pg .hero-bg {
    background-image: url('/imagens/slide/eventos-01.webp')
}

#reels-pg .hero-bg {
    background-image: url('/imagens/Mockup.jpg')
}

.event-case-hero .hero-bg {
    background-image   : var(--event-case-hero);
    /* transform       : scale(1.02); */
    /* filter          : saturate(.78) brightness(.36); */
}

.event-case-hero .hero-overlay {
    background: linear-gradient(180deg, rgba(6, 10, 18, .72) 0%, rgba(6, 10, 18, .9) 100%);
}

.event-case-hero-copy {
    margin         : 0 auto;
    display        : flex;
    flex-direction : column;
    align-items    : center;
    justify-content: center;
    text-align     : center;
}

.event-case-hero-copy>div {
    width         : 100%;
    max-width     : 980px;
    margin        : 0 auto;
    display       : flex;
    flex-direction: column;
    align-items   : center;
    text-align    : center;
}

.event-case-hero h1 {
    /* max-width: 13ch; */
    font-size: clamp(2.5rem, 5.2vw, 4.4rem);
}

.event-case-hero .chip {
    margin-left : auto;
    margin-right: auto;
}

.event-case-hero .hero-actions {
    justify-content: center;
}

.event-case-hero .events-hero-proof {
    justify-content: center;
}

.event-case-hero .text {}

.event-case-meta-strip {
    list-style     : none;
    padding        : 0;
    margin         : 0 0 1.4rem;
    display        : flex;
    flex-wrap      : wrap;
    justify-content: center;
    gap            : .75rem;
}

.event-case-meta-strip li {
    display       : inline-flex;
    align-items   : center;
    gap           : .45rem;
    min-height    : 48px;
    padding       : .72rem 1rem;
    border-radius : 999px;
    border        : 1px solid rgba(255, 255, 255, .1);
    background    : rgba(255, 255, 255, .04);
    color         : rgba(255, 255, 255, .92);
    font-weight   : 600;
    letter-spacing: .01em;
}

.event-case-meta-strip span {
    color         : rgba(255, 255, 255, .58);
    font-size     : .7rem;
    font-weight   : 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.event-case-section-intro {
    max-width : 720px;
    margin    : 0 auto;
    text-align: center;
}

.event-scene-carousel-wrap {
    margin-top: 2rem;
}

.event-scene-carousel-wrap .events-case-carousel-head {
    margin-bottom: .9rem;
}

.event-scene-carousel-wrap .events-case-item-featured {
    width: min(76vw, 520px);
}

.event-scene-footnote {
    max-width  : 720px;
    margin     : 1.25rem auto 0;
    text-align : center;
    color      : rgba(255, 255, 255, .62);
    line-height: 1.55;
}

.event-video-section {
    --event-video-progress      : 0;
    --event-video-max-width     : min(72vw, 920px);
    --event-video-expanded-width: min(100vw - 24px, 1680px);
}

.event-video-stage {
    height       : 180vh;
    margin-top   : 2rem;
    margin-bottom: 2rem;
    position     : relative;
}

.event-video-stage-sticky {
    position       : sticky;
    top            : 10vh;
    display        : flex;
    justify-content: center;
    align-items    : flex-start;
}

.event-video-panel {
    overflow     : hidden;
    padding      : 0;
    border-radius: 1.7rem;
    border       : 1px solid rgba(255, 255, 255, .08);
    background   : #05070c;
    box-shadow   : 0 22px 50px rgba(0, 0, 0, .18);
    width        : clamp(320px,
            calc(var(--event-video-max-width) + (var(--event-video-expanded-width) - var(--event-video-max-width)) * var(--event-video-progress)),
            var(--event-video-expanded-width));
    max-width    : calc(100vw - 16px);
    margin       : 0 auto;
    transform    : translateZ(0);
    will-change  : width, border-radius, box-shadow;
    border-radius: calc(1.7rem - 1.2rem * var(--event-video-progress));
    box-shadow   : 0 calc(22px + 18px * var(--event-video-progress)) calc(50px + 30px * var(--event-video-progress)) rgba(0, 0, 0, calc(.18 + .12 * var(--event-video-progress)));
}

.event-video-panel iframe {
    border: 0;
}

.event-video-copy {
    display  : grid;
    gap      : 1rem;
    max-width: 840px;
    margin   : 0 auto;
}

.event-deliverables-list {
    list-style: none;
    padding   : 0;
    margin    : 0;
    display   : grid;
    gap       : .8rem;
    text-align: left;
}

.event-deliverables-list li {
    display    : flex;
    align-items: flex-start;
    gap        : .8rem;
    padding    : .9rem 0;
    border-top : 1px solid rgba(255, 255, 255, .08);
}

.event-deliverables-list li:first-child {
    border-top: 0;
}

.event-deliverables-list i {
    flex       : 0 0 auto;
    color      : var(--accent2);
    font-size  : 1rem;
    line-height: 1.5;
}

.event-gallery-bleed {
    width      : 100vw;
    margin-left: calc(50% - 50vw);
    margin-top : 2rem;
    overflow   : hidden;
}

.event-gallery-shell {
    --event-gallery-collapsed-height: 980px;
    position                        : relative;
    max-height                      : var(--event-gallery-collapsed-height);
    overflow                        : hidden;
    transition                      : max-height .45s ease;
}

.event-gallery-shell::after {
    content       : "";
    position      : absolute;
    inset         : auto 0 0;
    height        : 180px;
    background    : linear-gradient(180deg, rgba(5, 8, 14, 0) 0%, rgba(5, 8, 14, .94) 88%);
    pointer-events: none;
    opacity       : 1;
    transition    : opacity .3s ease;
}

.event-gallery-shell.is-expanded {
    max-height: none;
}

.event-gallery-shell.is-expanded::after {
    opacity: 0;
}

.event-gallery-grid {
    column-count: 4;
    column-gap  : 0;
}

.event-gallery-actions {
    display        : flex;
    justify-content: center;
    margin-top     : 1.5rem;
}

.event-gallery-actions[hidden] {
    display: none !important;
}

.event-gallery-toggle {
    display       : inline-flex;
    align-items   : center;
    gap           : .65rem;
    padding       : .9rem 1.35rem;
    font-weight   : 700;
    letter-spacing: .02em;
    background    : rgba(255, 255, 255, .03);
    border-color  : rgba(255, 255, 255, .14);
}

.event-gallery-toggle i {
    transition: transform .3s ease;
}

.event-gallery-toggle[aria-expanded="true"] i {
    transform: rotate(180deg);
}

.event-gallery-item {
    position                   : relative;
    display                    : inline-block;
    width                      : 100%;
    margin                     : 0;
    vertical-align             : top;
    break-inside               : avoid;
    -webkit-column-break-inside: avoid;
    page-break-inside          : avoid;
    border-radius              : 0;
    overflow                   : hidden;
    background                 : rgba(255, 255, 255, .04);
}

.event-gallery-item img {
    width     : 100%;
    height    : auto;
    display   : block;
    object-fit: cover;
    transition: transform .7s ease;
}

.event-gallery-item::after {
    content   : "";
    position  : absolute;
    inset     : 0;
    background: linear-gradient(180deg, rgba(6, 10, 18, .02) 42%, rgba(6, 10, 18, .76) 100%);
}

.event-gallery-item:hover img,
.event-gallery-item:focus-visible img {
    transform: scale(1.05);
}

.event-gallery-caption {
    position   : absolute;
    left       : 1rem;
    right      : 1rem;
    bottom     : 1rem;
    z-index    : 1;
    color      : #fff;
    font-weight: 700;
    line-height: 1.3;
    text-wrap  : balance;
}

.event-case-cta {
    align-items          : center;
    justify-content      : space-between;
    gap                  : 1.25rem;
    padding              : 1.35rem 1.5rem;
    border-radius        : 1.5rem;
    display              : grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, .5fr);
    gap                  : 1rem;
}

.event-testimonial {
    position     : relative;
    max-width    : 920px;
    margin       : 0 auto;
    display      : grid;
    gap          : 1rem;
    text-align   : center;
    justify-items: center;
    padding      : 2rem 1.75rem;
    border-radius: 1.5rem;
    overflow     : hidden;
}

.event-testimonial::before {
    content       : "";
    position      : absolute;
    inset         : auto -60px -70px auto;
    width         : 220px;
    height        : 220px;
    border-radius : 50%;
    background    : radial-gradient(circle, rgba(225, 29, 46, .16), transparent 70%);
    pointer-events: none;
}

.event-testimonial-mark {
    width          : 58px;
    height         : 58px;
    display        : grid;
    place-items    : center;
    border-radius  : 50%;
    color          : #fff;
    font-size      : 1.3rem;
    background     : rgba(225, 29, 46, .18);
    border         : 1px solid rgba(225, 29, 46, .24);
    box-shadow     : 0 14px 30px rgba(0, 0, 0, .14);
    backdrop-filter: blur(8px);
}

.event-testimonial-quote {
    max-width  : 780px;
    margin     : 0;
    font-size  : clamp(1.1rem, 2vw, 1.5rem);
    line-height: 1.6;
    color      : rgba(255, 255, 255, .94);
    text-wrap  : balance;
}

.event-testimonial-author {
    display      : grid;
    gap          : .2rem;
    justify-items: center;
    color        : rgba(255, 255, 255, .84);
}

.event-testimonial-author strong {
    font-size     : 1rem;
    letter-spacing: .02em;
}

.event-testimonial-author span {
    color         : rgba(255, 255, 255, .6);
    font-size     : .92rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.event-testimonial-note {
    color    : rgba(255, 255, 255, .54);
    font-size: .88rem;
}

@media (max-width: 991.98px) {
    .event-scene-carousel-wrap .events-case-item-featured {
        width: min(82vw, 500px);
    }

    .event-gallery-shell {
        --event-gallery-collapsed-height: 820px;
    }

    .event-gallery-grid {
        column-count: 3;
    }

    .event-video-stage {
        height: 120vh;
    }

    .event-video-stage-sticky {
        top: 12vh;
    }

    .event-case-cta {
        flex-direction: column;
        align-items   : center;
        text-align    : center;
    }

    .event-case-cta .btn {
        align-self: center;
    }

    .event-testimonial {
        padding: 1.75rem 1.35rem;
    }
}

@media (max-width: 767.98px) {
    .event-case-meta-strip {
        flex-direction: column;
        align-items   : center;
        gap           : .45rem;
    }

    .event-case-hero h1 {
        font-size    : clamp(1.95rem, 8vw, 2.9rem);
        margin-bottom: 1.1rem !important;
    }

    .event-case-meta-strip li {
        min-height  : 0;
        padding     : .58rem .85rem;
        font-size   : .92rem;
        border-color: rgba(255, 255, 255, .06);
        background  : rgba(255, 255, 255, .025);
    }

    .event-case-meta-strip span {
        font-size     : .62rem;
        letter-spacing: .06em;
    }

    .event-scene-carousel-wrap .events-case-item-featured {
        width: min(84vw, 360px);
    }

    .event-video-section {
        --event-video-max-width     : calc(100vw - 64px);
        --event-video-expanded-width: calc(100vw - 12px);
    }

    .event-video-stage {
        height       : auto;
        margin-top   : 1.5rem;
        margin-bottom: 1.5rem;
    }

    .event-video-stage-sticky {
        position: static;
    }

    .event-video-panel {
        width        : 100%;
        max-width    : none;
        border-radius: 0;
    }

    .event-gallery-grid {
        column-count: 2;
    }

    .event-gallery-item {
        border-radius: 0;
    }

    .event-gallery-shell {
        --event-gallery-collapsed-height: 620px;
    }

    .event-gallery-shell::after {
        height: 140px;
    }

    .event-gallery-toggle {
        width          : min(100%, 320px);
        justify-content: center;
    }

    .event-testimonial-quote {
        text-wrap: pretty;
    }
}

@media (max-width: 575.98px) {
    .event-gallery-shell {
        --event-gallery-collapsed-height: 540px;
    }

    .event-gallery-grid {
        column-count: 2;
    }
}

#case-itaubba {}


#case-itaubba h4 {
    font-size: 2rem;
}