/*
Theme Name: Alerta Paraíba
Theme URI: https://alertaparaiba.com.br
Author: Redação Alerta Paraíba
Description: Tema leve, minimalista e rápido para o portal de notícias Alerta Paraíba. Construído do zero (HTML/CSS/PHP), sem page builders, com tipografia Newsreader + Public Sans e foco em performance, SEO (compatível com Rank Math) e Core Web Vitals.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: alerta-pb
*/

:root{
  --brand-red:#F84643;--brand-red-dark:#D8352F;
  --ink:#292929;--text:#33373B;--muted:#67737E;--bg:#FFFFFF;--line:#E8E8E8;--line-strong:#1A1A1A;
  --wrap:1180px;--measure:42rem;
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
  --sans:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.topbar{height:4px;background:var(--brand-red)}
.skip{position:absolute;left:-999px}
.skip:focus{left:1rem;top:1rem;background:#fff;padding:.6rem 1rem;z-index:50;border:2px solid var(--brand-red)}

/* ---------- Masthead ---------- */
.masthead{border-bottom:1px solid var(--line)}
.masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:clamp(.9rem,2.5vw,1.4rem) 0}
.brand{display:flex;align-items:center;line-height:1}
.brand img,.brand .logo{height:clamp(38px,6vw,52px);width:auto;display:block}
.brand .name{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3.6vw,2.2rem);letter-spacing:-.02em;color:var(--ink)}
.brand .name b{color:var(--brand-red);font-weight:600}
.masthead-right{display:flex;align-items:center;gap:1rem}
.dateline{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.icon-btn{background:none;border:0;cursor:pointer;color:var(--ink);display:grid;place-items:center;width:40px;height:40px;border-radius:50%}
.icon-btn:hover{background:#f3f4f5}
.icon-btn svg{width:20px;height:20px}

/* search dropdown */
.search-pop{display:none;border-bottom:1px solid var(--line);background:#fafbfb}
.search-pop.open{display:block}
.search-pop form{display:flex;gap:.5rem;padding:1rem 0}
.search-pop input[type=search]{flex:1;border:1px solid #cfd4d8;border-radius:3px;padding:.7rem .9rem;font-family:var(--sans);font-size:1rem}
.search-pop button{background:var(--brand-red);color:#fff;border:0;padding:0 1.3rem;border-radius:3px;font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}

/* ---------- Hero ---------- */
.lead{padding:clamp(2rem,5vw,3.5rem) 0 clamp(1.5rem,4vw,2.5rem)}
.lead-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:clamp(1.25rem,3vw,2.5rem);align-items:center}
.lead h1{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-.02em}
.lead h1 a{background-image:linear-gradient(var(--brand-red),var(--brand-red));background-size:0 2px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .3s ease;padding-bottom:.05em}
.lead h1 a:hover{background-size:100% 2px}
.media{position:relative;overflow:hidden;background:linear-gradient(135deg,#e7eaec,#d4d9dd);border-radius:2px}
.media img{width:100%;height:100%;object-fit:cover}
.r-4x3{aspect-ratio:4/3}.r-16x9{aspect-ratio:16/9}.r-1x1{aspect-ratio:1/1}

/* ---------- Section heading ---------- */
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;border-top:2px solid var(--line-strong);padding-top:.8rem;margin:clamp(1.5rem,4vw,2.5rem) 0 clamp(1.25rem,3vw,1.75rem)}
.section-head h2{font-family:var(--sans);font-size:.92rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.section-head h2 span{color:var(--brand-red)}

/* ---------- Lists ---------- */
.list-wrap{display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,5vw,4rem)}
.headlines{display:flex;flex-direction:column}
.headline{display:grid;grid-template-columns:1fr 96px;gap:1.25rem;align-items:start;padding:1.25rem 0;border-top:1px solid var(--line)}
.headline:first-child{border-top:0}
.headline.no-media{grid-template-columns:1fr}
.headline h3{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:1.2rem;line-height:1.2;letter-spacing:-.01em}
.headline h3 a{background-image:linear-gradient(var(--brand-red),var(--brand-red));background-size:0 1.5px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .3s ease}
.headline h3 a:hover{background-size:100% 1.5px}
.headline .media{border-radius:2px}

/* aside: most read */
.aside .section-head{margin-top:0}
.ranklist{counter-reset:r;display:flex;flex-direction:column;list-style:none}
.ranklist li{counter-increment:r;display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;padding:1rem 0;border-top:1px solid var(--line)}
.ranklist li:first-child{border-top:0}
.ranklist li::before{content:counter(r);font-family:var(--serif);font-size:1.6rem;font-weight:600;color:var(--brand-red);line-height:.9;width:1.4ch}
.ranklist h4{font-family:var(--serif);font-weight:500;font-size:1.02rem;line-height:1.18;color:var(--ink)}
.ranklist h4 a:hover{color:var(--brand-red)}

/* pagination */
.pagination{display:flex;gap:.5rem;flex-wrap:wrap;margin:2.5rem 0}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 .6rem;border:1px solid var(--line);border-radius:3px;font-size:.85rem;font-weight:600;color:var(--ink)}
.pagination .page-numbers.current{background:var(--brand-red);color:#fff;border-color:var(--brand-red)}
.pagination a.page-numbers:hover{border-color:var(--brand-red);color:var(--brand-red)}

/* ---------- Single article ---------- */
.article{padding:clamp(1.5rem,4vw,2.5rem) 0 0}
.breadcrumb{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.breadcrumb a{color:var(--brand-red);font-weight:600}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .separator{margin:0 .5rem;opacity:.4}
.article-head{max-width:var(--measure);margin:0 auto}
.cat-label{display:inline-block;background:var(--brand-red);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .7rem;border-radius:2px;margin-bottom:1.25rem}
.cat-label:hover{background:var(--brand-red-dark)}
.article h1{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.06;letter-spacing:-.022em;margin-bottom:1.1rem}
.standfirst{font-family:var(--serif);font-weight:400;font-style:italic;font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.45;color:var(--muted);margin-bottom:1.75rem}
.byline{display:flex;align-items:center;gap:.9rem;padding:1.1rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);max-width:var(--measure);margin:0 auto}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:1.05rem;flex:none;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.byline .who{font-weight:600;color:var(--ink);font-size:.92rem}
.byline .who a:hover{color:var(--brand-red)}
.byline .when{font-size:.76rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:.15rem}
.byline .share{margin-left:auto;display:flex;gap:.4rem}
.byline .share a{width:36px;height:36px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--muted)}
.byline .share a:hover{border-color:var(--brand-red);color:var(--brand-red)}
.byline .share svg{width:16px;height:16px}
.featured{margin:1.75rem auto;max-width:var(--wrap)}
.featured .media{aspect-ratio:16/9}
.featured figcaption{font-size:.76rem;color:var(--muted);margin-top:.6rem;font-style:italic}

/* body copy from editor (Newsreader reading) */
.article-body{max-width:var(--measure);margin:0 auto;font-family:var(--serif);font-size:1.235rem;line-height:1.72;color:var(--text)}
.article-body > p,.article-body > ul,.article-body > ol,.article-body > h2,.article-body > h3,.article-body > figure,.article-body > blockquote,.article-body > .wp-block-image{margin:0 0 1.4rem}
.article-body p:first-of-type::first-letter{float:left;font-weight:600;font-size:3.6rem;line-height:.78;padding:.35rem .55rem 0 0;color:var(--brand-red)}
.article-body h2{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.7rem;line-height:1.2;letter-spacing:-.01em;margin-top:2.4rem}
.article-body h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.35rem;margin-top:1.8rem}
.article-body a{color:var(--brand-red);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.article-body ul,.article-body ol{padding-left:1.4rem}
.article-body li{margin:0 0 .5rem}
.article-body blockquote{border-left:3px solid var(--brand-red);padding:.25rem 0 .25rem 1.5rem;font-size:1.45rem;line-height:1.4;color:var(--ink)}
.article-body img{border-radius:2px}
.article-body figcaption{font-family:var(--sans);font-size:.76rem;color:var(--muted);margin-top:.5rem}
.tags{max-width:var(--measure);margin:2.5rem auto 0;display:flex;flex-wrap:wrap;gap:.5rem}
.tags a{font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:.4rem .8rem;border-radius:2px}
.tags a:hover{border-color:var(--brand-red);color:var(--brand-red)}
.authorbox{max-width:var(--measure);margin:2.75rem auto 0;background:#fafbfb;border:1px solid var(--line);border-radius:3px;padding:1.5rem;display:flex;gap:1.25rem;align-items:flex-start}
.authorbox .avatar{width:60px;height:60px;font-size:1.4rem}
.authorbox h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-red);margin-bottom:.3rem}
.authorbox .name{font-family:var(--serif);font-weight:600;font-size:1.25rem;color:var(--ink);margin-bottom:.5rem}
.authorbox .name a:hover{color:var(--brand-red)}
.authorbox p{font-size:.92rem;color:var(--muted);line-height:1.55}

/* related */
.related{margin:clamp(2.5rem,6vw,4rem) 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.25rem,3vw,2.5rem)}
.card .media{aspect-ratio:16/9;margin-bottom:.9rem}
.card h3{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:1.25rem;line-height:1.16;letter-spacing:-.01em}
.card h3 a:hover{color:var(--brand-red)}

/* ---------- Pages (Sobre / Privacidade) ---------- */
main.page-main{padding:clamp(2rem,5vw,3.5rem) 0 clamp(2rem,5vw,3rem)}
.page{max-width:var(--measure)}
.page > .kicker{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-red);margin-bottom:1rem}
.page h1{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(2rem,4.4vw,3.1rem);line-height:1.07;letter-spacing:-.022em;margin-bottom:1.5rem}
.prose{font-family:var(--serif);font-size:1.18rem;line-height:1.7;color:var(--text)}
.prose p{margin:0 0 1.2rem}
.prose h2{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:1.5rem;line-height:1.2;margin:2rem 0 .8rem}
.prose ul,.prose ol{margin:0 0 1.2rem 1.4rem}
.prose strong{color:var(--ink)}
.prose a{color:var(--brand-red);text-decoration:underline;text-underline-offset:2px}
.updated{font-family:var(--sans);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--line)}

/* ---------- Contact form ---------- */
.contact-form{margin-top:2rem;max-width:var(--measure)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);margin-bottom:.45rem}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;border:1px solid #cfd4d8;border-radius:3px;padding:.8rem .9rem;transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brand-red);box-shadow:0 0 0 3px rgba(248,70,67,.12)}
.field textarea{min-height:160px;resize:vertical}
.hp{position:absolute;left:-9999px}
.form-actions{display:flex;align-items:center;gap:1rem;margin-top:.5rem}
.btn{background:var(--brand-red);color:#fff;border:0;padding:.85rem 1.6rem;font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border-radius:3px}
.btn:hover{background:var(--brand-red-dark)}
.form-note{font-size:.82rem;color:var(--muted)}
.form-ok{background:#f0faf3;border:1px solid #b9e3c6;color:#1f7a3f;padding:1rem 1.1rem;border-radius:3px;font-size:.95rem;margin-bottom:1.5rem}
.form-err{background:#fdeceb;border:1px solid #f3b6b3;color:#b3231d;padding:1rem 1.1rem;border-radius:3px;font-size:.95rem;margin-bottom:1.5rem}

/* ---------- Footer ---------- */
footer.site-footer{border-top:4px solid var(--brand-red);background:#fafbfb;margin-top:clamp(2rem,5vw,3rem)}
.foot-inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:clamp(2rem,5vw,3rem) 0}
.foot-brand .name{font-family:var(--serif);font-weight:600;font-size:1.4rem;color:var(--ink)}
.foot-brand .name b{color:var(--brand-red)}
.foot-brand img{height:46px;width:auto;margin-bottom:.6rem}
.foot-brand p{max-width:34ch;font-size:.85rem;color:var(--muted);margin-top:.6rem}
.foot-col h5{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:.9rem}
.foot-col a{display:block;font-size:.88rem;color:var(--text);padding:.25rem 0}
.foot-col a:hover{color:var(--brand-red)}
.foot-bottom{border-top:1px solid var(--line);padding:1.25rem 0;font-size:.74rem;color:var(--muted);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .lead-grid{grid-template-columns:1.2fr 1fr}
  .list-wrap{grid-template-columns:1fr}
  .aside{border-top:2px solid var(--line-strong);padding-top:1.5rem}
}
@media(max-width:900px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:720px){
  .dateline{display:none}
  .lead-grid{grid-template-columns:1fr;gap:1.25rem}
  .grid-3{grid-template-columns:1fr;gap:1.75rem}
  .headline{grid-template-columns:1fr 84px;gap:1rem}
  .article-body{font-size:1.15rem}
  .prose{font-size:1.1rem}
  .authorbox{flex-direction:column;gap:1rem}
  .form-actions{flex-direction:column;align-items:flex-start}
}
@media(max-width:420px){
  .headline{grid-template-columns:1fr 64px}
  .headline h3{font-size:1.08rem}
}
