/*
Theme Name: Natal Inesquecivel
Theme URI: https://blog.natalinesquecivel.com.br
Author: Studio Guerra
Author URI: https://natalinesquecivel.com.br
Description: Tema standalone festivo para o blog Natal Inesquecivel. Home editorial com hero, contagem regressiva, categorias, posts recentes dinamicos e newsletter. Posts e arquivos herdam o mesmo visual.
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
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: natal-inesquecivel
*/

:root{
  --pine:#143d2e;
  --pine-deep:#0d2a1f;
  --cream:#f7f1e6;
  --cream-soft:#fbf7ee;
  --gold:#c9a24b;
  --gold-soft:#e3c987;
  --cranberry:#9c2b32;
  --cranberry-bright:#c23b40;
  --ink:#21261f;
  --muted:#5e6657;
  --line:rgba(20,61,46,.14);
  --shadow:0 18px 50px -22px rgba(13,42,31,.55);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}

/* TOPBAR */
.topbar{background:var(--pine-deep);color:var(--cream);font-size:.82rem;letter-spacing:.04em;text-align:center;padding:9px 16px}
.topbar b{color:var(--gold-soft);font-weight:600}

/* HEADER */
header.site{position:sticky;top:0;z-index:50;background:rgba(247,241,230,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{flex:0 0 auto}
.brand .name{font-family:var(--serif);font-weight:600;font-size:1.35rem;line-height:1;color:var(--pine);letter-spacing:.01em}
.brand .name small{display:block;font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:5px}
nav.menu ul{display:flex;gap:30px;list-style:none;align-items:center;margin:0;padding:0}
nav.menu a{font-size:.9rem;font-weight:500;color:var(--ink);position:relative;padding:4px 0;transition:color .2s}
nav.menu a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--gold);transition:width .25s ease}
nav.menu a:hover{color:var(--pine)}
nav.menu a:hover::after{width:100%}
.nav-cta{background:var(--cranberry);color:var(--cream)!important;padding:9px 18px;border-radius:50px;font-weight:600;font-size:.85rem;transition:transform .2s,background .2s}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--cranberry-bright);transform:translateY(-1px)}
.burger{display:none;background:none;border:0;cursor:pointer;color:var(--pine)}

/* HERO */
.hero{position:relative;background:radial-gradient(1200px 500px at 80% -10%, rgba(201,162,75,.18), transparent 60%),linear-gradient(160deg,var(--pine) 0%, var(--pine-deep) 100%);color:var(--cream);overflow:hidden;padding:74px 0 88px}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1.4px);background-size:22px 22px;opacity:.6}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:22px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.5rem,5.4vw,4rem);line-height:1.04;letter-spacing:-.01em;margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero p.lead{font-size:1.1rem;color:rgba(247,241,230,.82);max-width:30rem;margin-bottom:32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:50px;font-weight:600;font-size:.95rem;transition:transform .2s,box-shadow .2s,background .2s;cursor:pointer;border:0;font-family:var(--sans)}
.btn-gold{background:var(--gold);color:var(--pine-deep);box-shadow:0 12px 30px -12px rgba(201,162,75,.7)}
.btn-gold:hover{transform:translateY(-2px);background:var(--gold-soft)}
.btn-ghost{border:1.5px solid rgba(247,241,230,.4);color:var(--cream);background:transparent}
.btn-ghost:hover{border-color:var(--gold-soft);color:var(--gold-soft)}
.countdown{margin-top:40px;display:flex;gap:18px}
.cd-box{text-align:center}
.cd-box .num{font-family:var(--serif);font-size:2rem;font-weight:600;line-height:1;color:var(--gold-soft);display:block}
.cd-box .lbl{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,241,230,.6);margin-top:7px}
.hero-card{position:relative;background:var(--cream-soft);color:var(--ink);border-radius:22px;padding:0;overflow:hidden;box-shadow:var(--shadow);transform:rotate(.6deg);transition:transform .35s ease;display:block}
.hero-card:hover{transform:rotate(0deg) translateY(-4px)}
.hero-card .thumb{height:200px;position:relative;overflow:hidden}
.hero-card .thumb img{width:100%;height:100%;object-fit:cover}
.hero-card .body{padding:26px 28px 30px}
.tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--cranberry);background:rgba(156,43,50,.1);padding:5px 11px;border-radius:50px;margin-bottom:14px}
.hero-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;line-height:1.15;color:var(--pine);margin-bottom:10px}
.hero-card p{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.readmore{font-weight:600;font-size:.9rem;color:var(--cranberry);display:inline-flex;align-items:center;gap:6px}
.readmore svg{transition:transform .2s}
.hero-card:hover .readmore svg,.card:hover .readmore svg{transform:translateX(4px)}

/* NEVE */
.snow{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.flake{position:absolute;top:-10px;color:#fff;opacity:.7;animation:fall linear infinite}
@keyframes fall{0%{transform:translateY(-10px) translateX(0) rotate(0)}100%{transform:translateY(105vh) translateX(40px) rotate(360deg)}}

/* SECOES */
.section{padding:84px 0}
.sec-head{text-align:center;max-width:46rem;margin:0 auto 52px}
.sec-head .eyebrow{color:var(--gold);justify-content:center;display:flex}
.sec-head .eyebrow .dot{background:var(--cranberry)}
.sec-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,3.8vw,2.9rem);color:var(--pine);line-height:1.08;letter-spacing:-.01em;margin-bottom:14px}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* CATEGORIAS */
.cats{background:var(--cream-soft)}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cat{position:relative;border-radius:18px;padding:30px 24px 28px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:transform .28s,box-shadow .28s;display:flex;flex-direction:column;gap:12px;min-height:230px}
.cat:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.cat .ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--pine);color:var(--gold-soft)}
.cat h3{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--pine)}
.cat p{color:var(--muted);font-size:.9rem;flex:1}
.cat .link{font-weight:600;font-size:.85rem;color:var(--cranberry);display:inline-flex;align-items:center;gap:6px}
.cat::after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.18),transparent 70%)}

/* POSTS */
.posts-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:42px;flex-wrap:wrap}
.posts-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.9rem,3.4vw,2.6rem);color:var(--pine);line-height:1.1}
.posts-head .eyebrow{margin-bottom:10px;color:var(--gold)}
.posts-head .eyebrow .dot{background:var(--cranberry)}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .28s,box-shadow .28s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .thumb{height:185px;position:relative;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.card .meta{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px}
.card h3{font-family:var(--serif);font-size:1.28rem;font-weight:600;line-height:1.2;color:var(--pine);margin-bottom:10px}
.card p{color:var(--muted);font-size:.92rem;flex:1;margin-bottom:16px}
.card .readmore{font-size:.85rem}
.art{width:100%;height:100%;display:block}

/* NEWSLETTER */
.news{background:radial-gradient(900px 400px at 15% 120%, rgba(201,162,75,.2), transparent 60%),linear-gradient(150deg,var(--cranberry) 0%, #7d2026 100%);color:var(--cream);text-align:center;position:relative;overflow:hidden}
.news::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1.4px);background-size:24px 24px}
.news .wrap{position:relative;max-width:46rem}
.news h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,3.6vw,2.7rem);line-height:1.1;margin-bottom:14px}
.news p{color:rgba(247,241,230,.86);font-size:1.05rem;margin-bottom:30px}
.news-form{display:flex;gap:10px;max-width:30rem;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news-form input{flex:1;min-width:220px;padding:15px 20px;border-radius:50px;border:0;font-family:var(--sans);font-size:.95rem;color:var(--ink)}
.news-form input:focus{outline:2px solid var(--gold-soft)}
.news small{display:block;margin-top:16px;color:rgba(247,241,230,.6);font-size:.78rem}

/* FOOTER */
footer.site{background:var(--pine-deep);color:rgba(247,241,230,.82);padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:46px}
.foot-grid h4{font-family:var(--serif);color:var(--cream);font-size:1.05rem;margin-bottom:16px;font-weight:600}
.foot-grid p{font-size:.92rem;line-height:1.7;max-width:22rem}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:10px}
.foot-grid a{font-size:.92rem;transition:color .2s}
.foot-grid a:hover{color:var(--gold-soft)}
.foot-brand .name{font-family:var(--serif);color:var(--cream);font-size:1.4rem;font-weight:600;margin-bottom:14px;display:block}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(247,241,230,.25);display:grid;place-items:center;transition:.2s}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--pine-deep)}
.foot-bottom{border-top:1px solid rgba(247,241,230,.14);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:rgba(247,241,230,.55)}

/* PAGINAS INTERNAS / ARQUIVOS (index.php) */
.page-head{background:linear-gradient(160deg,var(--pine) 0%, var(--pine-deep) 100%);color:var(--cream);padding:64px 0 56px;text-align:center;position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1.4px);background-size:22px 22px;opacity:.6}
.page-head .wrap{position:relative}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.1}
.page-head p{color:rgba(247,241,230,.8);margin-top:10px}
.list-wrap{padding:70px 0}
.single-content{max-width:760px;margin:0 auto;padding:60px 26px}
.single-content h1{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4vw,2.8rem);color:var(--pine);line-height:1.12;margin-bottom:16px}
.single-content .post-meta{color:var(--gold);font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:30px}
.single-content img{border-radius:14px;margin:24px 0}
.single-content h2,.single-content h3{font-family:var(--serif);color:var(--pine);margin:28px 0 12px}
.single-content p{margin-bottom:18px;font-size:1.05rem;color:var(--ink)}
.single-content ul,.single-content ol{margin:0 0 18px 22px}
.single-content a{color:var(--cranberry);text-decoration:underline}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:50px;flex-wrap:wrap}
.pagination .page-numbers{padding:10px 16px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--pine);font-weight:600;font-size:.9rem}
.pagination .page-numbers.current{background:var(--pine);color:var(--cream)}

/* RESPONSIVO */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:640px){
  nav.menu ul{display:none}
  .burger{display:block}
  .cat-grid,.post-grid{grid-template-columns:1fr}
  .countdown{gap:12px}
  .cd-box .num{font-size:1.6rem}
  .section{padding:60px 0}
}
