:root {
    --blue-950:#001f4f;
    --blue-900:#002d66;
    --blue-800:#003b79;
    --blue-700:#0057c2;
    --blue-100:#eaf2ff;
    --yellow:#ffcc29;
    --green:#159947;
    --orange:#f97316;
    --purple:#6d3fd1;
    --bg:#f5f7fb;
    --text:#101828;
    --muted:#667085;
    --border:#e5e7eb;
    --shadow:0 10px 30px rgba(16,24,40,.08);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}
a{text-decoration:none;color:var(--blue-700);font-weight:800}
.layout{display:flex;min-height:100vh}
.sidebar{width:282px;position:fixed;top:0;bottom:0;left:0;overflow:auto;color:#fff;padding:22px 18px;background:linear-gradient(180deg,#00265f 0%,#003b79 48%,#00235a 100%)}
.brand-box{background:#fff;border-radius:18px;padding:12px 14px;box-shadow:0 10px 28px rgba(0,0,0,.18)}
.brand-box img{width:100%;height:auto;display:block}
.brand-campaign{text-align:center;margin:22px 0 26px}
.brand-campaign small{letter-spacing:3px;font-weight:800;color:#fff}
.brand-campaign strong{display:block;font-size:34px;font-style:italic;font-weight:900;margin-top:5px}
.brand-campaign b{display:block;font-size:34px;color:var(--yellow);font-weight:900}
.nav{display:flex;flex-direction:column;gap:8px}
.nav a{color:#fff;display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:12px;font-weight:800}
.nav a span{width:24px;text-align:center}
.nav a.active,.nav a:hover{background:rgba(255,255,255,.14);box-shadow:inset 4px 0 0 var(--yellow)}
.sidebar-help{margin-top:28px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07);border-radius:18px;padding:18px}
.sidebar-help p{color:#dbeafe;margin:8px 0 16px}
.sidebar-help a{display:block;text-align:center;border:1px solid var(--yellow);color:var(--yellow);padding:10px;border-radius:10px}
.help-icon{font-size:30px;margin-bottom:8px}
.content{margin-left:282px;width:calc(100% - 282px);padding:24px 28px}
.topbar{display:flex;justify-content:space-between;margin-bottom:18px}
.userbox{display:flex;align-items:center;gap:14px;color:#344054}
.userbox small{display:block;color:var(--muted)}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--blue-800);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900}
.bell{position:relative;font-size:22px}.bell b{position:absolute;top:-8px;right:-8px;background:#e11d48;color:#fff;border-radius:99px;font-size:10px;padding:2px 5px}
.hero-dashboard{background:linear-gradient(110deg,#003b79,#0057c2);color:#fff;border-radius:20px;padding:28px 32px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:18px}
.hero-dashboard h1{margin:0 0 8px;font-size:30px}.hero-dashboard p{margin:0;color:#dbeafe}
.hero-action{background:#fff;color:var(--blue-800);border-radius:12px;padding:13px 18px;white-space:nowrap}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:20px 0}
.kpi-card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:22px}
.kpi-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;margin-bottom:12px}
.kpi-icon.blue{background:var(--blue-700)}.kpi-icon.green{background:var(--green)}.kpi-icon.purple{background:var(--purple)}.kpi-icon.orange{background:var(--orange)}
.kpi-card small{font-weight:800;color:#344054}.kpi-card strong{display:block;color:var(--blue-800);font-size:32px;margin:12px 0 4px}.kpi-card em{color:var(--muted);font-style:normal;font-size:13px}
.green-text{color:var(--green)!important}.purple-text{color:var(--purple)!important}.orange-text{color:var(--orange)!important}
.progress{height:8px;background:#e5e7eb;border-radius:99px;overflow:hidden;margin:12px 0 4px}.progress span{display:block;height:100%;width:70%;background:var(--purple)}
.two-columns{display:grid;grid-template-columns:1.35fr .65fr;gap:18px;margin-bottom:18px}
.panel{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:14px}.panel-head h2{margin:0;color:var(--blue-900);font-size:20px}.panel-head p{margin:5px 0 0;color:var(--muted)}
table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--border);padding:10px 8px;text-align:left;font-size:14px}th{color:#475467;font-size:13px}
.status{display:inline-block;padding:5px 10px;background:#dcfce7;color:#166534;border-radius:99px;font-size:12px;font-weight:900}
.revista-call{background:linear-gradient(135deg,#fff,#eef4ff)}.revista-call .spark{font-size:32px}.revista-call p{color:var(--muted);line-height:1.45}
.btn-primary,.btn-link{display:inline-block;background:var(--blue-800);color:#fff;border:none;border-radius:10px;padding:12px 16px;font-weight:900;cursor:pointer}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.product-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff}
.product-img{height:120px;background:linear-gradient(135deg,#eef4ff,#fff);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;overflow:hidden}.product-img img{width:100%;height:100%;object-fit:contain;padding:8px}
.product-card h3{font-size:15px;min-height:42px;margin:7px 0}.product-card p{color:var(--muted);font-size:13px}
.tag{display:inline-block;background:#dbeafe;color:#1d4ed8;border-radius:99px;padding:4px 8px;font-size:11px;font-weight:900}
.footer-lock{text-align:center;color:var(--muted);font-size:13px;margin:22px 0 6px}
.alert{padding:12px 14px;border-radius:12px;margin:16px 0;font-weight:700}.alert.error{background:#fee2e2;color:#991b1b}.alert.success{background:#dcfce7;color:#166534}
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#002d66,#0057c2);padding:28px}
.auth-card{width:450px;max-width:100%;background:#fff;border-radius:20px;box-shadow:0 24px 70px rgba(0,0,0,.28);padding:30px}
.auth-logo{width:260px;max-width:100%;display:block;margin:0 auto 22px}.auth-card h1{color:var(--blue-900);text-align:center;margin:0 0 20px}.auth-card label{display:block;font-weight:800;margin:12px 0 7px}.auth-card input{width:100%;border:1px solid #d0d5dd;border-radius:10px;padding:12px;font-size:15px}.auth-card .btn-primary{width:100%;margin-top:16px}.auth-links{text-align:center}
.rule-card{border:1px solid var(--border);border-radius:14px;padding:14px;margin:12px 0}.profile p{font-size:16px}
@media(max-width:1180px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.two-columns{grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.sidebar{position:relative;width:100%;height:auto}.content{margin-left:0;width:100%}.layout{display:block}.hero-dashboard{display:block}.hero-action{display:inline-block;margin-top:18px}.kpi-grid,.product-grid{grid-template-columns:1fr}}

.rules-hero{background:linear-gradient(110deg,#003b79,#0057c2);color:#fff;border-radius:20px;padding:28px 32px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.rules-hero h1{margin:0 0 8px;font-size:30px}.rules-hero p{margin:0;color:#dbeafe}.rules-image-panel{text-align:center;background:#eef4ff}.rules-image-panel img{max-width:100%;width:360px;border-radius:20px;box-shadow:0 14px 40px rgba(0,0,0,.18)}.rules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.rules-grid article{border:1px solid var(--border);border-radius:16px;padding:16px;background:#fff}.rules-grid b{color:var(--blue-900)}.rules-grid p{color:var(--muted);line-height:1.4}@media(max-width:900px){.rules-grid{grid-template-columns:1fr}.rules-hero{display:block}}

/* V8 - URLs de produtos e ajuste da imagem de regras */
.page-hero{
    background:linear-gradient(110deg,#003b79,#0057c2);
    color:#fff;
    border-radius:20px;
    padding:28px 32px;
    box-shadow:var(--shadow);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin-bottom:18px;
}
.page-hero h1{margin:0 0 8px;font-size:30px}
.page-hero p{margin:0;color:#dbeafe;line-height:1.45}
.not-bought-hero{background:linear-gradient(110deg,#003b79,#f97316)}
.top20-hero{background:linear-gradient(110deg,#001f4f,#003b79)}
.bought{background:linear-gradient(110deg,#003b79,#159947)}
.data-table{width:100%;border-collapse:collapse}
.data-table th{background:#003b79;color:#fff;text-align:left;padding:10px;font-size:13px}
.data-table td{border-bottom:1px solid #e5e7eb;padding:10px;font-size:13px;vertical-align:top}
.data-table tr:nth-child(even) td{background:#f8fbff}
.extended{grid-template-columns:repeat(5,1fr)}
.opportunity-card{position:relative}
.orange-tag{background:#ffedd5!important;color:#c2410c!important}
.ranking-list{display:grid;gap:12px}
.ranking-card{
    display:grid;
    grid-template-columns:54px 78px 1fr 120px;
    gap:14px;
    align-items:center;
    border:1px solid var(--border);
    border-radius:16px;
    padding:12px;
    background:#fff;
}
.rank-number{
    width:42px;height:42px;border-radius:50%;
    background:#003b79;color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-weight:900;
}
.rank-img{height:68px;background:#f8fbff;border-radius:12px;display:flex;align-items:center;justify-content:center}
.rank-img img{max-width:100%;max-height:100%;object-fit:contain;padding:6px}
.rank-info h3{margin:4px 0;font-size:16px;color:#003b79}
.rank-info p{margin:0;color:var(--muted)}
.rules-hero{
    background:linear-gradient(110deg,#003b79,#0057c2);
    color:#fff;
    border-radius:20px;
    padding:24px 28px;
    box-shadow:var(--shadow);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin-bottom:18px;
}
.rules-hero h1{margin:0 0 8px;font-size:30px}
.rules-hero p{margin:0;color:#dbeafe}
.rules-image-panel{
    text-align:center;
    background:#eef4ff;
    padding:22px;
}
.rules-image-wrap{
    display:inline-block;
    max-width:min(560px,100%);
    background:#fff;
    padding:10px;
    border-radius:20px;
    box-shadow:0 12px 30px rgba(0,0,0,.16);
}
.rules-image-wrap img{
    display:block;
    max-width:100%;
    width:auto;
    height:auto;
    max-height:560px;
    object-fit:contain;
    border-radius:14px;
}
.rules-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
}
.rules-grid article{
    border:1px solid var(--border);
    border-radius:16px;
    padding:16px;
    background:#fff;
}
.rules-grid b{color:var(--blue-900)}
.rules-grid p{color:var(--muted);line-height:1.4}
@media(max-width:1200px){.extended{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
    .extended,.rules-grid{grid-template-columns:1fr}
    .page-hero,.rules-hero{display:block}
    .ranking-card{grid-template-columns:44px 64px 1fr}
    .ranking-card a{grid-column:1/-1}
}

/* V9 - experiência cliente, busca, top 20 e regras profissional */
.quick-links-campaign{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
    margin:0 0 18px;
}
.quick-links-campaign a{
    background:#fff;
    border:1px solid var(--border);
    box-shadow:var(--shadow);
    border-radius:16px;
    padding:16px;
    color:var(--blue-900);
    font-weight:900;
}
.search-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    margin:12px 0 18px;
}
.search-box{
    flex:1;
    display:flex;
    align-items:center;
    gap:10px;
    background:#f8fbff;
    border:1px solid #dbeafe;
    border-radius:14px;
    padding:12px 14px;
}
.search-box span{font-size:19px}
.search-box input{
    border:0;
    outline:0;
    background:transparent;
    width:100%;
    font-size:15px;
    color:var(--text);
}
.counter-pill{
    background:var(--blue-100);
    color:var(--blue-900);
    border-radius:99px;
    padding:11px 16px;
    font-weight:900;
}
.products-head p{margin:5px 0 0;color:var(--muted)}
.top20-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:16px;
}
.top20-card{
    position:relative;
    display:grid;
    grid-template-columns:58px 110px 1fr;
    gap:14px;
    align-items:center;
    background:linear-gradient(135deg,#fff,#f8fbff);
    border:1px solid var(--border);
    border-radius:18px;
    padding:16px;
    box-shadow:0 8px 22px rgba(16,24,40,.06);
    overflow:hidden;
}
.top20-card:before{
    content:"";
    position:absolute;
    right:-35px;
    top:-35px;
    width:120px;
    height:120px;
    background:rgba(0,87,194,.08);
    border-radius:50%;
}
.top20-rank{
    width:48px;height:48px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#003b79;
    color:#fff;
    font-weight:900;
    font-size:17px;
}
.top20-img{
    width:110px;
    height:92px;
    background:#fff;
    border:1px solid #eef2f7;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
}
.top20-img img{
    max-width:100%;
    max-height:100%;
    object-fit:contain;
    padding:8px;
}
.top20-code{
    display:inline-block;
    color:#0057c2;
    font-weight:900;
    font-size:12px;
    margin-bottom:5px;
}
.top20-info h3{
    margin:0 0 8px;
    color:#003b79;
    font-size:17px;
    line-height:1.25;
}
.metric-row{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin-bottom:8px;
}
.metric-row span{
    background:#eaf2ff;
    color:#003b79;
    border-radius:99px;
    padding:5px 9px;
    font-size:12px;
    font-weight:900;
}
.top20-info p{
    color:var(--muted);
    margin:0;
    font-size:13px;
}
.top20-cta{
    grid-column:1/-1;
    display:block;
    text-align:center;
    background:#003b79;
    color:#fff;
    border-radius:10px;
    padding:10px;
}
.rules-layout{
    display:grid;
    grid-template-columns:1fr 420px;
    gap:18px;
    align-items:start;
}
.rules-summary-panel .lead{
    color:var(--muted);
    line-height:1.5;
}
.rules-grid.vertical{
    grid-template-columns:1fr;
}
.rules-image-panel{
    text-align:center;
    background:#eef4ff;
    padding:18px;
}
.rules-image-wrap{
    display:inline-block;
    width:100%;
    max-width:360px;
    background:#fff;
    padding:8px;
    border-radius:18px;
    box-shadow:0 12px 30px rgba(0,0,0,.16);
}
.rules-image-wrap img{
    display:block;
    width:100%;
    height:auto;
    max-height:560px;
    object-fit:contain;
    border-radius:12px;
}
.image-caption{
    margin:10px 0 0;
    color:var(--muted);
    font-size:13px;
}
@media(max-width:1180px){
    .top20-grid{grid-template-columns:1fr}
    .rules-layout{grid-template-columns:1fr}
    .quick-links-campaign{grid-template-columns:1fr}
}
@media(max-width:760px){
    .search-row{display:block}
    .counter-pill{display:inline-block;margin-top:10px}
    .top20-card{grid-template-columns:48px 90px 1fr}
    .top20-img{width:90px;height:78px}
}

/* V10 - categorias, faixas e indicador do cliente */
.categoria-indicator{display:grid;grid-template-columns:1.2fr .7fr 1.2fr auto;gap:16px;align-items:center;background:linear-gradient(110deg,#ffffff,#eef4ff);border:1px solid #dbeafe;border-radius:20px;padding:18px;box-shadow:var(--shadow);margin:20px 0}.categoria-indicator.standalone{grid-template-columns:1.2fr .7fr 1.2fr}.categoria-label{display:inline-block;background:#003b79;color:#fff;padding:6px 10px;border-radius:99px;font-size:12px;font-weight:900;margin-bottom:8px}.categoria-main h2{margin:0 0 6px;color:#003b79;font-size:28px}.categoria-main p,.categoria-next p{margin:0;color:var(--muted);line-height:1.4}.categoria-cashback{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;text-align:center}.categoria-cashback small,.categoria-next small{display:block;color:var(--muted);font-weight:800;margin-bottom:6px}.categoria-cashback strong{color:#159947;font-size:26px}.categoria-next{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px}.categoria-next strong{color:#003b79}.categoria-progress{height:10px;background:#e5e7eb;border-radius:99px;overflow:hidden;margin:10px 0}.categoria-progress span{display:block;height:100%;background:linear-gradient(90deg,#003b79,#0057c2,#ffcc29)}.categoria-link{white-space:nowrap;background:#003b79;color:#fff;padding:12px 16px;border-radius:12px;text-align:center}.faixas-hero{background:linear-gradient(110deg,#003b79,#0057c2)}.faixas-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:14px}.faixas-table th{background:#003b79;color:#fff;text-align:left;padding:12px;font-size:13px}.faixas-table td{border-bottom:1px solid var(--border);padding:12px;font-size:14px}.faixas-table tr:nth-child(even) td{background:#f8fbff}.faixas-table .current-row td{background:#fff7cc!important;border-top:2px solid #ffcc29;border-bottom:2px solid #ffcc29}.current-badge,.ok-badge,.pending-badge{display:inline-block;border-radius:99px;padding:5px 10px;font-size:12px;font-weight:900}.current-badge{background:#003b79;color:#fff}.ok-badge{background:#dcfce7;color:#166534}.pending-badge{background:#f3f4f6;color:#475467}.mini-indicator{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:10px 0 18px}.mini-indicator div{background:#f8fbff;border:1px solid #dbeafe;border-radius:14px;padding:12px}.mini-indicator small{display:block;color:var(--muted);font-weight:800;margin-bottom:5px}.mini-indicator strong{color:#003b79;font-size:18px}@media(max-width:1180px){.categoria-indicator,.categoria-indicator.standalone,.mini-indicator{grid-template-columns:1fr}.categoria-link{display:block}}

/* V11 - itens não comprados no mesmo padrão do Top 20 */
.opportunity-list .top20-rank {
    background: #f97316;
    font-size: 16px;
}

.opportunity-top-card {
    background: linear-gradient(135deg,#fff,#fff7ed);
}

.opportunity-top-card .metric-row span {
    background: #ffedd5;
    color: #c2410c;
}

.opportunity-top-card .top20-cta {
    background: #f97316;
}

.opportunity-top-card:before {
    background: rgba(249,115,22,.10);
}

/* V12 - não comprados no modelo Top 20, sem valor */
.opportunity-list .top20-rank {
    background: #f97316 !important;
    color: #fff;
}
.opportunity-top-card {
    background: linear-gradient(135deg,#fff,#fff7ed) !important;
    border-color: #fed7aa !important;
}
.opportunity-top-card .metric-row span {
    background: #ffedd5 !important;
    color: #c2410c !important;
}
.opportunity-top-card .top20-cta {
    background: #f97316 !important;
}


/* V13 - página standalone "ainda não comprou" conforme modelo aprovado */
.nao-comprados-lista-ref.standalone {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.nao-comprado-card-ref {
    display: grid;
    grid-template-columns: 118px 74px 1fr 118px;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid #d5e1f2;
    border-radius: 14px;
    padding: 10px;
    box-shadow: 0 7px 16px rgba(0,79,158,.08);
}

.nao-badge-ref {
    background: linear-gradient(180deg, #004F9E, #003B79);
    color: #fff;
    border-radius: 8px;
    padding: 8px;
    text-align: center;
    font-weight: 900;
}

.nao-badge-ref strong,
.nao-badge-ref span {
    display: block;
}

.nao-badge-ref strong {
    font-size: 10px;
}

.nao-badge-ref span {
    font-size: 14px;
}

.nao-img-ref {
    width: 70px;
    height: 58px;
    border-radius: 10px;
    background: #fff;
    border: 1px solid #e5e7eb;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.nao-img-ref img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    padding: 4px;
}

.nao-info-ref small {
    display: block;
    color: #004F9E;
    font-weight: 900;
    font-size: 11px;
}

.nao-info-ref h4 {
    color: #003B79;
    font-size: 14px;
    line-height: 1.2;
    margin: 2px 0 5px;
}

.nao-info-ref p,
.nao-info-ref em {
    display: block;
    color: #344054;
    margin: 0;
    font-size: 12px;
    font-style: normal;
}

.nao-btn-ref {
    background: #003B79;
    color: #fff !important;
    border-radius: 9px;
    text-align: center;
    padding: 10px 8px;
    font-weight: 900;
    text-decoration: none;
}

@media(max-width:1100px){
    .nao-comprados-lista-ref.standalone {
        grid-template-columns: 1fr;
    }
}


/* V16 - refinamentos profissionais */
.bell{position:relative;font-size:22px;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow)}
.bell.is-idle{opacity:.78}.bell.has-notification{color:#d97706;background:#fff7d6}
.bell b{position:absolute;top:-6px;right:-6px;background:#e11d48;color:#fff;border-radius:99px;font-size:10px;padding:2px 5px}
.suggestion-hero{background:linear-gradient(110deg,#001f4f,#0057c2)}
.top20-hero-pro{background:linear-gradient(110deg,#00265f,#0057c2)}
.mini-magazine-hero{display:flex;justify-content:space-between;gap:18px;align-items:center;background:linear-gradient(120deg,#00265f,#0057c2);border-radius:18px;padding:22px;color:#fff;margin-bottom:18px;overflow:hidden}
.mini-magazine-hero.full{padding:26px}
.mini-magazine-copy{max-width:600px}.mini-magazine-copy h3{margin:10px 0 8px;font-size:30px;line-height:1.08}.mini-magazine-copy p{margin:0;color:#dbeafe;line-height:1.45}
.mini-mag-badge{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:8px 14px;border-radius:999px;font-weight:900}
.mini-mag-icons{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.mini-mag-icons div{width:74px;height:74px;background:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(0,0,0,.12)}.mini-mag-icons img{max-width:100%;max-height:100%;object-fit:contain;padding:7px}
.magazine-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.magazine-card-grid.compact{grid-template-columns:repeat(4,1fr)}
.magazine-card{position:relative;border:1px solid #d9e4f1;border-radius:16px;background:#fff;padding:14px;box-shadow:0 5px 14px rgba(0,59,121,.08);display:grid;grid-template-columns:86px 1fr;gap:12px;min-height:175px}
.mag-card-tag{position:absolute;left:14px;top:12px;background:#e00000;color:#fff;border-radius:8px;padding:5px 9px;font-size:10px;font-weight:900;text-transform:uppercase;z-index:2}
.mag-card-img{width:86px;height:96px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;margin-top:24px}.mag-card-img img{max-width:100%;max-height:100%;object-fit:contain;padding:6px}
.mag-card-info{padding-top:28px}.mag-card-info .mag-sku{display:inline-block;background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:900}.mag-card-info h3{margin:10px 0 6px;font-size:18px;line-height:1.15;color:var(--blue-900)}.mag-card-info p{margin:0;color:var(--muted);font-size:13px;line-height:1.3}.mag-card-info strong{display:block;margin-top:14px;color:var(--blue-800);font-size:24px;line-height:1}
.mag-card-btn{grid-column:1/-1;display:block;background:var(--blue-800);color:#fff !important;text-align:center;border-radius:10px;padding:10px;font-weight:900;margin-top:6px}
.magazine-summary-banner{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px;background:linear-gradient(120deg,#eaf2ff,#fff);padding:16px;border-radius:18px;border:1px solid #dbeafe}.magazine-summary-banner div{background:#fff;border:1px solid #dbeafe;border-radius:14px;padding:14px}.magazine-summary-banner b{display:block;color:var(--blue-900);font-size:16px}.magazine-summary-banner span{display:block;color:var(--muted);margin-top:4px;line-height:1.35}
.top20-grid.pro{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.top20-card.pro{display:grid;grid-template-columns:70px 96px 1fr 120px;align-items:center;gap:14px;border:1px solid var(--border);border-radius:18px;padding:14px;background:linear-gradient(135deg,#fff,#fbfdff);box-shadow:0 6px 18px rgba(0,59,121,.08)}
.top20-card.pro .top20-rank{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#003b79;color:#fff;font-weight:900;font-size:16px}.top20-card.pro .top20-img{height:84px;border-radius:14px;background:#f8fbff;display:flex;align-items:center;justify-content:center}.top20-card.pro .top20-img img{max-width:100%;max-height:100%;object-fit:contain;padding:8px}.top20-card.pro h3{margin:5px 0 8px;font-size:17px;color:#003b79;line-height:1.15}.top20-card.pro .top20-code{display:inline-block;background:#eef4ff;color:#1d4ed8;padding:5px 8px;border-radius:999px;font-size:11px;font-weight:900}.metric-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.metric-pill{display:inline-block;background:#f3f4f6;color:#344054;border-radius:999px;padding:5px 8px;font-size:11px;font-weight:800}.metric-pill.blue{background:#eaf2ff;color:#1d4ed8}.top20-card.pro p{margin:0;color:var(--muted);font-size:13px;line-height:1.35}.top20-card.pro .top20-cta{display:flex;align-items:center;justify-content:center;background:#003b79;color:#fff!important;border-radius:12px;padding:10px 12px;font-weight:900;text-align:center}
@media(max-width:1180px){.magazine-card-grid,.magazine-card-grid.compact{grid-template-columns:repeat(2,1fr)}.top20-grid.pro{grid-template-columns:1fr}}
@media(max-width:760px){.mini-magazine-hero{display:block}.mini-mag-icons{justify-content:flex-start;margin-top:14px}.magazine-card-grid,.magazine-card-grid.compact,.magazine-summary-banner{grid-template-columns:1fr}.top20-card.pro{grid-template-columns:56px 84px 1fr}.top20-card.pro .top20-cta{grid-column:1/-1}}


/* V17 - ajustes solicitados */
.nao-badge-ref{
    background: linear-gradient(180deg, #ff2323, #d40000);
    min-height: 64px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
}
.nao-badge-ref strong{font-size:12px;letter-spacing:.2px;line-height:1.05}
.nao-badge-ref span{font-size:18px;line-height:1.05}
.sugestao-badge-ref{
    background: linear-gradient(180deg, #0a57b5, #003b79);
}
.sugestao-card-ref .nao-info-ref h4{font-size:13px;margin:2px 0 4px;line-height:1.15}
.suggestion-region{font-size:11px !important;color:#0a57b5 !important;font-weight:800}
.suggestion-price-line{margin-top:6px}
.suggestion-price-line b{font-size:20px;color:#003b79;line-height:1}
.top20-card.pro .top20-rank{
    min-width:64px;height:34px;padding:0 10px;border-radius:999px;
    font-size:12px;line-height:1;white-space:nowrap;
}
@media(max-width:760px){
    .nao-comprado-card-ref.sugestao-card-ref{grid-template-columns:96px 70px 1fr;}
    .nao-comprado-card-ref.sugestao-card-ref .nao-btn-ref{grid-column:1/-1}
}


/* V18 - correções finais de sugestões, região SP e Top20 */
.nao-badge-ref{
    background: linear-gradient(180deg, #e00000, #b90000) !important;
    width: 106px;
    min-height: 52px;
    padding: 6px 7px;
    border-radius: 9px;
    box-shadow: 0 6px 13px rgba(224,0,0,.20);
}
.nao-badge-ref strong{
    font-family: inherit;
    font-size: 10px;
    line-height: 1.03;
    letter-spacing: .1px;
}
.nao-badge-ref span{
    font-family: inherit;
    font-size: 16px;
    line-height: 1.02;
    margin-top: 1px;
}
.nao-comprado-card-ref{
    grid-template-columns: 112px 74px 1fr 118px;
}
.sugestao-badge-ref{
    background: linear-gradient(180deg, #e00000, #b90000) !important;
}
.suggestion-region{
    color:#003b79 !important;
    font-weight:900 !important;
    font-size:11px !important;
    margin-top:2px !important;
}
.suggestion-price-line small{
    display:block;
    color:#667085;
    font-size:10px;
    line-height:1.15;
    margin-bottom:3px;
}
.suggestion-price-line b{
    display:block;
    font-size:21px;
    color:#003b79;
}
.top20-card.pro .top20-rank.top20-red-rank{
    background:#e00000;
    color:#fff;
    border-radius:9px;
    min-width:58px;
    height:30px;
    font-size:12px;
    box-shadow:0 6px 13px rgba(224,0,0,.20);
}
.top20-card.pro{
    grid-template-columns:66px 96px 1fr 120px;
}
@media(max-width:760px){
    .nao-comprado-card-ref{grid-template-columns:100px 70px 1fr;}
    .nao-btn-ref{grid-column:1/-1}
}


/* V19 - refinamento final sugestões e Top20 */
.sugestao-card-ref{grid-template-columns:118px 78px 1fr 126px !important; gap:12px !important;}
.sugestao-badge-ref{background:linear-gradient(180deg,#e00000,#b90000) !important; width:118px !important; min-height:58px !important; padding:8px 8px !important; border-radius:10px !important; box-shadow:0 8px 18px rgba(224,0,0,.18)}
.sugestao-badge-ref strong,.sugestao-badge-ref span{display:block;text-align:center}
.sugestao-badge-ref strong{font-size:10px !important; line-height:1.02 !important; letter-spacing:.2px}
.sugestao-badge-ref span{font-size:14px !important; line-height:1.0 !important; margin-top:2px}
.sugestao-card-ref .nao-img-ref{width:78px !important;height:66px !important}
.sugestao-card-ref .nao-info-ref small{font-size:12px !important}
.sugestao-card-ref .nao-info-ref h4{font-size:14px !important;line-height:1.16 !important;margin:2px 0 5px !important}
.suggestion-region{font-size:11px !important;font-weight:900 !important;color:#003b79 !important;letter-spacing:.2px;text-transform:uppercase}
.suggestion-price-line small{display:block;color:#667085;font-size:10px !important;line-height:1.2;margin-bottom:4px}
.suggestion-price-line b{display:block;color:#003b79;font-size:20px !important;line-height:1.0}
.top20-card.pro .top20-rank.top20-red-rank{width:auto !important;min-width:68px !important;height:34px !important;padding:0 10px !important;border-radius:10px !important;background:#e00000 !important;color:#fff !important;font-size:12px !important;box-shadow:0 8px 18px rgba(224,0,0,.18) !important}
@media(max-width:760px){.sugestao-card-ref{grid-template-columns:96px 70px 1fr !important}.sugestao-card-ref .nao-btn-ref{grid-column:1/-1}}


/* V21 - Performance */
img{
    content-visibility:auto;
}
.product-card,
.magazine-card,
.nao-comprado-card-ref,
.top20-card,
.kpi-card,
.panel{
    content-visibility:auto;
    contain-intrinsic-size: 240px;
}
.modo-leve-badge-v21{
    display:inline-block;
    margin-left:8px;
    background:#dcfce7;
    color:#166534;
    border:1px solid #bbf7d0;
    padding:5px 8px;
    border-radius:999px;
    font-size:11px;
    font-weight:900;
    vertical-align:middle;
}
.performance-note-v21{
    background:#f0f9ff;
    border:1px solid #bae6fd;
    color:#075985;
    border-radius:12px;
    padding:10px 14px;
    margin:10px 0;
    font-weight:800;
}


/* ============================================================
   V22 FINAL REAL — Dashboard e Sugestões aprovadas
   ============================================================ */
.mini-magazine-hero{
    align-items:center !important;
    min-height:176px;
}
.mini-magazine-copy{max-width:520px !important;flex:1 1 44%;}
.mini-magazine-copy h3{font-size:29px !important;line-height:1.08 !important;}
.mini-mag-region-v22{
    display:flex;
    align-items:flex-start;
    gap:12px;
    min-width:360px;
    max-width:430px;
    padding:17px 18px;
    border:1px dashed rgba(255,255,255,.56);
    border-radius:16px;
    background:rgba(255,255,255,.07);
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
    color:#fff;
    flex:0 1 410px;
}
.mini-mag-region-v22 .region-pin-v22{font-size:23px;line-height:1;margin-top:2px;}
.mini-mag-region-v22 strong{display:block;font-size:18px;line-height:1.14;font-weight:950;letter-spacing:.1px;color:#fff;}
.mini-mag-region-v22 small{display:block;margin-top:5px;font-size:14px;line-height:1.25;font-weight:700;color:#f1f7ff;}
.mini-mag-region-v22 em{display:inline-flex;margin-top:8px;padding:4px 11px;border-radius:999px;background:#fff;color:#0d4ea6;font-size:12px;font-style:normal;font-weight:950;}
.mini-mag-icons{flex:0 0 auto;max-width:260px;}
.mini-mag-icons div{width:64px !important;height:64px !important;border-radius:15px !important;}
.mag-card-opportunity-v22{min-width:116px;text-align:center;line-height:1.02;padding:5px 9px !important;}
.mag-card-opportunity-v22 strong{display:block;font-size:9px;line-height:1.02;}
.mag-card-opportunity-v22 span{display:block;font-size:10px;line-height:1.02;}
.oportunidade-v22{min-height:76px !important;width:110px !important;padding:7px 9px !important;border-radius:12px !important;}
.oportunidade-v22 strong{font-size:11px !important;line-height:1.02 !important;}
.oportunidade-v22 b{display:block;color:#fff;font-size:30px;line-height:.95;margin:2px 0;font-weight:950;}
.oportunidade-v22 span{font-size:13px !important;line-height:1.02 !important;margin:0 !important;}
.sugestao-card-ref .suggestion-region{font-size:11px !important;font-weight:950 !important;letter-spacing:.2px;}
.sugestao-card-ref .suggestion-price-line small{font-size:10.5px !important;font-weight:800;color:#596579;}
@media(max-width:1180px){
  .mini-magazine-hero{flex-wrap:wrap;}
  .mini-mag-region-v22{order:3;flex-basis:100%;max-width:none;}
}


/* ============================================================
   V22 FINAL REAL 2 — ajustes finos dashboard
   ============================================================ */
.mini-magazine-hero{
    align-items:stretch !important;
    gap:18px !important;
}
.mini-magazine-copy{
    display:flex;
    flex-direction:column;
    justify-content:center;
}
.mini-mag-region-v22{
    display:flex;
    align-items:flex-start;
    justify-content:flex-start;
    gap:13px;
    min-width:360px;
    max-width:430px;
    padding:18px 20px;
    border:1px solid rgba(255,255,255,.44);
    border-radius:18px;
    background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.05));
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.06), 0 12px 28px rgba(0,0,0,.08);
    color:#fff;
    flex:0 1 410px;
}
.mini-mag-region-v22 .region-pin-v22{
    font-size:24px;
    line-height:1;
    margin-top:2px;
}
.mini-mag-region-v22 strong{
    display:block;
    font-size:21px;
    line-height:1.08;
    font-weight:950;
    letter-spacing:.15px;
    color:#fff;
}
.mini-mag-region-v22 small{
    display:block;
    margin-top:7px;
    font-size:15px;
    line-height:1.22;
    font-weight:800;
    color:#f8fbff;
}
.mini-mag-region-v22 em{
    display:inline-flex;
    margin-top:10px;
    padding:5px 12px;
    border-radius:999px;
    background:#fff;
    color:#0d4ea6;
    font-size:12px;
    font-style:normal;
    font-weight:950;
}
.mag-card-opportunity-v22{
    min-width:116px;
    max-width:116px;
    min-height:46px;
    text-align:center;
    line-height:1.02;
    padding:6px 8px !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
}
.mag-card-opportunity-v22 strong{display:block;font-size:9px;line-height:1.02;}
.mag-card-opportunity-v22 span{display:block;font-size:10px;line-height:1.02;}
.mag-card-info{padding-top:30px !important;}
.mag-card-info h3{margin:8px 0 5px !important;font-size:17px !important;line-height:1.12 !important;}
.mag-card-info p{margin:0 !important;}
.mag-card-info strong{margin-top:9px !important;font-size:22px !important;}
.mag-region-inline{
    margin-top:8px;
    padding:7px 8px;
    border-radius:10px;
    background:#f6f9ff;
    border:1px solid #d8e6fb;
}
.mag-region-inline span{
    display:block;
    color:#003b79;
    font-size:10.2px;
    line-height:1.15;
    font-weight:950;
    letter-spacing:.15px;
}
.mag-region-inline small{
    display:block;
    margin-top:3px;
    color:#5b6578;
    font-size:10px;
    line-height:1.18;
    font-weight:800;
}
@media(max-width:1180px){
  .mini-magazine-copy{max-width:none !important;}
}


/* ============================================================
   V23 — Padrão Jornal Global / Dashboard profissional
   ============================================================ */
.mini-magazine-hero{
    align-items:center !important;
    gap:18px !important;
    min-height:176px !important;
}
.mini-magazine-copy{
    flex:1 1 42% !important;
    max-width:560px !important;
}
.mini-magazine-copy h3{
    font-size:29px !important;
    line-height:1.08 !important;
    letter-spacing:-.4px !important;
}
.mini-mag-region-v22{
    display:flex !important;
    align-items:flex-start !important;
    gap:12px !important;
    min-width:350px !important;
    max-width:420px !important;
    padding:16px 18px !important;
    border:1px solid rgba(255,255,255,.36) !important;
    border-radius:16px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.055)) !important;
    box-shadow:0 12px 26px rgba(0,0,0,.08), inset 0 0 0 1px rgba(255,255,255,.08) !important;
    color:#fff !important;
    flex:0 1 400px !important;
}
.mini-mag-region-v22 .region-pin-v22{
    font-size:22px !important;
    line-height:1 !important;
    margin-top:2px !important;
}
.mini-mag-region-v22 strong{
    display:block !important;
    font-size:19px !important;
    line-height:1.08 !important;
    font-weight:950 !important;
    color:#fff !important;
}
.mini-mag-region-v22 small{
    display:block !important;
    margin-top:6px !important;
    font-size:13.5px !important;
    line-height:1.25 !important;
    font-weight:800 !important;
    color:#f4f8ff !important;
}
.mini-mag-region-v22 em{
    display:inline-flex !important;
    margin-top:8px !important;
    padding:4px 10px !important;
    border-radius:999px !important;
    background:#fff !important;
    color:#004f9e !important;
    font-size:11px !important;
    font-style:normal !important;
    font-weight:950 !important;
}
.mini-mag-icons{flex:0 0 auto !important;max-width:252px !important;}
.mini-mag-icons div{width:62px !important;height:62px !important;border-radius:14px !important;}

.magazine-card{
    min-height:250px !important;
}
.mag-card-opportunity-v22{
    min-width:116px !important;
    max-width:116px !important;
    min-height:40px !important;
    padding:5px 8px !important;
    border-radius:9px !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    line-height:1.02 !important;
}
.mag-card-opportunity-v22 strong{font-size:8.6px !important;line-height:1.0 !important;}
.mag-card-opportunity-v22 span{font-size:9.4px !important;line-height:1.0 !important;}

.mag-card-info{
    padding-top:29px !important;
}
.mag-card-info .mag-sku{
    font-size:10.5px !important;
    padding:3px 7px !important;
}
.mag-card-info h3{
    margin:8px 0 5px !important;
    font-size:16.5px !important;
    line-height:1.12 !important;
    color:#003b79 !important;
}
.mag-card-info p{
    margin:0 !important;
    font-size:12px !important;
    line-height:1.25 !important;
}
.mag-card-info strong{
    display:block !important;
    margin-top:8px !important;
    font-size:22px !important;
    line-height:1 !important;
}
.mag-region-inline-v23{
    margin-top:8px !important;
    padding:7px 9px !important;
    border-radius:10px !important;
    background:linear-gradient(180deg,#f8fbff,#eef5ff) !important;
    border:1px solid #dbeafe !important;
}
.mag-region-inline-v23 span{
    display:block !important;
    color:#003b79 !important;
    font-size:9.5px !important;
    line-height:1.12 !important;
    font-weight:950 !important;
    letter-spacing:.1px !important;
}
.mag-region-inline-v23 small{
    display:block !important;
    margin-top:3px !important;
    color:#667085 !important;
    font-size:9.2px !important;
    line-height:1.14 !important;
    font-weight:800 !important;
}
@media(max-width:1180px){
    .mini-magazine-hero{flex-wrap:wrap !important;}
    .mini-mag-region-v22{order:3 !important;flex-basis:100% !important;max-width:none !important;}
}


/* ============================================================
   V24 — Dashboard profissional / refinamento visual final
   ============================================================ */
.mini-magazine-hero{
    align-items:center !important;
    gap:20px !important;
    min-height:184px !important;
}
.mini-magazine-copy h3{
    font-size:30px !important;
    line-height:1.06 !important;
    max-width:520px !important;
}
.mini-mag-region-v22{
    min-width:390px !important;
    max-width:430px !important;
    padding:15px 18px !important;
    border-radius:18px !important;
    border:1px solid rgba(255,255,255,.30) !important;
    background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.07)) !important;
}
.mini-mag-region-v22 strong{
    font-size:17px !important;
    line-height:1.05 !important;
    letter-spacing:.1px !important;
}
.mini-mag-region-v22 small{
    margin-top:6px !important;
    font-size:12.8px !important;
    line-height:1.22 !important;
    font-weight:800 !important;
}
.magazine-card{
    min-height:258px !important;
}
.mag-card-opportunity-v22{
    min-width:102px !important;
    max-width:102px !important;
    min-height:34px !important;
    border-radius:10px !important;
}
.mag-card-opportunity-v22 strong{font-size:8.2px !important;}
.mag-card-opportunity-v22 span{font-size:8.7px !important;}
.mag-card-info{
    padding-top:25px !important;
}
.mag-card-info h3{
    margin:6px 0 4px !important;
    font-size:15px !important;
    line-height:1.08 !important;
    min-height:32px !important;
}
.mag-card-info p{
    font-size:11px !important;
    line-height:1.18 !important;
}
.mag-region-inline-v23{
    margin-top:7px !important;
    padding:3px 0 0 9px !important;
    border:0 !important;
    border-left:3px solid #f4c400 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
}
.mag-region-inline-v23 span{
    display:block !important;
    color:#1d2939 !important;
    font-size:9px !important;
    line-height:1.08 !important;
    font-weight:950 !important;
    letter-spacing:0 !important;
}
.mag-region-inline-v23 small{
    display:block !important;
    margin-top:2px !important;
    color:#667085 !important;
    font-size:8.7px !important;
    line-height:1.12 !important;
    font-weight:800 !important;
}
.mag-card-info strong{
    margin-top:10px !important;
    font-size:21px !important;
}


/* ============================================================
   V25 — Dashboard profissional e cards proporcionais
   ============================================================ */
.dashboard-page .magazine-preview-panel{
    padding-bottom:28px !important;
}
.dashboard-page .mini-magazine-hero{
    display:grid !important;
    grid-template-columns:minmax(360px,1.15fr) minmax(330px,.72fr) auto !important;
    align-items:center !important;
    gap:22px !important;
    min-height:178px !important;
    padding:24px 28px !important;
    border-radius:20px !important;
    background:
      radial-gradient(circle at 88% 34%,rgba(255,255,255,.12),transparent 28%),
      linear-gradient(120deg,#00265f 0%,#004f9e 58%,#0066c9 100%) !important;
}
.dashboard-page .mini-magazine-copy h3{
    font-size:29px !important;
    line-height:1.08 !important;
    max-width:520px !important;
}
.dashboard-page .mini-magazine-copy p{
    max-width:560px !important;
    font-size:14px !important;
}
.dashboard-page .mini-mag-region-v22{
    min-width:0 !important;
    max-width:390px !important;
    padding:15px 17px !important;
    border-radius:17px !important;
    border:1px solid rgba(255,255,255,.30) !important;
    background:linear-gradient(180deg,rgba(255,255,255,.13),rgba(255,255,255,.06)) !important;
}
.dashboard-page .mini-mag-region-v22 strong{
    font-size:16px !important;
    line-height:1.08 !important;
}
.dashboard-page .mini-mag-region-v22 small{
    font-size:12px !important;
    line-height:1.2 !important;
}
.dashboard-page .mini-mag-region-v22 em{
    font-size:10.5px !important;
    padding:4px 9px !important;
}
.dashboard-page .mini-mag-icons{
    width:172px !important;
    display:grid !important;
    grid-template-columns:repeat(2,64px) !important;
    gap:10px !important;
}
.dashboard-page .mini-mag-icons div{
    width:64px !important;
    height:64px !important;
    border-radius:14px !important;
}

.dashboard-page .magazine-card-grid.compact{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:15px !important;
}
.dashboard-page .magazine-card{
    min-height:270px !important;
    display:grid !important;
    grid-template-columns:92px 1fr !important;
    grid-template-rows:auto 1fr auto !important;
    gap:10px 12px !important;
    padding:15px 14px 13px !important;
    border-radius:18px !important;
    overflow:hidden !important;
}
.dashboard-page .mag-card-opportunity-v22{
    left:14px !important;
    top:12px !important;
    min-width:104px !important;
    max-width:104px !important;
    min-height:36px !important;
    padding:5px 8px !important;
    border-radius:10px !important;
    line-height:1.02 !important;
}
.dashboard-page .mag-card-opportunity-v22 strong{font-size:8px !important;}
.dashboard-page .mag-card-opportunity-v22 span{font-size:8.6px !important;}
.dashboard-page .mag-card-img{
    width:92px !important;
    height:104px !important;
    margin-top:38px !important;
    border-radius:14px !important;
}
.dashboard-page .mag-card-info{
    padding-top:24px !important;
    min-width:0 !important;
}
.dashboard-page .mag-card-info .mag-sku{
    font-size:10px !important;
    padding:3px 7px !important;
}
.dashboard-page .mag-card-info h3{
    margin:7px 0 5px !important;
    font-size:15.5px !important;
    line-height:1.10 !important;
    min-height:36px !important;
    max-height:54px !important;
    overflow:hidden !important;
}
.dashboard-page .mag-card-info p{
    margin:0 !important;
    font-size:11.5px !important;
    line-height:1.18 !important;
}
.dashboard-page .mag-region-inline-v23{
    margin-top:7px !important;
    padding:5px 0 0 8px !important;
    border:0 !important;
    border-left:3px solid #f4c400 !important;
    border-radius:0 !important;
    background:transparent !important;
}
.dashboard-page .mag-region-inline-v23 span{
    display:block !important;
    color:#263448 !important;
    font-size:8.8px !important;
    line-height:1.1 !important;
    font-weight:950 !important;
}
.dashboard-page .mag-region-inline-v23 small{
    display:block !important;
    margin-top:2px !important;
    color:#667085 !important;
    font-size:8.4px !important;
    line-height:1.1 !important;
    font-weight:800 !important;
}
.dashboard-page .mag-card-info strong{
    margin-top:9px !important;
    font-size:21px !important;
    line-height:1 !important;
}
.dashboard-page .mag-card-btn{
    grid-column:1/-1 !important;
    margin-top:8px !important;
    padding:10px 12px !important;
    border-radius:11px !important;
}
@media(max-width:1280px){
  .dashboard-page .mini-magazine-hero{grid-template-columns:1fr !important;}
  .dashboard-page .mini-mag-icons{display:flex !important;width:auto !important;}
  .dashboard-page .magazine-card-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}


/* ============================================================
   V31 - Botões dashboard Revista / PDF
   ============================================================ */
.revista-actions-dashboard{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    align-items:center;
    margin-top:14px;
}
.btn-secondary-dashboard{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:11px 18px;
    border-radius:10px;
    font-weight:900;
    text-decoration:none;
    color:#003B79;
    background:#F6C400;
    box-shadow:0 8px 18px rgba(0,59,121,.10);
}
.btn-secondary-dashboard:hover{
    filter:brightness(.97);
}


/* ============================================================
   V33 - Dashboard: botões Revista / PDF
   ============================================================ */
.revista-call .revista-actions-dashboard{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:12px !important;
    align-items:center !important;
    margin-top:18px !important;
}
.revista-call .revista-dashboard-btn{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:46px !important;
    padding:12px 20px !important;
    border-radius:12px !important;
    font-weight:950 !important;
    font-size:15px !important;
    text-decoration:none !important;
    line-height:1 !important;
    box-shadow:0 10px 22px rgba(0,59,121,.14) !important;
    transition:transform .15s ease, filter .15s ease !important;
}
.revista-call .revista-dashboard-btn:hover{
    transform:translateY(-1px) !important;
    filter:brightness(.98) !important;
}
.revista-call .revista-dashboard-btn-view{
    color:#fff !important;
    background:linear-gradient(135deg,#003B79,#0057A8) !important;
}
.revista-call .revista-dashboard-btn-pdf{
    color:#003B79 !important;
    background:#F6C400 !important;
}
@media(max-width:720px){
    .revista-call .revista-actions-dashboard{
        flex-direction:column !important;
        align-items:stretch !important;
    }
    .revista-call .revista-dashboard-btn{
        width:100% !important;
    }
}


/* ============================================================
   V34 - Revista Brasfort Dashboard CTA
   ============================================================ */
.revista-call .revista-subtitle-v34{
    margin:10px 0 4px !important;
    color:#003B79 !important;
    font-weight:950 !important;
    font-size:18px !important;
    line-height:1.22 !important;
}
.revista-call .revista-text-v34{
    margin:6px 0 0 !important;
    color:#5f6d82 !important;
    font-size:14px !important;
    line-height:1.45 !important;
    max-width:620px !important;
}
.revista-call .revista-dashboard-btn{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:8px !important;
    min-height:48px !important;
    padding:13px 21px !important;
    border-radius:14px !important;
    font-weight:950 !important;
    font-size:15px !important;
    line-height:1 !important;
    text-decoration:none !important;
}
.revista-call .revista-dashboard-btn-view{
    color:#ffffff !important;
    background:linear-gradient(135deg,#003B79,#0057A8) !important;
}
.revista-call .revista-dashboard-btn-pdf{
    color:#003B79 !important;
    background:#F6C400 !important;
}


/* ============================================================
   V43 FALLBACK - Meus Pedidos
   Aplicado mesmo se o template antigo pedidos-v37 continuar em uso.
   ============================================================ */
body .pedidos-v37 .pedidos-hero-v39{
    display:grid !important;
    grid-template-columns:1fr auto !important;
    gap:22px !important;
    align-items:center !important;
    margin-bottom:18px !important;
    padding:24px 26px !important;
    border-radius:24px !important;
    background:linear-gradient(135deg,#003B79 0%,#0057A8 58%,#0476D9 100%) !important;
    box-shadow:0 18px 40px rgba(0,59,121,.18) !important;
}
body .pedidos-v37 .pedidos-hero-v39 h2{
    font-size:36px !important;
    line-height:1.04 !important;
    margin:14px 0 8px !important;
}
body .pedidos-v37 .pedidos-hero-v39 p{
    max-width:760px !important;
    font-size:15px !important;
    line-height:1.45 !important;
}
body .pedidos-v37 .pedidos-hero-v39 .hero-status-card{
    display:none !important;
}
body .pedidos-v37 .pedidos-hero-v39 .hero-back,
body .pedidos-v37 .pedidos-hero-v39 a[href*="dashboard"]{
    background:#F6C400 !important;
    color:#003B79 !important;
    border-radius:14px !important;
    min-height:44px !important;
    padding:12px 18px !important;
    font-weight:950 !important;
    text-decoration:none !important;
}
body .pedidos-v37 .totalizador-grid{
    display:grid !important;
    grid-template-columns:repeat(4,minmax(160px,1fr)) !important;
    gap:12px !important;
}
body .pedidos-v37 .total-card{
    min-height:98px !important;
    padding:16px !important;
    border-radius:18px !important;
    background:linear-gradient(180deg,#ffffff,#f8fbff) !important;
    box-shadow:0 10px 24px rgba(0,59,121,.06) !important;
}
body .pedidos-v37 .total-card .value{
    font-size:26px !important;
}
body .pedidos-v37 .cashback-card{
    display:none !important;
}
body .pedidos-v37 .cashback-rule{
    background:#fff !important;
    border:1px solid #dbe6f4 !important;
    border-radius:15px !important;
    box-shadow:0 8px 20px rgba(0,59,121,.05) !important;
}
@media(max-width:980px){
    body .pedidos-v37 .pedidos-hero-v39,
    body .pedidos-v37 .totalizador-grid{
        grid-template-columns:1fr !important;
    }
}


/* ============================================================
   V47B - AJUSTE FINAL: cabeçalho moderno Meus Pedidos
   Corrige estouro do logo/menu e mantém proporção profissional.
   ============================================================ */
.layout-topbar-v47{
    display:block !important;
    min-height:100vh;
    background:#f3f7fc;
    overflow-x:hidden;
}
.top-header-v47{
    height:96px;
    padding:0 34px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    background:linear-gradient(90deg,#06245f 0%,#083b94 52%,#005bc8 100%);
    color:#fff;
    box-shadow:0 12px 28px rgba(5,31,85,.14);
    position:sticky;
    top:0;
    z-index:50;
}
.top-header-v47-left,
.top-header-v47-right{
    display:flex;
    align-items:center;
    gap:22px;
    min-width:0;
}
.top-logo-global{
    width:178px !important;
    height:auto !important;
    max-height:58px !important;
    object-fit:contain !important;
    display:block;
}
.top-logo-brasfort{
    width:122px !important;
    height:auto !important;
    max-height:56px !important;
    object-fit:contain !important;
    display:block;
}
.top-header-divider{
    width:1px;
    height:52px;
    background:rgba(255,255,255,.55);
    flex:0 0 auto;
}
.top-campaign-pill{
    display:inline-flex;
    align-items:center;
    gap:10px;
    height:46px;
    padding:0 24px;
    border:1px solid rgba(255,255,255,.26);
    border-radius:14px;
    background:rgba(255,255,255,.08);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
    color:#fff;
    text-transform:uppercase;
    font-weight:900;
    letter-spacing:.35px;
    white-space:nowrap;
}
.top-header-v47-right .bell{
    position:relative;
    width:42px;
    height:42px;
    border-radius:50%;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,.10);
    color:#fff;
    font-size:23px;
}
.top-header-v47-right .bell b{
    position:absolute;
    top:-5px;
    right:-4px;
    width:19px;
    height:19px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#ffc400;
    color:#09336f;
    font-size:11px;
    font-weight:950;
}
.top-header-v47-right .avatar{
    width:52px;
    height:52px;
    border-radius:50%;
    background:#0d7cea;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:950;
    font-size:18px;
    box-shadow:0 0 0 4px rgba(255,255,255,.08);
    flex:0 0 52px;
}
.top-user-v47{
    display:flex;
    flex-direction:column;
    min-width:0;
    line-height:1.15;
}
.top-user-v47 strong{
    max-width:250px;
    display:block;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:15px;
    font-weight:950;
    color:#fff;
}
.top-user-v47 small{
    margin-top:4px;
    color:rgba(255,255,255,.78);
    font-size:13px;
    font-weight:700;
}
.content-topbar-v47{
    margin:0 auto !important;
    padding:28px 34px 24px !important;
    width:100% !important;
    max-width:1600px !important;
    min-height:calc(100vh - 96px);
    box-sizing:border-box;
    overflow-x:hidden;
}
.layout-topbar-v47 .footer-lock{
    margin:22px auto 0;
    text-align:center;
    color:#5e6c80;
    font-size:13px;
}
@media(max-width:1200px){
    .top-header-v47{height:auto;min-height:88px;padding:16px 22px;align-items:flex-start;flex-direction:column;}
    .top-header-v47-left,.top-header-v47-right{width:100%;justify-content:space-between;gap:14px;}
    .top-logo-global{width:148px !important;max-height:48px !important;}
    .top-logo-brasfort{width:98px !important;max-height:44px !important;}
    .top-campaign-pill{height:40px;padding:0 14px;font-size:12px;}
    .content-topbar-v47{padding:22px 16px !important;}
}
@media(max-width:760px){
    .top-header-v47-left{flex-wrap:wrap;justify-content:flex-start;}
    .top-header-divider{display:none;}
    .top-user-v47 strong{max-width:180px;}
}

/* V47B - Revista: capa e contracapa sem corte/estouro */
.capa-brasfort-v46-imagem,
.contracapa-brasfort-v46-imagem,
.capa-brasfort-v47-imagem,
.contracapa-brasfort-v47-imagem{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#ffffff;
    overflow:hidden;
}
.capa-brasfort-v46-imagem img,
.contracapa-brasfort-v46-imagem img,
.capa-brasfort-v47-imagem img,
.contracapa-brasfort-v47-imagem img{
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
    object-position:center center !important;
    display:block !important;
    background:#ffffff;
}


/* ============================================================
   V48 - Topbar mais compacto e responsivo
   ============================================================ */
.layout-topbar-v47{background:#f4f7fb !important;overflow-x:hidden !important;}
.top-header-v47{height:74px !important;padding:0 28px !important;gap:18px !important;}
.top-header-v47-left,.top-header-v47-right{gap:16px !important;}
.top-logo-global{width:150px !important;max-height:46px !important;object-fit:contain !important;filter:none !important;}
.top-logo-brasfort{width:90px !important;max-height:42px !important;object-fit:contain !important;}
.top-header-divider{height:42px !important;background:rgba(255,255,255,.48) !important;}
.top-campaign-pill{height:38px !important;padding:0 18px !important;border-radius:12px !important;font-size:13px !important;}
.top-header-v47-right .bell{width:38px !important;height:38px !important;font-size:20px !important;}
.top-header-v47-right .avatar{width:44px !important;height:44px !important;flex-basis:44px !important;font-size:16px !important;}
.top-user-v47 strong{font-size:14px !important;max-width:230px !important;}
.top-user-v47 small{font-size:12px !important;}
.content-topbar-v47{max-width:1540px !important;padding:24px 28px 24px !important;min-height:calc(100vh - 74px) !important;}
@media(max-width:1024px){
  .top-header-v47{height:auto !important;min-height:72px !important;padding:12px 16px !important;flex-wrap:wrap !important;}
  .top-logo-global{width:128px !important;max-height:42px !important;}
  .top-logo-brasfort{width:78px !important;}
  .top-campaign-pill{height:34px !important;padding:0 12px !important;font-size:11px !important;}
  .content-topbar-v47{padding:18px 14px !important;}
}
@media(max-width:700px){
  .top-header-v47{align-items:flex-start !important;}
  .top-header-v47-left{width:100% !important;gap:10px !important;flex-wrap:wrap !important;}
  .top-header-v47-right{width:100% !important;justify-content:flex-start !important;gap:10px !important;}
  .top-header-divider{display:none !important;}
  .top-logo-global{width:118px !important;}
  .top-logo-brasfort{width:72px !important;}
  .top-user-v47 strong{max-width:185px !important;}
}


/* ==========================================================
   V52 - Ajustes globais: WhatsApp, rodapé e responsividade
   ========================================================== */
.sidebar-help{margin-top:18px;padding:16px;border-radius:18px}
.sidebar-help .whatsapp-link{display:block;text-align:center;background:#23c55e;border:1px solid #23c55e;color:#fff!important;font-weight:950;margin:10px 0 8px;padding:10px 12px;border-radius:11px;box-shadow:0 8px 18px rgba(35,197,94,.16)}
.sidebar-help .whatsapp-link:hover{filter:brightness(.96);transform:translateY(-1px)}
.sidebar-help .revista-link{display:block;text-align:center;border:1px solid var(--yellow);color:var(--yellow)!important;background:transparent;font-weight:900;padding:9px 12px;border-radius:11px}
.footer-lock{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;color:#61708a;font-size:12.5px;line-height:1.35;margin:18px 0 8px;padding:0 10px}
.footer-lock small{display:block;color:#7c8799;font-size:11.5px;font-weight:700;letter-spacing:.1px}
@media(max-width:720px){.footer-lock{font-size:11.5px}.footer-lock small{font-size:10.5px}.sidebar-help{margin-top:12px}}

/* V56A - Login: olho à direita dentro do campo */
.auth-card .password-field{
    position:relative;
    width:100%;
}
.auth-card .password-field input{
    width:100%;
    box-sizing:border-box;
    padding-right:56px;
}
.auth-card .toggle-password{
    position:absolute;
    right:12px;
    top:50%;
    transform:translateY(-50%);
    width:28px;
    height:28px;
    padding:0;
    margin:0;
    border:none;
    background:transparent;
    color:#0b4ea2;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:3;
    box-shadow:none;
}
.auth-card .toggle-password:hover{
    color:#083a79;
    background:transparent;
    border:none;
}
.auth-card .toggle-password:focus-visible{
    outline:2px solid rgba(0,85,194,.25);
    outline-offset:3px;
    border-radius:8px;
}
.auth-card .toggle-password .eye-icon{
    display:flex;
    align-items:center;
    justify-content:center;
}
.auth-card .toggle-password .eye-icon svg{
    width:22px;
    height:22px;
    display:block;
}
.auth-card .toggle-password .is-hidden{
    display:none;
}


/* V57 - Ajustes mobile Android/iOS: navegação, rolagem e textos sem atropelar */
html{
    scroll-behavior:smooth;
}
body{
    -webkit-text-size-adjust:100%;
}
img, svg, video{
    max-width:100%;
}
@media(max-width: 820px){
    body{
        overflow-x:hidden;
    }

    .app-shell,
    .portal-shell,
    .layout,
    .main-layout{
        width:100%;
        max-width:100%;
    }

    /* Menu lateral vira topo compacto no celular */
    .sidebar{
        position:relative !important;
        width:100% !important;
        min-width:0 !important;
        max-width:100% !important;
        height:auto !important;
        min-height:0 !important;
        padding:14px 12px !important;
        border-radius:0 0 20px 20px !important;
        overflow:visible !important;
        z-index:20;
    }
    .sidebar .logo,
    .sidebar-logo,
    .side-logo{
        max-width:190px !important;
        margin:0 auto 10px !important;
        display:block !important;
    }
    .sidebar .campaign,
    .sidebar-campaign,
    .side-campaign{
        text-align:center !important;
        margin-bottom:10px !important;
    }
    .sidebar nav,
    .sidebar .menu,
    .side-menu{
        display:flex !important;
        flex-direction:row !important;
        gap:8px !important;
        overflow-x:auto !important;
        overflow-y:hidden !important;
        white-space:nowrap !important;
        padding:8px 2px 10px !important;
        -webkit-overflow-scrolling:touch;
        scrollbar-width:thin;
    }
    .sidebar nav a,
    .sidebar .menu a,
    .side-menu a,
    .sidebar a{
        flex:0 0 auto !important;
        min-height:42px !important;
        padding:10px 13px !important;
        border-radius:12px !important;
        font-size:14px !important;
        line-height:1.1 !important;
        display:inline-flex !important;
        align-items:center !important;
        gap:7px !important;
    }
    .sidebar-help{
        display:none !important;
    }

    .content,
    .main-content,
    .page-content,
    main{
        width:100% !important;
        max-width:100% !important;
        margin-left:0 !important;
        padding:14px 12px 72px !important;
        overflow-x:hidden !important;
    }

    /* Ao abrir pelo menu, conteúdo começa visível sem parecer que não clicou */
    .page-anchor-mobile{
        display:block;
        height:1px;
        scroll-margin-top:10px;
    }

    /* Cards e cabeçalhos no celular */
    .hero,
    .hero-panel,
    .dashboard-hero,
    .orders-hero,
    .regras-v54 .hero,
    .regras-v53 .hero{
        width:100% !important;
        max-width:100% !important;
        margin:0 0 14px !important;
        border-radius:18px !important;
        padding:16px !important;
    }

    h1{
        font-size:28px !important;
        line-height:1.08 !important;
        letter-spacing:-.2px !important;
    }
    h2{
        font-size:22px !important;
        line-height:1.12 !important;
    }
    h3{
        font-size:18px !important;
        line-height:1.15 !important;
    }
    p, span, small, label, td, th, a, button{
        line-height:1.28 !important;
    }

    /* Listagens/cards não comprados/top20 */
    .products-grid,
    .cards-grid,
    .product-grid,
    .suggestions-grid,
    .top20-grid,
    .nao-comprados-grid,
    .comprados-grid{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:14px !important;
        width:100% !important;
    }
    .product-card,
    .produto-card,
    .card-produto,
    .top-card,
    .suggestion-card{
        width:100% !important;
        max-width:100% !important;
        min-height:auto !important;
        display:grid !important;
        grid-template-columns:112px minmax(0,1fr) !important;
        gap:12px !important;
        padding:14px !important;
        overflow:hidden !important;
    }
    .product-card img,
    .produto-card img,
    .card-produto img,
    .top-card img,
    .suggestion-card img{
        max-width:100% !important;
        height:auto !important;
        object-fit:contain !important;
    }
    .product-card .title,
    .produto-card .title,
    .card-produto .title,
    .product-title,
    .nome-produto{
        font-size:17px !important;
        line-height:1.08 !important;
        word-break:normal !important;
        overflow-wrap:anywhere !important;
    }
    .product-card .btn,
    .produto-card .btn,
    .card-produto .btn,
    .btn-site,
    .btn-primary{
        width:100% !important;
        min-height:42px !important;
        font-size:15px !important;
        white-space:normal !important;
    }

    /* Tabelas largas: rolagem horizontal, sem cortar colunas */
    table{
        width:100%;
    }
    .table-wrap,
    .table-responsive,
    .ranking-table,
    .faixas-table,
    .pedidos-table{
        overflow-x:auto !important;
        -webkit-overflow-scrolling:touch;
        max-width:100% !important;
    }
    .table-wrap table,
    .table-responsive table,
    .ranking-table table,
    .faixas-table table,
    .pedidos-table table{
        min-width:720px !important;
    }
    th,td{
        font-size:13px !important;
        padding:10px 9px !important;
        vertical-align:middle !important;
    }

    /* Revista no celular: evita cabeçalho/rodapé atropelando e botão fixo cobrindo produto */
    .magazine-page,
    .revista-page,
    .page-spread{
        width:100% !important;
        max-width:100% !important;
        transform:none !important;
        margin:0 auto 18px !important;
        overflow:visible !important;
    }
    .revista-actions,
    .magazine-actions,
    .flipbook-actions{
        position:sticky !important;
        bottom:8px !important;
        left:auto !important;
        right:auto !important;
        width:calc(100% - 18px) !important;
        margin:12px auto !important;
        display:flex !important;
        flex-wrap:wrap !important;
        justify-content:center !important;
        gap:8px !important;
        z-index:30;
    }
    .revista-actions a,
    .revista-actions button,
    .magazine-actions a,
    .magazine-actions button,
    .flipbook-actions a,
    .flipbook-actions button{
        flex:1 1 140px !important;
        min-height:44px !important;
    }

    /* Regras aprovadas */
    .regras-v54,
    .regras-v53,
    .regras-v55{
        width:100% !important;
        max-width:100% !important;
        padding:0 !important;
    }
    .regras-v54 .page-grid,
    .regras-v53 .layout{
        grid-template-columns:1fr !important;
    }
    .regras-v54 .rules-grid,
    .regras-v53 .rules-grid{
        grid-template-columns:1fr !important;
    }
    .regras-v54 .formula-row,
    .regras-v53 .formula{
        grid-template-columns:1fr !important;
    }
    .regras-v54 .side-panel,
    .regras-v53 .art-panel{
        max-width:100% !important;
    }

    /* Login */
    .auth-card{
        width:calc(100% - 28px) !important;
        padding:22px !important;
        border-radius:20px !important;
    }
    .auth-logo{
        width:220px !important;
    }
}

/* Telas muito estreitas */
@media(max-width: 420px){
    .product-card,
    .produto-card,
    .card-produto,
    .top-card,
    .suggestion-card{
        grid-template-columns:96px minmax(0,1fr) !important;
        padding:12px !important;
        gap:10px !important;
    }
    .product-card .title,
    .produto-card .title,
    .card-produto .title,
    .product-title,
    .nome-produto{
        font-size:15.5px !important;
    }
    h1{font-size:25px !important}
    h2{font-size:20px !important}
    .sidebar nav a,
    .sidebar .menu a,
    .side-menu a,
    .sidebar a{
        font-size:13px !important;
        padding:9px 11px !important;
    }
}

/* Melhor experiência: ao navegar por links internos no mobile, o navegador já posiciona o conteúdo */
@media(max-width: 820px){
    #conteudo,
    #main,
    main,
    .main-content,
    .page-content{
        scroll-margin-top:12px;
    }
}


/* V58 - Refinos mobile visual e destaque da promoção */
.mobile-only{display:none}
.table-mobile-stack{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}

@media(max-width:820px){
    .panel-head,
    .products-head,
    .search-row{
        display:grid !important;
        grid-template-columns:1fr !important;
        align-items:flex-start !important;
        gap:12px !important;
    }
    .panel-head > a,
    .products-head > a,
    .search-row > a{
        width:100%;
        text-align:center;
    }
    .counter-pill{width:fit-content !important}
    .search-box input{font-size:16px !important}

    /* Top 20 mobile */
    .top20-grid.pro{grid-template-columns:1fr !important;gap:16px !important}
    .top20-card.pro{
        grid-template-columns:1fr !important;
        gap:12px !important;
        padding:16px !important;
        align-items:start !important;
    }
    .top20-card.pro .top20-rank.top20-red-rank,
    .top20-card.pro .top20-rank{
        width:max-content !important;
        min-width:74px !important;
        justify-self:flex-start !important;
    }
    .top20-card.pro .top20-img{
        width:128px !important;
        height:110px !important;
        margin:0 auto !important;
    }
    .top20-card.pro .top20-info{width:100% !important}
    .top20-card.pro h3{font-size:16px !important;line-height:1.1 !important}
    .top20-card.pro p{font-size:14px !important;line-height:1.38 !important}
    .metric-row{gap:8px !important}
    .metric-pill{font-size:12px !important;line-height:1.2 !important;padding:7px 10px !important}
    .top20-card.pro .top20-cta{grid-column:auto !important;width:100% !important;min-height:46px !important}

    /* Sugestões e não comprados mobile */
    .nao-comprados-lista-ref.standalone,
    .suggestions-list-ref{grid-template-columns:1fr !important;gap:16px !important}
    .nao-comprado-card-ref,
    .sugestao-card-ref,
    .nao-comprado-card-ref.sugestao-card-ref{
        grid-template-columns:1fr !important;
        gap:12px !important;
        padding:15px !important;
        align-items:start !important;
    }
    .nao-badge-ref,
    .sugestao-badge-ref{
        width:max-content !important;
        min-width:132px !important;
        margin:0 auto 0 0 !important;
        min-height:56px !important;
    }
    .nao-img-ref,
    .sugestao-card-ref .nao-img-ref{
        width:128px !important;
        height:104px !important;
        margin:0 auto !important;
    }
    .nao-info-ref small{font-size:12px !important}
    .nao-info-ref h4,
    .sugestao-card-ref .nao-info-ref h4{
        font-size:16px !important;
        line-height:1.12 !important;
        margin:4px 0 6px !important;
        overflow-wrap:anywhere !important;
    }
    .nao-info-ref p,
    .nao-info-ref em{font-size:13px !important;line-height:1.32 !important}
    .sugestao-card-ref .suggestion-region{font-size:12px !important;line-height:1.15 !important}
    .suggestion-price-line small{font-size:11px !important;line-height:1.25 !important}
    .suggestion-price-line b{font-size:19px !important}
    .nao-btn-ref{grid-column:auto !important;width:100% !important;min-height:46px !important;padding:12px !important}

    /* Dashboard hero / mini magazine */
    .mini-magazine-hero,
    .mini-magazine-hero.full{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:14px !important;
        padding:18px !important;
    }
    .mini-magazine-copy h3{font-size:22px !important;line-height:1.07 !important}
    .mini-magazine-copy p{font-size:15px !important;line-height:1.35 !important}
    .mini-mag-region-v22{
        min-width:0 !important;
        max-width:100% !important;
        flex:none !important;
        padding:14px 14px !important;
    }
    .mini-mag-region-v22 strong{font-size:15px !important;line-height:1.15 !important}
    .mini-mag-region-v22 small{font-size:13px !important;line-height:1.3 !important}
    .mini-mag-icons{max-width:none !important;justify-content:flex-start !important}
    .mini-mag-icons div{width:70px !important;height:70px !important}

    /* Tabelas em cards no mobile */
    .mobile-card-table,
    .mobile-card-table tbody,
    .mobile-card-table tr,
    .mobile-card-table td{display:block !important;width:100% !important}
    .mobile-card-table thead{display:none !important}
    .mobile-card-table tbody{display:grid !important;gap:12px !important}
    .mobile-card-table tr{
        border:1px solid #dbe6f3 !important;
        border-radius:16px !important;
        padding:10px 12px !important;
        background:#fff !important;
        box-shadow:0 5px 14px rgba(0,59,121,.06) !important;
    }
    .mobile-card-table td{
        border:0 !important;
        padding:7px 0 !important;
        background:transparent !important;
        font-size:13.5px !important;
        line-height:1.3 !important;
    }
    .mobile-card-table td::before{
        content:attr(data-label);
        display:block;
        color:#667085;
        font-size:11px;
        font-weight:900;
        text-transform:uppercase;
        letter-spacing:.25px;
        margin-bottom:3px;
    }
    .faixas-table.mobile-card-table .current-row{
        border:2px solid #ffcc29 !important;
        background:#fff8d8 !important;
    }
    .current-badge,.ok-badge,.pending-badge{font-size:11px !important}

    /* Pedido detalhe */
    .panel h2{font-size:18px !important;line-height:1.14 !important}

    /* Revista mobile: evita botão tampando produto e melhora leitura */
    .content,main{padding-bottom:120px !important}
    .revista-actions,
    .magazine-actions,
    .flipbook-actions{
        bottom:calc(70px + env(safe-area-inset-bottom, 0px)) !important;
        width:calc(100% - 24px) !important;
        padding:0 !important;
    }
}

@media(max-width:420px){
    .top20-card.pro .top20-img,
    .nao-img-ref,
    .sugestao-card-ref .nao-img-ref{width:112px !important;height:94px !important}
    .top20-card.pro h3,
    .nao-info-ref h4,
    .sugestao-card-ref .nao-info-ref h4{font-size:15px !important}
    .metric-pill{font-size:11px !important}
}


/* ============================================================
   V60 - Menu mobile real + destaque 10.000 pontos + limpeza do dashboard
   ============================================================ */
.mobile-catalog-v59{display:none}
@media(max-width:820px){
    /* Dashboard mobile vira catálogo objetivo, sem cards gigantes duplicados */
    .mobile-catalog-v59{display:block;margin:0 auto 18px;max-width:720px;color:#07265a}
    .mobile-catalog-v59 ~ .hero-dashboard,
    .mobile-catalog-v59 ~ .kpi-grid,
    .mobile-catalog-v59 ~ .categoria-indicator,
    .mobile-catalog-v59 ~ .two-columns,
    .mobile-catalog-v59 ~ .quick-links-campaign,
    .mobile-catalog-v59 ~ .magazine-preview-panel{display:none!important}

    .mcat-hero{
        background:linear-gradient(135deg,#063987 0%,#0057c2 72%,#0071d8 100%);
        border-radius:0 0 18px 18px;
        padding:18px 16px 20px;
        color:#fff;
        display:grid;
        grid-template-columns:1fr;
        gap:14px;
        border-bottom:8px solid #ffcc29;
        box-shadow:0 12px 24px rgba(0,59,121,.14);
    }
    .mcat-menu-chip{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;max-width:210px;border:3px solid rgba(255,255,255,.82);border-radius:16px;padding:10px 14px;background:rgba(255,255,255,.06)}
    .mcat-menu-chip .mcat-hamb{font-size:26px;line-height:1}
    .mcat-menu-chip strong{font-size:24px;line-height:1;font-weight:950;letter-spacing:.3px}
    .mcat-menu-chip small{grid-column:1/-1;font-size:12px;line-height:1.2;color:#eaf2ff;font-weight:800}.mcat-menu-chip small b{color:#ffcc29}
    .mcat-title small{display:block;font-weight:900;font-size:16px;color:#dbeafe}.mcat-title h1{margin:4px 0 0;font-size:24px;line-height:1.05;color:#fff;font-weight:950}
    .mcat-logo{position:absolute;right:20px;top:24px;width:142px;max-width:34%;background:#fff;border-radius:24px;padding:10px 13px;box-shadow:0 10px 20px rgba(0,0,0,.12)}
    .mcat-hero{position:relative;min-height:178px}

    .mcat-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:16px 8px 10px;background:#fff}
    .mcat-menu-grid a{min-height:102px;text-align:center;border:1px solid #dce7f5;border-radius:14px;background:#fff;box-shadow:0 5px 16px rgba(0,59,121,.08);display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#08265b;padding:10px 6px;gap:5px;overflow:hidden}
    .mcat-menu-grid span{font-size:27px;line-height:1}.mcat-menu-grid b{font-size:14px;line-height:1.05;font-weight:950}.mcat-menu-grid small{font-size:11px;line-height:1.15;color:#405372}.mcat-menu-grid .blue{color:#0057c2}.mcat-menu-grid .gold{color:#e0a800}.mcat-menu-grid .green{color:#12a150}.mcat-menu-grid .purple{color:#7c3aed}.mcat-menu-grid .orange{color:#f97316}

    .mcat-whatsapp{margin:8px;display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:10px;border:1px solid #22c55e;background:linear-gradient(90deg,#edfff4,#f8fffb);border-radius:14px;padding:12px 14px;color:#0c6f35;text-decoration:none;box-shadow:0 5px 14px rgba(34,197,94,.10)}
    .mcat-whatsapp span{font-size:32px}.mcat-whatsapp b{font-size:17px;display:block;line-height:1.05}.mcat-whatsapp small{font-size:13px;color:#10233f}.mcat-whatsapp em{font-style:normal;font-size:42px;line-height:1;color:#0e7f3e}

    .mcat-points{margin:14px 8px 14px;border:2px solid #0057c2;border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 8px 18px rgba(0,59,121,.10)}
    .mcat-points-head{display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(90deg,#003b79,#0057c2);color:#fff;padding:12px 14px}.mcat-points-head b{font-size:16px;line-height:1.15}.mcat-points-head a{background:#ffcc29;color:#08265b!important;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:950;white-space:nowrap;text-decoration:none}
    .mcat-indicators{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:#fff}.mcat-indicators div{min-height:130px;padding:13px 8px;text-align:center;border-right:1px solid #e6edf7;border-bottom:1px solid #eef2f7;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px}.mcat-indicators div:nth-child(3n){border-right:0}.mcat-indicators span{font-size:24px}.mcat-indicators b{font-size:11px;line-height:1.15;color:#07265a}.mcat-indicators strong{font-size:22px;color:#0057c2;line-height:1}.mcat-indicators strong.green{color:#0a963c}.mcat-indicators strong.orange{color:#f97316}.mcat-indicators strong.teal{color:#0f9b9b}.mcat-indicators strong.gold{color:#d89400}.mcat-indicators small{font-size:11px;line-height:1.15;color:#34506e}.mcat-indicators i{display:block;width:54px;height:7px;border-radius:999px;background:linear-gradient(90deg,#7c3aed 75%,#e5e7eb 75%);margin:2px 0}

    .mcat-premio{display:grid;grid-template-columns:76px 1fr;gap:14px;align-items:center;margin:14px 8px 16px;padding:16px;border-radius:16px;border:1.5px solid #f2c94c;background:linear-gradient(120deg,#fff9df,#fffdf4);box-shadow:0 8px 18px rgba(210,147,0,.10)}
    .mcat-trophy{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#efb900;color:#fff;font-size:36px;box-shadow:0 8px 18px rgba(239,185,0,.2)}
    .mcat-premio small{display:inline-block;background:#fff;color:#b46b00;border-radius:999px;padding:4px 10px;font-weight:950;text-transform:uppercase;font-size:11px;line-height:1}.mcat-premio h2{margin:7px 0 4px;color:#003b79;font-size:19px;line-height:1.08;font-weight:950}.mcat-premio p{margin:0;color:#243a5a;font-size:13px;line-height:1.35}

    .mcat-products{display:grid;gap:12px;margin:0 8px 14px}.mcat-product-card{position:relative;display:grid;grid-template-columns:118px minmax(0,1fr) 20px;gap:12px;align-items:center;border:1px solid #dce7f5;border-radius:14px;background:#fff;box-shadow:0 6px 16px rgba(0,59,121,.08);padding:12px;overflow:hidden}.mcat-prod-left{text-align:center;position:relative}.mcat-red-tag{display:inline-flex;align-items:center;justify-content:center;min-width:86px;height:27px;border-radius:9px;background:#e00000;color:#fff;font-size:11px;font-weight:950;box-shadow:0 8px 16px rgba(224,0,0,.18);margin-bottom:6px}.mcat-prod-left img{width:88px;height:84px;object-fit:contain;border:1px solid #edf2f7;border-radius:11px;background:#fff;padding:5px}.mcat-prod-left small{display:block;color:#34506e;font-size:10.5px;line-height:1.05;font-weight:700;margin-top:4px}.mcat-prod-info{min-width:0}.mcat-prod-info h3{margin:0 0 5px;color:#004f9e;font-size:15px;line-height:1.08;font-weight:950;overflow-wrap:anywhere}.mcat-prod-info p{margin:2px 0;color:#10233f;font-size:11.5px;line-height:1.22}.mcat-prod-info small{display:block;margin-top:8px;color:#111827;font-size:10.5px;font-weight:950}.mcat-prod-info strong{display:block;color:#0057a8;font-size:20px;line-height:1.05;font-weight:950}.mcat-prod-info em{display:block;font-style:normal;color:#111827;font-size:11px;font-weight:800}.mcat-arrow{color:#667085!important;font-size:42px;line-height:1;text-decoration:none;align-self:center}
    .mcat-download{position:sticky;bottom:calc(10px + env(safe-area-inset-bottom,0px));z-index:40;display:flex;align-items:center;justify-content:center;margin:12px 8px 0;min-height:54px;border-radius:14px;background:linear-gradient(90deg,#003b79,#0057c2);color:#fff!important;text-decoration:none;font-weight:950;font-size:18px;box-shadow:0 10px 24px rgba(0,59,121,.22)}

    /* demais páginas mobile: evitar conteúdo atropelado */
    .top20-card.pro{grid-template-columns:88px minmax(0,1fr)!important;align-items:center!important;padding:13px!important;gap:11px!important}.top20-card.pro .top20-rank.top20-red-rank{grid-column:1/2;grid-row:1/2;min-width:66px!important;height:34px!important}.top20-card.pro .top20-img{grid-column:1/2;grid-row:2/3;width:82px!important;height:78px!important;margin:0!important}.top20-card.pro .top20-info{grid-column:2/3;grid-row:1/3}.top20-card.pro h3{font-size:15px!important;line-height:1.08!important;margin:5px 0!important}.top20-card.pro p{font-size:12px!important;line-height:1.24!important}.top20-card.pro .top20-cta{grid-column:1/-1!important;min-height:44px!important}
    .metric-pill{font-size:11px!important;padding:5px 8px!important}
    .page-hero h1{font-size:24px!important;line-height:1.05!important}.page-hero p{font-size:14px!important;line-height:1.35!important}.panel-head h2{font-size:22px!important;line-height:1.1!important}.panel-head p{font-size:15px!important;line-height:1.3!important}
    .revista-actions,.magazine-actions,.flipbook-actions{position:static!important;width:100%!important;margin:12px auto!important;box-shadow:none!important}.revista-actions a,.revista-actions button,.magazine-actions a,.magazine-actions button,.flipbook-actions a,.flipbook-actions button{min-height:46px!important;font-size:15px!important}
}
@media(max-width:390px){
    .mcat-logo{width:122px;right:14px}.mcat-menu-chip{max-width:190px}.mcat-title h1{font-size:22px}.mcat-menu-grid{gap:8px}.mcat-menu-grid a{min-height:92px}.mcat-menu-grid span{font-size:23px}.mcat-menu-grid b{font-size:13px}.mcat-menu-grid small{font-size:10px}.mcat-indicators strong{font-size:19px}.mcat-product-card{grid-template-columns:104px minmax(0,1fr) 16px;gap:9px;padding:11px}.mcat-prod-left img{width:78px;height:76px}.mcat-prod-info h3{font-size:14px}.mcat-prod-info strong{font-size:18px}
}


/* ============================================================
   V60 - Menu mobile real + banner 10.000 pontos + limpeza final
   ============================================================ */
.mobile-utility-bar,
.mobile-menu-toggle,
.mobile-score-chip{display:none}

.special-goal-banner{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:18px;align-items:center;margin:0 0 18px;padding:18px 20px;border:1px solid #f1d272;border-radius:18px;background:linear-gradient(120deg,#fff9df 0%,#fffdf3 100%);box-shadow:0 10px 24px rgba(203,151,15,.10)}
.special-goal-banner.within-page{margin:0 0 16px}
.special-goal-banner .goal-tag{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;background:#fff;color:#b67000;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.special-goal-banner .goal-copy h2{margin:0 0 6px;color:#003b79;font-size:32px;line-height:1.02;font-weight:950}
.special-goal-banner .goal-copy p{margin:0;color:#28405e;font-size:15px;line-height:1.4}
.special-goal-banner .goal-highlight{min-width:210px;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,#003b79,#0057c2);color:#fff;text-align:center;box-shadow:0 12px 24px rgba(0,59,121,.18)}
.special-goal-banner .goal-highlight span{display:block;font-size:12px;font-weight:800;opacity:.9;text-transform:uppercase;letter-spacing:.3px}
.special-goal-banner .goal-highlight strong{display:block;margin-top:5px;font-size:28px;line-height:1;font-weight:950}

@media(max-width:980px){.special-goal-banner{grid-template-columns:1fr;gap:12px;padding:16px}.special-goal-banner .goal-copy h2{font-size:26px}.special-goal-banner .goal-highlight{min-width:0;width:100%}}

@media(max-width:820px){
    .mobile-utility-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
    .mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 16px;border:2px solid rgba(255,255,255,.75);border-radius:14px;background:rgba(255,255,255,.08);color:#fff;font-size:16px;font-weight:950;box-shadow:0 8px 18px rgba(0,0,0,.10)}
    .mobile-score-chip{display:flex;flex-direction:column;justify-content:center;min-height:46px;flex:1;padding:8px 12px;border-radius:14px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);color:#fff;min-width:0}
    .mobile-score-chip span{font-size:10.5px;line-height:1.05;text-transform:uppercase;letter-spacing:.35px;opacity:.88;font-weight:800}
    .mobile-score-chip strong{display:block;margin-top:4px;font-size:15px;line-height:1.05;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .sidebar nav,.sidebar .menu,.side-menu{display:none !important;flex-direction:column !important;gap:8px !important;overflow:visible !important;white-space:normal !important;padding:8px 0 2px !important;width:100% !important}
    .sidebar.mobile-open nav,.sidebar.mobile-open .menu,.sidebar.mobile-open .side-menu{display:flex !important}
    .sidebar nav a,.sidebar .menu a,.side-menu a,.sidebar a{width:100% !important;justify-content:flex-start !important}
    .sidebar-help{display:none !important}
    .sidebar.mobile-open .sidebar-help{display:block !important;margin-top:12px !important}
    .mobile-catalog-v59{margin-top:6px}
    .mcat-points{margin-top:0}
    .mcat-indicators{grid-template-columns:repeat(2,1fr) !important}
    .mcat-indicators div:nth-child(3n){border-right:1px solid #e6edf7 !important}
    .mcat-indicators div:nth-child(2n){border-right:0 !important}
    .mcat-premio{padding:18px 14px !important;grid-template-columns:64px 1fr !important}
    .mcat-premio h2{font-size:22px !important;line-height:1.04 !important}
    .mcat-premio p{font-size:14px !important;line-height:1.36 !important}
}
@media(max-width:520px){.special-goal-banner .goal-copy h2{font-size:22px}.special-goal-banner .goal-copy p{font-size:14px}.special-goal-banner .goal-highlight strong{font-size:24px}}


/* ============================================================
   V61 - Cabeçalho unificado Web/Mobile + Experiência recomendada
   ============================================================ */

/* Web: transforma o topo em painel de performance constante */
.performance-userbar{
    position:sticky;
    top:0;
    z-index:35;
    width:100%;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:14px;
    padding:10px 20px;
    min-height:70px;
    background:rgba(245,249,255,.92);
    backdrop-filter:blur(12px);
    border-bottom:1px solid #dfe9f5;
    box-shadow:0 8px 24px rgba(0,59,121,.06);
}
.performance-userbar .user-main{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:250px;
}
.performance-userbar .bell{
    width:38px;
    height:38px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#fff;
    border:1px solid #e3edf7;
    box-shadow:0 6px 14px rgba(0,59,121,.08);
}
.performance-userbar .avatar{
    width:42px;
    height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    background:#004584;
    color:#fff;
    font-size:16px;
    font-weight:900;
}
.performance-userbar .user-text{
    display:flex;
    flex-direction:column;
    min-width:0;
}
.performance-userbar .user-text b{
    color:#1d2735;
    font-size:15px;
    line-height:1.1;
    max-width:230px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.performance-userbar .user-text small{
    color:#667085;
    font-size:12px;
    margin-top:2px;
}
.header-metrics{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}
.header-metrics div{
    min-width:92px;
    padding:8px 10px;
    border-radius:13px;
    background:#fff;
    border:1px solid #dbe6f3;
    box-shadow:0 6px 16px rgba(0,59,121,.05);
}
.header-metrics span{
    display:block;
    color:#667085;
    font-size:10px;
    line-height:1;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.3px;
}
.header-metrics strong{
    display:block;
    margin-top:4px;
    color:#003b79;
    font-size:16px;
    line-height:1;
    font-weight:950;
}
.header-revista-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:40px;
    padding:0 14px;
    border-radius:12px;
    background:#004584;
    color:#fff !important;
    font-weight:900;
    text-decoration:none;
    white-space:nowrap;
    box-shadow:0 8px 18px rgba(0,69,132,.18);
}

/* Mobile: topo menor, com pontuação e menu real; logos controlados */
.mobile-score-chip em{
    display:block;
    margin-top:2px;
    color:#ffcc29;
    font-size:12px;
    font-style:normal;
    line-height:1.05;
    font-weight:950;
}
.mobile-experience-note{
    display:none;
    border-radius:18px;
    border:1px solid #cfe1f5;
    background:linear-gradient(135deg,#f7fbff 0%,#ffffff 100%);
    padding:14px 16px;
    margin:14px 0;
    color:#003b79;
    box-shadow:0 8px 18px rgba(0,59,121,.05);
}
.mobile-experience-note strong{
    display:block;
    font-size:14px;
    line-height:1.2;
    margin-bottom:5px;
}
.mobile-experience-note span{
    display:block;
    color:#475467;
    font-size:13px;
    line-height:1.35;
}

@media(max-width:1180px){
    .performance-userbar{
        flex-wrap:wrap;
        justify-content:flex-end;
    }
    .header-metrics div{
        min-width:82px;
    }
}

@media(max-width:820px){
    .performance-userbar{
        position:relative;
        min-height:auto;
        padding:10px 14px;
        background:transparent;
        border:0;
        box-shadow:none;
        justify-content:center;
    }
    .performance-userbar .header-metrics,
    .performance-userbar .header-revista-btn{
        display:none;
    }
    .performance-userbar .user-main{
        min-width:0;
        width:100%;
        justify-content:center;
        padding:8px 10px;
        background:#fff;
        border:1px solid #dbe6f3;
        border-radius:18px;
        box-shadow:0 8px 20px rgba(0,59,121,.07);
    }
    .performance-userbar .bell{
        width:34px;
        height:34px;
    }
    .performance-userbar .avatar{
        width:38px;
        height:38px;
        font-size:14px;
    }
    .performance-userbar .user-text b{
        max-width:220px;
        font-size:14px;
    }

    .sidebar{
        padding:12px 14px !important;
        border-radius:0 0 22px 22px !important;
        background:linear-gradient(180deg,#003b79 0%,#004a96 100%) !important;
    }
    .sidebar .logo,
    .sidebar-logo,
    .side-logo{
        max-width:170px !important;
        max-height:64px !important;
        object-fit:contain !important;
        margin:8px auto 10px !important;
        border-radius:14px !important;
    }
    .sidebar .campaign,
    .sidebar-campaign,
    .side-campaign{
        transform:none !important;
        font-size:13px !important;
        line-height:1.2 !important;
        margin-bottom:10px !important;
    }
    .sidebar .campaign strong,
    .sidebar-campaign strong,
    .side-campaign strong{
        font-size:22px !important;
        line-height:1 !important;
    }

    .mobile-utility-bar{
        position:sticky;
        top:0;
        z-index:50;
        background:linear-gradient(180deg,#003b79 0%,#004a96 100%);
        padding:6px 0 10px;
        margin:-4px 0 10px;
    }
    .mobile-menu-toggle{
        min-height:42px !important;
        padding:0 14px !important;
        font-size:15px !important;
        border-radius:13px !important;
    }
    .mobile-score-chip{
        min-height:42px !important;
        padding:7px 11px !important;
    }
    .mobile-score-chip strong{
        font-size:16px !important;
    }

    .mobile-experience-note{
        display:block;
    }

    /* Evita card gigante duplicado no dashboard mobile */
    .mobile-catalog-v59{
        margin-top:0 !important;
    }
    .mobile-catalog-v59 .mcat-brand{
        padding:14px !important;
        border-radius:20px !important;
    }
    .mobile-catalog-v59 .mcat-brand img{
        max-width:210px !important;
        max-height:78px !important;
        object-fit:contain !important;
        margin:0 auto 10px !important;
    }
    .mobile-catalog-v59 .mcat-brand h2{
        font-size:24px !important;
        line-height:1.1 !important;
    }
    .mobile-catalog-v59 .mcat-brand .year,
    .mobile-catalog-v59 .mcat-brand strong{
        font-size:24px !important;
    }
    .hero,
    .dashboard-hero,
    .orders-hero{
        border-radius:18px !important;
        padding:16px !important;
    }
}

@media(max-width:420px){
    .performance-userbar .user-text b{
        max-width:170px;
    }
    .sidebar .logo,
    .sidebar-logo,
    .side-logo{
        max-width:150px !important;
        max-height:56px !important;
    }
    .mobile-catalog-v59 .mcat-brand img{
        max-width:180px !important;
    }
}


/* ============================================================
   V62 - Cabeçalho global com pontuação em todas as páginas
   ============================================================ */
.topbar-performance{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 18px;margin-bottom:10px;border-radius:20px;background:rgba(246,249,253,.92);border:1px solid #dce6f2;box-shadow:0 8px 20px rgba(0,59,121,.06);backdrop-filter:blur(10px);}
.topbar-client{display:flex;align-items:center;gap:12px;min-width:280px;}
.topbar-client .client-text{display:flex;flex-direction:column;min-width:0;}
.topbar-client .client-text strong{font-size:15px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#223047;max-width:260px;}
.topbar-client .client-text small{font-size:12px;color:#667085;}
.topbar-metrics{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px;flex:1;}
.metric-box{background:#fff;border:1px solid #dce6f2;border-radius:16px;padding:10px 12px;min-height:62px;box-shadow:0 4px 14px rgba(0,59,121,.04);}
.metric-box span{display:block;font-size:10px;font-weight:900;letter-spacing:.4px;text-transform:uppercase;color:#667085;margin-bottom:6px;}
.metric-box strong{display:block;font-size:20px;line-height:1.05;font-weight:950;color:#003b79;}
@media (max-width:1180px){.topbar-performance{flex-direction:column;align-items:stretch;}.topbar-client{min-width:0;}.topbar-metrics{grid-template-columns:repeat(2,minmax(140px,1fr));}}
@media (max-width:820px){.topbar-performance{display:none !important;} .sidebar .brand-box img{max-width:260px !important;max-height:120px !important;} .brand-campaign strong{font-size:56px !important;} .brand-campaign b{font-size:40px !important;} .mobile-utility-bar{padding:8px 0 8px !important;} .mobile-score-chip{min-width:0;flex:1;} .mobile-score-chip strong{font-size:15px !important;} .mobile-score-chip em{font-size:11px !important;} }
@media (max-width:480px){.sidebar .brand-box img{max-width:220px !important;max-height:100px !important;} .brand-campaign strong{font-size:46px !important;} .brand-campaign b{font-size:34px !important;}}


/* V63A_HEADER_PROFISSIONAL_ESTOQUE - topo web refinado e logo mobile centralizado */
.topbar-performance{
    display:grid !important;
    grid-template-columns:minmax(330px, 430px) minmax(0,1fr) !important;
    align-items:stretch !important;
    gap:14px !important;
    padding:10px 14px !important;
    margin:0 0 16px 0 !important;
    border-radius:18px !important;
    background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%) !important;
    border:1px solid #d9e5f2 !important;
    box-shadow:0 12px 30px rgba(0,59,121,.075) !important;
    backdrop-filter:blur(10px) !important;
}
.topbar-performance .topbar-client{
    min-width:0 !important;
    min-height:72px !important;
    display:flex !important;
    align-items:center !important;
    gap:12px !important;
    padding:0 16px !important;
    border-radius:16px !important;
    background:linear-gradient(135deg,#073f7d 0%,#0b65bd 100%) !important;
    border:1px solid rgba(255,255,255,.18) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.18) !important;
    color:#fff !important;
}
.topbar-performance .bell{
    flex:0 0 38px !important;
    width:38px !important;
    height:38px !important;
    border-radius:50% !important;
    background:rgba(255,255,255,.95) !important;
    color:#d08a00 !important;
    border:0 !important;
    box-shadow:0 8px 18px rgba(0,0,0,.14) !important;
}
.topbar-performance .avatar{
    flex:0 0 44px !important;
    width:44px !important;
    height:44px !important;
    border-radius:50% !important;
    background:#ffffff !important;
    color:#003b79 !important;
    border:2px solid rgba(255,255,255,.55) !important;
    font-size:16px !important;
    box-shadow:0 8px 18px rgba(0,0,0,.13) !important;
}
.topbar-performance .client-text{min-width:0 !important;}
.topbar-performance .client-text strong{
    display:block !important;
    max-width:100% !important;
    color:#fff !important;
    font-size:20px !important;
    line-height:1.05 !important;
    font-weight:950 !important;
    letter-spacing:-.2px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
}
.topbar-performance .client-text small{
    display:block !important;
    margin-top:3px !important;
    color:rgba(255,255,255,.86) !important;
    font-size:12px !important;
    font-weight:700 !important;
}
.topbar-performance .topbar-metrics{
    display:grid !important;
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:10px !important;
    background:transparent !important;
    border:0 !important;
    border-radius:0 !important;
    overflow:visible !important;
    box-shadow:none !important;
}
.topbar-performance .metric-box{
    min-height:72px !important;
    border-radius:16px !important;
    border:1px solid #dde8f4 !important;
    background:#ffffff !important;
    padding:12px 14px !important;
    box-shadow:0 8px 22px rgba(0,59,121,.055) !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
}
.topbar-performance .metric-box span{
    font-size:10px !important;
    line-height:1 !important;
    font-weight:950 !important;
    letter-spacing:.55px !important;
    color:#697995 !important;
    text-transform:uppercase !important;
    margin:0 0 7px 0 !important;
}
.topbar-performance .metric-box strong{
    font-size:20px !important;
    line-height:1.04 !important;
    color:#003b79 !important;
    font-weight:950 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
}
.topbar-performance .metric-box:nth-child(2) strong{color:#0a9953 !important;}
.topbar-performance .metric-box:nth-child(3) strong{color:#003b79 !important;}
.topbar-performance .metric-box:nth-child(4) strong{color:#f97316 !important;}
@media (max-width:1280px){
    .topbar-performance{grid-template-columns:1fr !important;}
    .topbar-performance .topbar-metrics{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
    .topbar-performance .client-text strong{font-size:18px !important;}
    .topbar-performance .metric-box strong{font-size:18px !important;}
}
@media (max-width:980px){
    .topbar-performance .topbar-metrics{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:820px){
    .topbar-performance{display:none !important;}
    .sidebar .brand-box{
        display:flex !important;
        justify-content:center !important;
        align-items:center !important;
        text-align:center !important;
        padding:16px 12px !important;
        margin-left:auto !important;
        margin-right:auto !important;
    }
    .sidebar .brand-box img{
        display:block !important;
        margin-left:auto !important;
        margin-right:auto !important;
        width:86% !important;
        max-width:240px !important;
        height:auto !important;
        object-fit:contain !important;
    }
}
@media (max-width:480px){
    .sidebar .brand-box img{width:82% !important;max-width:225px !important;}
}
