/* FOZ — Guadiana Digital
 * theme.css — folha de estilos partilhada
 * Extraído e limpo do index.html original (duplicações de .hero-img/.hero-body removidas)
 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--trans:.22s ease}

/* ── THEMES ── */
[data-theme="light"]{
  --bg:#faf8f3;
  --bg-2:#f0ece2;
  --bg-3:#e8e3d6;
  --border:#d4cfc0;
  --border-2:#bfb9a8;
  --text:#1a1a14;
  --text-2:#4a4840;
  --text-3:#8a8678;
  --accent:#2d5a1b;
  --accent-2:#4a7a32;
  --accent-light:#e8f0e2;
  --red:#8b2020;
  --overlay:rgba(250,248,243,.96);
  --card:#f0ece2;
  --card-hover:#e8e3d6;
  --white:#1a1a14;
}
[data-theme="dark"]{
  --bg:#0f1209;
  --bg-2:#161a0f;
  --bg-3:#1d2314;
  --border:#2a3420;
  --border-2:#3a4830;
  --text:#e8ead8;
  --text-2:#a8aa98;
  --text-3:#686a58;
  --accent:#7aaa4a;
  --accent-2:#9aca6a;
  --accent-light:#1a2a10;
  --red:#c04040;
  --overlay:rgba(15,18,9,.96);
  --card:#161a0f;
  --card-hover:#1d2314;
  --white:#e8ead8;
}

html{background:var(--bg);scroll-behavior:smooth}
body{
  font-family:'Source Serif 4',Georgia,serif;
  background:var(--bg);color:var(--text);
  min-height:100vh;
  transition:background var(--trans),color var(--trans);
  -webkit-font-smoothing:antialiased;
}

.wrap{max-width:1280px;margin:0 auto;padding:0 1.5rem}

header{
  position:sticky;top:0;z-index:100;
  background:var(--overlay);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  transition:background var(--trans),border-color var(--trans);
}
.hdr-top{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;padding:.9rem 1.5rem;
  max-width:1280px;margin:0 auto;
}
.hdr-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-3);line-height:1.8;
}
.hdr-meta strong{color:var(--accent);font-weight:500}
.logo{text-align:center;cursor:pointer;text-decoration:none;display:block}
.logo-foz{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.8rem,4vw,3rem);
  font-weight:700;letter-spacing:.06em;
  color:var(--white);line-height:1;display:block;
}
.logo-rule{display:flex;align-items:center;gap:.6rem;margin:.3rem 0;justify-content:center}
.logo-rule span{flex:1;height:1px;background:var(--accent);max-width:40px}
.logo-diamond{width:6px;height:6px;background:var(--accent);transform:rotate(45deg);flex-shrink:0}
.logo-sub{
  font-family:'JetBrains Mono',monospace;
  font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--text-3);font-style:normal;
}
.hdr-actions{display:flex;align-items:center;justify-content:flex-end;gap:.6rem}
.hdr-btn{
  background:none;border:1px solid var(--border);
  color:var(--text-3);cursor:pointer;
  width:32px;height:32px;display:flex;
  align-items:center;justify-content:center;font-size:.8rem;
  transition:border-color var(--trans),color var(--trans);
}
.hdr-btn:hover{border-color:var(--accent);color:var(--accent)}

nav{border-top:1px solid var(--border);transition:border-color var(--trans);overflow:hidden}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 1.5rem;
  display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none;
}
.nav-inner::-webkit-scrollbar{display:none}
.nav-btn{
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  background:none;border:none;border-bottom:2px solid transparent;
  color:var(--text-2);cursor:pointer;text-decoration:none;
  padding:.75rem 1rem;white-space:nowrap;display:inline-block;
  transition:color var(--trans),border-color var(--trans),opacity var(--trans);
}
.nav-btn:hover{color:var(--accent)}
.nav-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.nav-btn.dim{opacity:.65;font-size:.57rem}
.nav-sep{display:flex;align-items:center;padding:0 .4rem;color:var(--border-2);font-size:.8rem;user-select:none;flex-shrink:0}

.search-overlay{
  position:fixed;inset:0;z-index:200;background:var(--overlay);
  display:none;align-items:flex-start;justify-content:center;padding-top:10vh;
}
.search-overlay.open{display:flex}
.search-box{width:100%;max-width:640px;border:1px solid var(--border-2);background:var(--bg-2);box-shadow:0 20px 60px rgba(0,0,0,.15)}
.search-row{display:flex;align-items:center;padding:.6rem 1rem;border-bottom:1px solid var(--border)}
.search-row input{
  flex:1;background:none;border:none;outline:none;
  font-family:'Source Serif 4',serif;font-size:1.1rem;color:var(--text);padding:.4rem 0;
}
.search-row input::placeholder{color:var(--text-3);font-style:italic}
.search-close{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:1rem;padding:.4rem;transition:color var(--trans)}
.search-close:hover{color:var(--text)}
.search-results{max-height:60vh;overflow-y:auto}
.search-result{
  display:grid;grid-template-columns:64px 1fr;gap:.8rem;
  align-items:center;padding:.8rem 1rem;
  border-bottom:1px solid var(--border);cursor:pointer;
  transition:background var(--trans);
}
.search-result:hover{background:var(--bg-3)}
.sr-thumb{width:64px;height:44px;object-fit:cover;background:var(--bg-3);display:block}
.sr-title{font-family:'Playfair Display',serif;font-size:.95rem;font-weight:600;line-height:1.3;color:var(--white)}
.sr-meta{font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-top:.25rem}
.search-status{padding:1.5rem;text-align:center;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.1em;color:var(--text-3)}

main{padding:0}
.page{display:none}
.page.active{display:block}

.loading{display:flex;flex-direction:column;align-items:center;padding:6rem 2rem;gap:1.5rem;color:var(--text-3)}
.spinner{width:28px;height:28px;border:1px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading p{font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase}
.error-msg{text-align:center;padding:5rem 2rem;display:none}
.error-msg h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:400;font-style:italic;color:var(--text-2);margin-bottom:.75rem}
.error-msg p{font-family:'JetBrains Mono',monospace;font-size:.6rem;color:var(--text-3);letter-spacing:.08em}

#feed-loading{display:flex;flex-direction:column;align-items:center;padding:6rem 2rem;gap:1.5rem;color:var(--text-3)}
#feed-error{display:none;text-align:center;padding:5rem 2rem}
#feed-error h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:400;font-style:italic;color:var(--text-2)}

.hero{
  display:grid;grid-template-columns:1.1fr .9fr;
  border-bottom:1px solid var(--border);
  cursor:pointer;overflow:hidden;height:460px;
  position:relative;z-index:1;text-decoration:none;
  transition:border-color var(--trans);
}
.hero:hover{border-color:var(--accent-2)}
@media(max-width:720px){.hero{grid-template-columns:1fr;height:auto}}
.hero-img{position:relative;overflow:hidden;height:100%;width:100%;background:var(--bg-3)}
.hero-img img{
  width:100%;height:100%;object-fit:cover;object-position:center;display:block;
  transition:transform .5s ease;filter:brightness(.9)saturate(.95);
}
.hero:hover .hero-img img{transform:scale(1.03);filter:brightness(.95)saturate(1)}
.hero-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--border-2);font-size:3rem}
.hero-body{
  padding:1.5rem 2rem;display:flex;flex-direction:column;justify-content:space-between;
  background:var(--bg);border-left:1px solid var(--border);overflow:hidden;height:100%;
  transition:background var(--trans),border-color var(--trans);
}
.hero-eyebrow{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.hero-kicker{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-3)}
.hero-cat{font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:500}
.hero-title{
  font-family:'Playfair Display',serif;font-size:clamp(1.6rem,2.8vw,2.6rem);
  font-weight:700;line-height:1.15;color:var(--white);margin-bottom:.9rem;
  flex:1;transition:color var(--trans);
}
.hero-excerpt{font-size:.95rem;line-height:1.75;color:var(--text-2);margin-bottom:1.2rem;font-weight:300;transition:color var(--trans)}
.hero-meta{
  font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-3);border-top:1px solid var(--border);padding-top:.9rem;
  display:flex;justify-content:space-between;align-items:center;
  transition:color var(--trans),border-color var(--trans);
}
.hero-meta strong{color:var(--text-2);font-weight:500}

.sec-hdr{display:flex;align-items:center;gap:1rem;margin:2.5rem 0 1.4rem}
.sec-hdr::before{content:'';width:3px;height:1.1rem;background:var(--accent);flex-shrink:0}
.sec-hdr-title{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
.sec-hdr::after{content:'';flex:1;height:1px;background:var(--border)}

.dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:800px){.dest-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.dest-grid{grid-template-columns:1fr}}
.dest-card{background:var(--bg);cursor:pointer;display:flex;flex-direction:column;text-decoration:none;transition:background var(--trans);overflow:hidden}
.dest-card:hover{background:var(--card-hover)}
.dest-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-3)}
.dest-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;filter:brightness(.88)}
.dest-card:hover .dest-thumb img{transform:scale(1.04);filter:brightness(.96)}
.dest-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--border-2);font-size:2rem}
.dest-body{padding:1.1rem 1.2rem;flex:1;display:flex;flex-direction:column;gap:.5rem}
.dest-cat{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.dest-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;line-height:1.25;color:var(--white);transition:color var(--trans);flex:1}
.dest-meta{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border)}

.two-col{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:start}
@media(max-width:900px){.two-col{grid-template-columns:1fr}.sidebar{display:none}}
.sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:1.5rem;max-height:calc(100vh - 140px);overflow-y:auto;scrollbar-width:none}
.sidebar::-webkit-scrollbar{display:none}
.sidebar-sec-title{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:.8rem}
.sidebar-banner{display:block;text-decoration:none;border:1px solid var(--border);overflow:hidden;transition:border-color var(--trans),opacity .2s}
.sidebar-banner:hover{border-color:var(--accent);opacity:.93}
.sidebar-banner img{width:100%;height:auto;display:block}
.sidebar-banner-name{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:.35rem .5rem;background:var(--bg-2);text-align:center;border-top:1px solid var(--border)}
.sidebar-empty{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;border:1px dashed var(--border-2);font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);text-align:center;background:var(--bg-2)}

.mun-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:800px){.mun-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.mun-grid{grid-template-columns:1fr}}

.ad-strip{margin:2.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1rem 0}
.ad-strip-label{font-family:'JetBrains Mono',monospace;font-size:.47rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-3);display:block;text-align:center;margin-bottom:.6rem}
.ads-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
@media(max-width:700px){.ads-row{grid-template-columns:repeat(2,1fr)}}
.ad-card{display:block;text-decoration:none;border:1px solid var(--border);overflow:hidden;transition:border-color var(--trans),opacity .2s}
.ad-card:hover{border-color:var(--accent);opacity:.92}
.ad-card img{width:100%;height:auto;display:block}
.ad-card-name{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:.3rem .5rem;background:var(--bg-2);text-align:center;border-top:1px solid var(--border)}
.ad-placeholder{min-height:100px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);border:1px dashed var(--border);font-family:'JetBrains Mono',monospace;font-size:.5rem;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}

.sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:800px){.sec-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.sec-grid{grid-template-columns:1fr}}
.sec-card{background:var(--bg);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;text-decoration:none;transition:background var(--trans)}
.sec-card:hover{background:var(--card-hover)}
.sec-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-3)}
.sec-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;filter:brightness(.88)}
.sec-card:hover .sec-thumb img{transform:scale(1.04);filter:brightness(.96)}
.sec-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--border-2);font-size:2rem}
.sec-body{padding:1rem 1.1rem;flex:1;display:flex;flex-direction:column;gap:.45rem}
.sec-cat{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.sec-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;line-height:1.25;color:var(--white);flex:1;transition:color var(--trans)}
.sec-excerpt{font-size:.82rem;line-height:1.6;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sec-meta{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}

.outras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:800px){.outras-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.outras-grid{grid-template-columns:1fr}}
.outras-card{background:var(--bg);cursor:pointer;padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;border-left:3px solid transparent;text-decoration:none;transition:background var(--trans),border-left-color var(--trans);min-height:160px}
.outras-card:hover{background:var(--card-hover);border-left-color:var(--accent)}
.outras-cat{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.outras-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;line-height:1.3;color:var(--white);flex:1;transition:color var(--trans)}
.outras-card:hover .outras-title{color:var(--accent-2)}
.outras-exc{font-size:.82rem;line-height:1.6;color:var(--text-2)}
.outras-meta{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding-top:.5rem;border-top:1px solid var(--border);margin-top:auto}

.breves-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:600px){.breves-grid{grid-template-columns:1fr}}
.breve-item{background:var(--bg);cursor:pointer;padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.35rem;border-left:3px solid transparent;text-decoration:none;transition:background var(--trans),border-left-color var(--trans)}
.breve-item:hover{background:var(--card-hover);border-left-color:var(--accent)}
.breve-date{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.breve-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;line-height:1.3;color:var(--white);transition:color var(--trans)}
.breve-item:hover .breve-title{color:var(--accent-2)}
.breve-exc{font-size:.82rem;line-height:1.6;color:var(--text-2)}

#page-article{display:none}
.article-back{
  display:inline-flex;align-items:center;gap:.5rem;
  background:none;border:none;cursor:pointer;text-decoration:none;
  font-family:'JetBrains Mono',monospace;
  font-size:.57rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-3);padding:1rem 1.5rem;
  transition:color var(--trans);
}
.article-back:hover{color:var(--accent)}
.article-back::before{content:'←';font-size:.9rem}
.article-layout{
  display:grid;grid-template-columns:1fr 280px;gap:2.5rem;align-items:start;
  max-width:1280px;margin:0 auto;padding:0 1.5rem 3rem;
}
@media(max-width:900px){.article-layout{grid-template-columns:1fr}.article-aside{display:none}}
.post-cat{
  font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:.6rem;display:block;text-decoration:none;
}
.post-title{
  font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:700;line-height:1.1;color:var(--white);margin-bottom:1rem;
}
.post-meta{
  font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-3);display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
  padding:.8rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:1.5rem;
}
.post-meta strong{color:var(--text-2);font-weight:500}
.post-hero-img{width:100%;height:auto;display:block;margin-bottom:1.5rem;max-height:500px;object-fit:cover}
.post-body{font-size:1.05rem;line-height:1.85;color:var(--text);max-width:680px}
.post-body p{margin-bottom:1.2rem}
.post-body h2,.post-body h3{font-family:'Playfair Display',serif;font-weight:700;color:var(--white);margin:1.8rem 0 .8rem}
.post-body h2{font-size:1.5rem}
.post-body h3{font-size:1.2rem}
.post-body a{color:var(--accent);text-decoration:underline}
.post-body img{max-width:100%;height:auto;margin:1rem 0}
.post-body blockquote{border-left:3px solid var(--accent);padding:.5rem 0 .5rem 1.2rem;margin:1.5rem 0;color:var(--text-2);font-style:italic}
.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:2rem 0 1.5rem;padding-top:1rem;border-top:1px solid var(--border)}
.post-tag{
  font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.25rem .6rem;border:1px solid var(--border-2);color:var(--text-3);cursor:pointer;text-decoration:none;
  transition:border-color var(--trans),color var(--trans);
}
.post-tag:hover{border-color:var(--accent);color:var(--accent)}
.share-bar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:1rem 0;border-top:1px solid var(--border)}
.share-label{font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.share-btn{
  display:inline-flex;align-items:center;gap:.3rem;
  font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.4rem .8rem;border:1px solid var(--border-2);text-decoration:none;cursor:pointer;background:none;
  transition:border-color var(--trans),color var(--trans);color:var(--text-2);
}
.share-btn:hover{border-color:var(--accent);color:var(--accent)}
.share-btn.fb:hover{border-color:#1877f2;color:#1877f2}
.share-btn.tw:hover{border-color:var(--text);color:var(--text)}
.share-btn.copied{border-color:var(--accent);color:var(--accent)}

.article-aside{position:sticky;top:120px;display:flex;flex-direction:column;gap:2rem}
.aside-title{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:.8rem}
.related-item{display:grid;grid-template-columns:56px 1fr;gap:.7rem;align-items:center;padding:.7rem 0;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;transition:background var(--trans)}
.related-item:last-child{border-bottom:none}
.related-item:hover{background:var(--card-hover);padding:.7rem .4rem;margin:0 -.4rem}
.rel-thumb{width:56px;height:40px;object-fit:cover;background:var(--bg-3);display:block}
.rel-thumb-ph{width:56px;height:40px;background:var(--bg-3)}
.rel-title{font-family:'Playfair Display',serif;font-size:.88rem;font-weight:600;line-height:1.3;color:var(--white)}
.rel-meta{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-top:.2rem}

#page-cat{display:none}
.cat-hdr{padding:1.5rem 0 0;border-bottom:1px solid var(--border);margin-bottom:2rem}
.cat-hdr-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem 1rem;display:flex;justify-content:space-between;align-items:flex-end}
.cat-hdr-name{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--white)}
.cat-hdr-count{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.cat-back{
  background:none;border:none;cursor:pointer;text-decoration:none;
  font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-3);padding:.4rem 0;transition:color var(--trans);
}
.cat-back:hover{color:var(--accent)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
@media(max-width:800px){.cat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.cat-grid{grid-template-columns:1fr}}

.pagination{display:flex;justify-content:center;gap:.5rem;padding:2.5rem 0}
.page-btn{
  font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.5rem 1rem;border:1px solid var(--border-2);color:var(--text-2);text-decoration:none;
  transition:border-color var(--trans),color var(--trans);
}
.page-btn:hover{border-color:var(--accent);color:var(--accent)}
.page-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.page-btn.disabled{opacity:.4;pointer-events:none}

.op-hdr{background:var(--bg-2);border-bottom:2px solid var(--border);padding:2rem 0 0;margin-bottom:2.5rem}
.op-hdr-inner{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.op-hdr-title{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;font-style:italic;color:var(--white);margin-bottom:.3rem}
.op-hdr-sub{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.op-hdr-desc{font-size:.92rem;line-height:1.8;color:var(--text-2);max-width:680px;padding:1rem 0 1.5rem;border-top:1px solid var(--border);font-family:'Source Serif 4',serif;font-style:italic}
.op-authors{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem}
@media(max-width:900px){.op-authors{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.op-authors{grid-template-columns:1fr 1fr}}
.op-author{
  display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem;
  border:1px solid var(--border);background:var(--bg-2);cursor:pointer;text-decoration:none;
  transition:border-color var(--trans),background var(--trans);
}
.op-author:hover{border-color:var(--accent);background:var(--card-hover)}
.op-author-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;background:var(--bg-3);border:2px solid var(--border);margin-bottom:.8rem;display:block}
.op-author-avatar-ph{
  width:72px;height:72px;border-radius:50%;background:var(--accent-light);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--accent);margin-bottom:.8rem;font-weight:700;
}
.op-author-name{font-family:'Playfair Display',serif;font-size:.95rem;font-weight:700;color:var(--white);margin-bottom:.25rem;line-height:1.2}
.op-author-bio{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);line-height:1.6}
.op-author-count{margin-top:.6rem;font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:500}
.op-articles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:2.5rem}
@media(max-width:600px){.op-articles-grid{grid-template-columns:1fr}}
.op-article{
  background:var(--bg);cursor:pointer;padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;
  border-left:4px solid transparent;text-decoration:none;
  transition:background var(--trans),border-left-color var(--trans);
}
.op-article:hover{background:var(--card-hover);border-left-color:var(--accent)}
.op-article-author-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.2rem}
.op-article-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--bg-3);flex-shrink:0}
.op-article-avatar-ph{
  width:32px;height:32px;border-radius:50%;background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:.75rem;color:var(--accent);font-weight:700;flex-shrink:0;
}
.op-article-author-name{font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:500}
.op-article-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;line-height:1.3;color:var(--white);font-style:italic;transition:color var(--trans)}
.op-article:hover .op-article-title{color:var(--accent-2)}
.op-article-exc{font-size:.88rem;line-height:1.7;color:var(--text-2)}
.op-article-meta{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border)}
.op-cta{margin:3rem 0;border:1px solid var(--border-2);background:var(--bg-2);padding:2.5rem;text-align:center}
.op-cta-inner{max-width:480px;margin:0 auto}
.op-cta-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;font-style:italic;color:var(--white);margin-bottom:.8rem}
.op-cta-text{font-size:.9rem;line-height:1.75;color:var(--text-2);font-family:'Source Serif 4',serif;margin-bottom:1.2rem}
.op-cta-btn{
  display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.7rem 1.4rem;border:1px solid var(--accent);color:var(--accent);text-decoration:none;
  transition:background var(--trans),color var(--trans);
}
.op-cta-btn:hover{background:var(--accent);color:var(--bg)}

footer{border-top:2px solid var(--border);background:var(--bg-2);margin-top:3rem;padding:2.5rem 1.5rem;transition:background var(--trans),border-color var(--trans)}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem}
@media(max-width:700px){.footer-inner{grid-template-columns:1fr}}
.footer-col-title{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem}
.cat-cloud{display:flex;flex-wrap:wrap;gap:.35rem}
.cat-cloud-item{
  font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.2rem .5rem;border:1px solid var(--border-2);color:var(--text-3);cursor:pointer;text-decoration:none;
  transition:border-color var(--trans),color var(--trans);
}
.cat-cloud-item:hover{border-color:var(--accent);color:var(--accent)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:.3rem}
.tag-cloud-item{
  font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.08em;
  padding:.18rem .45rem;border:1px solid var(--border);color:var(--text-3);cursor:pointer;text-decoration:none;
  transition:border-color var(--trans),color var(--trans);
}
.tag-cloud-item:hover{border-color:var(--accent);color:var(--accent)}
.footer-about{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.06em;color:var(--text-3);line-height:2}
.footer-about a{color:var(--text-3);text-decoration:none}
.footer-bottom{max-width:1280px;margin:1.5rem auto 0;padding-top:1.2rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-copy{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}
.footer-links{display:flex;gap:1rem}
.footer-links a{font-family:'JetBrains Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);text-decoration:none;transition:color var(--trans)}
.footer-links a:hover{color:var(--accent)}

#section-municipios,#section-guadiana,#section-breves,.ad-strip,footer{content-visibility:auto;contain-intrinsic-size:0 400px}
.logo-foz,.hero-title,.post-title{font-display:swap}
header{will-change:auto}

.eventos-strip{padding:1.2rem 0 1.5rem;border-top:1px solid var(--border);margin-top:2rem}
.eventos-strip-label{font-family:'JetBrains Mono',monospace;font-size:.47rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-3);display:block;text-align:center;margin-bottom:.8rem}
.eventos-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
@media(max-width:700px){.eventos-row{grid-template-columns:repeat(2,1fr)}}
.evento-card{cursor:pointer;border:1px solid var(--border);overflow:hidden;background:var(--bg-2);display:flex;flex-direction:column;text-decoration:none;transition:border-color var(--trans),background var(--trans)}
.evento-card:hover{border-color:var(--accent);background:var(--card-hover)}
.evento-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg-3)}
.evento-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;filter:brightness(.88)}
.evento-card:hover .evento-thumb img{transform:scale(1.04);filter:brightness(.96)}
.evento-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--border-2);font-size:2rem}
.evento-body{padding:.8rem 1rem;flex:1;display:flex;flex-direction:column;gap:.35rem}
.evento-date{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.evento-title{font-family:'Playfair Display',serif;font-size:.92rem;font-weight:600;line-height:1.3;color:var(--white);flex:1;transition:color var(--trans)}
.evento-card:hover .evento-title{color:var(--accent-2)}

@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeUp .45s ease both}

/* ══════════════════════════════════════════════
   SSR homepage — acrescentos (jul 2026)
   ══════════════════════════════════════════════ */

/* Barra de Municípios (portada do index.html SPA) */
#nav-municipios{
  border-top:1px solid var(--border);
  background:var(--bg-2);
  overflow:hidden;
  transition:background var(--trans),border-color var(--trans);
}
.nav-mun-inner{
  max-width:1280px;margin:0 auto;
  padding:0 1.5rem;
  display:flex;align-items:stretch;
  overflow-x:auto;scrollbar-width:none;
}
.nav-mun-inner::-webkit-scrollbar{display:none}
.mun-label{
  font-family:'JetBrains Mono',monospace;
  font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-3);
  display:flex;align-items:center;
  padding:0 .8rem 0 0;
  border-right:1px solid var(--border);
  margin-right:.2rem;
  white-space:nowrap;
  flex-shrink:0;
}
.mun-btn{
  font-family:'JetBrains Mono',monospace;
  font-size:.57rem;letter-spacing:.16em;text-transform:uppercase;
  background:none;border:none;border-bottom:2px solid transparent;
  color:var(--text-3);cursor:pointer;
  padding:.55rem .85rem;white-space:nowrap;
  transition:color var(--trans),border-color var(--trans),background var(--trans);
  flex-shrink:0;
  display:flex;align-items:center;
  text-decoration:none;
}
.mun-btn:hover{color:var(--accent);border-bottom-color:var(--accent)}
.mun-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-light)}

/* Cartões renderizados como <a> no HTML server-side */
a.hero,a.dest-card,a.sec-card,a.outras-card,a.breve-item{color:inherit;text-decoration:none}
