﻿:root { --bg:#fff; --text:#222; --muted:#666; --link:#2b5468; --brand:#2b5468; --line:#e7e7e7; --bg-soft:#f8f8f8; --menu:#2b5468; }
* { box-sizing: border-box; }
html, body { margin:0; padding:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, 'Noto Sans', 'Liberation Sans', sans-serif; background: var(--bg); color: var(--text);} 
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }

.site-header { border-bottom: 1px solid var(--line); background: #fff; }
.topbar { background: #fff; }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px 0; }
.site-header .logo { font-weight: 800; font-size: 22px; color: var(--text); letter-spacing: 0.3px; display: inline-flex; align-items: center; gap: 8px; }
.site-header .logo img { height: 42px; width: auto; display: block; }
.site-header .search { display: flex; gap: 8px; width: 480px; max-width: 60%; }
.site-header input[type="text"], input[type="email"], input[type="password"], input[type="url"] { padding: 8px; border:1px solid var(--line); border-radius: 6px; width: 100%; }
.site-header button { padding: 8px 12px; border: 0; border-radius: 6px; background: var(--brand); color: #fff; cursor: pointer; }
.top-actions { display: flex; align-items: center; gap: 12px; }
.lang-select { display: inline-flex; align-items: center; gap: 6px; background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 4px 8px; }
.lang-select select { border: 0; background: transparent; font-size: 14px; color: #333; outline: none; }
.lang-select .flag { font-size: 16px; }
/* Social top */
.social-top { display: inline-flex; align-items: center; gap: 8px; }
.social-top .si { width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center; border-radius: 6px; color: #fff; border: 1px solid transparent; }
.social-top .si.yt { background: #ff0000; }
.social-top .si.fb { background: #1877f2; }
.social-top .si.ig { background: linear-gradient(45deg,#f9ce34,#ee2a7b,#6228d7); }
.btn.whats { background: #25d366; color: #fff; border: 0; border-radius: 999px; padding: 8px 12px; }

.mainnav { background: var(--menu); border-top: 1px solid #244556; border-bottom: 1px solid #244556; position: sticky; top: 0; z-index: 10; }
.mainnav .container { display: flex; gap: 18px; padding: 10px 0; }
.nav-link { color: #eaf4f8; font-weight: 600; }
.nav-link:hover { text-decoration: underline; }
.nav-link.active { color: #fff; font-weight: 700; text-decoration: none; }

.az { background: #fff; border-bottom: 1px solid var(--line); }
.az-top { background: var(--menu); border-bottom-color: #244556; }
.az-inner { display: grid; grid-template-columns: repeat(26, minmax(0, 1fr)); gap: 6px; padding: 10px 0; }
.az-link { padding: 4px 8px; border-radius: 4px; color: #eee; border: 1px solid transparent; text-align: center; font-weight: 600; }
.az-top .az-link { color: #eaf4f8; }
.az-link.current, .az-link:hover { border-color: rgba(255,255,255,0.6); }

main.container { padding: 20px 16px; }
.banner-rotator { position: relative; margin: -20px 0 14px; overflow: hidden; border: 0; border-radius: 0; width: calc(100% + 40px); margin-left: -20px; }
.banner-rotator .banner-img { width: 100%; height: 260px; object-fit: cover; display: block; }
.banner-dots { position: absolute; left: 50%; transform: translateX(-50%); bottom: 10px; display: flex; gap: 6px; }
.banner-dots .dot { width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.6); box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.banner-dots .dot.active { background: #2ea39a; }
.intro h1 { margin: 0 0 6px; font-size: 26px; }
.intro p { margin-top: 0; color: var(--muted); }

/* Barra de categorias (pÃ­lulas) */
.cats-bar { background: #fff; border-bottom: 1px solid var(--line); }
.cats-scroll { display: flex; gap: 10px; padding: 10px 20px; max-width: 1200px; margin: 0 auto; overflow-x: auto; scrollbar-width: thin; }
.pill { display: inline-flex; align-items: center; gap: 6px; background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 8px 12px; color: #2b5468; white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.pill:hover { border-color: #2ea39a; text-decoration: none; }
.pill .i { margin-right: 2px; }
.pill.p-artista { border-color: #ffb400; }
.pill.p-compositor { border-color: #2b5468; }
.pill.p-grupo { border-color: #7b5cff; }
.pill.p-instrumentista { border-color: #f2701a; }
.pill.p-produtor { border-color: #2ea39a; }
.pill.p-outro { border-color: #5c7f67; }

/* Hero */
.hero { position: relative; background: #223; border-radius: 12px; overflow: hidden; margin: 12px 0 20px; }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.55)), var(--hero, none) center/cover no-repeat; }
.hero-inner { position: relative; z-index: 1; padding: 80px 24px 60px; text-align: center; color: #fff; max-width: 980px; margin: 0 auto; }
.hero-inner h1 { font-size: 40px; line-height: 1.2; margin: 0 0 22px; text-shadow: 0 2px 8px rgba(0,0,0,.4); font-weight: 800; }
.hero-search { display: grid; grid-template-columns: 1fr 240px 120px; gap: 8px; max-width: 900px; margin: 0 auto; }
.hero-search input, .hero-search select { padding: 12px; border: 1px solid rgba(255,255,255,.4); border-radius: 999px; background: rgba(255,255,255,.9); color: #222; }
.hero-search button { border: 0; border-radius: 999px; background: #2ea39a; color: #fff; font-weight: 600; padding: 12px; cursor: pointer; }

/* Categoria cards */
.categories { margin: 20px 0 8px; }
.cat-grid { display: grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap: 14px; }
.cat-card { display: flex; flex-direction: column; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 18px; color: #334; box-shadow: 0 6px 18px rgba(0,0,0,.06); transition: transform .15s ease, box-shadow .15s ease; }
.cat-card .icon { font-size: 28px; width: 52px; height: 52px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; }
.cat-artista .icon { background: #fff4cc; border: 1px solid #ffb400; }
.cat-compositor .icon { background: #eaf4f8; border: 1px solid #2b5468; }
.cat-grupo .icon { background: #efe8ff; border: 1px solid #7b5cff; }
.cat-instrumentista .icon { background: #ffe7d6; border: 1px solid #f2701a; }
.cat-produtor .icon { background: #e4f6f2; border: 1px solid #2ea39a; }
.cat-outro .icon { background: #e8f0ec; border: 1px solid #5c7f67; }
.cat-card .icon svg { display: block; }
.cat-card .icon { font-size: 28px; width: 52px; height: 52px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; }
.cat-artista .icon { background: #fff4cc; border: 1px solid #ffb400; color:#ffb400; }
.cat-compositor .icon { background: #eaf4f8; border: 1px solid #2b5468; color:#2b5468; }
.cat-grupo .icon { background: #efe8ff; border: 1px solid #7b5cff; color:#7b5cff; }
.cat-instrumentista .icon { background: #ffe7d6; border: 1px solid #f2701a; color:#f2701a; }
.cat-produtor .icon { background: #e4f6f2; border: 1px solid #2ea39a; color:#2ea39a; }
.cat-outro .icon { background: #e8f0ec; border: 1px solid #5c7f67; color:#5c7f67; }
.cat-card:hover { border-color: #2ea39a; text-decoration: none; transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.08); }

.layout { display: grid; grid-template-columns: 1fr 340px; gap: 28px; align-items: start; }
.sidebar { position: sticky; top: 12px; }
.widget { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 12px; margin-bottom: 14px; }
.widget-title { margin: 0 0 8px; font-size: 15px; color: #333; }
.widget-list { list-style: none; padding: 0; margin: 0; }
.widget-list li { padding: 6px 0; border-bottom: 1px dashed #eee; }
.widget-list li:last-child { border: 0; }
.tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: 12px; padding: 4px 8px; border-radius: 16px; background: var(--bg-soft); color: #333; border: 1px solid var(--line); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.admin-form label { display:block; margin:8px 0; }
.admin-form input[type="text"], .admin-form input[type="url"], .admin-form input[type="date"], .admin-form select, .admin-form textarea, .admin-form input[type="file"] { width: 100%; padding: 8px; border: 1px solid var(--line); border-radius: 6px; }
.admin-form textarea { min-height: 120px; }
.gallery-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; }
.gallery-grid .gitem { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; }
.gallery-grid img { width: 100%; height: 140px; object-fit: cover; display: block; }
.gallery-grid .gact { padding: 6px; font-size: 12px; color: #555; }
.featured-image { width: 100%; height: auto; border-radius: 8px; display: block; }

.entry-list { list-style: none; margin: 0; padding: 0; }
.entry-item { padding: 12px 0; border-bottom: 1px solid var(--line); }
.entry-title { font-weight: 600; font-size: 18px; color: #222; }
.entry-excerpt { color: var(--muted); margin-top: 4px; }

.pagination { display: flex; gap: 6px; padding: 16px 0; }
.page-link { padding: 6px 10px; border: 1px solid var(--line); border-radius: 6px; color: #333; }
.page-link.current, .page-link:hover { border-color: var(--brand); }

.entry-detail h1 { margin-top: 0; }
.entry-photo { max-width: 280px; height: auto; float: right; margin: 0 0 12px 12px; border-radius: 6px; }
.entry-excerpt.lead { font-size: 16px; color: #333; }
.entry-content { line-height: 1.65; }
.entry-content p { margin: 10px 0; }
.entry-meta { margin-top: 10px; }
.breadcrumbs { font-size: 13px; margin-bottom: 12px; color: var(--muted); }
.breadcrumbs a { color: var(--muted); }

/* Abas de detalhe */
.tabs-nav { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0 8px; }
.tabs-nav .tab-btn { padding: 8px 12px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: #2b5468; cursor: pointer; }
.tabs-nav .tab-btn.active, .tab-btn:hover { border-color: #2ea39a; }
.tab-panel { display: none; }
.tab-panel.active { display: block; }
.rating { color: #f4c430; font-weight: 700; }
.meta-grid { display: grid; grid-template-columns: 280px 1fr; gap: 16px; align-items: start; }
.video-embed iframe { width: 100%; height: 360px; border: 0; border-radius: 8px; }
.video-embed.fixed-515 iframe { width: 515px; height: 287px; }
.video-embed.fixed-553 iframe { width: 553px; height: 285px; }

.widgets-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin: 22px 0; }
.box { background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 12px; box-shadow: 0 4px 14px rgba(0,0,0,.05); }
.box h3 { margin: 0 0 8px; font-size: 16px; color: #2b5468; }
.list.thin { list-style: none; margin: 0; padding: 0; }
.list.thin li { padding: 6px 0; border-bottom: 1px dashed #eee; }
.list.thin li:last-child { border: 0; }
.tabs { display: flex; gap: 8px; margin-bottom: 8px; }
.tab { padding: 6px 10px; border: 1px solid var(--line); border-radius: 16px; color: #334; background: #fff; }
.tab.active, .tab:hover { border-color: #2ea39a; }

.box-split { display: grid; grid-template-columns: 1.2fr 1fr; gap: 28px; align-items: center; margin: 32px 0; }
.box-split .col { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 16px; }
.box-split .media { display: flex; align-items: center; justify-content: center; }
.box-split .media img { max-width: 100%; height: auto; border-radius: 8px; }

.hero-alt { position: relative; background: linear-gradient(135deg, #1b2b34, #2b5468); color: #fff; border-radius: 8px; overflow: hidden; margin: 32px 0 8px; }
.hero-alt-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding: 28px; max-width: 1200px; margin: 0 auto; }
.btn.light { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.4); }
.video-placeholder { height: 140px; border-radius: 8px; background: linear-gradient(#111,#222); box-shadow: inset 0 6px 12px rgba(0,0,0,.5); }
.faces { width: 100%; display: block; margin-top: 0; height: 56px; object-fit: cover; }

.table { width: 100%; border-collapse: collapse; margin-top: 12px; }
.table th, .table td { border: 1px solid var(--line); padding: 8px; text-align: left; }
.table.alt tr:nth-child(even) td { background: #f9fbfc; }
.table-wrap { margin: 14px 0; }
.table-actions { display: flex; justify-content: flex-end; gap: 10px; align-items: center; margin-bottom: 8px; }
.table-actions .inline { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.table-actions input[type="text"] { padding: 6px 10px; border: 1px solid var(--line); border-radius: 8px; }
.table-actions .reset { color: #666; }
.alpha-second { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0; }
.alpha-second .pill { padding: 6px 10px; }
/* Thumbs */
.thumb { display: inline-block; width: 96px; height: 96px; object-fit: cover; border-radius: 6px; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--line) inset; background: #eee; }
.thumb.s { width: 72px; height: 72px; }
.lightbox { position: fixed; inset: 0; display: none; }
.lightbox.open { display: block; }
.lightbox-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.7); }
.lightbox-body { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); max-width: 90vw; max-height: 85vh; margin: 0; }
.lightbox-body img { max-width: 90vw; max-height: 80vh; border-radius: 10px; box-shadow: 0 10px 30px rgba(0,0,0,.5); display: block; }
.lightbox-body figcaption { text-align: center; color: #fff; margin-top: 8px; font-size: 14px; }
.lightbox-close { position: absolute; top: -10px; right: -10px; border: 0; background: #fff; color: #333; border-radius: 999px; width: 32px; height: 32px; cursor: pointer; box-shadow: 0 4px 10px rgba(0,0,0,.4); }
.btn { display: inline-block; background: var(--brand); color: #fff; padding: 8px 12px; border-radius: 6px; transition: background-color .15s ease, color .15s ease, box-shadow .15s ease, border-color .15s ease, transform .15s ease; }
.btn.outline { background: #fff; color: #2b5468; border: 1px solid var(--line); }
.btn.outline:hover { background: #eaf4f8; color: #2b5468; border-color: #2b5468; text-decoration: none; box-shadow: 0 2px 8px rgba(43,84,104,.12); }
.error { color: #b00; }
.success { color: #080; }

.site-footer { border-top: 1px solid var(--line); padding: 20px 0; color: var(--muted); }
.footer-chips { display: flex; flex-wrap: wrap; gap: 10px; margin: 8px 0 14px; }
.chip { border: 1px solid var(--line); border-radius: 999px; padding: 6px 10px; background: #fff; color: #333; }
.newsletter { display: flex; gap: 8px; align-items: center; }
.newsletter input { padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; }
.social { display: inline-flex; gap: 8px; margin-left: 8px; }
.social a { display: inline-flex; width: 28px; height: 28px; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 6px; color: #2b5468; }

.sr-only { position: absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Em destaque (cards) */
.featured-section { margin: 18px 0 8px; }
.section-title { margin: 0 0 10px; font-size: 18px; color: #2b5468; }
.featured-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.card { background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; box-shadow: 0 4px 14px rgba(0,0,0,.05); display: flex; flex-direction: column; }
.card-media { position: relative; display: block; }
.card-img { width: 100%; height: 160px; object-fit: cover; display: block; }
.badge { position: absolute; top: 10px; left: 10px; background: #eaf4f8; color: #2b5468; border: 1px solid #2b5468; padding: 4px 8px; border-radius: 999px; font-size: 12px; }
.badge-artista { background: #fff4cc; border-color: #ffb400; color: #8a6a00; }
.badge-compositor { background: #eaf4f8; border-color: #2b5468; color: #2b5468; }
.badge-grupo { background: #efe8ff; border-color: #7b5cff; color: #4a2fb3; }
.badge-instrumentista { background: #ffe7d6; border-color: #f2701a; color: #a34e0a; }
.badge-produtor { background: #e4f6f2; border-color: #2ea39a; color: #257a6e; }
.badge-outro { background: #e8f0ec; border-color: #5c7f67; color: #35594a; }
.card-body { padding: 10px 12px; }
.card-title { margin: 0 0 6px; font-size: 16px; }
.card-title a { color: #1d2b33; text-decoration: none; }
.card-title a:hover { text-decoration: underline; }
.card-meta { display: flex; gap: 12px; color: #666; font-size: 12px; }
/* Hide legacy broken meta in selected sections and show the clean replacement */
.featured-people .card-body > .card-meta:not(.clean),
.featured-top .card-body > .card-meta:not(.clean) { display: none; }
.card-meta.clean { display: flex; gap: 12px; color: #666; font-size: 12px; }

/* Chat alert popup */
.chat-alert { position: fixed; right: 16px; bottom: 16px; width: 340px; background: #fff; border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 10px 30px rgba(0,0,0,0.15); z-index: 9999; overflow: hidden; }
.chat-alert.hidden { display: none; }
.chat-alert .head { background: #2b5468; color: #fff; padding: 8px 10px; display: flex; align-items: center; justify-content: space-between; font-weight: 700; }
.chat-alert .body { padding: 10px; display: flex; gap: 10px; align-items: flex-start; }
.chat-alert .body img { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; border: 1px solid var(--line); }
.chat-alert .body .info { flex: 1; }
.chat-alert .body .ad { font-weight: 700; color: #2b5468; margin-bottom: 4px; }
.chat-alert .body .msg { color: #333; max-height: 5.5em; overflow: hidden; }
.chat-alert .foot { padding: 10px; display: flex; justify-content: flex-end; gap: 8px; border-top: 1px solid var(--line); }
.card-footer { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-top: 1px solid var(--line); }
.btn.tiny { padding: 6px 10px; font-size: 12px; }
.btn.outline { background: #fff; color: #2b5468; border: 1px solid var(--line); }
.btn.outline:hover { background: #eaf4f8; color: #2b5468; border-color: #2b5468; text-decoration: none; box-shadow: 0 2px 8px rgba(43,84,104,.12); }

/* Classificados */
.layout-left { display: grid; grid-template-columns: 260px 1fr; gap: 20px; align-items: start; }
.cls-search { display: flex; gap: 8px; margin: 8px 0 14px; }
.cls-search input[type="text"] { flex: 1; padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px; }
.cls-sidebar .cls-title { margin: 0 0 6px; font-size: 12px; letter-spacing: 1px; color: #2b5468; }
.cat-list { list-style: none; padding: 0; margin: 8px 0 12px; }
.cat-list li { margin: 0; }
.cat-list a { display: block; padding: 6px 4px; color: #334; border-radius: 4px; text-decoration: none; }
.cat-list a.current, .cat-list a:hover { text-decoration: none; background: #f3f7f9; }
.cls-filters { display: grid; gap: 8px; }
.cls-filters label { display: grid; gap: 4px; font-size: 14px; }
.cls-filters input[type="text"], .cls-filters input[type="number"], .cls-filters select { padding: 6px 8px; border: 1px solid var(--line); border-radius: 6px; }

@media (max-width: 880px) {
  .site-header .search { max-width: 100%; width: auto; }
  .az-inner { grid-template-columns: repeat(13, minmax(0, 1fr)); }
  .hero-search { grid-template-columns: 1fr; }
  .featured-grid { grid-template-columns: 1fr; }
  .widgets-grid { grid-template-columns: 1fr; }
  .box-split { grid-template-columns: 1fr; }
  .layout { grid-template-columns: 1fr; }
  .entry-photo { float: none; max-width: 100%; margin: 10px 0; }
}

/* Ad View */
.ad-head .ad-title { margin-bottom: 6px; }
.ad-meta-line { color: var(--muted); display: flex; gap: 8px; align-items: center; }
.ad-meta-line .ad-share { margin-left: auto; color: #2b5468; }
.ad-view .gallery { position: relative; padding: 0; overflow: hidden; }
.price-badge { position: absolute; top: 0; left: 0; background: #2b5468; color: #fff; padding: 10px 14px; border-radius: 0 0 8px 0; font-weight: 700; z-index: 2; }
.gallery-inner { display: grid; grid-template-columns: 1fr 120px; gap: 10px; padding: 10px; }
.gallery-main { width: 100%; height: 360px; object-fit: cover; border-radius: 6px; display: block; }
.thumbs { display: grid; grid-template-rows: repeat(3, 1fr); gap: 8px; }
.thumbs img { width: 100%; height: 112px; object-fit: cover; border-radius: 6px; border: 1px solid var(--line); }
.details-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 18px; }
.ad-desc { overflow-wrap: anywhere; word-break: break-word; }
.video-embed { position: relative; padding-top: 56.25%; }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border:0; border-radius: 8px; }
.one-line { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Community bar with action buttons */
.community-bar { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.community-bar .cb-text { font-weight:600; color:#2b5468; }
.community-bar .cb-actions { display:flex; gap:10px; flex-wrap:wrap; }
.community-bar .cb-btn { border-radius:999px; padding:8px 14px; font-weight:700; }
.community-bar .cb-primary { background:#2b5468; color:#fff; border:0; border-radius:999px; padding:8px 16px; font-weight:800; }
.community-bar .cb-primary:hover { filter:brightness(1.05); text-decoration:none; }
/* Small colorful icons for cb-actions */
.community-bar .cb-actions .i-badge { display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:8px; margin-right:6px; border:1px solid currentColor; box-shadow: 0 1px 2px rgba(0,0,0,.08); transition: transform .15s ease, filter .2s ease; }
.community-bar .cb-actions a:hover .i-badge { transform: translateY(-1px); filter: brightness(1.05); }
.community-bar .cb-actions .i-yellow { color:#9e6a00; background: linear-gradient(135deg, #fff7da, #ffe69a); border-color:#f5b300; }
.community-bar .cb-actions .i-blue { color:#1f3f50; background: linear-gradient(135deg, #eef7fb, #d8ebf3); border-color:#2b5468; }
.community-bar .cb-actions .i-teal { color:#1b7e74; background: linear-gradient(135deg, #e6faf6, #c8f1ea); border-color:#2ea39a; }
.community-bar .cb-actions .i-red { color:#8e2a22; background: linear-gradient(135deg, #fde2df, #f8b4ac); border-color:#c0392b; }
.community-bar .cb-actions .i-gray { color:#5c7f67; background:#e8f0ec; border-color:#5c7f67; }
/* Inverted badge for dark button */
.community-bar .cb-actions .i-inv { color:#fff; background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.55); }
.auth-box h2 { margin: 0 0 10px; color:#2b5468; }
.form { display: grid; gap: 12px; }
.form label { display: grid; gap: 6px; font-size: 14px; color:#2b5468; }
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form input[type="file"],
.form select,
.form textarea { width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:8px; background:#fff; }
.form textarea { min-height: 100px; resize: vertical; }
.form .form-grid { display: grid; gap: 12px; }
.form .two { grid-template-columns: 1fr 1fr; }
.form .three { grid-template-columns: repeat(3, 1fr); }
.auth-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
@media (max-width: 720px) {
  .form .two, .form .three { grid-template-columns: 1fr; }
}
/* community-bar removed */
.share-box { display: flex; gap: 8px; }
.contact-large .contact-head { display:flex; align-items:center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin: 10px 0; }
.captcha-placeholder { margin: 8px 0 12px; border: 1px dashed var(--line); padding: 10px; border-radius: 8px; color: var(--muted); font-size: 14px; }
.side-contact .seller-min { margin-bottom: 8px; color:#333; }

/* Click-to-show contacts */
.reveal-contact { display: grid; grid-template-columns: 56px 1fr; align-items: center; gap: 12px; border: 2px dashed var(--line); border-radius: 10px; padding: 10px; margin: 8px 0; text-decoration: none; }
.reveal-contact .icon { width: 56px; height: 56px; display: inline-flex; align-items: center; justify-content: center; border-radius: 8px; color: transparent; background-position: center; background-repeat: no-repeat; background-size: 60%; box-shadow: 0 1px 1px rgba(0,0,0,.05) inset; }
.reveal-contact .text { display: grid; line-height: 1.2; }
.reveal-contact .hint { color: #666; font-size: 12px; }
.reveal-contact .num { color: #1b825e; font-weight: 700; }
.reveal-contact.phone { border-color: #2f6fde; }
.reveal-contact.phone .icon { background-color: #3b6cd8; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M6.62 10.79a15.05 15.05 0 006.59 6.59l2.2-2.2a1 1 0 011-.24c1.1.37 2.28.57 3.5.57a1 1 0 011 1v3.5a1 1 0 01-1 1C12.3 22 2 11.7 2 4a1 1 0 011-1h3.5a1 1 0 011 1c0 1.22.2 2.4.57 3.5a1 1 0 01-.24 1l-2.2 2.29z'/></svg>"); }
.reveal-contact.whatsapp { border-color: #25d366; }
.reveal-contact.whatsapp .icon { background-color: #25d366; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M20.52 3.49A11.5 11.5 0 003.5 20.51L2 22l1.62-.47A11.5 11.5 0 1019 4.11l1.52-.62zM12.04 4a8 8 0 00-6.9 12.16l-.42 1.5 1.54-.4A8 8 0 1012.04 4zm4.61 9.7c-.25-.13-1.47-.72-1.7-.8-.22-.08-.38-.13-.54.13-.16.25-.62.8-.76.97-.14.17-.28.18-.53.06-.25-.13-1.06-.39-2.02-1.25-.75-.66-1.26-1.47-1.4-1.72-.15-.25-.02-.38.11-.5.11-.1.25-.28.38-.42.13-.14.17-.25.25-.42.08-.17.05-.32-.02-.45-.06-.13-.54-1.3-.74-1.78-.2-.48-.4-.41-.54-.41h-.46c-.16 0-.42.06-.64.32-.22.25-.85.84-.85 2.06 0 1.22.88 2.4 1 2.57.13.17 1.73 2.63 4.2 3.69.59.25 1.05.4 1.41.52.59.19 1.13.16 1.56.1.47-.07 1.47-.6 1.68-1.18.21-.57.21-1.07.15-1.18-.06-.11-.23-.18-.48-.31z'/></svg>"); }
.reveal-contact.chat { border-color: #7b5cff; }
.reveal-contact.chat .icon { background-color: #7b5cff; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'><path d='M3 6.5C3 4.57 4.57 3 6.5 3h11C19.43 3 21 4.57 21 6.5v7c0 1.93-1.57 3.5-3.5 3.5H9l-4 4v-4.5C3.9 16.06 3 14.9 3 13.5v-7Z' fill='%23ffffff'/></svg>"); }
.reveal-contact:hover { text-decoration: none; border-color: var(--brand); }
.reveal-contact.revealed .hint { color: #2b5468; }
.reveal-contact.phone .num { color: #2f6fde; }
.reveal-contact.whatsapp .num { color: #25d366; }

/* compact (header mini) */
.reveal-contact.mini { grid-template-columns: 32px 1fr; padding: 6px 8px; border-width: 1px; gap: 6px; }
.reveal-contact.mini .icon { width: 32px; height: 32px; }
.reveal-contact.mini .hint { font-size: 11px; }
.reveal-contact.mini .num { font-size: 13px; }

/* Oculta telefone antigo do bloco lateral (substituÃ­do pelos novos botÃµes) */
.side-contact .seller-min { display: none; }

/* Chat button under WhatsApp */
.chat-btn { display: inline-flex; align-items:center; gap:8px; background:#e53935; color:#fff; border:0; border-radius:999px; padding:10px 16px; margin-top: 8px; text-align: center; text-decoration:none; font-weight:700; }
.chat-btn:hover { filter: brightness(1.05); text-decoration:none; }
.chat-btn .chat-ico { width:18px; height:18px; display:inline-block; background-repeat:no-repeat; background-position:center; background-size: 18px 18px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 15a4 4 0 0 1-4 4H8l-5 4v-4a4 4 0 0 1-4-4V7a4 4 0 0 1 4-4h14a4 4 0 0 1 4 4z' fill='none'/><path d='M7 9h10M7 13h6' /></svg>"); }
/* Share buttons */
.share-box { display:flex; gap:8px; flex-wrap:wrap; }
.share-btn.si { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:8px 10px; border-radius:8px; color:#fff; border:0; text-decoration:none; }
.share-btn.si:hover { filter: brightness(1.05); text-decoration:none; }
.share-btn.si .ico { width:18px; height:18px; display:inline-block; background-repeat:no-repeat; background-position:center; background-size:18px 18px; }
.share-btn.fb { background:#1877f2; }
.share-btn.fb .ico { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M13 10h3l1-4h-4V4c0-1.03.27-1.73 1.7-1.73H17V0h-2.6C11.4 0 10 1.67 10 4.7V6H7v4h3v10h3V10Z'/></svg>"); }
.share-btn.tw { background:#1da1f2; }
.share-btn.tw .ico { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M23 5.92c-.84.37-1.75.62-2.7.74a4.72 4.72 0 0 0 2.07-2.6 9.43 9.43 0 0 1-3 1.15 4.71 4.71 0 0 0-8.02 4.29A13.36 13.36 0 0 1 3.16 4.9 4.71 4.71 0 0 0 4.6 11.2a4.64 4.64 0 0 1-2.14-.59v.06a4.71 4.71 0 0 0 3.78 4.62c-.42.11-.86.17-1.31.17-.32 0-.63-.03-.93-.09a4.72 4.72 0 0 0 4.4 3.27A9.45 9.45 0 0 1 2 20.54 13.33 13.33 0 0 0 9.23 22c8.38 0 12.97-6.94 12.97-12.96l-.01-.59A9.24 9.24 0 0 0 23 5.92Z'/></svg>"); }
.share-btn.wa { background:#25d366; }
.share-btn.wa .ico { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M20.52 3.49A11.5 11.5 0 003.5 20.51L2 22l1.62-.47A11.5 11.5 0 1019 4.11l1.52-.62zM12.04 4a8 8 0 00-6.9 12.16l-.42 1.5 1.54-.4A8 8 0 1012.04 4zm4.61 9.7c-.25-.13-1.47-.72-1.7-.8-.22-.08-.38-.13-.54.13-.16.25-.62.8-.76.97-.14.17-.28.18-.53.06-.25-.13-1.06-.39-2.02-1.25-.75-.66-1.26-1.47-1.4-1.72-.15-.25-.02-.38.11-.5.11-.1.25-.28.38-.42.13-.14.17-.25.25-.42.08-.17.05-.32-.02-.45-.06-.13-.54-1.3-.74-1.78-.2-.48-.4-.41-.54-.41h-.46c-.16 0-.42.06-.64.32-.22.25-.85.84-.85 2.06 0 1.22.88 2.4 1 2.57.13.17 1.73 2.63 4.2 3.69.59.25 1.05.4 1.41.52.59.19 1.13.16 1.56.1.47-.07 1.47-.6 1.68-1.18.21-.57.21-1.07.15-1.18-.06-.11-.23-.18-.48-.31z'/></svg>"); }
.share-btn.ig { background:#E1306C; }
.share-btn.ig .ico { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M7 2h10a5 5 0 015 5v10a5 5 0 01-5 5H7a5 5 0 01-5-5V7a5 5 0 015-5zm0 2a3 3 0 00-3 3v10a3 3 0 003 3h10a3 3 0 003-3V7a3 3 0 00-3-3H7zm5 3.5A5.5 5.5 0 1112 18.5 5.5 5.5 0 0112 7.5zm0 2A3.5 3.5 0 1015.5 13 3.5 3.5 0 0012 9.5zm6-2a1 1 0 110 2 1 1 0 010-2z'/></svg>"); }
/* Contact icons: use per-kind colors/icons */
/* Slightly larger WhatsApp symbol */
.reveal-contact.whatsapp .icon { background-size: 70%; }


