/* ═══════════════════════════════════════════════════
   Weather Hunters – Main Stylesheet
   ═══════════════════════════════════════════════════ */

/* ═══ RESET & CUSTOM PROPERTIES ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#C9A84C;
  --gold-light:#E8C96B;
  --gold-dim:#8B6F2A;
  --gold-glow:rgba(201,168,76,.15);
  --bg:#1A1C1E;
  --bg-mid:#222528;
  --bg-card:#2A2D31;
  --bg-border:#363A3F;
  --txt:#F0EDE6;
  --txt-m:#8A8880;
  --txt-d:#5A5855;
  --focus-ring:0 0 0 3px rgba(201,168,76,.4);
  --transition-base:.2s ease;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--txt);
  font-family:'Outfit',system-ui,-apple-system,sans-serif;
  font-weight:300;
  min-height:100vh;
  min-height:100dvh;
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* ═══ ACCESSIBILITY: Focus & Skip Link ═══ */
.skip-link{
  position:absolute;top:-100%;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--bg);padding:.75rem 1.5rem;
  border-radius:0 0 6px 6px;font-weight:600;text-decoration:none;
  z-index:10000;transition:top .2s;
}
.skip-link:focus{top:0}
:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:3px}
::selection{background:var(--gold);color:var(--bg)}

/* ═══ BACKGROUNDS ═══ */
.bg-grid{
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,.04) 1px,transparent 1px);
  background-size:60px 60px;
  z-index:0;pointer-events:none;will-change:auto;contain:strict;
}
.bg-r1{
  position:fixed;top:-20%;left:50%;transform:translateX(-50%);
  width:800px;height:600px;
  background:radial-gradient(ellipse at center,rgba(201,168,76,.08) 0%,transparent 65%);
  z-index:0;pointer-events:none;contain:strict;
}
.bg-r2{
  position:fixed;bottom:-20%;right:-10%;
  width:500px;height:500px;
  background:radial-gradient(ellipse at center,rgba(201,168,76,.04) 0%,transparent 65%);
  z-index:0;pointer-events:none;contain:strict;
}
.page{
  position:relative;z-index:1;
  min-height:100vh;min-height:100dvh;
  display:flex;flex-direction:column;align-items:center;
}

/* ═══ HEADER ═══ */
header{
  width:100%;padding:1.5rem 2rem;
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid rgba(201,168,76,.15);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:100;
  background:rgba(26,28,30,.85);contain:layout;
}
.tbadge{
  display:flex;align-items:center;gap:.5rem;
  font-size:.6875rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
}
.tbadge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--gold);animation:pulse 2s ease-in-out infinite;
}
.sm-top{display:flex;gap:1rem}
.sm-top a{color:var(--txt-m);transition:color var(--transition-base);display:flex;align-items:center}
.sm-top a:hover,.sm-top a:focus-visible{color:var(--gold)}
.sm-top svg{width:18px;height:18px}

/* ═══ HERO / MAIN ═══ */
.hero{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:4rem 2rem 3rem;text-align:center;max-width:900px;width:100%;
}
.logo-wrap{margin-bottom:2.5rem;animation:fadeInDown .8s ease forwards}
.logo-img{
  height:90px;width:auto;
  filter:brightness(0) saturate(100%) invert(73%) sepia(50%) saturate(500%) hue-rotate(5deg) brightness(.95);
}
.headline{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem,10vw,7.5rem);
  letter-spacing:.04em;line-height:.92;
  color:var(--txt);animation:fadeUp .9s .2s ease both;
}
.headline span{color:var(--gold);display:block}
.sub{
  margin-top:1.5rem;font-size:clamp(.95rem,2vw,1.15rem);
  color:var(--txt-m);max-width:560px;line-height:1.7;
  animation:fadeUp .9s .35s ease both;
}
.divider{
  width:60px;height:2px;background:var(--gold);
  margin:2rem auto;animation:fadeUp .9s .4s ease both;
}

/* ═══ COUNTDOWN ═══ */
.cd-wrap{margin:2rem 0 2.5rem;animation:fadeUp .9s .5s ease both}
.cd-lbl{font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:1rem}
.cd{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.cd-u{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.cd-n{
  font-family:'Bebas Neue',sans-serif;font-size:clamp(2.5rem,7vw,4rem);
  color:var(--gold);line-height:1;min-width:2ch;text-align:center;
}
.cd-t{font-size:.625rem;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-d)}
.cd-s{font-family:'Bebas Neue',sans-serif;font-size:3rem;color:var(--bg-border);align-self:flex-start;padding-top:6px}

/* ═══ NEWSLETTER FORM ═══ */
.form-wrap{animation:fadeUp .9s .6s ease both;width:100%;max-width:480px}
.form-lbl{font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dim);display:block;margin-bottom:.75rem}
.erow{display:flex;border:1px solid var(--bg-border);border-radius:4px;overflow:hidden;transition:border-color var(--transition-base)}
.erow:focus-within{border-color:var(--gold)}
.einp{
  flex:1;background:var(--bg-card);border:none;outline:none;
  padding:.9rem 1.1rem;font-family:'Outfit',sans-serif;font-size:.9rem;
  color:var(--txt);font-weight:300;
}
.einp::placeholder{color:var(--txt-d)}
.ebtn{
  background:var(--gold);color:var(--bg);border:none;
  padding:.9rem 1.4rem;font-family:'Outfit',sans-serif;font-size:.85rem;
  font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:background var(--transition-base);white-space:nowrap;
}
.ebtn:hover,.ebtn:focus-visible{background:var(--gold-light)}
.fnote{margin-top:.6rem;font-size:.6875rem;color:var(--txt-d);letter-spacing:.04em}
.fsuccess{display:none;margin-top:.8rem;font-size:.85rem;color:var(--gold);letter-spacing:.04em}

/* ═══ FEATURES ═══ */
.features{width:100%;max-width:880px;padding:3rem 2rem 2rem;animation:fadeUp .9s .7s ease both}
.sec-title{text-align:center;font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:2rem}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;border:1px solid var(--bg-border);border-radius:6px;overflow:hidden}
.feat-card{background:var(--bg-card);padding:1.75rem 1.5rem;transition:background var(--transition-base)}
.feat-card:hover{background:#2F333A}
.feat-icon{width:36px;height:36px;margin-bottom:1rem;color:var(--gold)}
.feat-title{font-size:1rem;font-weight:500;color:var(--txt);margin-bottom:.4rem}
.feat-text{font-size:.85rem;color:var(--txt-m);line-height:1.6}

/* ═══ FAQ SECTION ═══ */
.faq-section{width:100%;max-width:880px;padding:2rem 2rem 3rem}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:var(--bg-card);border:1px solid var(--bg-border);border-radius:6px;overflow:hidden;transition:border-color var(--transition-base)}
.faq-item:hover{border-color:rgba(201,168,76,.3)}
.faq-q{
  width:100%;background:none;border:none;padding:1.25rem 1.5rem;
  display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;text-align:left;font-family:'Outfit',sans-serif;
  font-size:.95rem;font-weight:500;color:var(--txt);letter-spacing:.02em;
  transition:color var(--transition-base);
}
.faq-q:hover{color:var(--gold)}
.faq-q svg{width:16px;height:16px;color:var(--gold-dim);flex-shrink:0;transition:transform .3s ease}
.faq-item[open] .faq-q svg{transform:rotate(180deg)}
.faq-a{padding:0 1.5rem 1.25rem;font-size:.875rem;color:var(--txt-m);line-height:1.75}

/* ═══ SOCIAL ═══ */
.social-sec{width:100%;max-width:880px;padding:1rem 2rem 3rem;text-align:center}
.sm-grid{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.sm-card{
  display:flex;align-items:center;gap:.6rem;
  background:var(--bg-card);border:1px solid var(--bg-border);border-radius:4px;
  padding:.7rem 1.2rem;text-decoration:none;color:var(--txt-m);
  font-size:.85rem;font-weight:400;letter-spacing:.04em;
  transition:border-color var(--transition-base),color var(--transition-base),background var(--transition-base);
}
.sm-card:hover,.sm-card:focus-visible{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06)}
.sm-card svg{width:18px;height:18px;flex-shrink:0}

/* ═══ FOOTER ═══ */
footer{
  width:100%;border-top:1px solid var(--bg-border);padding:1.5rem 2rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  flex-wrap:wrap;font-size:.6875rem;color:var(--txt-d);letter-spacing:.06em;
}
footer a{color:var(--txt-d);text-decoration:none;transition:color var(--transition-base)}
footer a:hover,footer a:focus-visible{color:var(--gold)}
.flinks{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
.flbtn{
  background:none;border:none;padding:0;cursor:pointer;
  color:var(--txt-d);font-family:'Outfit',sans-serif;font-size:.6875rem;
  letter-spacing:.06em;transition:color var(--transition-base);
}
.flbtn:hover,.flbtn:focus-visible{color:var(--gold)}

/* ═══ KEYFRAMES ═══ */
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.7)}
}
@keyframes fadeInDown{
  from{opacity:0;transform:translateY(-20px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}

/* ═══ RESPONSIVE ═══ */

/* ── Large Desktop (1400px+) ── */
@media(min-width:1400px){
  .hero{max-width:1000px;padding:5rem 2rem 4rem}
  .features,.faq-section,.social-sec{max-width:1000px}
  .feat-grid{grid-template-columns:repeat(4,1fr)}
}

/* ── Desktop / Small Desktop (1024–1399px) ── */
@media(max-width:1399px){
  .feat-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
}

/* ── Tablet Landscape (769–1024px) ── */
@media(max-width:1024px){
  .hero{padding:3.5rem 2rem 2.5rem}
  .logo-img{height:75px}
  .headline{font-size:clamp(2.8rem,8vw,5.5rem)}
  .sub{font-size:clamp(.9rem,1.8vw,1.05rem);max-width:500px}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .sm-grid{gap:.75rem}
}

/* ── Tablet Portrait (601–768px) ── */
@media(max-width:768px){
  header{padding:1.25rem 1.5rem}
  .hero{padding:3rem 1.5rem 2rem}
  .logo-img{height:65px}
  .headline{font-size:clamp(2.4rem,7vw,4rem)}
  .sub{font-size:.95rem;max-width:440px}
  .divider{margin:1.5rem auto}
  .cd-wrap{margin:1.5rem 0 2rem}
  .cd-n{font-size:clamp(2rem,6vw,3rem)}
  .cd{gap:1rem}
  .form-wrap{max-width:400px}
  .features{padding:2rem 1.5rem 1.5rem}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .feat-card{padding:1.5rem 1.25rem}
  .faq-section{padding:1.5rem 1.5rem 2.5rem}
  .social-sec{padding:1rem 1.5rem 2.5rem}
  .sm-grid{flex-wrap:wrap;gap:.6rem}
  .sm-card{padding:.6rem 1rem;font-size:.8rem}
  footer{padding:1.25rem 1.5rem;font-size:.65rem}
}

/* ── Large Phone / Phablet (481–600px) ── */
@media(max-width:600px){
  header{padding:1rem 1.25rem}
  .sm-top{gap:.75rem}
  .sm-top svg{width:16px;height:16px}
  .tbadge{font-size:.6rem;gap:.4rem}
  .hero{padding:2.5rem 1.25rem 1.5rem}
  .logo-img{height:55px}
  .headline{font-size:clamp(2rem,9vw,3.2rem);letter-spacing:.02em}
  .sub{font-size:.9rem;margin-top:1rem;line-height:1.65;max-width:100%}
  .divider{width:40px;margin:1.25rem auto}
  .cd-wrap{margin:1.25rem 0 1.75rem}
  .cd{gap:.8rem}
  .cd-s{display:none}
  .cd-n{font-size:clamp(1.8rem,8vw,2.5rem)}
  .cd-t{font-size:.55rem}
  .cd-lbl{font-size:.6rem}
  .form-wrap{max-width:100%}
  .form-lbl{font-size:.6rem}
  .erow{flex-direction:column;border-radius:6px}
  .einp{padding:.85rem 1rem;font-size:.85rem;border-bottom:1px solid var(--bg-border)}
  .ebtn{padding:.85rem 1rem;font-size:.8rem;border-radius:0 0 4px 4px}
  .fnote{font-size:.6rem}
  .features{padding:2rem 1.25rem 1.5rem}
  .feat-grid{grid-template-columns:1fr}
  .feat-card{padding:1.5rem 1.25rem}
  .feat-icon{width:30px;height:30px;margin-bottom:.75rem}
  .feat-title{font-size:.95rem}
  .feat-text{font-size:.8rem}
  .sec-title{font-size:.625rem;margin-bottom:1.5rem}
  .faq-section{padding:1.5rem 1.25rem 2rem}
  .faq-q{padding:1rem 1.25rem;font-size:.9rem}
  .faq-a{padding:0 1.25rem 1rem;font-size:.825rem}
  .social-sec{padding:1rem 1.25rem 2rem}
  .sm-grid{gap:.5rem}
  .sm-card{padding:.6rem .9rem;font-size:.78rem;flex:1 1 calc(50% - .5rem);justify-content:center;min-width:130px}
  .sm-card svg{width:16px;height:16px}
  footer{justify-content:center;text-align:center;flex-direction:column;gap:.75rem;padding:1.25rem 1rem}
  .flinks{justify-content:center;gap:1rem}
}

/* ── Small Phone (≤ 380px) ── */
@media(max-width:380px){
  header{padding:.75rem 1rem}
  .tbadge{font-size:.55rem;letter-spacing:.08em}
  .tbadge::before{width:5px;height:5px}
  .sm-top{gap:.5rem}
  .sm-top svg{width:14px;height:14px}
  .hero{padding:2rem 1rem 1.25rem}
  .logo-wrap{margin-bottom:1.5rem}
  .logo-img{height:45px}
  .headline{font-size:clamp(1.7rem,10vw,2.5rem)}
  .sub{font-size:.825rem;line-height:1.6}
  .cd{gap:.5rem}
  .cd-n{font-size:clamp(1.5rem,9vw,2rem)}
  .cd-u{gap:.2rem}
  .cd-t{font-size:.5rem}
  .einp{padding:.75rem .9rem;font-size:.8rem}
  .ebtn{padding:.75rem .9rem;font-size:.75rem}
  .features,.faq-section,.social-sec{padding-left:1rem;padding-right:1rem}
  .feat-card{padding:1.25rem 1rem}
  .faq-q{padding:.85rem 1rem;font-size:.85rem}
  .faq-a{padding:0 1rem .85rem;font-size:.8rem;line-height:1.65}
  .sm-card{flex:1 1 100%;padding:.55rem .75rem;font-size:.75rem}
  footer{font-size:.6rem;padding:1rem .75rem}
  .flinks{gap:.75rem;font-size:.6rem}
  .flbtn{font-size:.6rem}
}

/* ── Landscape orientation on phones ── */
@media(max-height:500px) and (orientation:landscape){
  .hero{padding:1.5rem 2rem 1rem;min-height:auto}
  .logo-wrap{margin-bottom:1rem}
  .logo-img{height:40px}
  .headline{font-size:clamp(1.8rem,5vw,3rem)}
  .sub{margin-top:.75rem;font-size:.85rem}
  .divider{margin:1rem auto}
  .cd-wrap{margin:1rem 0 1.25rem}
  .cd-n{font-size:2rem}
  header{padding:.75rem 1.5rem;position:relative}
  .page{min-height:auto}
}

/* ── Touch target sizing for mobile ── */
@media(hover:none) and (pointer:coarse){
  .sm-top a{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
  .faq-q{min-height:48px}
  .sm-card{min-height:44px}
  .ebtn{min-height:48px}
  .m-close{min-width:44px;min-height:44px}
  .flbtn{min-height:44px;padding:.5rem}
  footer a{min-height:44px;display:inline-flex;align-items:center}
}

/* ═══ REDUCED MOTION ═══ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  html{scroll-behavior:auto}
}

/* ═══ PRINT ═══ */
@media print{
  .bg-grid,.bg-r1,.bg-r2,.sm-top,.social-sec,.cd-wrap,.m-overlay{display:none!important}
  body{background:#fff;color:#111}
  header{position:static;background:#fff;border-bottom:1px solid #ccc}
  .headline,.headline span{color:#111}
}
