:root{
    color-scheme:dark;
    --bg:#06110f;
    --bg-2:#0a1b17;
    --surface:#0d211d;
    --surface-2:#123128;
    --surface-3:#08231d;
    --text:#f8fafc;
    --muted:#a8b8b2;
    --line:rgba(168,184,178,.18);
    --green:#22c55e;
    --green-2:#16a34a;
    --orange:#f97316;
    --shadow:0 18px 44px rgba(0,0,0,.26);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    background:var(--bg);
    color:var(--text);
    font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.site-nav{
    position:sticky;
    top:0;
    z-index:50;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    padding:.75rem 3.5rem;
    border-bottom:1px solid var(--line);
    background:rgba(6,17,15,.92);
    backdrop-filter:blur(14px);
}
.site-brand{display:flex;align-items:center;min-width:0}
.site-brand img{width:150px;max-width:38vw;display:block}
.site-nav__links{display:flex;align-items:center;gap:1.2rem;color:var(--muted);font-size:.95rem;font-weight:800}
.site-nav__links a:hover{color:var(--text)}
.site-nav__actions{display:flex;align-items:center;gap:.65rem}
.login-link{
    display:inline-flex;
    align-items:center;
    gap:.35rem;
    color:#d7ffe5;
    font-size:.9rem;
    font-weight:900;
}
.login-link svg,.mobile-menu__login svg{
    width:18px;
    height:18px;
    fill:currentColor;
}
.nav-toggle{
    display:none;
    width:42px;
    height:42px;
    align-items:center;
    justify-content:center;
    gap:4px;
    flex-direction:column;
    border:1px solid rgba(248,250,252,.16);
    border-radius:8px;
    background:rgba(248,250,252,.06);
    color:var(--text);
    cursor:pointer;
}
.nav-toggle span{
    display:block;
    width:18px;
    height:2px;
    border-radius:8px;
    background:currentColor;
}
.mobile-menu{
    position:absolute;
    top:calc(100% + 8px);
    left:1rem;
    right:1rem;
    display:none;
    gap:.25rem;
    padding:.7rem;
    border:1px solid var(--line);
    border-radius:8px;
    background:rgba(6,17,15,.98);
    box-shadow:var(--shadow);
}
.mobile-menu a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    min-height:42px;
    padding:.65rem .75rem;
    border-radius:8px;
    color:#d7ffe5;
    font-weight:900;
}
.mobile-menu a:hover{background:rgba(34,197,94,.09)}
.mobile-menu__login{
    margin-top:.35rem;
    border-top:1px solid var(--line);
    gap:.4rem;
    justify-content:flex-start!important;
}
.site-nav.is-open .mobile-menu{display:grid}
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:.72rem 1rem;
    border-radius:8px;
    border:1px solid transparent;
    font-weight:900;
    line-height:1;
    white-space:nowrap;
}
.btn--primary{background:var(--green);color:#03110a;box-shadow:0 16px 32px rgba(34,197,94,.22)}
.btn--primary:hover{background:#39dc72}
.btn--light{background:#f8fafc;color:#071511}
.btn--ghost{border-color:rgba(248,250,252,.22);background:rgba(248,250,252,.06);color:var(--text)}
.btn--whatsapp{background:#128c4b;color:#f8fafc;border-color:rgba(248,250,252,.14);box-shadow:0 16px 32px rgba(18,140,75,.24)}
.btn:focus-visible,.site-nav__links a:focus-visible,.site-footer__links a:focus-visible,.social-panel a:focus-visible,.login-link:focus-visible,.nav-toggle:focus-visible,.mobile-menu a:focus-visible{
    outline:3px solid rgba(34,197,94,.72);
    outline-offset:3px;
}
.hero{
    position:relative;
    min-height:680px;
    display:grid;
    align-items:center;
    padding:5rem 5rem 4rem;
    overflow:hidden;
    border-bottom:1px solid var(--line);
}
.hero__backdrop{
    position:absolute;
    inset:0;
    background:
        linear-gradient(90deg,rgba(6,17,15,.98) 0%,rgba(6,17,15,.86) 44%,rgba(6,17,15,.45) 100%),
        url("../img/logovistro.webp") right 7% center/610px auto no-repeat,
        linear-gradient(135deg,var(--bg) 0%,var(--bg-2) 100%);
}
.hero__content{position:relative;max-width:780px}
.eyebrow{margin:0 0 .9rem;color:var(--green);font-size:.78rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
h1,h2,h3,p{overflow-wrap:anywhere}
h1{margin:0;font-size:4.25rem;line-height:1.02;max-width:850px}
h2{margin:0;font-size:2.75rem;line-height:1.08;max-width:780px}
h3{margin:.55rem 0 0;font-size:1.15rem;line-height:1.2}
.hero__lead{max-width:650px;margin:1.1rem 0 0;color:var(--muted);font-size:1.12rem;line-height:1.65}
.hero__actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}
.showcase-carousel{
    display:grid;
    grid-template-columns:minmax(280px,.42fr) minmax(0,1fr);
    gap:1rem;
    align-items:center;
    padding:3rem 5rem;
    border-bottom:1px solid var(--line);
    background:var(--bg-2);
}
.showcase-copy h2{max-width:520px}
.showcase-stage{
    position:relative;
    min-height:420px;
    border:1px solid var(--line);
    border-radius:8px;
    overflow:hidden;
    background:#071511;
    box-shadow:var(--shadow);
}
.showcase-slide{
    position:absolute;
    inset:0;
    opacity:0;
    transform:scale(.985);
    transition:opacity .38s ease,transform .38s ease;
}
.showcase-slide.is-active{opacity:1;transform:scale(1)}
.showcase-slide img{width:100%;height:100%;object-fit:cover;display:block}
.showcase-caption{
    position:absolute;
    left:1rem;
    bottom:1rem;
    display:grid;
    gap:.25rem;
    max-width:min(420px,calc(100% - 2rem));
    padding:.85rem 1rem;
    border:1px solid rgba(248,250,252,.14);
    border-radius:8px;
    background:rgba(6,17,15,.8);
    backdrop-filter:blur(10px);
}
.showcase-caption span{color:var(--green);font-size:.76rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.showcase-caption strong{font-size:1.4rem}
.showcase-nav{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:2;
    width:44px;
    height:44px;
    border:1px solid rgba(248,250,252,.18);
    border-radius:8px;
    background:rgba(6,17,15,.72);
    color:var(--text);
    font-size:2rem;
    line-height:1;
    cursor:pointer;
}
.showcase-nav--prev{left:1rem}
.showcase-nav--next{right:1rem}
.showcase-dots{
    grid-column:2;
    display:flex;
    gap:.45rem;
    justify-content:center;
}
.showcase-dots button{
    width:36px;
    height:8px;
    border:0;
    border-radius:8px;
    background:rgba(248,250,252,.24);
    cursor:pointer;
}
.showcase-dots button.is-active{background:var(--green)}
.visual-story{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:1rem;
    padding:1rem 5rem 0;
    margin-top:-56px;
    position:relative;
    z-index:2;
}
.visual-card{
    min-height:152px;
    display:grid;
    grid-template-columns:120px minmax(0,1fr);
    align-items:center;
    gap:1rem;
    padding:1rem;
    border:1px solid var(--line);
    border-radius:8px;
    background:rgba(13,33,29,.94);
    box-shadow:var(--shadow);
}
.visual-card img{width:120px;border-radius:8px;border:1px solid rgba(248,250,252,.08)}
.visual-card span{display:block;color:var(--green);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.visual-card strong{display:block;margin-top:.35rem;line-height:1.35}
.section{padding:4.2rem 5rem}
.section--tight{padding-top:3rem;padding-bottom:3.4rem}
.section__head{display:grid;gap:.4rem;margin-bottom:1.4rem}
.section__lead{max-width:720px;margin:.35rem 0 0;color:var(--muted);line-height:1.6}
.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem}
.module-card,.price-card,.cost-points div{
    border:1px solid var(--line);
    border-radius:8px;
    background:linear-gradient(180deg,var(--surface) 0%,rgba(13,33,29,.68) 100%);
}
.module-card{min-height:108px;padding:.9rem;display:flex;flex-direction:column;justify-content:space-between}
.module-card span,.price-card span{color:var(--green);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.module-card strong{font-size:1rem;line-height:1.35}
.cost-section{
    display:grid;
    grid-template-columns:minmax(0,.92fr) minmax(320px,.78fr);
    gap:1.4rem;
    align-items:center;
    background:var(--bg-2);
    border-block:1px solid var(--line);
}
.cost-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1rem}
.cost-points div{padding:.9rem}
.cost-points strong{display:block;font-size:1.05rem}
.cost-points span{display:block;margin-top:.3rem;color:var(--muted);font-size:.9rem}
.cost-section__visual{
    position:relative;
    min-height:340px;
    border:1px solid var(--line);
    border-radius:8px;
    overflow:hidden;
    background:var(--surface);
    box-shadow:var(--shadow);
}
.recipe-carousel{position:absolute;inset:0;background:#071511}
.recipe-slide{
    position:absolute;
    inset:0;
    opacity:0;
    transform:scale(1.03);
    transition:opacity .45s ease,transform .45s ease;
}
.recipe-slide.is-active{opacity:1;transform:scale(1)}
.recipe-slide img{display:block;width:100%;height:100%;object-fit:cover}
.recipe-slide::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(6,17,15,.04) 0%,rgba(6,17,15,.72) 100%);
}
.recipe-slide span{
    position:absolute;
    left:1rem;
    bottom:1rem;
    z-index:1;
    display:inline-flex;
    min-height:34px;
    align-items:center;
    padding:.45rem .75rem;
    border:1px solid rgba(248,250,252,.18);
    border-radius:8px;
    background:rgba(6,17,15,.7);
    color:#d7ffe5;
    font-size:.82rem;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
    backdrop-filter:blur(8px);
}
.product-strip{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:1.5rem;
    align-items:center;
    border-bottom:1px solid var(--line);
}
.product-strip__copy p{max-width:700px;color:var(--muted);line-height:1.7}
.product-strip img{
    border:1px solid var(--line);
    border-radius:8px;
    background:var(--surface);
    box-shadow:var(--shadow);
}
.pricing-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:1rem}
.price-card{
    position:relative;
    flex:0 1 320px;
    display:flex;
    flex-direction:column;
    gap:.35rem;
    padding:1.2rem;
    overflow:hidden;
}
.price-card h3{margin:.35rem 0 0;font-size:1.25rem}
.price-card__tag{
    display:inline-flex;
    align-self:flex-start;
    min-height:28px;
    align-items:center;
    padding:.25rem .55rem;
    border:1px solid rgba(248,250,252,.15);
    border-radius:8px;
    background:rgba(248,250,252,.05);
}
.price-card__ribbon{
    position:absolute;
    top:.8rem;
    right:-2.1rem;
    z-index:1;
    min-width:140px;
    min-height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:.2rem .6rem;
    border:1px solid rgba(248,250,252,.2);
    border-radius:8px;
    background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);
    color:#052213!important;
    font-size:.72rem!important;
    font-weight:900;
    letter-spacing:.06em!important;
    transform:rotate(24deg);
    text-transform:uppercase;
}
.price-card--featured{
    border-color:rgba(34,197,94,.7);
    background:linear-gradient(180deg,rgba(34,197,94,.16) 0%,var(--surface) 100%);
    box-shadow:0 16px 38px rgba(34,197,94,.16),var(--shadow);
}
.price-card__price{display:block;margin:.45rem 0 .65rem;color:#fff;font-size:1.45rem}
.price-card__text{color:var(--muted);line-height:1.55}
.price-card__features{
    margin:1rem 0 0;
    padding:0;
    list-style:none;
    display:grid;
    gap:.55rem;
    color:var(--muted);
}
.price-card__features li::before{content:"\2713";color:var(--green);font-weight:900;margin-right:.45rem}
.price-card__cta{
    margin-top:auto;
    padding-top:1rem;
}
.btn--buy{
    position:relative;
    width:100%;
    min-height:46px;
    border-color:rgba(34,197,94,.44);
    background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);
    color:#03110a;
    box-shadow:0 14px 30px rgba(34,197,94,.28);
    transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
    animation:buyPulse 2.2s ease-in-out infinite;
}
.btn--buy:hover{
    transform:translateY(-1px) scale(1.01);
    box-shadow:0 18px 34px rgba(34,197,94,.32);
    filter:saturate(1.06);
}
.btn--buy:active{
    transform:translateY(0);
    box-shadow:0 12px 22px rgba(34,197,94,.24);
}
@keyframes buyPulse{
    0%,100%{box-shadow:0 14px 30px rgba(34,197,94,.28)}
    50%{box-shadow:0 19px 36px rgba(34,197,94,.34)}
}
.addons-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:.85rem;
}
.addon-card{
    border:1px solid var(--line);
    border-radius:8px;
    background:linear-gradient(180deg,var(--surface) 0%,rgba(13,33,29,.68) 100%);
    padding:1rem;
    display:grid;
    gap:.6rem;
}
.addon-card__header{
    display:flex;
    align-items:center;
    gap:.55rem;
}
.addon-card__plus{
    width:26px;
    height:26px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(34,197,94,.35);
    border-radius:8px;
    background:rgba(34,197,94,.14);
    color:var(--green)!important;
    font-size:1.1rem!important;
    font-weight:900;
    line-height:1;
}
.addon-card h3{margin:0;font-size:1.03rem}
.addon-card p{margin:0;color:var(--muted);line-height:1.5}
.addon-card strong{font-size:1rem;color:#dfffea}
.quote-builder{
    margin-top:1.1rem;
    display:grid;
    grid-template-columns:minmax(0,1.25fr) minmax(260px,.75fr);
    gap:1rem;
}
.quote-builder__panel,.quote-builder__summary{
    border:1px solid var(--line);
    border-radius:8px;
    background:linear-gradient(180deg,var(--surface) 0%,rgba(13,33,29,.62) 100%);
    padding:1rem;
}
.quote-builder__panel{
    display:grid;
    gap:.65rem;
}
.quote-builder__panel label{
    color:#d7ffe5;
    font-size:.78rem;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.07em;
}
.quote-builder__panel select{
    width:100%;
    min-height:42px;
    border:1px solid rgba(248,250,252,.18);
    border-radius:8px;
    background:rgba(248,250,252,.06);
    color:var(--text);
    padding:.55rem .7rem;
    font:inherit;
}
.quote-builder__modules{
    margin-top:.35rem;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:.55rem;
}
.quote-module{
    border:1px solid var(--line);
    border-radius:8px;
    padding:.65rem .75rem;
    display:flex;
    align-items:flex-start;
    gap:.55rem;
    background:rgba(248,250,252,.03);
}
.quote-module input{margin-top:.2rem}
.quote-module strong{display:block;font-size:.92rem}
.quote-module small{display:block;margin-top:.12rem;color:var(--muted);line-height:1.35}
.quote-module.is-disabled{opacity:.55}
.quote-builder__summary h3{margin:0 0 .7rem;font-size:1.2rem}
.quote-line{
    display:flex;
    justify-content:space-between;
    gap:.8rem;
    padding:.6rem 0;
    border-bottom:1px solid var(--line);
}
.quote-line:last-of-type{border-bottom:0}
.quote-line--total strong{font-size:1.22rem;color:#fff}
.quote-builder__summary p{margin:.7rem 0 0;color:var(--muted);line-height:1.45}
.faq-section{background:var(--bg-2);border-top:1px solid var(--line)}
.faq-list{display:grid;gap:.65rem;max-width:980px;margin:0 auto}
.faq-item{
    border:1px solid var(--line);
    border-radius:8px;
    background:linear-gradient(180deg,var(--surface) 0%,rgba(13,33,29,.62) 100%);
}
.faq-item summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    padding:1rem 1.1rem;
    cursor:pointer;
    color:var(--text);
    font-weight:900;
    list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary svg{
    flex:0 0 auto;
    width:24px;
    height:24px;
    fill:var(--green);
    transition:transform .2s ease;
}
.faq-item[open] summary svg{transform:rotate(180deg)}
.faq-item p{margin:0;padding:0 1.1rem 1rem;color:var(--muted);line-height:1.55}
.contact-section{
    display:grid;
    grid-template-columns:minmax(0,.92fr) minmax(340px,.72fr);
    gap:1rem;
    padding:4.5rem 5rem;
    border-top:1px solid var(--line);
    background:
        linear-gradient(135deg,rgba(34,197,94,.11) 0%,rgba(249,115,22,.08) 100%),
        var(--surface-3);
}
.contact-copy,.contact-form{
    border:1px solid var(--line);
    border-radius:8px;
    background:rgba(6,17,15,.58);
    box-shadow:var(--shadow);
}
.contact-copy{padding:1.6rem}
.contact-copy p{max-width:720px;color:var(--muted);line-height:1.65}
.contact-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.2rem}
.contact-details{
    display:grid;
    grid-template-columns:1fr;
    gap:.45rem;
    margin-top:1.2rem;
}
.contact-details div{
    display:grid;
    gap:.15rem;
    padding:.1rem 0;
}
.contact-details span{display:block;color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.contact-details strong{display:block}
.social-panel{display:grid;gap:.45rem;margin-top:1.2rem}
.social-panel a{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    min-height:38px;
    padding:.2rem 0;
    border:0;
    border-radius:0;
    color:#d7ffe5;
    background:transparent;
    font-weight:800;
}
.social-panel span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:28px;
    height:28px;
    border-radius:8px;
    background:rgba(34,197,94,.18);
    color:var(--green);
    font-size:.72rem;
}
.social-panel svg{width:17px;height:17px;fill:currentColor}
.contact-form{display:grid;gap:.6rem;padding:1.3rem}
.contact-form h3{margin:0;font-size:1.45rem}
.contact-form p{margin:0 0 .2rem;color:var(--muted);line-height:1.5}
.contact-form label{color:#d7ffe5;font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.contact-form input,.contact-form textarea{
    width:100%;
    border:1px solid rgba(248,250,252,.14);
    border-radius:8px;
    background:rgba(248,250,252,.07);
    color:var(--text);
    padding:.8rem .85rem;
    font:inherit;
}
.contact-form textarea{resize:vertical;min-height:110px}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(168,184,178,.72)}
.contact-alert{
    padding:.75rem .85rem;
    border-radius:8px;
    border:1px solid rgba(248,250,252,.14);
    background:rgba(248,250,252,.06);
    color:var(--text);
}
.contact-alert--success{border-color:rgba(34,197,94,.42);background:rgba(34,197,94,.12);color:#d7ffe5}
.contact-alert--error{border-color:rgba(249,115,22,.5);background:rgba(249,115,22,.13);color:#fff2e8}
.contact-consent{
    display:flex;
    align-items:flex-start;
    gap:.7rem;
    margin:.2rem 0;
    color:var(--muted);
    font-size:.92rem;
    line-height:1.55;
    text-transform:none!important;
    letter-spacing:normal!important;
}
.contact-consent input{
    width:18px;
    height:18px;
    margin-top:.16rem;
    padding:0;
    flex:0 0 auto;
}
.contact-consent a{color:#d7ffe5;font-weight:800}
.map-section{
    display:grid;
    grid-template-columns:minmax(0,.48fr) minmax(0,1fr);
    gap:1rem;
    align-items:center;
    padding:3.8rem 5rem;
    border-top:1px solid var(--line);
    background:var(--bg);
}
.map-card{
    display:grid;
    gap:.8rem;
    padding:1rem;
    border:1px solid var(--line);
    border-radius:8px;
    background:var(--surface);
    box-shadow:var(--shadow);
}
.map-card iframe{
    display:block;
    width:100%;
    border-radius:8px;
    background:#10261f;
}
.site-footer{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.6rem;
    padding:1.4rem;
    border-top:1px solid var(--line);
    color:var(--muted);
}
.site-footer__start{
    display:grid;
    gap:.45rem;
}
.site-footer__brand,.site-footer__links,.site-footer__legal{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}
.site-footer__legal a{
    color:var(--muted);
    font-size:.9rem;
    font-weight:700;
}
.site-footer__legal a:hover{color:#d7ffe5}
.site-footer__links a{color:#d7ffe5;font-weight:800}
.site-footer__links a:hover{color:var(--green)}
.site-footer img{width:26px;height:26px}
.cookie-banner{
    position:fixed;
    left:1rem;
    right:1rem;
    bottom:1rem;
    z-index:60;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:1rem;
    padding:1rem 1.1rem;
    border:1px solid rgba(248,250,252,.16);
    border-radius:8px;
    background:rgba(6,17,15,.96);
    box-shadow:var(--shadow);
}
.cookie-banner[hidden]{display:none!important}
.cookie-banner__copy{
    display:grid;
    gap:.28rem;
    max-width:720px;
}
.cookie-banner__copy strong{font-size:1rem}
.cookie-banner__copy p{
    margin:0;
    color:var(--muted);
    line-height:1.5;
}
.cookie-banner__actions{
    display:flex;
    align-items:center;
    gap:.55rem;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.cookie-banner__actions a{
    color:#d7ffe5;
    font-weight:800;
}
.cookie-banner__button{width:auto}
.legal-page{
    min-height:100vh;
    padding:3rem 5rem 4.5rem;
    background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
}
.legal-page__hero{
    max-width:840px;
    margin:0 auto 2rem;
    padding:2rem 0 1.5rem;
}
.legal-page__meta{
    margin-top:1rem;
    color:var(--muted);
    font-weight:700;
}
.legal-page__content{
    max-width:980px;
    margin:0 auto;
    display:grid;
    gap:1rem;
}
.legal-block{
    padding:1.2rem 1.2rem 1rem;
    border:1px solid var(--line);
    border-radius:8px;
    background:linear-gradient(180deg,var(--surface) 0%,rgba(13,33,29,.68) 100%);
}
.legal-block h2{
    font-size:1.35rem;
    margin-bottom:.9rem;
}
.legal-block ul{
    margin:0;
    padding-left:1.15rem;
    color:var(--muted);
    display:grid;
    gap:.75rem;
    line-height:1.65;
}
@media (max-width:1180px){
    .site-nav,.hero,.section,.contact-section,.showcase-carousel,.map-section{padding-left:2rem;padding-right:2rem}
    .visual-story{padding-left:2rem;padding-right:2rem}
    .visual-card{grid-template-columns:92px minmax(0,1fr)}
    .visual-card img{width:92px}
}
@media (max-width:1080px){
    .site-nav__links{display:none}
    .nav-toggle{display:flex}
}
@media (max-width:900px){
    .hero{min-height:620px;padding-top:4rem}
    .hero__backdrop{background:linear-gradient(180deg,rgba(6,17,15,.92) 0%,rgba(6,17,15,.78) 100%),url("../img/logovistro.webp") center top 2rem/340px auto no-repeat,var(--bg)}
    .hero__content{padding-top:240px}
    h1{font-size:2.85rem}
    h2{font-size:2.15rem}
    .visual-story,.cost-section,.product-strip,.contact-section,.showcase-carousel,.map-section{grid-template-columns:1fr}
    .cost-points{grid-template-columns:1fr}
    .showcase-stage{min-height:360px}
    .showcase-dots{grid-column:auto}
    .visual-story{margin-top:0;padding-top:1rem}
    .module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .product-strip img{max-width:360px}
    .cost-section__visual{min-height:300px}
    .cookie-banner{flex-direction:column;align-items:flex-start}
    .cookie-banner__actions{justify-content:flex-start}
    .legal-page{padding:2.8rem 2rem 4rem}
    .pricing-grid{
        display:grid;
        grid-auto-flow:column;
        grid-auto-columns:minmax(270px,82vw);
        justify-content:start;
        overflow-x:auto;
        overscroll-behavior-inline:contain;
        scroll-snap-type:x mandatory;
        padding-bottom:.8rem;
    }
    .price-card{scroll-snap-align:center;min-width:0}
    .quote-builder{grid-template-columns:1fr}
    .quote-builder__modules{grid-template-columns:1fr}
}
@media (max-width:560px){
    .site-nav{padding:.7rem .85rem}
    .site-brand img{width:118px}
    .btn{width:100%;font-size:.9rem}
    .site-nav .btn{width:auto}
    .hero{min-height:auto;padding:2.5rem .9rem}
    .hero__content{padding-top:190px}
    h1{font-size:2.18rem}
    h2{font-size:1.75rem}
    .section,.contact-section,.showcase-carousel,.map-section{padding:2.8rem .9rem}
    .showcase-stage{min-height:280px}
    .showcase-nav{width:38px;height:38px;font-size:1.6rem}
    .cost-section__visual{min-height:260px}
    .visual-story{padding:.9rem}
    .visual-card{grid-template-columns:82px minmax(0,1fr)}
    .visual-card img{width:82px}
    .module-grid{grid-template-columns:1fr}
    .site-footer{justify-content:center;text-align:center}
    .site-footer__start,.site-footer__brand,.site-footer__links,.site-footer__legal{justify-content:center}
    .legal-page{padding:2.3rem .9rem 3rem}
    .cookie-banner{left:.7rem;right:.7rem;bottom:.7rem;padding:.9rem}
}
