/* =========================================================
   DB PDV · Home pública + autenticação
   CSS separado por área, com estilos da home isolados por .site-*
   Versão V4: visual mais leve, elegante, com rodapé e cards compactos.
   ========================================================= */

/* ------------------------------
   Autenticação
--------------------------------- */
.auth-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 105, 8, .12), transparent 26%),
        radial-gradient(circle at 88% 18%, rgba(37, 165, 91, .10), transparent 30%),
        linear-gradient(112deg, #ffe7cf 0%, #fffaf3 48%, #eef8ef 100%);
}

.auth-wrap {
    min-height: 100vh;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 24px;
    padding: 30px;
}

.auth-logo { color: var(--text); }

.auth-card {
    width: min(590px, 100%);
    background: rgba(255, 253, 250, .94);
    border: 1px solid rgba(235, 224, 213, .96);
    border-radius: 24px;
    box-shadow: 0 24px 62px rgba(37, 23, 20, .12);
    padding: 32px;
    backdrop-filter: blur(14px);
}

.auth-card h1 {
    margin: 30px 0 8px;
    font-size: 32px;
    letter-spacing: -.04em;
}

.auth-card p {
    margin: 0 0 28px;
    color: var(--muted);
    font-size: 18px;
}

.tabs {
    background: var(--cream);
    border-radius: 16px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 4px;
}

.tabs a {
    min-height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    color: var(--muted);
    font-weight: 800;
}

.tabs a.active {
    background: #fffdf8;
    color: var(--text);
    box-shadow: var(--shadow);
}

.or {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 12px;
    color: var(--muted);
    margin: 24px 0;
}

.or span { height: 1px; background: var(--line); }
.terms { color: var(--muted); }

/* ------------------------------
   Home pública V4
--------------------------------- */
.site-body.home-v4 {
    --home-text: #241513;
    --home-muted: #746760;
    --home-soft: #fff7ee;
    --home-line: rgba(226, 213, 202, .82);
    --home-panel: rgba(255, 253, 250, .84);
    --home-shadow: 0 22px 60px rgba(41, 24, 18, .09);
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--home-text);
    background:
        linear-gradient(180deg, #fffaf3 0%, #fffdf9 40%, #fff7ef 100%);
}

.site-body.home-v4::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: .42;
    background-image:
        linear-gradient(rgba(78, 55, 43, .05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(78, 55, 43, .05) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(180deg, #000, transparent 72%);
}

.page-glow {
    position: fixed;
    z-index: 0;
    pointer-events: none;
    filter: blur(8px);
    border-radius: 999px;
}

.glow-one {
    width: 430px;
    height: 430px;
    left: -160px;
    top: 120px;
    background: radial-gradient(circle, rgba(255, 105, 8, .16), transparent 66%);
}

.glow-two {
    width: 460px;
    height: 460px;
    right: -150px;
    top: 190px;
    background: radial-gradient(circle, rgba(22, 154, 77, .11), transparent 64%);
}

.site-main,
.site-header,
.site-footer,
.zap { position: relative; z-index: 1; }

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    padding: 14px clamp(16px, 4.4vw, 74px) 0;
}

.site-header-inner {
    min-height: 72px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 26px;
    padding: 12px 18px;
    border: 1px solid rgba(226, 213, 202, .76);
    border-radius: 0 0 28px 28px;
    background: rgba(255, 252, 247, .82);
    backdrop-filter: blur(18px);
    box-shadow: 0 18px 48px rgba(41, 24, 18, .07);
}

.site-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: max-content;
    color: var(--home-text);
}

.brand-bolt {
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    border-radius: 15px;
    background: linear-gradient(135deg, #ff7a1a, #ff5e00);
    color: #fff;
    font-weight: 800;
    box-shadow: 0 13px 28px rgba(255, 105, 8, .20);
}

.site-brand strong,
.site-brand small {
    display: block;
}

.site-brand strong {
    font-size: 22px;
    line-height: 1;
    letter-spacing: -.035em;
    font-weight: 760;
}

.site-brand small {
    margin-top: 4px;
    color: var(--home-muted);
    font-size: 11px;
    font-weight: 750;
    letter-spacing: .15em;
    text-transform: uppercase;
}

.site-nav {
    justify-self: end;
    display: flex;
    align-items: center;
    gap: clamp(16px, 2.1vw, 30px);
    font-weight: 720;
    color: #3d2c25;
}

.site-nav a,
.site-footer a {
    color: inherit;
    transition: color .18s ease, transform .18s ease;
}

.site-nav a:hover,
.site-footer a:hover {
    color: var(--orange);
}

.site-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.btn {
    border-radius: 16px;
    font-weight: 760;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn.orange {
    background: linear-gradient(135deg, #ff7a1a, #ff5e00);
    box-shadow: 0 14px 32px rgba(255, 105, 8, .22);
}

.btn.light,
.btn.ghost {
    background: rgba(255, 253, 250, .74);
    color: var(--home-text);
    border: 1px solid rgba(226, 213, 202, .88);
    box-shadow: 0 12px 26px rgba(41, 24, 18, .05);
}

.btn.xl {
    min-height: 52px;
    padding-inline: 24px;
    font-size: 15px;
}

.home-hero {
    display: grid;
    grid-template-columns: minmax(0, .87fr) minmax(500px, 1.13fr);
    align-items: center;
    gap: clamp(34px, 5vw, 74px);
    padding: clamp(54px, 6.5vw, 86px) clamp(18px, 4.8vw, 74px) 38px;
}

.home-hero-copy { max-width: 660px; }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    padding: 7px 11px;
    border: 1px solid rgba(255, 105, 8, .16);
    border-radius: 999px;
    background: rgba(255, 238, 220, .72);
    color: #e95300;
    font-size: 13px;
    font-weight: 760;
    letter-spacing: -.01em;
}

.eyebrow::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--orange);
    box-shadow: 0 0 0 4px rgba(255, 105, 8, .11);
}

.eyebrow.soft {
    background: rgba(255, 253, 250, .78);
}

.eyebrow.dark {
    border-color: rgba(255, 255, 255, .18);
    background: rgba(255, 255, 255, .08);
    color: #ffd9bf;
}

.home-hero h1,
.section-head h2,
.home-split h2,
.home-cta h2 {
    color: var(--home-text);
    letter-spacing: -.052em;
    line-height: 1.04;
    font-weight: 680;
}

.home-hero h1 {
    margin: 18px 0 18px;
    font-size: clamp(42px, 4.55vw, 70px);
}

.home-hero p,
.section-head p,
.home-split p,
.faq p {
    color: var(--home-muted);
    font-size: clamp(16px, 1.15vw, 19px);
    line-height: 1.64;
    font-weight: 430;
}

.home-hero p { margin: 0; max-width: 620px; }

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.hero-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.hero-proof span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(226, 213, 202, .76);
    border-radius: 999px;
    background: rgba(255, 253, 250, .62);
    color: #68564f;
    font-size: 13px;
    font-weight: 620;
}

.hero-proof b {
    color: var(--home-text);
    font-weight: 780;
}

.hero-showcase {
    min-width: 0;
}

.showcase-frame {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(226, 213, 202, .82);
    border-radius: 32px;
    background: rgba(255, 253, 250, .76);
    box-shadow: var(--home-shadow);
    backdrop-filter: blur(16px);
    transform: translateZ(0);
}

.showcase-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(110deg, transparent 18%, rgba(255,255,255,.42) 38%, transparent 58%);
    transform: translateX(-110%);
    animation: softShine 8s ease-in-out infinite;
}

@keyframes softShine {
    0%, 74% { transform: translateX(-115%); }
    100% { transform: translateX(115%); }
}

.showcase-top {
    min-height: 50px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(226, 213, 202, .80);
    background: rgba(255, 250, 244, .74);
}

.showcase-top span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #ff755d;
}

.showcase-top span:nth-child(2) { background: #eab744; }
.showcase-top span:nth-child(3) { background: #3ab86c; }

.showcase-top strong {
    margin-left: 8px;
    color: #6b5c55;
    font-size: 13px;
    font-weight: 720;
}

.showcase-body {
    min-height: 392px;
    display: grid;
    grid-template-columns: 78px 1fr 232px;
    background:
        linear-gradient(90deg, #261410 0 78px, transparent 78px),
        linear-gradient(135deg, #fffdf9, #fff6ec);
}

.showcase-menu {
    display: grid;
    align-content: start;
    justify-items: center;
    gap: 12px;
    padding: 18px 12px;
}

.showcase-menu b {
    width: 39px;
    height: 39px;
    display: grid;
    place-items: center;
    border-radius: 13px;
    background: linear-gradient(135deg, #ff7a1a, #ff5e00);
    color: #fff;
    font-size: 13px;
}

.showcase-menu i {
    display: block;
    width: 38px;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .24);
}

.showcase-menu i.is-active {
    height: 30px;
    background: rgba(255, 105, 8, .30);
}

.showcase-products {
    min-width: 0;
    padding: 20px;
}

.fake-input {
    height: 44px;
    display: flex;
    align-items: center;
    padding: 0 15px;
    border: 1px solid rgba(226, 213, 202, .88);
    border-radius: 15px;
    background: rgba(255, 255, 255, .78);
    color: #8a7b73;
    font-size: 14px;
    font-weight: 620;
}

.fake-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
}

.fake-grid article {
    min-height: 142px;
    display: grid;
    align-content: end;
    gap: 7px;
    padding: 13px;
    border: 1px solid rgba(226, 213, 202, .86);
    border-radius: 18px;
    background: rgba(255, 253, 250, .82);
    box-shadow: 0 14px 32px rgba(41, 24, 18, .055);
}

.fake-grid article.active {
    border-color: rgba(255, 105, 8, .70);
    box-shadow: 0 18px 38px rgba(255, 105, 8, .11);
}

.fake-grid em {
    width: 46px;
    height: 56px;
    margin: 0 auto 5px;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255, 105, 8, .14), rgba(255, 105, 8, .04));
    border: 1px solid rgba(226, 213, 202, .86);
}

.fake-grid strong {
    min-height: 28px;
    font-size: 13px;
    line-height: 1.1;
    font-weight: 720;
}

.fake-grid span {
    color: var(--orange);
    font-size: 19px;
    font-weight: 760;
}

.showcase-cart {
    min-width: 0;
    align-self: stretch;
    margin: 20px 20px 20px 0;
    padding: 16px;
    border: 1px solid rgba(226, 213, 202, .86);
    border-radius: 22px;
    background: rgba(255, 253, 250, .90);
    box-shadow: 0 18px 38px rgba(41, 24, 18, .065);
}

.cart-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 11px;
    border-bottom: 1px solid rgba(226, 213, 202, .78);
}

.cart-head strong { font-size: 20px; font-weight: 740; }
.cart-head small { color: var(--home-muted); font-weight: 650; }

.cart-row,
.cart-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #66564f;
    font-size: 14px;
    margin-top: 11px;
}

.cart-row b { font-weight: 720; }

.cart-total {
    align-items: flex-end;
    margin: 14px 0;
    padding-top: 13px;
    border-top: 1px dashed rgba(226, 213, 202, .88);
    color: var(--home-text);
    text-transform: uppercase;
}

.cart-total span { font-weight: 720; }
.cart-total strong {
    color: var(--orange);
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: -.05em;
}

.cart-payment {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid rgba(22, 154, 77, .18);
    border-radius: 16px;
    background: rgba(22, 154, 77, .06);
}

.cart-payment small {
    color: #08733c;
    font-size: 11px;
    font-weight: 780;
    text-transform: uppercase;
}

.cart-payment b { font-size: 17px; font-weight: 740; }
.cart-payment em { color: var(--green); font-style: normal; font-weight: 780; }

.showcase-cart button {
    width: 100%;
    min-height: 50px;
    margin-top: 12px;
    border: 0;
    border-radius: 16px;
    background: linear-gradient(135deg, #13a254, #087f3d);
    color: #fff;
    font-weight: 780;
    text-transform: uppercase;
    box-shadow: 0 16px 30px rgba(18, 161, 80, .20);
}

.home-mini-cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 13px;
    padding: 0 clamp(18px, 4.8vw, 74px) 42px;
}

.home-mini-cards article,
.feature-grid.compact article,
.steps-card.slim,
.modern-plans .plan,
.faq details {
    border: 1px solid rgba(226, 213, 202, .82);
    background: rgba(255, 253, 250, .72);
    box-shadow: 0 16px 42px rgba(41, 24, 18, .055);
    backdrop-filter: blur(12px);
}

.home-mini-cards article {
    min-height: 92px;
    display: grid;
    gap: 5px;
    padding: 17px 18px;
    border-radius: 22px;
    transition: transform .18s ease, box-shadow .18s ease;
}

.home-mini-cards article:hover,
.feature-grid.compact article:hover,
.modern-plans .plan:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 54px rgba(41, 24, 18, .075);
}

.home-mini-cards span {
    color: var(--orange);
    font-size: 12px;
    font-weight: 760;
}

.home-mini-cards strong {
    font-size: 18px;
    font-weight: 720;
    letter-spacing: -.025em;
}

.home-mini-cards small {
    color: var(--home-muted);
    font-size: 13px;
    line-height: 1.35;
    font-weight: 500;
}

.site-section {
    padding: clamp(58px, 7vw, 92px) clamp(18px, 4.8vw, 74px);
}

.section-head {
    max-width: 780px;
    margin-bottom: 30px;
}

.section-head.centered {
    max-width: 820px;
    margin-inline: auto;
    text-align: center;
}

.section-head.centered .eyebrow { margin-inline: auto; }
.section-head h2,
.home-split h2,
.home-cta h2 { font-size: clamp(30px, 3.25vw, 50px); }
.section-head h2 { margin: 15px 0 12px; }
.section-head p { margin: 0; }

.feature-grid.compact {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.feature-grid.compact article {
    min-height: 176px;
    display: grid;
    align-content: start;
    gap: 10px;
    padding: 22px;
    border-radius: 24px;
}

.feature-grid.compact i {
    width: fit-content;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(255, 105, 8, .08);
    color: var(--orange);
    font-size: 12px;
    font-style: normal;
    font-weight: 760;
}

.feature-grid.compact strong {
    color: var(--home-text);
    font-size: 20px;
    line-height: 1.14;
    font-weight: 720;
    letter-spacing: -.035em;
}

.feature-grid.compact span {
    color: var(--home-muted);
    font-size: 15px;
    line-height: 1.52;
    font-weight: 450;
}

.home-split {
    display: grid;
    grid-template-columns: minmax(0, .86fr) minmax(420px, 1fr);
    gap: clamp(30px, 5vw, 70px);
    align-items: center;
    padding: clamp(56px, 7vw, 90px) clamp(18px, 4.8vw, 74px);
    background: linear-gradient(180deg, rgba(255, 253, 250, .20), rgba(255, 246, 236, .52));
}

.split-copy p { max-width: 620px; }
.home-split .btn { margin-top: 18px; border-radius: 16px; }

.steps-card.slim {
    display: grid;
    gap: 12px;
    padding: 16px;
    border-radius: 28px;
}

.steps-card.slim article {
    display: grid;
    grid-template-columns: 44px 1fr;
    align-items: center;
    gap: 13px;
    padding: 15px;
    border: 1px solid rgba(226, 213, 202, .74);
    border-radius: 20px;
    background: rgba(255, 250, 244, .74);
}

.steps-card.slim b {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 15px;
    background: #281812;
    color: #fff;
    font-size: 17px;
    font-weight: 760;
}

.steps-card.slim strong,
.steps-card.slim small { display: block; }
.steps-card.slim strong { font-size: 17px; font-weight: 720; letter-spacing: -.025em; }
.steps-card.slim small { margin-top: 3px; color: var(--home-muted); font-size: 14px; line-height: 1.4; }

.plans-section { background: rgba(255, 253, 250, .28); }

.modern-plans.small-plans {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 15px;
}

.modern-plans .plan {
    position: relative;
    display: grid;
    align-content: start;
    gap: 13px;
    padding: 24px;
    border-radius: 26px;
}

.modern-plans .plan.featured {
    border-color: rgba(255, 105, 8, .42);
    box-shadow: 0 24px 62px rgba(255, 105, 8, .10);
}

.modern-plans h3 {
    margin: 0;
    color: var(--home-text);
    font-size: 25px;
    font-weight: 720;
    letter-spacing: -.045em;
}

.modern-plans p {
    margin: 0;
    color: var(--home-muted);
    line-height: 1.48;
}

.modern-plans .price {
    color: var(--home-text);
    font-size: 35px;
    font-weight: 760;
    letter-spacing: -.055em;
}

.modern-plans .price small {
    margin-left: 4px;
    color: var(--home-muted);
    font-size: 14px;
    letter-spacing: 0;
    font-weight: 600;
}

.modern-plans ul {
    display: grid;
    gap: 9px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.modern-plans li {
    display: flex;
    gap: 8px;
    align-items: center;
    color: #5f514a;
    font-size: 14px;
    font-weight: 600;
}

.modern-plans li::before {
    content: "✓";
    width: 18px;
    height: 18px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: rgba(37, 165, 91, .12);
    color: var(--green);
    font-size: 12px;
    font-weight: 780;
}

.modern-plans .popular {
    width: fit-content;
    padding: 7px 10px;
    border-radius: 999px;
    background: #281812;
    color: #fff;
    font-size: 12px;
    font-weight: 720;
}

.modern-plans .full { width: 100%; border-radius: 15px; }

.dynamic-plans .plan-limits {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: -2px;
}

.dynamic-plans .plan-limits span {
    padding: 7px 9px;
    border: 1px solid rgba(226, 213, 202, .76);
    border-radius: 999px;
    background: rgba(255, 250, 244, .68);
    color: #6b5c55;
    font-size: 12px;
    font-weight: 620;
    line-height: 1;
}

.dynamic-plans .plan-modules-title {
    color: var(--home-text);
    font-size: 13px;
    font-weight: 680;
    letter-spacing: -.01em;
}

.dynamic-plans .plan-module-list {
    gap: 8px;
}

.dynamic-plans .plan-module-list li {
    font-size: 13px;
    font-weight: 580;
}

.dynamic-plans .plan p {
    font-size: 14px;
}

.dynamic-plans .plan .price {
    font-size: clamp(28px, 3vw, 34px);
}


.home-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin: 12px clamp(18px, 4.8vw, 74px) 0;
    padding: clamp(28px, 4vw, 48px);
    border-radius: 32px;
    background:
        radial-gradient(circle at 12% 10%, rgba(255,255,255,.15), transparent 28%),
        linear-gradient(135deg, #251512, #3a2119);
    color: #fff;
    box-shadow: 0 26px 70px rgba(41, 24, 18, .18);
}

.home-cta h2 {
    max-width: 750px;
    margin: 14px 0 0;
    color: #fff;
}

.home-cta .btn.orange { flex: 0 0 auto; }

.faq-list {
    max-width: 900px;
    margin-inline: auto;
    display: grid;
    gap: 11px;
}

.faq details {
    border-radius: 20px;
    padding: 18px 22px;
}

.faq summary {
    cursor: pointer;
    color: var(--home-text);
    font-size: 17px;
    font-weight: 720;
}

.faq p { margin: 10px 0 0; }

.site-footer {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 22px;
    margin: 0 clamp(16px, 4.4vw, 74px) 24px;
    padding: 22px;
    border: 1px solid rgba(226, 213, 202, .82);
    border-radius: 28px;
    background: rgba(255, 253, 250, .72);
    box-shadow: 0 18px 48px rgba(41, 24, 18, .06);
    color: var(--home-muted);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--home-text);
}

.footer-brand strong,
.footer-brand small { display: block; }
.footer-brand strong { font-weight: 760; font-size: 18px; }
.footer-brand small { color: var(--home-muted); font-size: 12px; }

.site-footer nav {
    justify-self: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    color: #4c3d36;
    font-weight: 620;
}

.site-footer p {
    margin: 0;
    text-align: right;
    font-size: 13px;
}

.zap {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 60;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, #1faa59, #0c8a43);
    color: #fff;
    font-size: 14px;
    font-weight: 760;
    box-shadow: 0 16px 34px rgba(31, 170, 89, .28);
}

/* ------------------------------
   Responsividade
--------------------------------- */
@media (max-width: 1180px) {
    .site-header-inner {
        grid-template-columns: auto auto;
    }

    .site-nav {
        order: 3;
        grid-column: 1 / -1;
        justify-self: start;
        width: 100%;
        overflow-x: auto;
        padding-bottom: 4px;
    }

    .home-hero {
        grid-template-columns: 1fr;
        padding-top: 44px;
    }

    .hero-showcase {
        max-width: 980px;
        width: 100%;
    }

    .home-mini-cards,
    .feature-grid.compact,
    .modern-plans.small-plans {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-split {
        grid-template-columns: 1fr;
    }

    .site-footer {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .footer-brand,
    .site-footer nav {
        justify-self: center;
    }

    .site-footer p {
        text-align: center;
    }
}

@media (max-width: 820px) {
    .site-header {
        padding: 10px 12px 0;
    }

    .site-header-inner {
        grid-template-columns: 1fr auto;
        gap: 12px;
        border-radius: 0 0 22px 22px;
        padding: 10px 12px;
    }

    .site-brand .brand-bolt,
    .brand-bolt {
        width: 40px;
        height: 40px;
        border-radius: 13px;
    }

    .site-brand strong {
        font-size: 19px;
    }

    .site-actions {
        justify-self: end;
    }

    .site-actions .btn.ghost {
        display: none;
    }

    .site-actions .btn.orange {
        min-height: 44px;
        padding-inline: 14px;
    }

    .site-nav {
        gap: 18px;
        font-size: 14px;
    }

    .home-hero {
        padding: 32px 16px 30px;
    }

    .home-hero h1 {
        font-size: clamp(36px, 10.5vw, 52px);
        letter-spacing: -.055em;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .hero-proof span {
        flex: 1 1 145px;
        justify-content: center;
    }

    .showcase-frame {
        border-radius: 24px;
    }

    .showcase-body {
        grid-template-columns: 58px 1fr;
        min-height: auto;
        background:
            linear-gradient(90deg, #261410 0 58px, transparent 58px),
            linear-gradient(135deg, #fffdf9, #fff6ec);
    }

    .showcase-menu {
        padding: 14px 9px;
    }

    .showcase-menu b {
        width: 35px;
        height: 35px;
        border-radius: 12px;
    }

    .showcase-menu i {
        width: 30px;
    }

    .showcase-products {
        padding: 14px;
    }

    .fake-grid {
        grid-template-columns: 1fr;
        gap: 9px;
        margin-top: 12px;
    }

    .fake-grid article {
        min-height: 92px;
        grid-template-columns: 44px 1fr auto;
        align-items: center;
        align-content: center;
        gap: 10px;
    }

    .fake-grid em {
        margin: 0;
        width: 38px;
        height: 46px;
    }

    .fake-grid strong {
        min-height: auto;
    }

    .showcase-cart {
        grid-column: 1 / -1;
        margin: 0 12px 14px;
    }

    .home-mini-cards,
    .feature-grid.compact,
    .modern-plans.small-plans {
        grid-template-columns: 1fr;
    }

    .home-mini-cards {
        padding: 0 16px 26px;
    }

    .site-section,
    .home-split {
        padding: 46px 16px;
    }

    .feature-grid.compact article {
        min-height: auto;
        padding: 20px;
        border-radius: 22px;
    }

    .home-cta {
        margin: 6px 16px 0;
        flex-direction: column;
        align-items: flex-start;
        border-radius: 26px;
    }

    .home-cta .btn {
        width: 100%;
    }

    .site-footer {
        margin: 0 16px 80px;
        border-radius: 24px;
    }

    .zap {
        right: 14px;
        bottom: 14px;
        min-height: 46px;
        padding: 0 16px;
        font-size: 13px;
    }
}

@media (max-width: 520px) {
    .site-header-inner {
        grid-template-columns: 1fr;
    }

    .site-actions,
    .site-actions .btn.orange {
        width: 100%;
    }

    .site-nav {
        order: 2;
        padding-bottom: 6px;
    }

    .site-actions {
        order: 3;
    }

    .home-hero h1 {
        font-size: clamp(34px, 10.6vw, 43px);
        line-height: 1.05;
    }

    .home-hero p,
    .section-head p,
    .home-split p,
    .faq p {
        font-size: 15.5px;
    }

    .showcase-top strong {
        display: none;
    }

    .showcase-body {
        grid-template-columns: 1fr;
        background: linear-gradient(135deg, #fffdf9, #fff6ec);
    }

    .showcase-menu {
        display: none;
    }

    .fake-grid article {
        grid-template-columns: 42px 1fr;
    }

    .fake-grid span {
        grid-column: 2;
    }

    .cart-total strong {
        font-size: 26px;
    }

    .section-head h2,
    .home-split h2,
    .home-cta h2 {
        font-size: clamp(28px, 8vw, 38px);
    }

    .steps-card.slim article {
        grid-template-columns: 40px 1fr;
        padding: 13px;
    }

    .steps-card.slim b {
        width: 40px;
        height: 40px;
        border-radius: 14px;
    }
}

/* ------------------------------
   Autenticação V2 · login/cadastro/recuperação
   Mesmo acabamento visual da home V4, sem botão Google falso.
--------------------------------- */
.auth-body.auth-v2 {
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--home-text, #241513);
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 105, 8, .16), transparent 30%),
        radial-gradient(circle at 88% 16%, rgba(22, 154, 77, .12), transparent 32%),
        linear-gradient(145deg, #fff8ef 0%, #fffdf9 48%, #eff8ef 100%);
}

.auth-body.auth-v2::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: .34;
    background-image:
        linear-gradient(rgba(78, 55, 43, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(78, 55, 43, .045) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(180deg, #000, transparent 76%);
}

.auth-glow {
    position: fixed;
    z-index: 0;
    pointer-events: none;
    border-radius: 999px;
    filter: blur(8px);
}

.auth-glow-one {
    width: 430px;
    height: 430px;
    left: -160px;
    top: 140px;
    background: radial-gradient(circle, rgba(255, 105, 8, .17), transparent 66%);
}

.auth-glow-two {
    width: 440px;
    height: 440px;
    right: -140px;
    top: 110px;
    background: radial-gradient(circle, rgba(22, 154, 77, .12), transparent 64%);
}

.auth-shell {
    position: relative;
    z-index: 1;
    width: min(1180px, calc(100% - 32px));
    min-height: 100vh;
    margin: 0 auto;
    display: grid;
    align-content: center;
    gap: 22px;
    padding: 36px 0;
}

.auth-brand {
    width: fit-content;
    margin-inline: auto;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--home-text, #241513);
}

.auth-brand strong,
.auth-brand small {
    display: block;
}

.auth-brand strong {
    font-size: 26px;
    line-height: 1;
    letter-spacing: -.04em;
    font-weight: 760;
}

.auth-brand small {
    margin-top: 4px;
    color: var(--home-muted, #746760);
    font-size: 11px;
    font-weight: 760;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.auth-panel {
    display: grid;
    grid-template-columns: minmax(0, .86fr) minmax(420px, .74fr);
    gap: 0;
    overflow: hidden;
    border: 1px solid rgba(226, 213, 202, .82);
    border-radius: 34px;
    background: rgba(255, 253, 250, .72);
    box-shadow: 0 30px 86px rgba(41, 24, 18, .11);
    backdrop-filter: blur(18px);
}

.auth-side {
    min-height: 620px;
    display: grid;
    align-content: center;
    padding: clamp(36px, 5vw, 64px);
    background:
        radial-gradient(circle at 18% 18%, rgba(255, 105, 8, .14), transparent 34%),
        linear-gradient(135deg, rgba(255, 246, 236, .84), rgba(255, 253, 250, .62));
    border-right: 1px solid rgba(226, 213, 202, .72);
}

.auth-side h1 {
    max-width: 560px;
    margin: 18px 0 16px;
    color: var(--home-text, #241513);
    font-size: clamp(38px, 4vw, 58px);
    line-height: 1.03;
    letter-spacing: -.055em;
    font-weight: 680;
}

.auth-side p {
    max-width: 560px;
    margin: 0;
    color: var(--home-muted, #746760);
    font-size: 17px;
    line-height: 1.65;
    font-weight: 430;
}

.auth-benefits {
    display: grid;
    gap: 10px;
    margin-top: 30px;
}

.auth-benefits span {
    width: min(420px, 100%);
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 48px;
    padding: 10px 14px;
    border: 1px solid rgba(226, 213, 202, .76);
    border-radius: 18px;
    background: rgba(255, 253, 250, .62);
    color: #5d4c44;
    font-size: 14px;
    font-weight: 620;
}

.auth-benefits b {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 11px;
    background: #281812;
    color: #fff;
    font-size: 12px;
    font-weight: 760;
}

.auth-card.auth-card-v2 {
    width: 100%;
    min-height: 620px;
    display: grid;
    align-content: center;
    padding: clamp(28px, 4vw, 50px);
    border: 0;
    border-radius: 0;
    background: rgba(255, 253, 250, .88);
    box-shadow: none;
    backdrop-filter: none;
}

.auth-tabs {
    margin-bottom: 28px;
    background: rgba(246, 238, 228, .82);
    border: 1px solid rgba(226, 213, 202, .72);
}

.auth-tabs a {
    font-weight: 760;
}

.back-login {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    margin-bottom: 24px;
    color: #5d4c44;
    font-weight: 720;
    transition: color .18s ease, transform .18s ease;
}

.back-login:hover {
    color: var(--orange);
    transform: translateX(-2px);
}

.auth-title-block h2 {
    margin: 0 0 8px;
    color: var(--home-text, #241513);
    font-size: clamp(30px, 3vw, 40px);
    line-height: 1.08;
    letter-spacing: -.045em;
    font-weight: 680;
}

.auth-title-block p {
    margin: 0 0 26px;
    color: var(--home-muted, #746760);
    font-size: 16.5px;
    line-height: 1.55;
    font-weight: 430;
}

.auth-form {
    gap: 15px;
}

.auth-form label {
    color: #4f3f38;
    font-size: 13.5px;
    font-weight: 720;
}

.auth-form input,
.reset-box input {
    min-height: 52px;
    margin-top: 7px;
    border-radius: 16px;
    border: 1px solid rgba(226, 213, 202, .90);
    background: rgba(255, 253, 250, .92);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.auth-form input:focus,
.reset-box input:focus {
    border-color: rgba(255, 105, 8, .62);
    box-shadow: 0 0 0 4px rgba(255, 105, 8, .10);
    background: #fff;
}

.auth-form .btn.full,
.reset-box .btn.full {
    min-height: 54px;
    margin-top: 3px;
    border-radius: 17px;
    font-weight: 760;
}

.auth-row-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: -4px;
}

.auth-row-link a {
    color: #ef5d00;
    font-size: 14px;
    font-weight: 720;
}

.auth-row-link a:hover {
    text-decoration: underline;
}

.toast {
    margin: 0 0 18px;
    border-radius: 16px;
    font-weight: 650;
}

.toast.success {
    border: 1px solid rgba(22, 154, 77, .20);
    background: rgba(22, 154, 77, .08);
    color: #08733c;
}

.toast.danger {
    border: 1px solid rgba(196, 32, 55, .22);
    background: rgba(196, 32, 55, .08);
    color: #a70f27;
}

.reset-box {
    display: grid;
    gap: 12px;
    margin-top: 18px;
    padding: 16px;
    border: 1px solid rgba(255, 105, 8, .20);
    border-radius: 20px;
    background: rgba(255, 238, 220, .42);
}

.reset-box strong {
    color: var(--home-text, #241513);
    font-size: 15px;
    font-weight: 760;
}

.reset-box p {
    margin: 0;
    color: var(--home-muted, #746760);
    font-size: 13.5px;
    line-height: 1.45;
}

.reset-box input {
    width: 100%;
    padding-inline: 14px;
    color: #5d4c44;
    font-size: 13px;
}

.auth-v2 .terms {
    margin: 0;
    color: var(--home-muted, #746760);
    text-align: center;
    font-size: 13.5px;
}

.auth-v2 .btn.cream {
    background: rgba(255, 253, 250, .80);
    color: var(--home-text, #241513);
    border: 1px solid rgba(226, 213, 202, .88);
    box-shadow: 0 12px 26px rgba(41, 24, 18, .05);
}

@media (max-width: 980px) {
    .auth-shell {
        width: min(720px, calc(100% - 28px));
        padding: 24px 0;
    }

    .auth-panel {
        grid-template-columns: 1fr;
        border-radius: 28px;
    }

    .auth-side {
        min-height: auto;
        padding: 30px;
        border-right: 0;
        border-bottom: 1px solid rgba(226, 213, 202, .72);
    }

    .auth-side h1 {
        font-size: clamp(32px, 7vw, 44px);
    }

    .auth-benefits {
        grid-template-columns: 1fr;
        margin-top: 22px;
    }

    .auth-card.auth-card-v2 {
        min-height: auto;
        padding: 30px;
    }
}

@media (max-width: 560px) {
    .auth-shell {
        width: min(100% - 20px, 520px);
        gap: 16px;
        padding: 18px 0 24px;
    }

    .auth-brand strong {
        font-size: 22px;
    }

    .auth-panel {
        border-radius: 24px;
    }

    .auth-side {
        padding: 24px 20px;
    }

    .auth-side h1 {
        margin: 14px 0 12px;
        font-size: clamp(30px, 9.4vw, 38px);
    }

    .auth-side p {
        font-size: 15px;
    }

    .auth-benefits span {
        min-height: 44px;
        font-size: 13px;
    }

    .auth-card.auth-card-v2 {
        padding: 22px 18px 24px;
    }

    .auth-title-block h2 {
        font-size: 28px;
    }

    .auth-title-block p {
        font-size: 15px;
    }

    .auth-tabs a {
        min-height: 40px;
        font-size: 14px;
    }

    .auth-form input,
    .reset-box input {
        min-height: 50px;
    }

    .auth-v2 .terms {
        padding-inline: 8px;
        font-size: 12.5px;
    }
}

/* =========================================================
   Ajuste solicitado: Login/Cadastro compacto
   Reduz o tamanho geral do painel para caber melhor em notebook,
   mantendo o mesmo visual da home e sem alterar regras do sistema.
   ========================================================= */
.auth-body.auth-v2 {
    min-height: 100vh;
}

.auth-shell {
    width: min(1040px, calc(100% - 42px));
    gap: 16px;
    padding: 24px 0 22px;
}

.auth-brand {
    transform: scale(.92);
    transform-origin: center;
}

.auth-panel {
    grid-template-columns: minmax(0, .82fr) minmax(390px, .68fr);
    max-width: 1040px;
    margin-inline: auto;
    border-radius: 28px;
    box-shadow: 0 22px 58px rgba(41, 24, 18, .095);
}

.auth-side {
    min-height: 500px;
    padding: clamp(28px, 4vw, 48px);
}

.auth-side h1 {
    max-width: 470px;
    margin: 14px 0 12px;
    font-size: clamp(32px, 3.25vw, 46px);
    line-height: 1.04;
    letter-spacing: -.052em;
    font-weight: 640;
}

.auth-side p {
    max-width: 470px;
    font-size: 15.5px;
    line-height: 1.56;
}

.auth-benefits {
    gap: 8px;
    margin-top: 22px;
}

.auth-benefits span {
    width: min(380px, 100%);
    min-height: 42px;
    padding: 8px 12px;
    border-radius: 15px;
    font-size: 13.25px;
    font-weight: 590;
}

.auth-benefits b {
    width: 27px;
    height: 27px;
    border-radius: 9px;
    font-size: 11px;
}

.auth-card.auth-card-v2 {
    min-height: 500px;
    padding: clamp(24px, 3vw, 38px);
}

.auth-tabs {
    margin-bottom: 22px;
    border-radius: 15px;
}

.tabs a,
.auth-tabs a {
    min-height: 39px;
    border-radius: 13px;
    font-size: 13.5px;
}

.auth-title-block h2 {
    margin-bottom: 6px;
    font-size: clamp(27px, 2.45vw, 34px);
    font-weight: 640;
}

.auth-title-block p {
    margin-bottom: 20px;
    font-size: 15.25px;
    line-height: 1.46;
}

.auth-form {
    gap: 12px;
}

.auth-form label {
    font-size: 13px;
    font-weight: 680;
}

.auth-form input,
.reset-box input {
    min-height: 47px;
    margin-top: 6px;
    border-radius: 14px;
}

.auth-form .btn.full,
.reset-box .btn.full {
    min-height: 49px;
    border-radius: 15px;
}

.auth-row-link {
    margin-top: -2px;
}

.auth-v2 .terms {
    font-size: 12.8px;
}

@media (max-width: 1180px) {
    .auth-shell {
        width: min(960px, calc(100% - 32px));
    }

    .auth-panel {
        max-width: 960px;
        grid-template-columns: minmax(0, .78fr) minmax(360px, .7fr);
    }

    .auth-side,
    .auth-card.auth-card-v2 {
        min-height: 480px;
    }
}

@media (max-width: 980px) {
    .auth-shell {
        width: min(680px, calc(100% - 26px));
        padding: 18px 0 20px;
    }

    .auth-brand {
        transform: none;
    }

    .auth-panel {
        grid-template-columns: 1fr;
        border-radius: 24px;
    }

    .auth-side {
        min-height: auto;
        padding: 24px;
    }

    .auth-side h1 {
        max-width: none;
        font-size: clamp(28px, 6vw, 38px);
    }

    .auth-benefits {
        grid-template-columns: 1fr;
        margin-top: 18px;
    }

    .auth-card.auth-card-v2 {
        min-height: auto;
        padding: 24px;
    }
}

@media (max-width: 560px) {
    .auth-shell {
        width: min(100% - 18px, 500px);
        gap: 12px;
        padding: 14px 0 18px;
    }

    .auth-panel {
        border-radius: 20px;
    }

    .auth-side {
        padding: 20px 16px;
    }

    .auth-side h1 {
        font-size: clamp(27px, 8.2vw, 33px);
    }

    .auth-side p {
        font-size: 14.25px;
    }

    .auth-benefits span {
        min-height: 40px;
        font-size: 12.5px;
    }

    .auth-card.auth-card-v2 {
        padding: 20px 16px;
    }

    .auth-title-block h2 {
        font-size: 26px;
    }

    .auth-title-block p {
        margin-bottom: 16px;
    }

    .auth-form input,
    .reset-box input {
        min-height: 46px;
    }
}

/* =========================================================
   Ajuste PWA/Login: preserva o layout do login mesmo após a
   instalação como app e evita quebra em cache antigo do Chrome.
   ========================================================= */
.auth-body.auth-v2 {
    width: 100%;
    min-height: 100svh;
    display: block;
}

.auth-body.auth-v2 .auth-shell {
    width: min(1040px, calc(100% - 42px));
    min-height: 100svh;
    margin-inline: auto;
    display: grid;
    place-content: center;
    gap: 16px;
    padding: 20px 0;
}

.auth-body.auth-v2 .auth-brand {
    justify-self: center;
}

.auth-body.auth-v2 .auth-panel {
    width: 100%;
    max-width: 1040px;
    margin-inline: auto;
}

.pwa-standalone .auth-body.auth-v2,
.auth-body.auth-v2.pwa-standalone {
    padding-top: 0;
}

@media (min-width: 981px) {
    .auth-body.auth-v2 .auth-panel {
        display: grid;
        grid-template-columns: minmax(0, .82fr) minmax(390px, .68fr);
    }
}

@media (max-width: 980px) {
    .auth-body.auth-v2 .auth-shell {
        width: min(680px, calc(100% - 26px));
        place-content: start center;
        padding-top: 18px;
    }

    .auth-body.auth-v2 .auth-panel {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .auth-body.auth-v2 .auth-shell {
        width: min(100% - 18px, 500px);
        padding-top: 14px;
    }
}

/* Ajuste final da home: remove barra/elemento solto e deixa menu mobile funcional */
.site-body.home-v4 .site-menu-toggle {
    display: none !important;
    appearance: none;
    -webkit-appearance: none;
    width: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 1px solid rgba(226, 213, 202, .88) !important;
    border-radius: 14px !important;
    background: rgba(255, 253, 250, .86) !important;
    box-shadow: 0 10px 22px rgba(41, 24, 18, .06) !important;
    color: var(--home-text, #241513) !important;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
    overflow: hidden;
}
.site-body.home-v4 .site-menu-toggle span {
    display: block !important;
    width: 18px !important;
    height: 2px !important;
    min-height: 2px !important;
    border-radius: 999px !important;
    background: currentColor !important;
    transition: transform .18s ease, opacity .18s ease;
}
.site-body.home-v4 .site-header-inner.menu-open .site-menu-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.site-body.home-v4 .site-header-inner.menu-open .site-menu-toggle span:nth-child(2) { opacity: 0; }
.site-body.home-v4 .site-header-inner.menu-open .site-menu-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.site-body.home-v4 .home-hero h1 { font-size: clamp(38px, 4.2vw, 62px); font-weight: 660; }
.site-body.home-v4 .feature-grid.compact strong,
.site-body.home-v4 .home-mini-cards strong,
.site-body.home-v4 .steps-card strong { font-weight: 650; }

@media (max-width: 820px) {
    .site-body.home-v4 .site-header { padding: 10px 12px 0; }
    .site-body.home-v4 .site-header-inner,
    .site-body.home-v4 .site-header-inner.menu-open {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 10px;
        border-radius: 22px;
        padding: 10px;
    }
    .site-body.home-v4 .site-menu-toggle {
        display: inline-flex !important;
        grid-column: 2;
        grid-row: 1;
        justify-self: end;
    }
    .site-body.home-v4 .site-brand {
        grid-column: 1;
        grid-row: 1;
        min-width: 0;
    }
    .site-body.home-v4 .site-nav,
    .site-body.home-v4 .site-actions {
        display: none !important;
    }
    .site-body.home-v4 .site-header-inner.menu-open .site-nav {
        grid-column: 1 / -1;
        grid-row: 2;
        width: 100%;
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 6px;
        padding: 10px 0 0;
        font-size: 14px;
        font-weight: 600;
    }
    .site-body.home-v4 .site-header-inner.menu-open .site-nav a {
        min-height: 42px;
        display: flex;
        align-items: center;
        padding: 0 12px;
        border: 1px solid rgba(226, 213, 202, .72);
        border-radius: 14px;
        background: rgba(255, 253, 250, .64);
    }
    .site-body.home-v4 .site-header-inner.menu-open .site-actions {
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        padding-top: 8px;
    }
    .site-body.home-v4 .site-header-inner.menu-open .site-actions .btn {
        width: 100%;
        justify-content: center;
        min-height: 42px;
        padding-inline: 12px;
    }
}
@media (max-width: 520px) {
    .site-body.home-v4 .site-brand strong { font-size: 18px; }
    .site-body.home-v4 .site-brand small { font-size: 10px; letter-spacing: .08em; }
    .site-body.home-v4 .site-header-inner.menu-open .site-actions { grid-template-columns: 1fr; }
    .site-body.home-v4 .home-hero h1 { font-size: 36px; }
}

/* =========================================================
   Home pública V5 · refinamento visual
   Logo própria DB PDV, tipografia menor e rodapé alinhado.
   ========================================================= */
.site-body.home-v4 {
    --home-text: #221512;
    --home-muted: #6e615b;
    --home-line: rgba(222, 209, 199, .88);
    --home-panel: rgba(255, 253, 250, .88);
}

.site-body.home-v4 .site-main,
.site-body.home-v4 .site-header,
.site-body.home-v4 .site-footer {
    position: relative;
    z-index: 1;
}

.site-body.home-v4 .site-header {
    padding-top: 12px;
}

.site-body.home-v4 .site-header-inner {
    min-height: 66px;
    gap: 22px;
    padding: 10px 16px;
    border-radius: 0 0 24px 24px;
}

.site-body.home-v4 .site-brand {
    gap: 10px;
}

.site-body.home-v4 .brand-mark {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 46px;
}

.site-body.home-v4 .brand-mark svg {
    width: 100%;
    height: 100%;
    display: block;
    filter: drop-shadow(0 10px 22px rgba(41, 24, 18, .10));
}

.site-body.home-v4 .site-brand strong {
    font-size: 20px;
    letter-spacing: -.03em;
}

.site-body.home-v4 .site-brand small,
.site-body.home-v4 .footer-brand small {
    margin-top: 3px;
    font-size: 10px;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.site-body.home-v4 .site-nav {
    gap: 18px;
    font-size: 14px;
    font-weight: 650;
}

.site-body.home-v4 .site-actions {
    gap: 8px;
}

.site-body.home-v4 .btn {
    min-height: 42px;
    padding-inline: 16px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 700;
}

.site-body.home-v4 .btn.xl {
    min-height: 46px;
    padding-inline: 18px;
    font-size: 14px;
}

.site-body.home-v4 .btn.orange {
    box-shadow: 0 12px 26px rgba(255, 105, 8, .18);
}

.site-body.home-v4 .btn.whatsapp {
    background: linear-gradient(135deg, #1faa59, #0c8a43);
    color: #fff;
    border: 0;
    box-shadow: 0 12px 28px rgba(31, 170, 89, .20);
}

.site-body.home-v4 .home-hero {
    grid-template-columns: minmax(0, .92fr) minmax(420px, 1.08fr);
    gap: clamp(28px, 4vw, 48px);
    padding: clamp(34px, 4.8vw, 58px) clamp(18px, 4vw, 64px) 26px;
}

.site-body.home-v4 .home-hero-copy {
    max-width: 590px;
}

.site-body.home-v4 .eyebrow {
    padding: 6px 10px;
    font-size: 12px;
}

.site-body.home-v4 .eyebrow::before {
    width: 6px;
    height: 6px;
}

.site-body.home-v4 .home-hero h1 {
    margin: 14px 0 14px;
    font-size: clamp(34px, 3.55vw, 48px);
    line-height: 1.06;
    font-weight: 680;
}

.site-body.home-v4 .home-hero p,
.site-body.home-v4 .section-head p,
.site-body.home-v4 .home-split p,
.site-body.home-v4 .faq p {
    font-size: 15px;
    line-height: 1.58;
}

.site-body.home-v4 .hero-actions {
    gap: 10px;
    margin-top: 20px;
}

.site-body.home-v4 .hero-proof {
    gap: 8px;
    margin-top: 18px;
}

.site-body.home-v4 .hero-proof span {
    min-height: 30px;
    padding: 0 11px;
    font-size: 12px;
}

.site-body.home-v4 .showcase-frame {
    border-radius: 26px;
}

.site-body.home-v4 .showcase-top {
    min-height: 44px;
    padding: 0 14px;
}

.site-body.home-v4 .showcase-top strong {
    font-size: 12px;
}

.site-body.home-v4 .showcase-body {
    min-height: 340px;
    grid-template-columns: 68px 1fr 216px;
}

.site-body.home-v4 .showcase-menu {
    gap: 10px;
    padding: 16px 10px;
}

.site-body.home-v4 .showcase-menu b {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    font-size: 12px;
}

.site-body.home-v4 .showcase-products {
    padding: 16px;
}

.site-body.home-v4 .showcase-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 12px;
}

.site-body.home-v4 .showcase-stats article {
    display: grid;
    gap: 3px;
    padding: 10px 11px;
    border: 1px solid rgba(226, 213, 202, .86);
    border-radius: 14px;
    background: rgba(255, 255, 255, .72);
}

.site-body.home-v4 .showcase-stats small {
    color: var(--home-muted);
    font-size: 11px;
    font-weight: 620;
}

.site-body.home-v4 .showcase-stats strong {
    font-size: 13px;
    line-height: 1.2;
    font-weight: 730;
}

.site-body.home-v4 .fake-input {
    height: 40px;
    padding: 0 13px;
    border-radius: 13px;
    font-size: 13px;
}

.site-body.home-v4 .fake-grid {
    gap: 10px;
    margin-top: 14px;
}

.site-body.home-v4 .fake-grid article {
    min-height: 120px;
    padding: 11px;
    border-radius: 16px;
}

.site-body.home-v4 .fake-grid em {
    width: 40px;
    height: 48px;
    border-radius: 12px;
}

.site-body.home-v4 .fake-grid strong {
    font-size: 12px;
}

.site-body.home-v4 .fake-grid span {
    font-size: 16px;
}

.site-body.home-v4 .showcase-cart {
    margin: 16px 16px 16px 0;
    padding: 14px;
    border-radius: 20px;
}

.site-body.home-v4 .cart-head strong {
    font-size: 17px;
}

.site-body.home-v4 .cart-head small,
.site-body.home-v4 .cart-row,
.site-body.home-v4 .cart-total,
.site-body.home-v4 .cart-payment b,
.site-body.home-v4 .cart-payment em {
    font-size: 13px;
}

.site-body.home-v4 .cart-total strong {
    font-size: 24px;
}

.site-body.home-v4 .showcase-cart button {
    min-height: 44px;
    border-radius: 14px;
    font-size: 13px;
}

.site-body.home-v4 .home-mini-cards {
    gap: 12px;
    padding: 0 clamp(18px, 4vw, 64px) 30px;
}

.site-body.home-v4 .home-mini-cards article {
    min-height: 84px;
    padding: 15px 16px;
    border-radius: 18px;
}

.site-body.home-v4 .home-mini-cards strong {
    font-size: 16px;
}

.site-body.home-v4 .home-mini-cards small {
    font-size: 12.5px;
}

.site-body.home-v4 .site-section,
.site-body.home-v4 .home-split {
    padding: clamp(42px, 5vw, 64px) clamp(18px, 4vw, 64px);
}

.site-body.home-v4 .compact-section {
    padding-top: 28px;
}

.site-body.home-v4 .section-head {
    margin-bottom: 22px;
}

.site-body.home-v4 .narrow-head {
    max-width: 740px;
}

.site-body.home-v4 .section-head h2,
.site-body.home-v4 .home-split h2,
.site-body.home-v4 .home-cta h2 {
    font-size: clamp(26px, 2.75vw, 36px);
    line-height: 1.1;
}

.site-body.home-v4 .section-head h2 {
    margin: 12px 0 10px;
}

.site-body.home-v4 .trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.site-body.home-v4 .trust-grid article,
.site-body.home-v4 .feature-grid.compact article {
    min-height: unset;
    padding: 18px;
    border: 1px solid rgba(226, 213, 202, .82);
    border-radius: 20px;
    background: rgba(255, 253, 250, .74);
    box-shadow: 0 12px 32px rgba(41, 24, 18, .05);
}

.site-body.home-v4 .trust-grid strong,
.site-body.home-v4 .feature-grid.compact strong {
    display: block;
    margin-bottom: 6px;
    font-size: 18px;
    line-height: 1.18;
    font-weight: 700;
}

.site-body.home-v4 .trust-grid p,
.site-body.home-v4 .feature-grid.compact span {
    margin: 0;
    color: var(--home-muted);
    font-size: 14px;
    line-height: 1.52;
}

.site-body.home-v4 .feature-grid.compact {
    gap: 12px;
}

.site-body.home-v4 .feature-grid.compact i {
    padding: 6px 9px;
    font-size: 11px;
}

.site-body.home-v4 .home-split {
    gap: clamp(24px, 4vw, 44px);
}

.site-body.home-v4 .steps-card.slim {
    gap: 10px;
    padding: 14px;
    border-radius: 22px;
}

.site-body.home-v4 .steps-card.slim article {
    grid-template-columns: 38px 1fr;
    gap: 11px;
    padding: 12px;
    border-radius: 16px;
}

.site-body.home-v4 .steps-card.slim b {
    width: 38px;
    height: 38px;
    font-size: 14px;
    border-radius: 12px;
}

.site-body.home-v4 .steps-card.slim strong {
    font-size: 15px;
}

.site-body.home-v4 .steps-card.slim small {
    font-size: 13px;
}

.site-body.home-v4 .sector-pills {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

.site-body.home-v4 .sector-pills span,
.site-body.home-v4 .dynamic-plans .plan-limits span {
    padding: 8px 10px;
    border: 1px solid rgba(226, 213, 202, .78);
    border-radius: 999px;
    background: rgba(255, 250, 244, .7);
    color: #665850;
    font-size: 12px;
    font-weight: 620;
}

.site-body.home-v4 .plans-section {
    padding-top: 34px;
}

.site-body.home-v4 .modern-plans.small-plans {
    gap: 12px;
}

.site-body.home-v4 .modern-plans .plan {
    gap: 11px;
    padding: 18px;
    border-radius: 22px;
}

.site-body.home-v4 .modern-plans h3 {
    font-size: 18px;
}

.site-body.home-v4 .modern-plans p,
.site-body.home-v4 .dynamic-plans .plan p {
    font-size: 13.5px;
    line-height: 1.5;
}

.site-body.home-v4 .modern-plans .price,
.site-body.home-v4 .dynamic-plans .plan .price {
    font-size: clamp(24px, 2.4vw, 30px);
}

.site-body.home-v4 .modern-plans .price small {
    font-size: 13px;
}

.site-body.home-v4 .modern-plans ul {
    gap: 7px;
}

.site-body.home-v4 .modern-plans li,
.site-body.home-v4 .dynamic-plans .plan-module-list li {
    font-size: 13px;
}

.site-body.home-v4 .modern-plans .popular {
    padding: 6px 10px;
    font-size: 11px;
}

.site-body.home-v4 .dynamic-plans .plan-modules-title {
    font-size: 12px;
}

.site-body.home-v4 .home-cta {
    gap: 18px;
    margin: 8px clamp(18px, 4vw, 64px) 0;
    padding: 24px 26px;
    border-radius: 24px;
}

.site-body.home-v4 .home-cta h2 {
    max-width: 560px;
    margin: 10px 0 0;
}

.site-body.home-v4 .home-cta-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.site-body.home-v4 .faq-list {
    max-width: 980px;
    gap: 10px;
}

.site-body.home-v4 .faq details {
    padding: 15px 18px;
    border-radius: 18px;
}

.site-body.home-v4 .faq summary {
    font-size: 15px;
}

.site-body.home-v4 .site-footer {
    grid-template-columns: auto 1fr auto;
    gap: 16px 20px;
    margin: 0 clamp(16px, 4vw, 64px) 24px;
    padding: 16px 18px;
    border-radius: 22px;
}

.site-body.home-v4 .footer-brand {
    gap: 10px;
}

.site-body.home-v4 .footer-brand strong {
    font-size: 16px;
}

.site-body.home-v4 .site-footer nav {
    gap: 14px;
    font-size: 13px;
}

.site-body.home-v4 .footer-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
}

.site-body.home-v4 .footer-btn {
    min-height: 40px;
    padding-inline: 14px;
    font-size: 13px;
    white-space: nowrap;
}

.site-body.home-v4 .site-footer p {
    grid-column: 1 / -1;
    text-align: center;
    font-size: 12px;
    color: var(--home-muted);
}

@media (max-width: 1180px) {
    .site-body.home-v4 .home-hero {
        grid-template-columns: 1fr;
    }

    .site-body.home-v4 .trust-grid,
    .site-body.home-v4 .feature-grid.compact,
    .site-body.home-v4 .home-mini-cards,
    .site-body.home-v4 .modern-plans.small-plans {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-body.home-v4 .site-footer {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .site-body.home-v4 .footer-brand,
    .site-body.home-v4 .site-footer nav,
    .site-body.home-v4 .footer-actions {
        justify-self: center;
        justify-content: center;
    }
}

@media (max-width: 820px) {
    .site-body.home-v4 .site-brand strong {
        font-size: 18px;
    }

    .site-body.home-v4 .brand-mark {
        width: 42px;
        height: 42px;
        flex-basis: 42px;
    }

    .site-body.home-v4 .home-hero {
        padding: 28px 16px 24px;
    }

    .site-body.home-v4 .showcase-body {
        grid-template-columns: 56px 1fr;
    }

    .site-body.home-v4 .showcase-stats {
        grid-template-columns: 1fr 1fr 1fr;
    }

    .site-body.home-v4 .showcase-cart {
        grid-column: 1 / -1;
        margin: 0 14px 14px;
    }

    .site-body.home-v4 .trust-grid,
    .site-body.home-v4 .feature-grid.compact,
    .site-body.home-v4 .home-mini-cards,
    .site-body.home-v4 .modern-plans.small-plans {
        grid-template-columns: 1fr;
    }

    .site-body.home-v4 .site-section,
    .site-body.home-v4 .home-split {
        padding: 38px 16px;
    }

    .site-body.home-v4 .home-cta {
        margin: 6px 16px 0;
        flex-direction: column;
        align-items: flex-start;
    }

    .site-body.home-v4 .home-cta-actions {
        width: 100%;
        justify-content: stretch;
    }

    .site-body.home-v4 .home-cta-actions .btn {
        flex: 1 1 100%;
        width: 100%;
    }

    .site-body.home-v4 .site-footer {
        margin: 0 16px 20px;
        padding: 16px;
    }

    .site-body.home-v4 .footer-actions {
        width: 100%;
        flex-direction: column;
    }

    .site-body.home-v4 .footer-btn {
        width: 100%;
    }
}

@media (max-width: 520px) {
    .site-body.home-v4 .brand-copy {
        min-width: 0;
    }

    .site-body.home-v4 .site-brand small,
    .site-body.home-v4 .footer-brand small {
        letter-spacing: .12em;
    }

    .site-body.home-v4 .home-hero h1 {
        font-size: 32px;
    }

    .site-body.home-v4 .showcase-stats {
        grid-template-columns: 1fr;
    }

    .site-body.home-v4 .section-head h2,
    .site-body.home-v4 .home-split h2,
    .site-body.home-v4 .home-cta h2 {
        font-size: 25px;
    }
}

/* Ajuste adicional V5.1 · logo mais legível e posicionamento mais firme */
.site-body.home-v4 .site-header-inner {
    background: rgba(255, 252, 247, .94);
}

.site-body.home-v4 .site-brand {
    min-width: 0;
}

.site-body.home-v4 .brand-copy {
    display: block;
    min-width: 0;
}

.site-body.home-v4 .site-brand strong,
.site-body.home-v4 .footer-brand strong {
    color: #241513;
    font-weight: 780;
}

.site-body.home-v4 .site-brand small,
.site-body.home-v4 .footer-brand small {
    color: #8a7a72;
    font-weight: 700;
}

.site-body.home-v4 .brand-mark {
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
}

.site-body.home-v4 .brand-mark svg {
    filter: drop-shadow(0 8px 16px rgba(41, 24, 18, .10));
}

.site-body.home-v4 .site-brand strong {
    font-size: 21px;
}

.site-body.home-v4 .site-brand small {
    font-size: 10px;
}

.site-body.home-v4 .footer-brand .brand-mark {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
}

@media (max-width: 820px) {
    .site-body.home-v4 .brand-mark {
        width: 44px;
        height: 44px;
        flex-basis: 44px;
    }

    .site-body.home-v4 .site-brand strong {
        font-size: 17px;
    }
}

/* Ajuste V5.2 · home mais objetiva para cliente final */
.site-body.home-v4 .site-header-inner {
    min-height: 62px;
    padding: 9px 14px;
}

.site-body.home-v4 .brand-mark {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
}

.site-body.home-v4 .site-brand strong {
    font-size: 19px;
    letter-spacing: -.025em;
}

.site-body.home-v4 .site-brand small {
    font-size: 9.5px;
    letter-spacing: .14em;
}

.site-body.home-v4 .site-nav {
    font-size: 13.5px;
}

.site-body.home-v4 .home-hero {
    grid-template-columns: minmax(0, .88fr) minmax(390px, .98fr);
    gap: clamp(24px, 3.4vw, 42px);
    padding-top: clamp(28px, 4vw, 46px);
}

.site-body.home-v4 .home-hero-copy {
    max-width: 560px;
}

.site-body.home-v4 .home-hero h1 {
    max-width: 560px;
    font-size: clamp(32px, 3.05vw, 42px);
    line-height: 1.08;
    letter-spacing: -.048em;
}

.site-body.home-v4 .home-hero p {
    max-width: 540px;
    font-size: 14.5px;
    line-height: 1.56;
}

.site-body.home-v4 .hero-proof span {
    min-height: 28px;
    font-size: 11.8px;
}

.site-body.home-v4 .hero-showcase {
    max-width: 690px;
    justify-self: end;
    width: 100%;
}

.site-body.home-v4 .showcase-frame {
    border-radius: 24px;
}

.site-body.home-v4 .showcase-body {
    min-height: 300px;
    grid-template-columns: 60px minmax(0, 1fr) 188px;
}

.site-body.home-v4 .showcase-products {
    padding: 14px;
}

.site-body.home-v4 .showcase-stats article {
    padding: 8px 9px;
    border-radius: 12px;
}

.site-body.home-v4 .showcase-stats small {
    font-size: 10px;
}

.site-body.home-v4 .showcase-stats strong {
    font-size: 12px;
}

.site-body.home-v4 .fake-input {
    height: 36px;
    font-size: 12px;
}

.site-body.home-v4 .fake-grid article {
    min-height: 106px;
    gap: 5px;
    padding: 10px;
}

.site-body.home-v4 .fake-grid em {
    width: 34px;
    height: 42px;
}

.site-body.home-v4 .fake-grid span {
    font-size: 14px;
}

.site-body.home-v4 .showcase-cart {
    margin: 14px 14px 14px 0;
    padding: 12px;
    border-radius: 18px;
}

.site-body.home-v4 .cart-head {
    padding-bottom: 9px;
}

.site-body.home-v4 .cart-head strong {
    font-size: 15px;
}

.site-body.home-v4 .cart-row,
.site-body.home-v4 .cart-total,
.site-body.home-v4 .cart-payment b,
.site-body.home-v4 .cart-payment em {
    font-size: 12px;
}

.site-body.home-v4 .cart-total strong {
    font-size: 21px;
}

.site-body.home-v4 .cart-payment {
    padding: 10px;
    border-radius: 14px;
}

.site-body.home-v4 .showcase-cart button {
    min-height: 40px;
    font-size: 12px;
}

.site-body.home-v4 .home-mini-cards article,
.site-body.home-v4 .trust-grid article,
.site-body.home-v4 .feature-grid.compact article,
.site-body.home-v4 .modern-plans .plan,
.site-body.home-v4 .faq details {
    box-shadow: 0 10px 26px rgba(41, 24, 18, .045);
}

.site-body.home-v4 .home-mini-cards article {
    min-height: 76px;
    padding: 13px 14px;
}

.site-body.home-v4 .home-mini-cards strong {
    font-size: 15px;
}

.site-body.home-v4 .home-mini-cards small {
    font-size: 12px;
}

@media (max-width: 1180px) {
    .site-body.home-v4 .hero-showcase {
        justify-self: stretch;
        max-width: 100%;
    }
}

@media (max-width: 820px) {
    .site-body.home-v4 .home-hero h1 {
        font-size: 31px;
    }
}

@media (max-width: 520px) {
    .site-body.home-v4 .home-hero h1 {
        font-size: 29px;
    }
}

/* =========================================================
   Home V5.2 · correções finais mobile + logo mais legível
   ========================================================= */
.site-body.home-v4 .brand-mark {
    width: 52px;
    height: 52px;
    flex: 0 0 52px;
}

.site-body.home-v4 .site-brand strong {
    letter-spacing: -.035em;
}

.site-body.home-v4 .eyebrow {
    max-width: 260px;
    line-height: 1.25;
    white-space: normal;
}

.site-body.home-v4 .home-hero {
    align-items: start;
}

.site-body.home-v4 .hero-showcase,
.site-body.home-v4 .home-hero-copy {
    min-width: 0;
    width: 100%;
}

.site-body.home-v4 .showcase-frame {
    width: 100%;
    overflow: hidden;
}

.site-body.home-v4 .showcase-products,
.site-body.home-v4 .showcase-cart {
    min-width: 0;
}

@media (max-width: 900px) {
    .site-body.home-v4 .home-hero {
        display: flex;
        flex-direction: column;
        gap: 18px;
        padding-top: 22px;
    }

    .site-body.home-v4 .home-hero-copy,
    .site-body.home-v4 .hero-showcase {
        order: initial;
        max-width: 100%;
    }

    .site-body.home-v4 .hero-showcase {
        margin-top: 2px;
    }

    .site-body.home-v4 .showcase-body {
        grid-template-columns: 54px 1fr;
        min-height: 0;
    }

    .site-body.home-v4 .showcase-menu {
        padding: 12px 8px;
    }

    .site-body.home-v4 .showcase-menu b {
        width: 32px;
        height: 32px;
        font-size: 11px;
    }

    .site-body.home-v4 .showcase-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .site-body.home-v4 .showcase-cart {
        grid-column: 1 / -1;
        margin: 0 12px 12px;
    }
}

@media (max-width: 640px) {
    .site-body.home-v4 .site-header {
        padding: 10px 10px 0;
    }

    .site-body.home-v4 .site-header-inner,
    .site-body.home-v4 .site-header-inner.menu-open {
        border-radius: 0 0 22px 22px;
        padding: 10px 12px;
    }

    .site-body.home-v4 .brand-mark {
        width: 48px;
        height: 48px;
        flex-basis: 48px;
    }

    .site-body.home-v4 .site-brand strong {
        font-size: 17px;
    }

    .site-body.home-v4 .site-brand small {
        font-size: 9px;
        letter-spacing: .12em;
    }

    .site-body.home-v4 .eyebrow {
        max-width: 198px;
        padding: 7px 10px;
        border-radius: 20px;
        font-size: 11px;
    }

    .site-body.home-v4 .home-hero {
        padding: 18px 12px 22px;
        gap: 16px;
    }

    .site-body.home-v4 .home-hero h1 {
        font-size: 29px;
        line-height: 1.08;
        margin: 12px 0 12px;
    }

    .site-body.home-v4 .home-hero p {
        font-size: 14px;
        line-height: 1.5;
    }

    .site-body.home-v4 .hero-actions {
        flex-direction: column;
        gap: 8px;
    }

    .site-body.home-v4 .hero-actions .btn {
        width: 100%;
    }

    .site-body.home-v4 .hero-proof {
        gap: 7px;
    }

    .site-body.home-v4 .hero-proof span {
        flex: 1 1 calc(50% - 7px);
        justify-content: center;
    }

    .site-body.home-v4 .showcase-frame {
        border-radius: 22px;
    }

    .site-body.home-v4 .showcase-top {
        min-height: 40px;
        padding: 0 12px;
    }

    .site-body.home-v4 .showcase-top strong {
        font-size: 11px;
    }

    .site-body.home-v4 .showcase-body {
        display: block;
        background: linear-gradient(135deg, #fffdf9, #fff6ec);
    }

    .site-body.home-v4 .showcase-menu {
        display: none;
    }

    .site-body.home-v4 .showcase-products {
        padding: 12px;
    }

    .site-body.home-v4 .showcase-stats {
        grid-template-columns: 1fr 1fr 1fr;
        gap: 7px;
        margin-bottom: 10px;
    }

    .site-body.home-v4 .showcase-stats article {
        padding: 8px;
        border-radius: 12px;
    }

    .site-body.home-v4 .showcase-stats small {
        font-size: 10px;
    }

    .site-body.home-v4 .showcase-stats strong {
        font-size: 12px;
    }

    .site-body.home-v4 .fake-input {
        height: 38px;
        font-size: 12px;
    }

    .site-body.home-v4 .fake-grid {
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 10px;
    }

    .site-body.home-v4 .fake-grid article {
        min-height: 84px;
        display: grid;
        grid-template-columns: 38px 1fr auto;
        align-items: center;
        gap: 10px;
        padding: 10px;
    }

    .site-body.home-v4 .fake-grid em {
        width: 34px;
        height: 40px;
        margin: 0;
    }

    .site-body.home-v4 .fake-grid strong {
        min-height: 0;
        font-size: 11px;
        line-height: 1.1;
    }

    .site-body.home-v4 .fake-grid span {
        font-size: 14px;
        white-space: nowrap;
    }

    .site-body.home-v4 .showcase-cart {
        margin: 0 12px 12px;
        padding: 12px;
        border-radius: 18px;
    }

    .site-body.home-v4 .cart-row,
    .site-body.home-v4 .cart-total,
    .site-body.home-v4 .cart-payment b,
    .site-body.home-v4 .cart-payment em {
        font-size: 12px;
    }

    .site-body.home-v4 .cart-total strong {
        font-size: 22px;
    }

    .site-body.home-v4 .showcase-cart button {
        min-height: 42px;
        font-size: 12px;
    }

    .site-body.home-v4 .home-mini-cards {
        padding: 0 12px 26px;
    }

    .site-body.home-v4 .site-section,
    .site-body.home-v4 .home-split,
    .site-body.home-v4 .plans-section {
        padding-left: 12px;
        padding-right: 12px;
    }

    .site-body.home-v4 .home-cta {
        margin-left: 12px;
        margin-right: 12px;
    }

    .site-body.home-v4 .site-footer {
        margin-left: 12px;
        margin-right: 12px;
    }
}

/* Hotfix V5.3 · botão Entrar visível no menu mobile */
@media (max-width: 820px) {
    .site-body.home-v4 .site-header-inner.menu-open .site-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
    }

    .site-body.home-v4 .site-header-inner.menu-open .site-actions .btn.ghost,
    .site-body.home-v4 .site-header-inner.menu-open .site-actions .btn.orange {
        display: inline-flex !important;
        width: 100% !important;
        min-height: 48px !important;
        align-items: center !important;
        justify-content: center !important;
        padding-inline: 12px !important;
        font-size: 14px !important;
    }
}

@media (max-width: 520px) {
    .site-body.home-v4 .site-header-inner.menu-open .site-actions {
        grid-template-columns: 1fr !important;
    }
}
