/* ============================================================
   SWEETDEALS — SHARED PAGE STYLES
   Nav, footer, homepage, dark-mode ready throughout
   ============================================================ */

/* ── NAV ────────────────────────────────────────────────────── */
.site-nav{
  background:var(--forest);position:sticky;top:0;z-index:100;
  transition:box-shadow var(--t-med);
}
.site-nav.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.3);}
.nav-inner{display:flex;align-items:center;gap:8px;padding:14px 24px;}
.nav-logo{font-family:'Fredoka One',cursive;font-size:24px;color:#fff;
  display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.nav-logo__icon{width:36px;height:36px;background:var(--gold);border-radius:9px;
  display:flex;align-items:center;justify-content:center;font-size:19px;}
.nav-logo span{color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none;margin:0 auto 0 16px;}
.nav-links a{color:rgba(255,255,255,.85);font-family:'Nunito',sans-serif;font-weight:700;
  font-size:14px;padding:8px 13px;border-radius:var(--r-sm);transition:all var(--t-fast);white-space:nowrap;}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.1);color:#fff;}
.nav-links a.active{color:var(--gold);}
.nav-right{display:flex;align-items:center;gap:10px;margin-left:auto;}
.nav-search-wrap{position:relative;}
.nav-search{display:flex;align-items:center;background:rgba(255,255,255,.12);
  border-radius:var(--r-pill);padding:8px 16px;gap:8px;border:1px solid rgba(255,255,255,.15);
  transition:all var(--t-fast);}
.nav-search:focus-within{background:rgba(255,255,255,.2);border-color:var(--gold);}
.nav-search input{background:none;border:none;outline:none;color:#fff;font-size:14px;width:170px;}
.nav-search input::placeholder{color:rgba(255,255,255,.5);}
.nav-icon-btn,.dark-toggle-btn.nav-icon-btn{
  width:36px;height:36px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  border-radius:50%;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--t-fast);flex-shrink:0;}
.nav-icon-btn:hover{background:rgba(255,255,255,.2);}
.nav-hamburger{display:none;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r-sm);color:#fff;font-size:18px;padding:6px 10px;cursor:pointer;}

/* Dropdown */
.nav-dropdown{position:relative;}
.nav-dropdown__menu{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--bg-card);border-radius:var(--r-md);box-shadow:var(--shadow-lg);
  padding:8px;min-width:220px;z-index:200;display:none;border:1px solid var(--border);
}
.nav-dropdown:hover .nav-dropdown__menu{display:block;}
.nav-dropdown__item{
  display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-sm);
  font-family:'Nunito',sans-serif;font-weight:600;font-size:14px;color:var(--text);
  transition:background var(--t-fast);}
.nav-dropdown__item:hover{background:var(--bg-alt);color:var(--forest);}
[data-theme="dark"] .nav-dropdown__item:hover{color:var(--gold-lt);}

/* Mobile nav */
.mobile-nav{
  position:fixed;top:0;right:-100%;width:300px;height:100vh;
  background:var(--bg-card);z-index:500;transition:right var(--t-slow) var(--ease);
  padding:24px;overflow-y:auto;box-shadow:-8px 0 40px rgba(0,0,0,.25);
  border-left:1px solid var(--border);
}
.mobile-nav.open{right:0;}
.mobile-nav__inner{display:flex;flex-direction:column;}
.mobile-nav__close{align-self:flex-end;background:var(--bg-alt);border:1px solid var(--border);
  width:36px;height:36px;border-radius:50%;font-size:16px;cursor:pointer;margin-bottom:20px;color:var(--text);}
.mobile-nav__logo{font-family:'Fredoka One',cursive;font-size:22px;color:var(--forest);margin-bottom:24px;}
.mobile-nav__logo span{color:var(--gold);}
[data-theme="dark"] .mobile-nav__logo{color:var(--gold-lt);}
.mobile-nav__link{display:block;padding:14px 0;border-bottom:1px solid var(--border);
  font-family:'Nunito',sans-serif;font-weight:700;font-size:16px;color:var(--text);}
.mobile-nav__link:hover{color:var(--forest);}
[data-theme="dark"] .mobile-nav__link:hover{color:var(--gold-lt);}
.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:499;display:none;}
.mobile-nav-overlay.show{display:block;}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{background:var(--ink);color:rgba(255,255,255,.65);padding:64px 0 32px;}
[data-theme="dark"] .site-footer{background:#070e08;border-top:1px solid var(--border);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-logo{font-family:'Fredoka One',cursive;font-size:22px;color:#fff;
  display:block;margin-bottom:14px;}
.footer-logo span{color:var(--gold);}
.footer-brand p{font-size:14px;line-height:1.7;margin-bottom:16px;}
.footer-social{display:flex;gap:10px;}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:16px;transition:background var(--t-fast);}
.footer-social a:hover{background:rgba(255,255,255,.16);}
.footer-col h3{font-family:'Nunito',sans-serif;font-weight:700;font-size:12px;color:var(--gold-lt);
  text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:10px;}
.footer-col a{font-size:14px;color:rgba(255,255,255,.55);transition:color var(--t-fast);}
.footer-col a:hover{color:var(--gold-lt);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;
  display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;}
.footer-disclosure{font-size:12px;color:rgba(255,255,255,.35);max-width:620px;line-height:1.7;}
.footer-copy{font-size:12px;color:rgba(255,255,255,.28);}

/* ── HERO (homepage) ─────────────────────────────────────────── */
.hero{
  background:linear-gradient(135deg,var(--forest) 0%,#1e5c1e 45%,#2a7030 100%);
  position:relative;overflow:hidden;padding:80px 0 100px;min-height:560px;
}
.hero__pattern{position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none;}
.hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 600px 400px at 80% 50%,rgba(255,179,0,.12) 0%,transparent 60%),
             radial-gradient(ellipse 400px 300px at 10% 80%,rgba(139,195,74,.08) 0%,transparent 60%);
  pointer-events:none;}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:center;}
.hero__kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);border-radius:var(--r-pill);padding:6px 16px;
  font-family:'Nunito',sans-serif;font-weight:700;font-size:13px;color:var(--gold-lt);
  margin-bottom:20px;backdrop-filter:blur(8px);}
.hero__title{font-family:'Fredoka One',cursive;font-size:clamp(38px,5.5vw,62px);color:#fff;
  line-height:1.05;margin-bottom:20px;text-shadow:0 2px 20px rgba(0,0,0,.15);}
.hero__title em{color:var(--gold);font-style:normal;}
.hero__sub{font-size:16px;color:rgba(255,255,255,.82);margin-bottom:28px;max-width:500px;line-height:1.65;}
.hero__search{margin-bottom:20px;max-width:500px;position:relative;}
.hero__quicklinks{display:flex;flex-wrap:wrap;gap:8px;max-width:500px;}
.hero__quicklink{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.85);border-radius:var(--r-pill);padding:6px 14px;font-size:13px;
  font-weight:600;cursor:pointer;transition:all var(--t-fast);font-family:'Nunito',sans-serif;}
.hero__quicklink:hover{background:rgba(255,255,255,.2);color:#fff;}
.hero__deal-card{background:var(--bg-card);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,.3);border:1px solid var(--border);}

/* Featured deals grid */
.featured-grid{display:grid;grid-template-columns:1.35fr 1fr;grid-template-rows:auto auto;gap:var(--space-lg);}
.featured-card{background:var(--bg-card);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-card);transition:transform var(--t-med) var(--ease),box-shadow var(--t-med);
  border:1px solid var(--border);}
.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.featured-card--large{grid-row:1/3;}
.featured-card__img{display:flex;align-items:center;justify-content:center;font-size:80px;position:relative;}
.featured-card__img--large{height:260px;}
.featured-card__img--small{height:140px;}
[data-theme="dark"] .featured-card__img{filter:brightness(.85);}
.featured-card__body{padding:var(--space-lg);}
.featured-card__quote{font-style:italic;font-size:13px;color:var(--text-muted);
  border-left:3px solid var(--gold);padding-left:12px;margin:12px 0;line-height:1.5;}

/* Email section */
.email-title{font-family:'Fredoka One',cursive;font-size:clamp(26px,4vw,42px);color:#fff;margin-bottom:12px;}
.email-title em{color:var(--gold);font-style:normal;}
.email-sub{color:rgba(255,255,255,.78);font-size:16px;margin-bottom:28px;}
.email-form{display:flex;max-width:520px;margin:0 auto 16px;background:#fff;
  border-radius:var(--r-pill);overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.25);}
.email-form input{flex:1;border:none;outline:none;padding:16px 24px;font-size:15px;color:#1C2B1E !important;background:#fff !important;min-width:0;}
.email-form input::placeholder{color:#7A8C7D;}
.email-form button{border-radius:0;flex-shrink:0;padding:0 24px;font-size:14px;}

/* Dark mode — use !important to beat autofill and inherited styles */
[data-theme="dark"] .email-form{background:#2a3c2d !important;box-shadow:0 8px 32px rgba(0,0,0,.5);}
[data-theme="dark"] .email-form input{background:#2a3c2d !important;color:#e8f0e9 !important;-webkit-text-fill-color:#e8f0e9 !important;}
[data-theme="dark"] .email-form input::placeholder{color:#9ab89d !important;opacity:1;}
[data-theme="dark"] .email-form input:-webkit-autofill,
[data-theme="dark"] .email-form input:-webkit-autofill:hover,
[data-theme="dark"] .email-form input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 1000px #2a3c2d inset !important;
  -webkit-text-fill-color:#e8f0e9 !important;
  caret-color:#e8f0e9;
}
.email-trust-row{display:flex;justify-content:center;flex-wrap:wrap;gap:24px;}
.email-trust-item{font-size:13px;color:rgba(255,255,255,.65);}

/* Blog cards */
.blog-card{background:var(--bg-card);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:all var(--t-med);border:1px solid var(--border);}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.blog-card__img{height:180px;display:flex;align-items:center;justify-content:center;font-size:60px;}
.blog-card__body{padding:var(--space-lg);}
.blog-card__meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:10px;}
.blog-card__title{font-family:'Nunito',sans-serif;font-weight:800;font-size:16px;margin-bottom:10px;line-height:1.3;}
.blog-card__title a{color:var(--text);transition:color var(--t-fast);}
.blog-card__title a:hover{color:var(--grove);}
[data-theme="dark"] .blog-card__title a:hover{color:var(--gold-lt);}
.blog-card__excerpt{font-size:13px;color:var(--text-sub);line-height:1.6;margin-bottom:14px;}

/* Popup extras */
.popup-deal-preview{background:var(--bg-alt);border-radius:var(--r-md);padding:16px;margin-bottom:16px;border:1px solid var(--border);}
.popup-skip{text-align:center;margin-top:12px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:color var(--t-fast);}
.popup-skip:hover{color:var(--forest);}
[data-theme="dark"] .popup-skip:hover{color:var(--gold-lt);}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero__inner{grid-template-columns:1fr 360px;gap:32px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:768px){
  .hero__inner{grid-template-columns:1fr;}
  .hero__deal-card{max-width:400px;margin:0 auto;}
  .hero{padding:60px 0 80px;min-height:auto;}
  .nav-links,.nav-search-wrap,.nav-icon-btn:not(.nav-hamburger){display:none;}
  .nav-hamburger{display:block;}
  .featured-grid{grid-template-columns:1fr;}
  .featured-card--large{grid-row:auto;}
  .footer-grid{grid-template-columns:1fr;gap:24px;}
  .email-form{flex-direction:column;border-radius:var(--r-lg);}
  .email-form input,.email-form button{border-radius:var(--r-md)!important;}
  .email-form button{padding:14px;}
}
@media(max-width:480px){
  .hero__title{font-size:34px;}
  .hero{padding:48px 0 64px;}
}

.announce-bar{
  background:#1A4D1A; color:#fff;
  padding:0 52px 0 16px;
  font-family:'Nunito',sans-serif; font-weight:700; font-size:14px;
  display:none; align-items:center; gap:12px; position:relative;
  overflow:hidden; min-height:46px;
  transition:background .5s ease, color .3s;
}

/* Shimmer sweep animation */
.announce-bar__shimmer {
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%);
  background-size:200% 100%;
  animation:shimmer-sweep 2.8s ease-in-out infinite;
}
@keyframes shimmer-sweep {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Pulsing dot */
@keyframes pulse-dot {
  0%,100% { transform:scale(1); opacity:1; }
  50%     { transform:scale(1.6); opacity:.6; }
}
.announce-bar__pulse {
  width:8px; height:8px; background:#fff; border-radius:50%;
  animation:pulse-dot 1.5s ease-in-out infinite; flex-shrink:0;
}

/* Slider container */
.announce-bar__slider {
  flex:1; overflow:hidden; display:flex; align-items:center;
  min-height:46px;
}
.announce-bar__slide {
  display:flex; align-items:center; gap:12px; width:100%;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1), opacity .3s;
}
.announce-bar__text { flex:1; }

/* CTA button */
.announce-bar__cta {
  display:inline-flex; align-items:center;
  padding:5px 14px; border-radius:var(--r-pill);
  font-family:'Nunito',sans-serif; font-weight:800; font-size:12px;
  border:1.5px solid rgba(255,255,255,.3); cursor:pointer;
  transition:all .15s; flex-shrink:0; text-decoration:none;
  white-space:nowrap;
}
.announce-bar__cta:hover { filter:brightness(1.15); transform:scale(1.03); }

/* Close button */
.announce-bar__close {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,.12); border:none; width:26px; height:26px;
  border-radius:50%; cursor:pointer; font-size:13px;
  display:flex; align-items:center; justify-content:center;
  color:inherit; opacity:.7; transition:opacity .15s, background .15s;
  flex-shrink:0;
}
.announce-bar__close:hover { background:rgba(0,0,0,.22); opacity:1; }
/* ── STAT COUNTER ────────────────────────────────────────────
   The #deal-count and #sub-count animate in via JS             */
#deal-count, #sub-count {
  font-variant-numeric: tabular-nums;
  transition: opacity .3s;
}
