:root{
  --accent:#ff5a3d;
  --accent2:#f97316;
  --dark:#0f172a;
  --muted:#64748b;
  --line:#e5e7eb;
  --soft:#f8fafc;
  --shadow:0 18px 45px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#fff;color:#111827;overflow-x:hidden}.fw-black{font-weight:900}.text-accent{color:var(--accent)!important}.app-navbar{background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.9);box-shadow:0 8px 30px rgba(15,23,42,.04)}.brand-mark{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#fff1ec;color:var(--accent);border:1px solid rgba(255,90,61,.18)}.nav-link{font-weight:750;color:#334155!important}.nav-link.active,.nav-link:hover{color:var(--accent)!important}.btn-accent{background:linear-gradient(135deg,var(--accent),var(--accent2));border:0;color:#fff;font-weight:800;box-shadow:0 14px 30px rgba(255,90,61,.22)}.btn-accent:hover{color:#fff;transform:translateY(-1px)}.page-shell{padding:2.2rem 0 4rem;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);min-height:calc(100vh - 66px)}.container-wide{width:min(1240px,calc(100% - 2rem));margin-inline:auto}.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 5% 15%,rgba(255,90,61,.30) 0 38px,transparent 39px),radial-gradient(circle at 95% 35%,rgba(255,90,61,.24) 0 100px,transparent 102px),radial-gradient(ellipse at 88% -12%,rgba(255,247,244,.98) 0 35%,transparent 36%),#fff;min-height:calc(100vh - 66px);padding:4.5rem 0 4rem}.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:3rem;align-items:center}.hero h1{font-size:clamp(2.4rem,5vw,4.8rem);line-height:1.04;font-weight:950;letter-spacing:-.06em;color:#111827}.hero p{font-size:1.08rem;line-height:1.75;color:#64748b;max-width:650px}.phone-preview{max-width:540px;width:100%;filter:drop-shadow(0 30px 45px rgba(15,23,42,.18))}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.section-title{font-size:clamp(1.7rem,3vw,2.7rem);letter-spacing:-.04em;font-weight:900}.card-soft{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}.metric-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.15rem;box-shadow:0 12px 30px rgba(15,23,42,.05);height:100%}.metric-label{font-size:.82rem;color:#64748b;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.metric-value{font-size:1.4rem;font-weight:900;color:#0f172a}.metric-detail{font-size:.86rem;color:#64748b}.feature-icon{width:44px;height:44px;border-radius:16px;background:#fff1ec;color:var(--accent);display:grid;place-items:center;font-size:1.2rem}.ticker-strip{display:flex;gap:.8rem;overflow-x:auto;padding:.7rem 0}.ticker-pill{min-width:145px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:.8rem 1rem;box-shadow:0 10px 24px rgba(15,23,42,.04)}.up{color:#079455!important}.down{color:#dc2626!important}.table{--bs-table-bg:transparent}.table thead th{font-size:.77rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.table td,.table th{vertical-align:middle}.sticky-filter{position:sticky;top:78px;z-index:10;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:22px;padding:1rem;box-shadow:0 16px 36px rgba(15,23,42,.07)}.htmx-indicator{display:none}.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{display:inline-flex}.htmx-request .hide-while-loading{opacity:.45}.form-control,.form-select{border-radius:14px;border-color:#dbe3ef;padding:.72rem .9rem}.form-check-input:checked{background-color:var(--accent);border-color:var(--accent)}.chart-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:1rem;margin-bottom:1rem}.alert{border-radius:18px}.tabulator{border-radius:18px;overflow:hidden;border:1px solid var(--line)!important}.tabulator .tabulator-header{background:#f8fafc!important}@media(max-width:992px){.hero-grid{grid-template-columns:1fr;text-align:center}.hero p{margin-inline:auto}.hero-actions{justify-content:center}.phone-preview{max-width:390px}.sticky-filter{position:relative;top:auto}}@media(max-width:640px){.container-wide{width:min(100% - 1rem,1240px)}.hero{padding:2.5rem 0}.hero h1{font-size:2.35rem}.metric-card{padding:1rem}.page-shell{padding-top:1rem}.phone-preview{max-width:105%;transform:translateX(-2%)}}

/* Ranking Graham — tabela larga com paginação amigável */
.ranking-table-card{overflow:hidden}.ranking-table-card .tabulator{width:100%;font-size:.9rem}.ranking-table-card .tabulator-tableholder{overflow-x:auto!important}.ranking-table-card .tabulator-footer{gap:.45rem;align-items:center}.ranking-table-card .tabulator-paginator label{font-weight:700;color:#475569;margin-right:.35rem}.ranking-table-card .tabulator-page-size{border:1px solid #dbe3ef;border-radius:10px;padding:.35rem .55rem;background:#fff}.ranking-table-card .tabulator .tabulator-cell{white-space:nowrap}.ranking-table-card .tabulator .tabulator-col-title{white-space:nowrap}

.info-dot{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#fff1ec;color:var(--accent);font-size:.8rem;font-weight:900;border:1px solid rgba(255,90,61,.18);cursor:help;line-height:1}
.info-dot:hover{transform:translateY(-1px)}
.kpi-stack{display:flex;flex-direction:column;gap:.25rem}
.kpi-caption{font-size:.78rem;color:#64748b;line-height:1.4}
.metric-card.soft-accent{background:linear-gradient(180deg,#fff,#fff7f3)}
.chart-card h4,.card-soft h4,.card-soft h5{letter-spacing:-.02em}
.list-tight li{margin-bottom:.45rem}
.pie-wrap{min-height:380px}
.indicator-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.indicator-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1rem;box-shadow:0 10px 24px rgba(15,23,42,.04)}
.indicator-card .title-row{display:flex;align-items:center;gap:.45rem;margin-bottom:.3rem}
.indicator-card .value{font-size:1.35rem;font-weight:900;color:#0f172a}
.indicator-card .help{font-size:.84rem;color:#64748b;line-height:1.5}
.graham-badge{font-size:.72rem;font-weight:800;letter-spacing:.03em;padding:.4rem .65rem;border-radius:999px;border:1px solid var(--line);background:#f8fafc;color:#334155}
.macro-highlight{background:linear-gradient(135deg,rgba(255,90,61,.08),rgba(249,115,22,.08));border:1px solid rgba(255,90,61,.12);border-radius:22px;padding:1rem}
.tooltip-inner{max-width:320px;text-align:left}

/* Busca global e filtros mobile-first */
.global-asset-search{width:min(310px,26vw);min-width:220px;flex-shrink:1}
.global-asset-search .input-group{border:1px solid #dbe3ef;border-radius:999px;overflow:hidden;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.04)}
.global-asset-search .input-group-text,.global-asset-search .form-control,.global-asset-search .btn{border:0;border-radius:0!important}
.global-asset-search .input-group-text{background:#fff;color:#64748b;padding-left:.85rem}
.global-asset-search .form-control{padding:.55rem .65rem;font-weight:700}
.global-asset-search .btn{padding-inline:.95rem;box-shadow:none}
.navbar-account-actions{white-space:nowrap}
.filter-panel{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:24px;padding:1rem;box-shadow:0 14px 34px rgba(15,23,42,.06)}
.filter-primary-row{display:flex;gap:1rem;align-items:end;justify-content:space-between}
.filter-panel .input-group{border:1px solid #dbe3ef;border-radius:18px;overflow:hidden;background:#fff}
.filter-panel .input-group-text{border:0;background:#fff;color:#64748b;padding-inline:1rem}
.filter-panel .input-group .form-control{border:0;border-radius:0!important;box-shadow:none!important}
.filter-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;min-width:max-content}
.advanced-filter-body{border-top:1px solid var(--line);margin-top:1rem;padding-top:1rem}
.advanced-checks{display:flex;gap:1rem 1.5rem;flex-wrap:wrap;padding:.8rem .95rem;background:#f8fafc;border:1px solid var(--line);border-radius:18px}
.mobile-comparison-input{min-height:58px;resize:vertical}
.sticky-filter{position:relative;top:auto;z-index:1}
@media(max-width:992px){
  .global-asset-search{width:100%;min-width:0;margin-inline:0!important;order:2}
  .navbar-account-actions{width:100%;justify-content:space-between;order:3}
  .filter-primary-row{flex-direction:column;align-items:stretch}
  .filter-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;min-width:0;justify-content:stretch}
  .filter-actions .btn{width:100%}
  .advanced-checks{display:grid;grid-template-columns:1fr;gap:.65rem}
}
@media(max-width:640px){
  .filter-panel{padding:.85rem;border-radius:20px}
  .filter-actions{grid-template-columns:1fr}
  .global-asset-search .form-control{font-size:.95rem}
  .section-title{letter-spacing:-.035em}
}

/* Gráficos responsivos — ECharts + Lightweight Charts */
.chart-card{overflow:hidden}
.chart-card .mobile-chart{width:100%;min-height:280px}
.mobile-chart{position:relative;border-radius:18px;background:#fff}
.tv-fin-chart{touch-action:pan-y;overflow:hidden}
.tv-fin-chart table{font-size:11px!important}
@media(max-width:640px){
  .chart-card{padding:.75rem;border-radius:20px;margin-bottom:.85rem}
  .chart-card h4{font-size:1rem;margin-bottom:.65rem;line-height:1.25}
  .chart-card .mobile-chart{min-height:260px}
  .tv-fin-chart{min-height:290px}
  .pie-wrap{min-height:330px}
}

/* Ajustes mobile-first — leitura positiva de investimento */
.mobile-chart{background:linear-gradient(180deg,#ffffff 0%,#fbfefc 100%)}
.chart-card{border-color:#d9e8df;box-shadow:0 18px 44px rgba(5,150,105,.07)}
.chart-card h4{color:#0f172a}
.tv-fin-chart{border:1px solid #e2f3e8}

/* Tabulator leve para substituir tabelas largas no mobile */
.lite-tabulator-wrap{width:100%;overflow:hidden;border-radius:18px;border:1px solid var(--line);background:#fff}
.lite-tabulator-wrap .tabulator{border:0!important;border-radius:18px!important;font-size:.88rem;background:#fff}
.lite-tabulator-wrap .tabulator-header{background:#f8fafc!important;border-bottom:1px solid #e2e8f0!important}
.lite-tabulator-wrap .tabulator-col{background:#f8fafc!important;border-right:1px solid #e2e8f0!important}
.lite-tabulator-wrap .tabulator-col-title{font-size:.76rem;font-weight:900;color:#475569;text-transform:uppercase;letter-spacing:.03em}
.lite-tabulator-wrap .tabulator-row{border-bottom:1px solid #eef2f7!important}
.lite-tabulator-wrap .tabulator-row:hover{background:#f0fdf4!important}
.lite-tabulator-wrap .tabulator-cell{border-right:0!important;white-space:normal;line-height:1.35;padding:.65rem .7rem!important}
.lite-tabulator-wrap .tabulator-responsive-collapse{background:#f8fafc;border-top:1px dashed #e2e8f0;color:#475569}
.lite-tabulator-wrap .tabulator-footer{background:#fff!important;border-top:1px solid #e2e8f0!important;padding:.5rem!important}
.lite-tabulator-wrap .tabulator-page{border:1px solid #dbe3ef!important;border-radius:999px!important;background:#fff!important;color:#334155!important;padding:.28rem .65rem!important;margin-inline:.12rem!important}
.lite-tabulator-wrap .tabulator-page.active{background:#059669!important;border-color:#059669!important;color:#fff!important}
.table-mobile-lite.d-none + .lite-tabulator-wrap{margin-top:.25rem}

@media(max-width:640px){
  .lite-tabulator-wrap{border-radius:16px}
  .lite-tabulator-wrap .tabulator{font-size:.82rem}
  .lite-tabulator-wrap .tabulator-cell{padding:.55rem .6rem!important}
  .card-soft.p-4{padding:1rem!important}
  .filter-panel .btn{width:100%}
}

/* PATCH_ANALISE_ATIVO_MOBILE_OVERFLOW: evita estouro horizontal na análise de ativo */
html,body{max-width:100%;overflow-x:hidden}
#analise-resultados{max-width:100%;overflow-x:hidden}
#analise-resultados .card-soft{max-width:100%;overflow:hidden}
#analise-resultados h1,#analise-resultados h2,#analise-resultados h3,#analise-resultados h4,#analise-resultados p,#analise-resultados .text-muted{max-width:100%;overflow-wrap:anywhere;word-break:normal}
#analise-resultados img,#analise-resultados svg,#analise-resultados canvas{max-width:100%;height:auto}
@media(max-width:640px){
  #analise-resultados .card-soft{padding:1.15rem!important}
  #analise-resultados h2{font-size:1.45rem;line-height:1.16}
  #analise-resultados .text-muted{font-size:.96rem;line-height:1.45}
}

/* PATCH_TABELAS_FIT_WIDTH_MOBILE: tabelas ocupam 100% do card e não quebram para a direita */
.table-responsive{width:100%;max-width:100%;overflow-x:auto}
.table-responsive>table,.table-responsive>.table,.painel-table-fit{width:100%!important;min-width:100%;margin-bottom:0}
.table-responsive>table th,.table-responsive>table td{vertical-align:middle;overflow-wrap:anywhere}
.tabulator{width:100%!important;max-width:100%}
.tabulator .tabulator-tableholder{width:100%}
.tabulator .tabulator-table{min-width:100%}
@media(max-width:640px){
  .card-soft .table-responsive{border:1px solid var(--line);border-radius:16px;overflow:hidden}
  .table-responsive>table,.table-responsive>.table,.painel-table-fit{table-layout:fixed;font-size:.88rem}
  .table-responsive>table th,.table-responsive>table td{white-space:normal!important;padding:.55rem .5rem}
  .tabulator{font-size:.88rem}
  .tabulator .tabulator-cell,.tabulator .tabulator-col-title{white-space:normal!important;overflow-wrap:anywhere}
  .tabulator .tabulator-page{padding:.35rem .55rem;margin:.12rem}
}
/* Painel Macro otimizado */
@media(max-width:640px){.sticky-filter .form-check{padding-top:.25rem}.sticky-filter .btn{min-height:44px}}

/* PATCH_MERCADO_ESTRUTURA_20260530: página Mercado com seções, cards e scroll lateral mobile-first */
.market-page{background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.market-hero{overflow:hidden;background:radial-gradient(circle at 92% 0%,rgba(255,90,61,.09),transparent 34%),linear-gradient(180deg,#fff,#fff)}
.market-subtitle{max-width:720px;line-height:1.55}
.market-actions .btn{min-height:42px;font-weight:850}
.market-scroll-wrap{position:relative;max-width:100%;overflow:hidden}
.market-scroll-wrap::after{content:"";position:absolute;right:0;top:0;bottom:0;width:38px;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.96))}
.market-scroll-row{display:flex;gap:1rem;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding:.15rem .2rem 1rem;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}
.market-scroll-row::-webkit-scrollbar{height:7px}.market-scroll-row::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.market-scroll-row::-webkit-scrollbar-track{background:transparent}
.market-ticker-card{scroll-snap-align:start;min-width:158px;max-width:158px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:1rem;box-shadow:0 12px 26px rgba(15,23,42,.05);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.market-ticker-card:hover,.market-mini-card:hover,.market-ranking-card:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(15,23,42,.08);border-color:#d9e8df}
.market-price{font-size:1.05rem;font-weight:900;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.market-sparkline{height:34px;margin-top:.75rem;border-radius:12px;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff,#f8fafc)}
.market-sparkline::before{content:"";position:absolute;left:8px;right:8px;top:16px;border-top:1px dashed #e2e8f0}.market-sparkline span{position:absolute;left:8px;right:8px;bottom:9px;height:18px;border-radius:50%;border-top:3px solid #059669;transform:skewX(-18deg) rotate(-7deg)}.market-sparkline.is-down span{border-top-color:#dc2626;transform:skewX(18deg) rotate(9deg)}.market-sparkline.small{height:28px;margin-top:.45rem}.market-sparkline.small span{height:14px}
.market-index-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:1.15rem;box-shadow:0 12px 28px rgba(15,23,42,.05)}
.market-main-chart{min-height:100%}.market-main-chart .mobile-chart{min-height:260px}
.market-section{max-width:100%}.market-section-title{font-size:clamp(1.35rem,2.1vw,2rem);font-weight:950;letter-spacing:-.04em;color:#0f172a}.market-tabs{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.25rem;box-shadow:0 8px 20px rgba(15,23,42,.04)}.market-tabs .nav-link{border-radius:999px!important;padding:.45rem 1.2rem;font-weight:900;color:#334155!important}.market-tabs .nav-link.active{background:#0f172a!important;color:#fff!important;box-shadow:0 10px 22px rgba(15,23,42,.16)}
.market-ranking-row{align-items:stretch}.market-ranking-card{scroll-snap-align:start;min-width:310px;max-width:330px;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:24px;padding:1rem;box-shadow:0 14px 32px rgba(15,23,42,.06);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.market-card-kicker{font-size:.78rem;font-weight:900;letter-spacing:.03em;text-transform:uppercase;color:#64748b;display:flex;align-items:center;gap:.4rem}.market-ranking-card h3{font-size:1.05rem;font-weight:950;letter-spacing:-.02em;margin:.25rem 0 .7rem;color:#0f172a}.market-rank-list{display:flex;flex-direction:column;gap:.15rem}.market-rank-item{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:.65rem;padding:.62rem .2rem;border-bottom:1px solid #edf2f7}.market-rank-item:last-child{border-bottom:0}.rank-pos{font-size:.82rem;font-weight:900;color:#64748b}.rank-name{min-width:0}.rank-name b{display:block;font-size:.9rem;color:#0f172a}.rank-name small{display:block;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.market-rank-item strong{font-size:.88rem;white-space:nowrap}.market-card-link{margin-top:auto;padding-top:.8rem;font-size:.84rem;font-weight:900;color:#0f172a;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem}.market-card-link.muted{color:#64748b;cursor:default}
.market-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.market-column-card{min-width:0;overflow:hidden}.market-card-title{font-size:1rem;font-weight:950;letter-spacing:-.02em;margin-bottom:.75rem;color:#0f172a}.market-table-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1rem;box-shadow:0 10px 24px rgba(15,23,42,.04);overflow:hidden}.market-compact-table th{font-size:.74rem!important}.market-compact-table td{font-size:.9rem}.market-mini-card-row{gap:.75rem}.market-mini-card{scroll-snap-align:start;min-width:138px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:.9rem;box-shadow:0 10px 24px rgba(15,23,42,.05);display:flex;flex-direction:column;gap:.25rem;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.market-mini-card strong{font-size:1rem}.market-mini-card small{font-size:.82rem}
.market-fii-highlight{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#fff,#f0fdf4);border:1px solid #d9e8df;border-radius:22px;padding:1.1rem;box-shadow:0 10px 26px rgba(5,150,105,.06)}.market-fii-highlight i{font-size:2rem;color:#059669;background:#fff;border:1px solid #d9e8df;border-radius:18px;width:54px;height:54px;display:grid;place-items:center;flex:0 0 auto}.market-fii-ranking-row{gap:.75rem}.market-small-ranking{scroll-snap-align:start;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:.9rem;box-shadow:0 10px 24px rgba(15,23,42,.04)}.market-small-ranking h3{font-size:.88rem;font-weight:950;margin-bottom:.55rem}.market-small-ranking div{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border-bottom:1px solid #eef2f7;padding:.45rem 0;font-size:.82rem}.market-small-ranking div:last-child{border-bottom:0}.market-small-ranking strong{font-size:.82rem;white-space:nowrap}.market-news-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1rem;box-shadow:0 10px 24px rgba(15,23,42,.04)}.market-news-item{display:grid;grid-template-columns:36px 1fr 16px;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #eef2f7}.market-news-item:last-child{border-bottom:0}.market-news-icon{width:36px;height:36px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;display:grid;place-items:center;color:#64748b}.market-news-item b{font-size:.9rem;display:block}.market-news-item small{display:block;color:#64748b;line-height:1.35}.market-news-item>.bi-chevron-right{color:#94a3b8}.market-summary-row{align-items:stretch}.market-summary-card{scroll-snap-align:start;min-width:265px;max-width:310px;background:#fff;border:1px solid var(--line);border-radius:22px;padding:1rem;box-shadow:0 12px 28px rgba(15,23,42,.05)}.market-summary-card h3{font-size:1rem;font-weight:950;margin-bottom:.75rem;display:flex;gap:.45rem;align-items:center}.market-summary-card h3 i{color:var(--accent)}
@media(max-width:992px){.market-two-col{grid-template-columns:1fr}.market-actions{width:100%}.market-actions .btn{flex:1 1 180px}.market-ranking-card{min-width:min(84vw,330px)}.market-scroll-wrap::after{width:28px}.market-main-chart .mobile-chart{min-height:245px}}
@media(max-width:640px){.market-hero{border-radius:22px;padding:1rem!important}.market-ticker-row{gap:.75rem}.market-ticker-card{min-width:138px;max-width:138px;padding:.85rem;border-radius:18px}.market-price{font-size:.95rem}.market-index-card{padding:1rem;border-radius:18px}.market-index-card .display-6{font-size:1.65rem}.market-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.market-tabs .nav-item,.market-tabs .nav-link{width:100%}.market-ranking-card{min-width:82vw;padding:.9rem;border-radius:20px}.market-rank-item{grid-template-columns:30px minmax(0,1fr) auto;gap:.5rem}.rank-name small{max-width:130px}.market-table-card{padding:.8rem;border-radius:18px}.market-compact-table td,.market-compact-table th{padding:.55rem .45rem!important;font-size:.82rem}.market-mini-card{min-width:124px}.market-fii-highlight{align-items:flex-start;padding:1rem}.market-fii-highlight i{width:46px;height:46px;font-size:1.55rem}.market-news-item{grid-template-columns:32px 1fr 12px;gap:.55rem}.market-news-icon{width:32px;height:32px;border-radius:12px}.market-summary-card{min-width:80vw}.market-scroll-row{padding-bottom:.85rem}.market-scroll-wrap::after{display:none}}


/* PATCH_MERCADO_REFINO_20260530: remove botão atualizar, real sparklines, ibov abaixo do ranking e ações no mesmo padrão de FIIs */
.market-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}
.market-hero-actions .btn{min-height:42px;font-weight:850}
.market-sparkline.has-real-chart{background:linear-gradient(180deg,#fff,#f8fafc);padding:0;display:flex;align-items:flex-end}
.market-sparkline-svg{display:block;width:100%;height:34px}
.market-sparkline-svg .spark-line{fill:none;stroke:var(--spark-color,#059669);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.market-sparkline-svg .spark-area{fill:color-mix(in srgb, var(--spark-color,#059669) 12%, transparent)}
.market-sparkline.is-down .market-sparkline-svg .spark-line{stroke:#dc2626}
.market-sparkline.is-down .market-sparkline-svg .spark-area{fill:color-mix(in srgb, #dc2626 12%, transparent)}
.market-ibov-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid var(--line);border-radius:24px;padding:1.1rem;box-shadow:0 14px 32px rgba(15,23,42,.05)}
.market-ibov-value{font-size:clamp(2rem,4vw,3rem);font-weight:950;letter-spacing:-.05em;color:#0f172a;line-height:1.0}
.market-ibov-caption{font-size:.9rem;color:#64748b;font-weight:700;margin-top:.2rem}
.market-ibov-meta{display:flex;flex-wrap:wrap;gap:.65rem 1rem}
.market-ibov-meta span{display:inline-flex;align-items:center;gap:.45rem;background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:.45rem .8rem;font-size:.82rem;font-weight:700;color:#475569}
.market-ibov-chart .mobile-chart{min-height:270px}
.market-highlight-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#fff,#eff6ff);border:1px solid #dbe7f3;border-radius:22px;padding:1.1rem;box-shadow:0 10px 24px rgba(15,23,42,.04)}
.market-highlight-card i{font-size:2rem;color:#0f172a;background:#fff;border:1px solid #dbe7f3;border-radius:18px;width:54px;height:54px;display:grid;place-items:center;flex:0 0 auto}
.market-highlight-stock{background:linear-gradient(135deg,#fff,#fff7ed);border-color:#f5d9c5}
.market-highlight-stock i{border-color:#f5d9c5;color:#ea580c}
@media(max-width:640px){
  .market-hero-actions .btn{width:100%}
  .market-ibov-card{padding:1rem;border-radius:20px}
  .market-ibov-value{font-size:2.1rem}
  .market-ibov-meta{gap:.55rem}
  .market-ibov-meta span{font-size:.78rem;padding:.4rem .7rem}
  .market-highlight-card{align-items:flex-start;padding:1rem}
  .market-highlight-card i{width:46px;height:46px;font-size:1.55rem}
}


/* PATCH_HEADER_LOGIN_MERCADO_REFINO2_20260530 */
.app-navbar{overflow:visible;z-index:1030}
.app-navbar .navbar-brand{min-width:0;white-space:nowrap}
.app-navbar .navbar-collapse{min-width:0}
.navbar-account-actions{min-width:0;flex-shrink:0;display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.navbar-account-actions img,
.navbar-account-actions .avatar,
.navbar-account-actions .user-avatar,
.navbar-account-actions .profile-avatar,
.navbar-account-actions .profile-photo,
.app-navbar img[src*="googleusercontent"],
.app-navbar img[src*="lh3.googleusercontent"]{width:32px!important;height:32px!important;max-width:32px!important;max-height:32px!important;min-width:32px!important;min-height:32px!important;border-radius:999px!important;object-fit:cover!important;display:inline-block!important;flex:0 0 32px!important;box-shadow:0 8px 18px rgba(15,23,42,.12)}
.app-navbar .dropdown-toggle,
.app-navbar .user-chip,
.app-navbar .account-chip{display:inline-flex!important;align-items:center!important;gap:.45rem!important;max-width:240px!important;min-width:0!important;overflow:hidden!important;border-radius:999px!important}
.app-navbar .user-email,
.app-navbar .usuario-email,
.app-navbar .account-email,
.navbar-account-actions .small{max-width:175px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;display:inline-block!important;vertical-align:middle!important}
@media(max-width:1200px){.navbar-account-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;padding-top:.65rem}.app-navbar .user-email,.app-navbar .usuario-email,.app-navbar .account-email,.navbar-account-actions .small{max-width:calc(100vw - 145px)!important}}
@media(max-width:640px){.app-navbar .container-fluid{padding-inline:.75rem}.navbar-account-actions img,.navbar-account-actions .avatar,.navbar-account-actions .user-avatar,.navbar-account-actions .profile-avatar,.navbar-account-actions .profile-photo,.app-navbar img[src*="googleusercontent"],.app-navbar img[src*="lh3.googleusercontent"]{width:30px!important;height:30px!important;max-width:30px!important;max-height:30px!important;min-width:30px!important;min-height:30px!important}.navbar-account-actions .btn{padding:.42rem .72rem;font-size:.82rem}.app-navbar .navbar-brand{font-size:1rem}}

body:has(a[href*="/login/google"]) .card-soft img,
body:has(a[href*="/login/google"]) .card-soft svg,
body:has(a[href*="/auth/google"]) .card-soft img,
body:has(a[href*="/auth/google"]) .card-soft svg{width:28px!important;height:28px!important;max-width:28px!important;max-height:28px!important;object-fit:contain!important;display:inline-block!important;margin:0!important}
.login-page img,.login-page svg,.auth-page img,.auth-page svg,.login-card img,.login-card svg,.auth-card img,.auth-card svg{width:28px!important;height:28px!important;max-width:28px!important;max-height:28px!important;object-fit:contain!important}
.google-hero,.google-visual,.google-illustration,.login-google-hero,.login-google-visual,.login-google-logo-large,.google-logo-large{display:none!important}
body:has(a[href*="/login/google"]) .section-title + p{max-width:420px}
body:has(a[href*="/login/google"]) .card-soft{overflow:hidden}
body:has(a[href*="/login/google"]) a[href*="/login/google"],
body:has(a[href*="/auth/google"]){font-weight:850;text-decoration:none!important}

.market-ticker-card-clean{min-height:132px;display:flex;flex-direction:column;justify-content:space-between}
.market-ticker-card-clean .market-sparkline{display:none!important}
.market-change-line{margin-top:.75rem;display:flex;align-items:center;gap:.45rem;color:#64748b;font-size:.78rem;font-weight:800;line-height:1.2;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;padding:.42rem .55rem;width:max-content;max-width:100%}
.market-change-line.is-up{color:#047857;background:#ecfdf5;border-color:#bbf7d0}.market-change-line.is-down{color:#b91c1c;background:#fef2f2;border-color:#fecaca}
.market-change-icon{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:999px;background:#fff;border:1px solid currentColor;flex:0 0 20px;font-size:.75rem}.market-news-card-single{border-radius:24px;padding:1rem 1.05rem}.market-news-card-single .market-section-title{font-size:clamp(1.25rem,2vw,1.65rem)}
@media(max-width:640px){.market-ticker-card-clean{min-height:124px}.market-change-line{font-size:.72rem;padding:.36rem .48rem}.market-change-icon{width:18px;height:18px;flex-basis:18px}.market-news-card-single{padding:.9rem;border-radius:20px}}


/* PATCH_HEADER_LOGIN_REFINO3_20260530 */
.app-navbar{overflow:visible;z-index:1030;background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}
.app-navbar .navbar-collapse{min-width:0}
.navbar-account-actions{min-width:0;flex-shrink:0;display:flex;align-items:center;gap:.55rem;white-space:nowrap}
.user-pill{display:inline-flex;align-items:center;gap:.5rem;max-width:220px;min-width:0;padding:.28rem .62rem .28rem .32rem;border:1px solid #e2e8f0;border-radius:999px;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 10px 24px rgba(15,23,42,.07);color:#0f172a;font-weight:900;line-height:1}
.user-pill-avatar{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;flex:0 0 30px;background:linear-gradient(135deg,var(--accent,#ff5a3d),#ff8a3d);color:#fff;font-size:.84rem;font-weight:950;box-shadow:0 8px 18px rgba(255,90,61,.22)}
.user-pill-label{font-size:.74rem;color:#64748b;font-weight:800}.user-pill-name{display:inline-block;max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.86rem}.navbar-logout-btn{font-weight:850;padding-inline:.85rem}
.app-navbar img[src*="googleusercontent"],.app-navbar img[src*="lh3.googleusercontent"],.navbar-account-actions img{width:30px!important;height:30px!important;max-width:30px!important;max-height:30px!important;border-radius:999px!important;object-fit:cover!important;flex:0 0 30px!important}
.btn-google-login{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.65rem!important;min-height:44px!important;border:1px solid #dadce0!important;background:#fff!important;color:#1f2937!important;font-weight:850!important;text-decoration:none!important;box-shadow:0 8px 18px rgba(15,23,42,.06)!important;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease!important}.btn-google-login:hover{transform:translateY(-1px);border-color:#cbd5e1!important;box-shadow:0 12px 24px rgba(15,23,42,.09)!important}.google-g-mark{width:24px;height:24px;border-radius:999px;display:inline-grid;place-items:center;flex:0 0 24px;background:#fff;color:#4285f4;font-family:Arial,Helvetica,sans-serif;font-size:1.12rem;font-weight:900;box-shadow:inset 0 0 0 1px #e5e7eb}.login-page .google-g-mark,.auth-page .google-g-mark,.card-soft .google-g-mark{width:24px!important;height:24px!important;max-width:24px!important;max-height:24px!important}
.login-card img,.auth-card img,.login-page img,.auth-page img{max-width:42px!important;max-height:42px!important;object-fit:contain!important}.google-hero,.google-visual,.google-illustration,.login-google-hero,.login-google-visual,.login-google-logo-large,.google-logo-large{display:none!important}
@media(max-width:1200px){.navbar-account-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;padding-top:.65rem}.user-pill{max-width:calc(100vw - 120px)}}
@media(max-width:640px){.app-navbar .container-fluid{padding-inline:.75rem}.user-pill{padding:.25rem .52rem .25rem .28rem;max-width:calc(100vw - 92px)}.user-pill-avatar{width:28px;height:28px;flex-basis:28px}.user-pill-label{display:none}.user-pill-name{max-width:120px;font-size:.84rem}.navbar-logout-btn{padding:.38rem .72rem}.btn-google-login{min-height:42px!important;font-size:.92rem!important}.google-g-mark{width:22px;height:22px;flex-basis:22px;font-size:1rem}}


/* PATCH_LOGIN_GOOGLE_BUTTON_REFINO4_20260530 */
.login-google-btn,.btn-google.login-google-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.7rem!important;width:100%!important;min-height:46px!important;padding:.65rem 1rem!important;border:1px solid #dadce0!important;border-radius:999px!important;background:#fff!important;color:#111827!important;font-weight:900!important;font-size:.95rem!important;text-decoration:none!important;box-shadow:0 8px 18px rgba(15,23,42,.06)!important;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background-color .15s ease!important}.login-google-btn:hover,.btn-google.login-google-btn:hover{transform:translateY(-1px);background:#fff!important;border-color:#cbd5e1!important;box-shadow:0 13px 26px rgba(15,23,42,.10)!important;color:#0f172a!important}.login-google-btn:active,.btn-google.login-google-btn:active{transform:translateY(0)!important;box-shadow:0 6px 14px rgba(15,23,42,.08)!important}.login-google-btn .login-google-icon,.btn-google .login-google-icon{display:block!important;width:24px!important;height:24px!important;min-width:24px!important;max-width:24px!important;min-height:24px!important;max-height:24px!important;object-fit:contain!important;flex:0 0 24px!important;border-radius:0!important;box-shadow:none!important;background:transparent!important}.login-google-btn span{line-height:1!important}.google-g-mark{display:none!important}
@media(max-width:640px){.login-google-btn,.btn-google.login-google-btn{min-height:44px!important;font-size:.92rem!important}.login-google-btn .login-google-icon,.btn-google .login-google-icon{width:22px!important;height:22px!important;min-width:22px!important;max-width:22px!important;min-height:22px!important;max-height:22px!important;flex-basis:22px!important}}


/* PATCH_LOGIN_BUTTON_SPACING_20260530: espaço entre Entrar com Google e demo */
.login-google-btn,
.btn-google.login-google-btn{
  margin-bottom:.78rem!important;
}
.login-google-btn + .btn,
.login-google-btn + a.btn,
.login-google-btn + button.btn{
  margin-top:.05rem!important;
}
@media(max-width:640px){
  .login-google-btn,
  .btn-google.login-google-btn{
    margin-bottom:.72rem!important;
  }
}

/* PATCH_CARDS_GRAFICO_20260530: altera apenas os cards do topo para mini gráfico */
.market-ticker-card-chart{display:flex;flex-direction:column;justify-content:space-between;gap:.25rem}
.market-mini-chart{margin-top:.7rem;height:48px;display:flex;align-items:flex-end}
.market-mini-chart-svg{display:block;width:100%;height:48px;overflow:visible}
.market-mini-chart-svg path{vector-effect:non-scaling-stroke}
@media(max-width:640px){.market-mini-chart{height:42px;margin-top:.55rem}.market-mini-chart-svg{height:42px}}

/* PATCH_ROTINA_MERCADO_SNAPSHOT_20260530: ajuda visual das métricas */
.metric-help{
  display:inline-grid;
  place-items:center;
  width:18px;
  height:18px;
  margin-left:.28rem;
  border-radius:999px;
  border:1px solid #cbd5e1;
  background:#f8fafc;
  color:#475569;
  font-size:.72rem;
  font-weight:950;
  line-height:1;
  cursor:help;
  vertical-align:middle;
}
.metric-help:hover,.metric-help:focus{
  background:#fff7ed;
  border-color:var(--accent,#ff5a3d);
  color:var(--accent,#ff5a3d);
  outline:none;
}
.market-card-title .metric-help,.market-section-title .metric-help{transform:translateY(-1px)}
@media(max-width:640px){.metric-help{width:20px;height:20px;font-size:.75rem;margin-left:.22rem}}

/* HOTFIX_TOOLTIP_TITULO_LIMPO_20260530
   Mantém os títulos originais e usa o próprio título como gatilho do tooltip.
   Não insere o texto explicativo no fluxo visual da página. */
.market-page .metric-title-help{
  cursor:help;
  outline:none;
}
.metric-title-tooltip{
  position:fixed;
  z-index:3000;
  max-width:360px;
  width:min(360px,calc(100vw - 24px));
  padding:.75rem .85rem;
  border-radius:14px;
  background:#0f172a;
  color:#f8fafc;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 18px 45px rgba(15,23,42,.24);
  font-size:.82rem;
  font-weight:600;
  line-height:1.45;
  letter-spacing:0;
  text-transform:none;
  white-space:normal;
  opacity:0;
  visibility:hidden;
  transform:translateY(6px);
  transition:opacity .16s ease,transform .16s ease,visibility .16s ease;
  pointer-events:none;
  text-align:left;
}
.metric-title-tooltip.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.metric-title-tooltip strong{
  color:#fff;
  font-weight:950;
}
@media(max-width:640px){
  .metric-title-tooltip{
    left:.75rem!important;
    right:.75rem!important;
    width:auto!important;
    max-width:none;
    font-size:.82rem;
  }
}

/* HOTFIX_TIMEZONE_CAROUSEL_20260530: autoplay horizontal no carrossel superior sem alterar layout */
.market-page .market-ticker-row[data-market-autoplay="right"]{
  scroll-snap-type:none;
  scroll-behavior:auto;
}
.market-page .market-carousel-clone{
  pointer-events:none;
}


/* HOTFIX_CAROUSEL_AUTOPLAY_CSS_20260530
   Autoplay real do carrossel de ativos, independente de script inline/HTMX.
   Mantém o layout dos cards e usa duplicação server-side para loop contínuo. */
.market-page .market-ticker-autoplay-shell{
  overflow:hidden!important;
}
.market-page .market-ticker-autoplay-shell::after{
  z-index:2;
}
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]{
  width:max-content!important;
  max-width:none!important;
  overflow:visible!important;
  scroll-snap-type:none!important;
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
  animation:marketTickerAutoplayRight 34s linear infinite;
  will-change:transform;
  transform:translate3d(0,0,0);
}
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]::-webkit-scrollbar{
  display:none!important;
}
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"] .market-ticker-card{
  flex:0 0 158px;
}
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]:hover,
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]:focus-within,
.market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]:active{
  animation-play-state:paused;
}
@keyframes marketTickerAutoplayRight{
  0%{transform:translate3d(0,0,0)}
  100%{transform:translate3d(-50%,0,0)}
}
@media(max-width:640px){
  .market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]{
    animation-duration:26s;
  }
  .market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"] .market-ticker-card{
    flex-basis:138px;
  }
}
@media(prefers-reduced-motion:reduce){
  .market-page .market-ticker-autoplay-track[data-market-css-autoplay="right"]{
    animation:none!important;
    width:auto!important;
    overflow-x:auto!important;
    scroll-snap-type:x proximity!important;
  }
}

/* Mercado — gráfico IBOV com seletor de período estilo cotação */
.market-ibov-card{background:#fff;border:1px solid #dbe3ef;border-radius:24px;padding:1.55rem;box-shadow:0 18px 45px rgba(15,23,42,.07)}
.market-ibov-topbar{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:1rem 1.5rem;align-items:start}
.market-ibov-main-info{min-width:0}.market-ibov-value{font-size:clamp(2.45rem,5vw,4rem);font-weight:950;letter-spacing:-.065em;color:#0f172a;line-height:.95;margin-top:.35rem}.market-ibov-caption{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;font-size:1rem;color:#64748b;font-weight:800;margin-top:.55rem}.market-ibov-variation{font-weight:900}.market-ibov-update{color:#475569}.market-ibov-update .badge{font-size:.9rem;padding:.5rem .75rem;color:#0f172a!important;background:#fff!important}.market-ibov-period-row{display:flex;align-items:center;justify-content:flex-end;width:max-content;max-width:100%;margin-left:auto;border:1px solid #d1d5db;border-radius:999px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.05);overflow:hidden}.market-period-btn{appearance:none;border:0;border-right:1px solid #e5e7eb;background:#fff;color:#0f172a;font-weight:800;min-width:76px;padding:.72rem 1rem;line-height:1;transition:background .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease}.market-period-btn:last-child{border-right:0}.market-period-btn:hover{background:#fff7ed;color:#ea580c}.market-period-btn.active{background:#111827;color:#fff;border-radius:999px;margin:3px;box-shadow:0 8px 18px rgba(15,23,42,.25)}.market-period-btn.loading{opacity:.68;pointer-events:none}.market-ibov-chart{min-height:360px}.market-ibov-chart .mobile-chart{min-height:360px;background:#fff}.market-ibov-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #eef2f7;border-radius:16px;overflow:hidden}.market-ibov-stat{padding:.9rem 1rem;text-align:center;border-right:1px solid #e2e8f0}.market-ibov-stat:last-child{border-right:0}.market-ibov-stat span{display:block;font-size:.82rem;font-weight:700;color:#64748b;margin-bottom:.35rem}.market-ibov-stat strong{font-size:.95rem;color:#0f172a}.market-ibov-footnote{text-align:center;color:#64748b;font-size:.82rem}.market-ibov-loading{display:flex;align-items:center;justify-content:center;gap:.6rem;min-height:320px;color:#64748b;font-weight:800}.market-ibov-loading::before{content:"";width:18px;height:18px;border-radius:50%;border:2px solid #fed7aa;border-top-color:#f97316;animation:pi-spin .7s linear infinite}@keyframes pi-spin{to{transform:rotate(360deg)}}
@media(max-width:992px){.market-ibov-topbar{grid-template-columns:1fr}.market-ibov-period-row{justify-content:flex-start;margin-left:0;width:100%;overflow-x:auto;scrollbar-width:none}.market-ibov-period-row::-webkit-scrollbar{display:none}.market-period-btn{min-width:70px;white-space:nowrap}.market-ibov-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.market-ibov-stat{border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}.market-ibov-stat:nth-child(2n){border-right:0}.market-ibov-stat:last-child{grid-column:1/-1;border-bottom:0}}
@media(max-width:640px){.market-ibov-card{padding:1rem;border-radius:20px}.market-ibov-value{font-size:2.7rem}.market-ibov-caption{font-size:.92rem;gap:.55rem}.market-ibov-update .badge{font-size:.78rem}.market-period-btn{min-width:63px;padding:.67rem .78rem;font-size:.86rem}.market-ibov-chart{min-height:300px}.market-ibov-chart .mobile-chart{min-height:300px}.market-ibov-stat{padding:.78rem .7rem}.market-ibov-stat span{font-size:.76rem}.market-ibov-stat strong{font-size:.88rem}}
