/* =========================================================================
   Kota Weather — main stylesheet
   Modern, smooth, responsive UI. Sky-blue + Rajasthan-sunset palette.
   ========================================================================= */

:root{
  --blue-900:#0c4a6e; --blue-700:#0369a1; --blue-600:#0284c7; --blue-500:#0ea5e9;
  --blue-100:#e0f2fe; --blue-50:#f0f9ff;
  --amber-600:#d97706; --amber-500:#f59e0b; --amber-400:#fbbf24; --amber-100:#fef3c7;
  --ink:#0f172a; --ink-2:#334155; --muted:#64748b; --line:#e2e8f0;
  --bg:#f7fafc; --card:#ffffff; --white:#fff;
  --ok:#16a34a; --warn:#ea580c; --danger:#dc2626;
  --grad-sky:linear-gradient(135deg,#0ea5e9 0%,#0369a1 55%,#0c4a6e 100%);
  --grad-sun:linear-gradient(120deg,#f59e0b 0%,#ef4444 100%);
  --grad-hero:linear-gradient(120deg,#0c4a6e 0%,#0369a1 45%,#0ea5e9 100%);
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.08);
  --shadow:0 6px 18px -6px rgba(15,23,42,.18);
  --shadow-lg:0 24px 48px -16px rgba(15,23,42,.28);
  --radius:16px; --radius-sm:10px; --radius-lg:24px;
  --container:1180px;
  --t:.25s cubic-bezier(.4,0,.2,1);
  --font-head:"Poppins",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:16.5px;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--blue-700);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--blue-500)}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.18;color:var(--ink);margin:.2em 0 .5em;font-weight:700}
h1{font-size:clamp(2rem,4.4vw,3.25rem);letter-spacing:-.02em}
h2{font-size:clamp(1.5rem,3vw,2.25rem);letter-spacing:-.01em}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
ul{margin:0 0 1rem}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:20px}
section{position:relative}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.eyebrow{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:600;color:var(--blue-600)}
.lead{font-size:1.15rem;color:var(--ink-2)}
.muted{color:var(--muted)}
.center{text-align:center}
.mx-auto{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  font-family:var(--font-head);font-weight:600;font-size:.97rem;
  padding:.8rem 1.4rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);
  background:var(--blue-600);color:#fff;box-shadow:var(--shadow-sm);text-align:center;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);color:#fff}
.btn--accent{background:var(--grad-sun);color:#fff}
.btn--ghost{background:transparent;color:var(--blue-700);border-color:var(--blue-200,#bae6fd)}
.btn--ghost:hover{background:var(--blue-50);color:var(--blue-700)}
.btn--light{background:#fff;color:var(--blue-700)}
.btn--light:hover{color:var(--blue-700)}
.btn--lg{padding:1rem 1.8rem;font-size:1.05rem}
.btn--ad{background:var(--ad-accent,var(--blue-600));padding:.6rem 1.05rem;font-size:.88rem}

/* ---------- Topbar ---------- */
.topbar{background:var(--ink);color:#cbd5e1;font-size:.82rem}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:1rem}
.topbar a{color:#cbd5e1}
.topbar a:hover{color:#fff}
.topbar__links{display:flex;gap:1.2rem}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line);transition:box-shadow var(--t)}
.site-header.scrolled{box-shadow:var(--shadow)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:70px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-head)}
.brand__logo{font-size:1.8rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(2,132,199,.4))}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-weight:800;font-size:1.25rem;color:var(--ink)}
.brand__sub{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.brand--foot .brand__name{color:#fff}

.primary-nav{display:flex;align-items:center;gap:.4rem}
.nav-list{display:flex;align-items:center;gap:.1rem;list-style:none;margin:0;padding:0}
.nav-item{position:relative}
.nav-item>a{display:flex;align-items:center;gap:.25rem;padding:.6rem .8rem;border-radius:10px;font-weight:600;font-size:.94rem;color:var(--ink-2)}
.nav-item>a:hover{background:var(--blue-50);color:var(--blue-700)}
.nav-item.is-active>a{color:var(--blue-700)}
.nav-item.is-active>a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.25rem;height:2px;background:var(--blue-600);border-radius:2px}
.caret{font-size:.6rem;opacity:.7}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:.5rem;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--t);z-index:120}
.has-dropdown:hover>.dropdown,.has-dropdown:focus-within>.dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:block;padding:.6rem .8rem;border-radius:9px;font-size:.92rem;color:var(--ink-2);font-weight:500}
.dropdown li a:hover,.dropdown li a.is-active{background:var(--blue-50);color:var(--blue-700)}
.nav-cta{margin-left:.6rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:0;background:transparent;cursor:pointer;padding:10px}
.nav-toggle span{height:2.5px;background:var(--ink);border-radius:2px;transition:var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Weather strip (sitewide) ---------- */
.wx-strip{background:var(--grad-sky);color:#fff;position:sticky;top:70px;z-index:90;box-shadow:var(--shadow-sm)}
.wx-strip__inner{display:flex;align-items:center;gap:1.4rem;min-height:64px;padding-block:.5rem;flex-wrap:wrap}
.wx-now{display:flex;align-items:center;gap:.7rem;color:#fff}
.wx-now:hover{color:#fff;opacity:.95}
.wx-now__icon{font-size:2rem;line-height:1}
.wx-now__temp{font-family:var(--font-head);font-weight:800;font-size:1.7rem}
.wx-now__main{display:flex;align-items:center;gap:.6rem}
.wx-now__meta{display:flex;flex-direction:column;line-height:1.2}
.wx-now__cond{font-weight:600;font-size:.95rem}
.wx-now__place{font-size:.74rem;opacity:.82;text-transform:uppercase;letter-spacing:.08em}
.wx-days{display:flex;gap:.6rem;margin-left:auto}
.wx-day{display:flex;flex-direction:column;align-items:center;gap:.1rem;background:rgba(255,255,255,.14);padding:.4rem .9rem;border-radius:12px;color:#fff;min-width:84px}
.wx-day:hover{background:rgba(255,255,255,.24);color:#fff}
.wx-day__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;opacity:.85}
.wx-day__icon{font-size:1.15rem}
.wx-day__temp b{font-weight:800}
.wx-day__temp i{font-style:normal;opacity:.75;margin-left:.3rem}
.wx-warn{display:flex;align-items:center;gap:.5rem;background:var(--grad-sun);color:#fff;padding:.45rem .9rem;border-radius:999px;font-weight:600;font-size:.86rem;box-shadow:var(--shadow-sm);animation:pulseWarn 2.4s infinite}
.wx-warn:hover{color:#fff}
.wx-warn__dot{width:9px;height:9px;background:#fff;border-radius:50%}
@keyframes pulseWarn{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 8px rgba(239,68,68,0)}}
.wx-strip__cta{color:#fff;font-weight:600;font-size:.9rem;white-space:nowrap}
.wx-strip__cta:hover{color:#fff;text-decoration:underline}
.wx-strip[data-state="error"] .wx-now__cond{opacity:.85}

/* ---------- Hero ---------- */
.hero{background:var(--grad-hero);color:#fff;position:relative;overflow:hidden;padding:clamp(3rem,7vw,5.5rem) 0}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 380px at 85% -10%,rgba(245,158,11,.34),transparent),radial-gradient(700px 360px at 0% 120%,rgba(14,165,233,.4),transparent);pointer-events:none}
.hero__inner{position:relative;z-index:2;max-width:760px}
.hero h1{color:#fff;margin-bottom:.5rem}
.hero p{color:#e0f2fe;font-size:1.18rem;max-width:60ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero__badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.hero__badge{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:.4rem .9rem;border-radius:999px;font-size:.82rem;font-weight:600;backdrop-filter:blur(4px)}
.hero--page{padding:clamp(2.4rem,5vw,3.6rem) 0}
.hero--page h1{font-size:clamp(1.8rem,4vw,2.7rem)}

/* breadcrumbs */
.crumbs{font-size:.84rem;color:rgba(255,255,255,.85);margin-bottom:.8rem;display:flex;gap:.4rem;flex-wrap:wrap}
.crumbs a{color:#fff;opacity:.85}
.crumbs a:hover{opacity:1}
.crumbs span{opacity:.6}

/* ---------- Sections / layout ---------- */
.section{padding:clamp(2.6rem,6vw,4.4rem) 0}
.section--tint{background:linear-gradient(180deg,var(--blue-50),#fff)}
.section--ink{background:var(--ink);color:#e2e8f0}
.section--ink h2,.section--ink h3{color:#fff}
.section-head{max-width:720px;margin-bottom:2rem}
.section-head.center{margin-inline:auto}
.with-aside{display:grid;grid-template-columns:1fr 320px;gap:2.4rem;align-items:start}
.aside{position:sticky;top:150px;display:flex;flex-direction:column;gap:1.2rem}
.prose>*{max-width:72ch}
.prose h2{margin-top:2rem}
.prose h3{margin-top:1.6rem}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.4rem}
.prose blockquote{border-left:4px solid var(--blue-500);background:var(--blue-50);margin:1.4rem 0;padding:1rem 1.3rem;border-radius:0 12px 12px 0;color:var(--ink-2)}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:1.4rem}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform var(--t),box-shadow var(--t);height:100%;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card__body{padding:1.3rem 1.35rem 1.4rem}
.card__body h3{margin-top:0}
.card__tag{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--blue-700);background:var(--blue-50);padding:.25rem .6rem;border-radius:999px;margin-bottom:.6rem}
.card__link{margin-top:auto;font-weight:600;font-family:var(--font-head);font-size:.92rem}

/* media box with graceful gradient fallback */
.media{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--grad-sky)}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .media img{transform:scale(1.06)}
.media-label{color:#fff;font-family:var(--font-head);font-weight:700;font-size:1.05rem;text-align:center;padding:1rem;text-shadow:0 2px 10px rgba(0,0,0,.35);z-index:0}
.media--tall{aspect-ratio:3/4}

/* feature/icon cards */
.feature{display:flex;gap:1rem;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow-sm);transition:var(--t)}
.feature:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.feature__icon{font-size:1.7rem;background:var(--blue-50);width:54px;height:54px;min-width:54px;display:flex;align-items:center;justify-content:center;border-radius:14px}
.feature h3{font-size:1.1rem;margin:.1rem 0 .35rem}
.feature p{margin:0;font-size:.95rem;color:var(--ink-2)}

/* quick weather link tiles */
.wx-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.wx-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;text-align:center;box-shadow:var(--shadow-sm);transition:var(--t);color:var(--ink)}
.wx-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--blue-700);border-color:var(--blue-200,#bae6fd)}
.wx-tile__emoji{font-size:1.8rem}
.wx-tile__title{font-family:var(--font-head);font-weight:700;margin-top:.3rem}
.wx-tile__sub{font-size:.82rem;color:var(--muted)}

/* ---------- Forecast components (filled by weather.js) ---------- */
.wx-hero-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.6rem;display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:center}
.wx-hero-card__icon{font-size:4.2rem;line-height:1}
.wx-hero-card__temp{font-family:var(--font-head);font-weight:800;font-size:3.4rem;line-height:1;color:var(--ink)}
.wx-hero-card__cond{font-weight:600;color:var(--ink-2)}
.wx-hero-card__meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;margin-top:.7rem;font-size:.9rem;color:var(--muted)}
.wx-hero-card__meta b{color:var(--ink);font-weight:700}

.forecast{display:grid;gap:.8rem}
.fc-day{display:grid;grid-template-columns:130px 56px 1fr auto;align-items:center;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.85rem 1.1rem;box-shadow:var(--shadow-sm);transition:var(--t)}
.fc-day:hover{box-shadow:var(--shadow);border-color:var(--blue-200,#bae6fd)}
.fc-day__date b{display:block;font-family:var(--font-head)}
.fc-day__date span{font-size:.8rem;color:var(--muted)}
.fc-day__icon{font-size:1.9rem;text-align:center}
.fc-day__cond{color:var(--ink-2);font-size:.95rem}
.fc-day__cond small{display:block;color:var(--muted);font-size:.8rem}
.fc-day__temps{font-family:var(--font-head);font-weight:700;white-space:nowrap;font-size:1.05rem}
.fc-day__temps i{font-style:normal;color:var(--muted);font-weight:600;margin-left:.4rem}
.fc-day--warn{border-left:4px solid var(--warn)}

.fc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.fc-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.1rem;text-align:center;box-shadow:var(--shadow-sm);transition:var(--t)}
.fc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.fc-card__day{font-family:var(--font-head);font-weight:700}
.fc-card__date{font-size:.78rem;color:var(--muted);margin-bottom:.4rem}
.fc-card__icon{font-size:2.4rem;margin:.2rem 0}
.fc-card__max{font-family:var(--font-head);font-weight:800;font-size:1.25rem}
.fc-card__min{color:var(--muted);font-weight:600}
.fc-card__rain{font-size:.78rem;color:var(--blue-600);margin-top:.3rem}

.wx-skel{background:linear-gradient(90deg,#eef2f7 25%,#e2e8f0 37%,#eef2f7 63%);background-size:400% 100%;animation:shimmer 1.4s infinite;border-radius:12px;min-height:64px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* alert / advisory boxes */
.alert{display:flex;gap:.8rem;align-items:flex-start;border-radius:14px;padding:1rem 1.2rem;margin:1rem 0;border:1px solid;font-size:.96rem}
.alert__icon{font-size:1.3rem;line-height:1.2}
.alert--warn{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.alert--info{background:var(--blue-50);border-color:#bae6fd;color:var(--blue-900)}
.alert--ok{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.alert--danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;text-align:center;box-shadow:var(--shadow-sm)}
.stat__num{font-family:var(--font-head);font-weight:800;font-size:1.9rem;color:var(--blue-700)}
.stat__label{font-size:.85rem;color:var(--muted)}

/* climate table */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
table.data{width:100%;border-collapse:collapse;background:#fff;min-width:560px}
table.data th,table.data td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
table.data thead th{background:var(--blue-50);font-family:var(--font-head);color:var(--blue-900);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}
table.data tbody tr:hover{background:var(--blue-50)}
table.data td b{color:var(--ink)}

/* itinerary timeline */
.timeline{position:relative;padding-left:1.6rem;margin:1.5rem 0}
.timeline::before{content:"";position:absolute;left:7px;top:.4rem;bottom:.4rem;width:2px;background:linear-gradient(var(--blue-500),var(--amber-400))}
.tl-item{position:relative;margin-bottom:1.5rem}
.tl-item::before{content:"";position:absolute;left:-1.6rem;top:.35rem;width:14px;height:14px;border-radius:50%;background:var(--blue-600);border:3px solid #fff;box-shadow:0 0 0 2px var(--blue-200,#bae6fd)}
.tl-item h4{margin:0 0 .2rem;font-family:var(--font-head)}
.tl-time{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--amber-600)}

/* pills / chips */
.pills{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.4rem .9rem;font-size:.85rem;font-weight:600;color:var(--ink-2)}

/* faq */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:.2rem 1.1rem;margin-bottom:.7rem;box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-family:var(--font-head);font-weight:600;padding:.9rem 0;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue-600);font-size:1.3rem;transition:var(--t)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding-bottom:1rem;margin:0;color:var(--ink-2)}

/* CTA band */
.cta-band{background:var(--grad-sun);color:#fff;border-radius:var(--radius-lg);padding:clamp(1.8rem,4vw,3rem);text-align:center;box-shadow:var(--shadow)}
.cta-band h2{color:#fff}
.cta-band p{color:#fff;opacity:.95;max-width:60ch;margin-inline:auto}
.cta-band .btn--light{margin-top:1rem}

/* ---------- ADS ---------- */
.ad{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;transition:var(--t)}
.ad:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.ad__badge{position:absolute;top:.7rem;left:.7rem;z-index:3;background:var(--ad-accent,var(--blue-600));color:#fff;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.25rem .6rem;border-radius:999px;box-shadow:var(--shadow-sm)}
.ad__media{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:16/9;overflow:hidden}
.ad__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ad__media-label{color:#fff;font-family:var(--font-head);font-weight:700;text-align:center;padding:.8rem;text-shadow:0 2px 10px rgba(0,0,0,.4)}
.ad__body{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.ad__title{font-size:1.08rem;margin:0}
.ad__title a{color:var(--ink)}
.ad__title a:hover{color:var(--ad-accent,var(--blue-700))}
.ad__subtitle{font-size:.86rem;font-weight:600;color:var(--ad-accent,var(--blue-700));margin:0}
.ad__content{font-size:.88rem;color:var(--ink-2);margin:.2rem 0}
.ad__actions{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.4rem}
.ad__phone{font-weight:600;font-size:.85rem;color:var(--ink-2)}
.ad__site{font-size:.8rem;font-weight:600;color:var(--ad-accent,var(--blue-600));margin-top:.2rem}
.ad--inline{flex-direction:row;align-items:stretch}
.ad--inline .ad__media{aspect-ratio:auto;width:240px;min-width:240px}
.ad--inline .ad__body{justify-content:center}
.ad-inline-wrap{margin:2rem 0}
.ad--footer .ad__media{aspect-ratio:21/9}
.ad-strip{background:linear-gradient(180deg,#fff,var(--blue-50));border-top:1px solid var(--line);padding:2.4rem 0}
.ad-strip__eyebrow{text-align:center;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:600;color:var(--muted);margin-bottom:1.2rem}
.ad-strip__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#94a3b8;padding-top:3rem;margin-top:0}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr 1.2fr;gap:2rem;padding-bottom:2.4rem}
.site-footer h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.site-footer a{color:#94a3b8;font-size:.9rem}
.site-footer a:hover{color:#fff}
.foot-about{font-size:.92rem;line-height:1.7;color:#cbd5e1}
.foot-about strong{color:#fff}
.foot-social{display:flex;gap:.5rem;margin-top:1rem}
.foot-social a{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid #334155;border-radius:10px;font-size:.8rem;font-weight:700;color:#cbd5e1}
.foot-social a:hover{background:var(--blue-600);border-color:var(--blue-600);color:#fff}
.foot-companies li a{display:flex;flex-direction:column}
.foot-companies strong{color:#e2e8f0;font-size:.95rem}
.foot-companies span{font-size:.78rem;color:#64748b}
.foot-companies li a:hover strong{color:#fff}
.foot-contact li{color:#cbd5e1;font-size:.9rem}
.foot-bottom{border-top:1px solid #1e293b;padding:1.3rem 0}
.foot-bottom__inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem}
.foot-bottom p{margin:0;font-size:.84rem}
.foot-legal{display:flex;gap:1.1rem;flex-wrap:wrap}
.foot-legal a{font-size:.84rem}
.foot-disclaimer{width:100%;font-size:.76rem;color:#64748b;margin-top:.4rem}

/* WhatsApp float */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:120;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.7rem;box-shadow:var(--shadow-lg);transition:var(--t)}
.wa-float:hover{transform:scale(1.08);color:#fff}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .with-aside{grid-template-columns:1fr}
  .aside{position:static;flex-direction:row;flex-wrap:wrap}
  .aside>*{flex:1 1 280px}
  .site-footer__grid{grid-template-columns:1fr 1fr 1fr}
  .foot-col--brand{grid-column:1/-1}
}
@media(max-width:900px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .wx-tiles{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .ad-strip__grid{grid-template-columns:1fr}
  .nav-cta{display:none}
  /* mobile nav */
  .nav-toggle{display:flex}
  .primary-nav{position:fixed;inset:0 0 0 auto;width:min(86%,360px);background:#fff;flex-direction:column;align-items:stretch;padding:5rem 1.2rem 2rem;gap:.2rem;transform:translateX(100%);transition:transform var(--t);box-shadow:var(--shadow-lg);overflow-y:auto;z-index:130}
  .primary-nav.open{transform:translateX(0)}
  body.nav-open{overflow:hidden}
  .nav-list{flex-direction:column;align-items:stretch;gap:.1rem;width:100%}
  .nav-item>a{padding:.85rem .6rem;font-size:1.02rem;justify-content:space-between}
  .nav-item.is-active>a::after{display:none}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--line);border-radius:0;margin:.1rem 0 .4rem .6rem;padding:.1rem .4rem;max-height:0;overflow:hidden;transition:max-height var(--t)}
  .has-dropdown.open>.dropdown{max-height:600px}
  .has-dropdown>a .caret{transition:var(--t)}
  .has-dropdown.open>a .caret{transform:rotate(180deg)}
  .nav-cta{display:inline-flex;margin:.8rem 0 0}
  .nav-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);opacity:0;visibility:hidden;transition:var(--t);z-index:125}
  .nav-backdrop.show{opacity:1;visibility:visible}
  .wx-strip{top:0;position:relative}
  .wx-strip__inner{gap:.8rem}
  .wx-days{margin-left:0}
  .wx-strip__cta{display:none}
  .ad--inline{flex-direction:column}
  .ad--inline .ad__media{width:100%;min-width:0;aspect-ratio:16/9}
  .wx-hero-card{grid-template-columns:1fr;text-align:center;justify-items:center}
  .fc-day{grid-template-columns:1fr auto;grid-template-areas:"date temps" "cond cond";row-gap:.3rem}
  .fc-day__date{grid-area:date}.fc-day__temps{grid-area:temps;text-align:right}
  .fc-day__icon{display:none}.fc-day__cond{grid-area:cond}
}
@media(max-width:560px){
  .grid--2,.grid--3{grid-template-columns:1fr}
  .topbar__links a:nth-child(2){display:none}
  .wx-now__temp{font-size:1.4rem}
  .wx-day{min-width:72px;padding:.35rem .6rem}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .foot-bottom__inner{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- page utilities ---------- */
.home-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center;position:relative;z-index:2}
.split{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:center}
.split--text{align-items:start}
.split .media{border-radius:var(--radius-lg);box-shadow:var(--shadow);aspect-ratio:4/3}
.mt-2{margin-top:1.4rem}.mt-3{margin-top:2rem}.mb-0{margin-bottom:0}.mb-2{margin-bottom:1.4rem}
.list-check{list-style:none;padding:0;margin:0 0 1rem}
.list-check li{position:relative;padding-left:1.9rem;margin-bottom:.55rem}
.list-check li::before{content:"✓";position:absolute;left:0;top:.15rem;color:#15803d;font-weight:800;background:#dcfce7;width:1.35rem;height:1.35rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.4rem 0 1rem}
.note{font-size:.85rem;color:var(--muted)}
.box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}
.box--tint{background:var(--blue-50);border-color:#bae6fd}
.price{font-family:var(--font-head);font-weight:800;font-size:1.5rem;color:var(--blue-700)}
.price small{font-weight:600;color:var(--muted);font-size:.8rem}
.ribbon{display:inline-block;background:var(--grad-sun);color:#fff;font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.07em;padding:.3rem .8rem;border-radius:999px;margin-bottom:.6rem}
@media(max-width:860px){.home-hero-grid,.split{grid-template-columns:1fr}}
