/*
Theme Name: Somos News
Theme URI: https://somosnoticia.com.br
Author: Somos Notícia
Author URI: https://somosnoticia.com.br
Description: Tema de portal de notícias regional — design editorial azul & branco, responsivo, otimizado para Core Web Vitals e Google News. Páginas de post, categoria, tag, busca e 404 customizado. Compatível com Rank Math.
Version: 1.2.4
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: somos-news
Tags: news, blog, two-columns, right-sidebar, custom-menu, featured-images, translation-ready, threaded-comments
*/

/* ════════════════ DESIGN TOKENS ════════════════ */
:root {
  --blue-900:#062a5e; --blue-800:#073a82; --blue-700:#0a4ea3;
  --blue-600:#1565d8; --blue-500:#2b7de9; --blue-100:#e7f0fc; --blue-050:#f3f8ff;
  --ink:#0f1b2d; --ink-soft:#3a4a60; --muted:#6b7a90; --line:#e3e8f0;
  --surface:#fff; --surface-alt:#f6f8fc; --bg:#fbfcfe; --danger:#c0392b;
  --font-serif: Georgia, 'Times New Roman', serif;
  --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --radius:10px; --radius-sm:6px;
  --shadow-sm:0 1px 2px rgba(15,27,45,.06); --shadow:0 6px 24px rgba(15,27,45,.08);
  --container:1180px; --gap:24px;
}

/* Para o visual editorial pretendido (Lora + Libre Franklin), auto-hospede os
   .woff2 e descomente: ver functions.php (sn_enqueue_fonts) e README. */

/* ════════════════ BASE / RESET ════════════════ */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;max-width:100%}
h1,h2,h3,h4{font-family:var(--font-serif);line-height:1.2;color:var(--ink)}
a{color:var(--blue-700);text-decoration:none}
a:hover{color:var(--blue-600)}
img{max-width:100%;height:auto;display:block}
figure{margin:0}

.sn-container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
.site-main{min-height:60vh;padding-bottom:56px}

.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--blue-700);
  color:#fff;padding:10px 16px;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:4px}

/* ════════════════ HEADER ════════════════ */
.site-header{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.site-header__bar{display:flex;align-items:center;gap:16px;height:68px}
.site-header__brand{display:flex;align-items:center;gap:10px;font-family:var(--font-serif);
  font-weight:700;font-size:24px;color:var(--ink);letter-spacing:-.02em;margin-right:auto}
.site-header__brand:hover{color:var(--blue-700)}
.site-header__brand-mark{width:12px;height:26px;border-radius:3px;
  background:linear-gradient(160deg,var(--blue-500),var(--blue-800))}
.site-header__brand img{max-height:40px;width:auto}
.site-header__search{width:320px;max-width:38vw}
.site-header__burger{display:none;flex-direction:column;gap:4px;background:none;border:0;padding:8px;cursor:pointer}
.site-header__burger span{width:22px;height:2px;background:var(--ink);border-radius:2px}

.site-nav{background:var(--blue-700)}
.site-nav__inner{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;margin:0;padding:0;list-style:none}
.site-nav__inner::-webkit-scrollbar{display:none}
.site-nav__inner li{margin:0}
.site-nav__inner a{display:block;color:#dbe7fb;font-size:14px;font-weight:600;letter-spacing:.01em;
  padding:13px 14px;white-space:nowrap;border-bottom:3px solid transparent}
.site-nav__inner a:hover,.site-nav__inner .current-menu-item>a{color:#fff;border-bottom-color:var(--blue-500)}

/* ════════════════ SEARCH ════════════════ */
.searchbar{display:flex;align-items:center;background:var(--surface-alt);border:1px solid var(--line);
  border-radius:999px;overflow:hidden}
.searchbar input[type=search]{flex:1;border:0;background:transparent;padding:11px 16px;font-size:15px;
  color:var(--ink);font-family:inherit;min-width:0}
.searchbar input:focus{outline:none}
.searchbar button{border:0;background:var(--blue-700);color:#fff;width:44px;height:44px;
  display:grid;place-items:center;cursor:pointer;flex-shrink:0}
.searchbar button:hover{background:var(--blue-600)}
.searchbar:focus-within{border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-100)}

/* ════════════════ HERO ════════════════ */
.hero{display:grid;grid-template-columns:1.7fr 1fr;gap:var(--gap);padding:28px 0}
.hero__side{display:grid;grid-template-rows:repeat(4,1fr);gap:14px}

/* ════════════════ CARDS ════════════════ */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card__media{position:relative;display:block;aspect-ratio:16/9;background:var(--blue-100);overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__media img{transform:scale(1.04)}
.card__media-ph{position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-100),var(--blue-050))}
.card__body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:9px;flex:1}
.card__title{margin:0;font-size:19px;line-height:1.28}
.card__title a{color:var(--ink)}
.card__title a:hover{color:var(--blue-700)}
.card__excerpt{margin:0;color:var(--ink-soft);font-size:14.5px}
.card__meta{margin-top:auto;display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:12.5px}

.card--hero .card__title{font-size:30px}
.card--hero .card__media{aspect-ratio:16/10}
.card--hero .card__excerpt{font-size:16px}
.card--compact{flex-direction:row;box-shadow:none;align-items:flex-start}
.card--compact .card__media{width:116px;height:116px;flex-shrink:0;aspect-ratio:auto;align-self:flex-start}
.card--compact .card__body{padding:10px 12px}
.card--compact .card__title{font-size:15.5px;line-height:1.25}

.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.post-grid--compact{grid-template-columns:repeat(2,1fr);gap:14px}

/* ════════════════ LAYOUT ARCHIVE ════════════════ */
.archive-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:36px;padding-top:28px}
.archive__head{margin-bottom:22px}
.archive__kicker{display:inline-block;text-transform:uppercase;letter-spacing:.12em;font-size:12px;
  font-weight:700;color:var(--blue-600);margin-bottom:6px}
.archive__title{margin:0;font-size:34px}
.archive__desc{color:var(--ink-soft);margin:8px 0 0;max-width:60ch}

.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:6px 0 18px;
  padding-bottom:10px;border-bottom:2px solid var(--ink)}
.section-head h2{margin:0;font-size:22px}
.section-head__link{font-size:14px;font-weight:600}

/* ════════════════ SIDEBAR / WIDGETS ════════════════ */
.sidebar{display:flex;flex-direction:column;gap:28px}
.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.widget .widget-title,.widget__title{margin:0 0 14px;font-size:15px;text-transform:uppercase;
  letter-spacing:.08em;color:var(--blue-800);padding-bottom:10px;border-bottom:1px solid var(--line);font-family:var(--font-serif)}
.widget ul{list-style:none;margin:0;padding:0}
.widget ul li{padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.widget ul li:last-child{border-bottom:0}
.widget a{color:var(--ink);font-weight:600}
.widget a:hover{color:var(--blue-700)}

.ranked{list-style:none;margin:0;padding:0;counter-reset:r}
.ranked li{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.ranked li:last-child{border-bottom:0}
.ranked__num{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--blue-500);line-height:1;width:24px;flex-shrink:0}
.ranked a{color:var(--ink);font-weight:600;font-size:14.5px;line-height:1.35}

.tagcloud{display:flex;flex-wrap:wrap;gap:8px}
.tagcloud a,.tag-chip{display:inline-block;font-size:13px!important;font-weight:600;color:var(--ink-soft);
  background:var(--surface-alt);border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.tagcloud a:hover,.tag-chip:hover{background:var(--blue-700);color:#fff;border-color:var(--blue-700)}

/* ════════════════ BADGES / BREADCRUMBS ════════════════ */
.badge{display:inline-block;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:var(--blue-700);background:var(--blue-100);padding:4px 10px;border-radius:999px}
a:hover .badge{background:var(--blue-700);color:#fff}
.breadcrumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.breadcrumbs a{color:var(--blue-700)}
.breadcrumbs .sep{margin:0 8px;color:var(--line)}

/* ════════════════ SINGLE POST ════════════════ */
.single-post{max-width:760px;margin:0 auto;padding-top:28px}
.post__head{margin:12px 0 22px}
.post__title{font-size:40px;line-height:1.12;margin:12px 0 14px;letter-spacing:-.01em}
.post__lead{font-size:20px;color:var(--ink-soft);line-height:1.5;margin:0 0 18px;font-family:var(--font-serif)}
.post__meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:14px;padding:14px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.post__cover{margin:0 0 26px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

.entry-content{font-size:19.5px;line-height:1.8;color:#1d2a3d}
.entry-content p{margin:0 0 1.3em}
.entry-content h2{font-size:27px;margin:1.6em 0 .5em}
.entry-content h3{font-size:22px;margin:1.4em 0 .4em}
.entry-content a{text-decoration:underline;text-underline-offset:2px}
.entry-content img{border-radius:var(--radius-sm);margin:1.4em 0}
.entry-content blockquote{margin:1.5em 0;padding:6px 0 6px 22px;border-left:4px solid var(--blue-500);
  font-family:var(--font-serif);font-size:21px;color:var(--ink);font-style:italic}
.entry-content ul,.entry-content ol{padding-left:1.3em;margin:0 0 1.3em}
.entry-content li{margin-bottom:.4em}
.entry-content figcaption,.wp-caption-text{font-size:13.5px;color:var(--muted);text-align:center;margin-top:6px}

/* alinhamentos do WP */
.alignleft{float:left;margin:.4em 1.4em 1em 0;max-width:50%}
.alignright{float:right;margin:.4em 0 1em 1.4em;max-width:50%}
.aligncenter{margin-left:auto;margin-right:auto}
.alignwide,.alignfull{max-width:100%}
@media(min-width:1100px){
  .alignwide{max-width:1040px;margin-left:calc(50% - 520px);margin-right:calc(50% - 520px)}
}
.wp-caption{max-width:100%}
.sticky .card{border-color:var(--blue-500)}

.post__tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0;padding-top:22px;border-top:1px solid var(--line)}
.related{padding-top:40px}

/* Embeds responsivos (YouTube, etc.) — evita estouro de largura/scroll horizontal */
.entry-content iframe,
.entry-content embed,
.entry-content object,
.entry-content video{max-width:100%}
.entry-content iframe{width:100%;aspect-ratio:16/9;height:auto;border:0}
/* embeds em bloco do Gutenberg (mantém proporção e largura) */
.entry-content .wp-block-embed{margin:1.4em 0}
.entry-content .wp-block-embed__wrapper{max-width:100%}
.entry-content .wp-block-embed__wrapper iframe{aspect-ratio:auto} /* o WP já controla a proporção do bloco */

/* Artigo dentro da coluna de conteúdo (layout 2 colunas) */
.post-article{max-width:820px}

/* Widget destaque (ex.: Esportes) — cabeçalho azul + lista compacta */
.widget--feature{padding:0;overflow:hidden}
.widget__feature-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--blue-700);color:#fff;padding:12px 16px}
.widget__feature-head h2{display:flex;align-items:center;gap:8px;margin:0;color:#fff;font-size:15px;
  text-transform:uppercase;letter-spacing:.06em;border:0;padding:0;font-family:var(--font-serif)}
.widget__feature-head a{color:#dbe7fb;font-size:13px;font-weight:600;white-space:nowrap}
.widget__feature-head a:hover{color:#fff}
.widget--feature .feature-list{padding:6px 16px;display:flex;flex-direction:column;gap:0}
.widget--feature .feature-list .card--compact{border:0;border-radius:0;box-shadow:none;
  padding:12px 0;border-bottom:1px solid var(--line)}
.widget--feature .feature-list .card--compact:last-child{border-bottom:0}
.widget--feature .feature-list .card--compact .card__media{width:84px;height:84px;border-radius:var(--radius-sm)}
.widget--feature .feature-list .card--compact .card__body{padding:0 0 0 12px}
.widget--feature .feature-list .badge{display:none}

/* Submenus do menu principal (subcategorias de Cidades, Publicidade, etc.) */
.site-nav__inner li{position:relative}
.site-nav__inner .sub-menu,.site-nav__inner .children{position:absolute;top:100%;left:0;min-width:210px;
  background:var(--blue-800);list-style:none;margin:0;padding:6px 0;box-shadow:var(--shadow);
  display:none;z-index:200;border-radius:0 0 8px 8px}
.site-nav__inner li:hover>.sub-menu,.site-nav__inner li:focus-within>.sub-menu,
.site-nav__inner li:hover>.children,.site-nav__inner li:focus-within>.children{display:block}
.site-nav__inner .sub-menu li,.site-nav__inner .children li{margin:0}
.site-nav__inner .sub-menu a,.site-nav__inner .children a{display:block;padding:9px 16px;border:0;
  color:#cfe0fb;font-size:13.5px;font-weight:500;white-space:nowrap}
.site-nav__inner .sub-menu a:hover,.site-nav__inner .children a:hover{background:var(--blue-700);color:#fff;border:0}

/* Post de destaque no topo da categoria */
.category-featured{margin-bottom:24px}
.category-featured .card--hero .card__title{font-size:26px}

/* Blocos por categoria na home */
.cat-block{margin-bottom:38px}
.cat-block .section-head h2{font-size:20px}
.cat-block .section-head h2 a{color:var(--ink)}
.cat-block .section-head h2 a:hover{color:var(--blue-700)}

/* Compartilhamento social */
.share{margin:30px 0 6px;padding-top:22px;border-top:1px solid var(--line)}
.share__label{display:block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}
.share__btns{display:flex;flex-wrap:wrap;gap:8px}
.share__btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:999px;
  font-size:14px;font-weight:600;color:#fff;border:0;cursor:pointer;font-family:inherit}
.share__btn--whatsapp{background:#25d366}
.share__btn--facebook{background:#1877f2}
.share__btn--twitter{background:#111}
.share__btn--telegram{background:#229ed9}
.share__btn--copy{background:var(--surface-alt);color:var(--ink-soft);border:1px solid var(--line)}
.share__btn:hover{opacity:.9;color:#fff}
.share__btn--copy:hover{background:var(--blue-100);color:var(--blue-700);opacity:1}
.share__btn--copy.is-copied{background:var(--blue-700);color:#fff;border-color:var(--blue-700)}

/* comentários (estilo enxuto) */
.comments-area{max-width:760px;margin:40px auto 0;padding-top:24px;border-top:1px solid var(--line)}
.comments-area .comment-list{list-style:none;padding:0}
.comments-area .comment-body{padding:14px 0;border-bottom:1px solid var(--line)}
.comment-respond input[type=text],.comment-respond input[type=email],.comment-respond textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:inherit;margin-bottom:10px}

/* ════════════════ PAGINAÇÃO ════════════════ */
.pagination{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:40px 0 10px}
.pagination .page-numbers{min-width:40px;height:40px;padding:0 12px;display:inline-flex;align-items:center;
  justify-content:center;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);
  font-size:14px;font-weight:600;color:var(--ink-soft)}
.pagination .page-numbers:hover{border-color:var(--blue-500);color:var(--blue-700)}
.pagination .page-numbers.current{background:var(--blue-700);border-color:var(--blue-700);color:#fff}
.pagination .dots{border:0;background:transparent}

/* ════════════════ 404 / BUSCA VAZIA ════════════════ */
.notfound{min-height:60vh;display:grid;place-items:center;padding:60px 20px;
  background:radial-gradient(120% 120% at 50% 0%,var(--blue-050),var(--bg))}
.notfound__inner{text-align:center;max-width:480px}
.notfound__code{font-family:var(--font-serif);font-size:110px;font-weight:700;line-height:1;
  background:linear-gradient(160deg,var(--blue-500),var(--blue-800));-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent}
.notfound__title{font-size:28px;margin:8px 0 12px}
.notfound__text{color:var(--ink-soft);margin:0 0 24px}
.notfound__search{margin-bottom:22px}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 22px;border-radius:var(--radius-sm);
  font-weight:700;font-size:15px;cursor:pointer;border:1px solid transparent}
.btn--primary{background:var(--blue-700);color:#fff}
.btn--primary:hover{background:var(--blue-600);color:#fff}
.empty{color:var(--muted);padding:40px 0;text-align:center}

/* ════════════════ FOOTER ════════════════ */
.site-footer{background:linear-gradient(165deg,var(--blue-700) 0%,var(--blue-900) 100%);color:#d3e0f5;margin-top:40px}
.site-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding:48px 0 32px}
.site-footer__brand strong{font-family:var(--font-serif);font-size:22px;color:#fff;display:block;margin-bottom:8px}
.site-footer__brand p{margin:0;font-size:14px;max-width:42ch;color:#bcd0ef}
.site-footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin:0 0 14px;font-family:var(--font-sans)}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:9px}
.site-footer a{color:#c3cee0;font-size:14px}
.site-footer a:hover{color:#fff}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.18);padding:18px 0;font-size:13px;color:#a7bde0}

/* ════════════════ RESPONSIVO ════════════════ */
@media(max-width:1080px){
  .archive-layout{grid-template-columns:1fr;gap:32px}
}
@media(max-width:980px){
  .hero{grid-template-columns:1fr}
  .hero__side{grid-template-rows:none;grid-template-columns:1fr 1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .post-grid{grid-template-columns:1fr 1fr}
  .site-header__search{display:none}
  .site-header__burger{display:flex}
  .post__title{font-size:30px}
  .archive__title{font-size:27px}
  .card--hero .card__title{font-size:24px}
  .site-nav{display:none}
  .site-nav.is-open{display:block}
  .site-nav__inner{flex-direction:column;overflow:visible}
  .site-nav__inner a{border-bottom:1px solid rgba(255,255,255,.12);border-left:3px solid transparent}
  /* subcategorias ficam visíveis e indentadas no mobile */
  .site-nav__inner li{position:static}
  .site-nav__inner .sub-menu,.site-nav__inner .children{position:static;display:block;
    background:rgba(0,0,0,.18);box-shadow:none;padding:0;border-radius:0;min-width:0}
  .site-nav__inner .sub-menu a,.site-nav__inner .children a{padding-left:34px;font-size:13px}
}
@media(max-width:480px){
  .post-grid,.post-grid--compact{grid-template-columns:1fr}
  .hero__side{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr;gap:28px}
  .entry-content{font-size:18px}
  .post__title{font-size:26px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
