/* ═══════════════════════════════════════════════
   ECLIPSE 2026 — GIJON
   Responsive, fast, distinctive design
   ═══════════════════════════════════════════════ */

/* ── RESET & BASE ─────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  background:#060810;
  color:#c8c8d8;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:#e8a020;text-decoration:none}
a:hover{text-decoration:underline}

/* ── VARIABLES ────────────────────────────────── */
:root{
  --c-bg:#060810;
  --c-bg2:#0c1018;
  --c-bg3:#111828;
  --c-card:#12182c;
  --c-border:#1c2440;
  --c-gold:#e8a020;
  --c-gold-soft:rgba(232,160,32,.12);
  --c-gold-border:rgba(232,160,32,.30);
  --c-text:#c8c8d8;
  --c-text2:#7a7a94;
  --c-white:#f0f0f5;
  --c-blue:#5aadff;
  --c-purple:#a78bfa;
  --c-green:#4ade80;
  --c-red:#f87171;
  --c-orange:#fb923c;
  --max-w:1080px;
  --r:12px;
}

/* ── UTILITY ──────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ── NAVIGATION ───────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:999;
  height:52px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.5rem;
  background:rgba(6,8,16,.82);
  backdrop-filter:blur(16px) saturate(1.5);
  -webkit-backdrop-filter:blur(16px) saturate(1.5);
  border-bottom:1px solid var(--c-border);
  transition:background .3s;
}
.nav-logo{font-weight:800;font-size:.95rem;color:var(--c-white);letter-spacing:-.01em}
.nav-logo em{font-style:normal;color:var(--c-gold)}
.nav-links{list-style:none;display:flex;gap:1.8rem}
.nav-links a{
  color:var(--c-text2);font-size:.8rem;font-weight:500;
  letter-spacing:.02em;transition:color .2s;text-decoration:none;
}
.nav-links a:hover{color:var(--c-white)}
@media(max-width:680px){.nav-links{display:none}}

/* ── HERO ─────────────────────────────────────── */
.hero{
  min-height:100svh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;
  padding:5rem 1.5rem 3rem;
  position:relative;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 55%,#18103a 0%,transparent 70%),
    radial-gradient(circle at 50% 40%,#0a0a20 0%,var(--c-bg) 100%);
  z-index:0;
}
.hero-eclipse{
  position:absolute;
  top:32%;left:50%;
  transform:translate(-50%,-50%);
  width:min(360px,60vw);height:min(360px,60vw);
  z-index:1;pointer-events:none;
}
.hero-eclipse .moon{
  position:absolute;inset:0;
  border-radius:50%;
  background:#000;
  box-shadow:
    0 0 60px 20px rgba(255,200,80,.08),
    0 0 120px 40px rgba(255,200,80,.04);
}
.hero-eclipse .corona{
  position:absolute;inset:-15%;
  border-radius:50%;
  background:radial-gradient(circle,transparent 36%,rgba(255,210,100,.25) 40%,rgba(255,210,100,.06) 55%,transparent 70%);
  animation:corona-pulse 5s ease-in-out infinite;
}
.hero-eclipse .ring{
  position:absolute;inset:0;
  border-radius:50%;
  border:1.5px solid rgba(255,210,100,.35);
}
@keyframes corona-pulse{
  0%,100%{transform:scale(1);opacity:.7}
  50%{transform:scale(1.08);opacity:1}
}
.hero-content{position:relative;z-index:2}
.hero h1{
  font-size:clamp(2.6rem,7vw,5rem);
  font-weight:800;
  color:var(--c-white);
  letter-spacing:-.03em;
  line-height:1.05;
}
.hero h1 .accent{color:var(--c-gold)}
.hero-sub{
  font-size:clamp(1rem,2.5vw,1.35rem);
  color:var(--c-text2);
  font-weight:300;
  margin-top:.8rem;
  max-width:540px;margin-left:auto;margin-right:auto;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:2rem;
  padding:.55rem 1.5rem;
  border-radius:99px;
  background:var(--c-gold-soft);
  border:1px solid var(--c-gold-border);
  color:var(--c-gold);
  font-weight:700;font-size:1rem;
}
.hero-scroll{
  position:absolute;bottom:1.5rem;left:50%;
  transform:translateX(-50%);
  color:var(--c-text2);font-size:.75rem;
  animation:hero-bounce 2.5s infinite;
  z-index:2;
}
@keyframes hero-bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(6px)}
}

/* ── FACTS STRIP ──────────────────────────────── */
.facts{
  background:var(--c-bg2);
  border-top:1px solid var(--c-border);
  border-bottom:1px solid var(--c-border);
  padding:1.8rem 1rem;
}
.facts-inner{
  display:flex;justify-content:center;gap:2rem;
  flex-wrap:wrap;max-width:1000px;margin:0 auto;
}
.fact{text-align:center;min-width:100px}
.fact-v{font-size:1.7rem;font-weight:800;color:var(--c-gold);line-height:1.2}
.fact-l{font-size:.68rem;color:var(--c-text2);text-transform:uppercase;letter-spacing:.1em;margin-top:.1rem}

/* ── SECTION HEADERS ──────────────────────────── */
section{padding:5rem 0}
.sec-hdr{text-align:center;margin-bottom:3rem}
.sec-label{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--c-gold);font-weight:700;margin-bottom:.5rem;
}
.sec-title{
  font-size:clamp(1.5rem,4vw,2.2rem);
  font-weight:800;color:var(--c-white);
  letter-spacing:-.02em;margin-bottom:.5rem;
}
.sec-desc{color:var(--c-text2);max-width:560px;margin:0 auto;font-size:.92rem}

/* ── MAP ──────────────────────────────────────── */
#eclipse-map{
  width:100%;height:clamp(420px,60vh,700px);
  border-radius:var(--r);
  border:1px solid var(--c-border);
  box-shadow:0 16px 64px rgba(0,0,0,.5);
}
.map-legend-box{
  background:rgba(6,8,16,.9);
  backdrop-filter:blur(8px);
  border:1px solid var(--c-border);
  border-radius:10px;
  padding:10px 14px;
  font-size:.78rem;color:var(--c-text);line-height:2;
}
.map-legend-box h4{color:var(--c-gold);font-size:.82rem;margin-bottom:2px}
.ml-row{display:flex;align-items:center;gap:7px}
.ml-line{width:20px;height:3px;border-radius:2px;flex-shrink:0}
.ml-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:2px solid #fff}

/* Leaflet popup override */
.leaflet-popup-content-wrapper{
  background:var(--c-card)!important;color:var(--c-text)!important;
  border-radius:10px!important;border:1px solid var(--c-border)!important;
  box-shadow:0 10px 40px rgba(0,0,0,.5)!important;
}
.leaflet-popup-tip{background:var(--c-card)!important}
.leaflet-popup-content{font-size:.82rem!important;line-height:1.6!important}
.leaflet-popup-content strong{color:var(--c-gold)}
.leaflet-popup-close-button{color:var(--c-text2)!important}
.popup-highlight{color:var(--c-gold);font-weight:700;font-size:1.05rem}

/* ── SUN DIAGRAM ──────────────────────────────── */
.sun-svg{width:100%;max-width:860px;margin:0 auto;display:block}

/* ── TIMELINE ─────────────────────────────────── */
.tl-section{background:var(--c-bg2)}
.tl{position:relative;max-width:620px;margin:0 auto;padding-left:44px}
.tl::before{
  content:'';position:absolute;left:18px;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,transparent,var(--c-gold),var(--c-gold),transparent);
}
.tl-item{position:relative;margin-bottom:2rem}
.tl-item:last-child{margin-bottom:0}
.tl-item::before{
  content:'';position:absolute;
  left:-30px;top:5px;
  width:10px;height:10px;border-radius:50%;
  background:var(--c-gold);border:2px solid var(--c-bg2);
}
.tl-item.big::before{
  width:16px;height:16px;left:-33px;top:2px;
  background:var(--c-white);
  box-shadow:0 0 14px var(--c-gold),0 0 40px rgba(232,160,32,.25);
}
.tl-time{font-size:1.25rem;font-weight:800;color:var(--c-gold)}
.tl-item.big .tl-time{color:var(--c-white);font-size:1.5rem}
.tl-name{color:var(--c-white);font-weight:600;font-size:.95rem}
.tl-desc{color:var(--c-text2);font-size:.83rem;margin-top:.1rem}

/* ── LOCATION CARDS ───────────────────────────── */
.loc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));
  gap:1rem;
}
.loc-card{
  background:var(--c-card);
  border:1px solid var(--c-border);
  border-radius:var(--r);
  padding:1.4rem;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  cursor:pointer;position:relative;
}
.loc-card:hover{
  border-color:var(--c-gold);
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(232,160,32,.08);
}
.loc-card.featured{border-color:var(--c-gold-border)}
.loc-badge{
  position:absolute;top:-9px;right:14px;
  background:var(--c-gold);color:var(--c-bg);
  font-size:.6rem;font-weight:800;
  padding:3px 10px;border-radius:5px;
  letter-spacing:.04em;
}
.loc-card h3{color:var(--c-white);font-size:1.05rem;font-weight:700;margin-bottom:.4rem}
.loc-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}
.ltag{font-size:.68rem;font-weight:600;padding:3px 8px;border-radius:5px}
.ltag-elev{color:var(--c-blue);background:rgba(90,173,255,.1)}
.ltag-dist{color:var(--c-purple);background:rgba(167,139,250,.1)}
.ltag-dur{color:var(--c-gold);background:var(--c-gold-soft)}
.ltag-drive{color:var(--c-text2);background:rgba(255,255,255,.04)}
.loc-desc{color:var(--c-text2);font-size:.83rem}
.loc-plus{margin-top:.4rem;font-size:.8rem;color:var(--c-green);font-weight:500}
.loc-warn{margin-top:.3rem;font-size:.78rem;color:var(--c-orange)}

/* ── ACCOMMODATION ────────────────────────────── */
.accom-section{background:var(--c-bg2)}
.accom-card{
  max-width:640px;margin:0 auto;
  background:var(--c-card);border:1px solid var(--c-border);
  border-radius:16px;padding:2rem;
}
.accom-card h3{color:var(--c-white);font-size:1.15rem;margin-bottom:1rem}
.ac-row{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:.75rem;font-size:.88rem}
.ac-icon{
  flex-shrink:0;width:30px;height:30px;
  background:var(--c-gold-soft);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;
}
.ac-label{color:var(--c-text2);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}
.ac-val{color:var(--c-white);font-weight:500}
#accom-map{
  width:100%;height:260px;border-radius:var(--r);
  border:1px solid var(--c-border);margin-top:1rem;
}

/* ── WEATHER ──────────────────────────────────── */
.w-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:1rem;max-width:780px;margin:0 auto;
}
.w-card{
  background:var(--c-card);border:1px solid var(--c-border);
  border-radius:var(--r);padding:1.1rem;text-align:center;
}
.w-region{color:var(--c-white);font-weight:600;font-size:.88rem;margin-bottom:.4rem}
.w-pct{font-size:2.2rem;font-weight:800;line-height:1.1}
.w-pct.good{color:var(--c-green)}.w-pct.mid{color:var(--c-gold)}.w-pct.bad{color:var(--c-red)}
.w-label{font-size:.68rem;color:var(--c-text2);text-transform:uppercase;letter-spacing:.08em}
.w-note{font-size:.72rem;color:var(--c-text2);margin-top:.25rem}
.planb{
  max-width:640px;margin:1.5rem auto 0;
  background:rgba(74,222,128,.05);border:1px solid rgba(74,222,128,.18);
  border-radius:10px;padding:1rem 1.3rem;
  font-size:.88rem;color:var(--c-green);line-height:1.6;
}
.planb b{color:var(--c-white)}

/* ── EXPERIENCE SECTION ───────────────────────── */
.exp-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));
  gap:1rem;
}
.exp-card{
  background:var(--c-card);border:1px solid var(--c-border);
  border-radius:var(--r);padding:1.4rem;
}
.exp-card h4{color:var(--c-gold);font-size:.92rem;margin-bottom:.5rem}
.exp-card p{color:var(--c-text2);font-size:.85rem}

/* ── TIPS ─────────────────────────────────────── */
.tips-section{background:var(--c-bg2)}
.tips{list-style:none;max-width:680px;margin:0 auto}
.tips li{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1rem 0;border-bottom:1px solid var(--c-border);
  font-size:.88rem;
}
.tips li:last-child{border-bottom:none}
.tip-n{
  flex-shrink:0;width:30px;height:30px;
  background:var(--c-gold-soft);border:1px solid var(--c-gold-border);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.82rem;color:var(--c-gold);
}
.tips b{color:var(--c-white)}

/* ── PACK LIST ────────────────────────────────── */
.pack-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1rem;max-width:800px;margin:0 auto;
}
.pack-card{
  background:var(--c-card);border:1px solid var(--c-border);
  border-radius:var(--r);padding:1.2rem;
}
.pack-card h4{color:var(--c-gold);font-size:.88rem;margin-bottom:.5rem}
.pack-card ul{list-style:none;font-size:.83rem}
.pack-card li{padding:.2rem 0}
.pack-card li::before{content:'\2713';color:var(--c-green);margin-right:.5rem;font-weight:700}

/* ── COUNTDOWN ────────────────────────────────── */
.cd-section{
  background:linear-gradient(135deg,#0a0e20,#18103a);
  padding:3rem 1rem;text-align:center;
}
.cd-grid{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;margin-top:1.2rem}
.cd-box{min-width:70px}
.cd-n{font-size:2.6rem;font-weight:800;color:var(--c-white);line-height:1}
.cd-u{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--c-text2);margin-top:.2rem}

/* ── FOOTER ───────────────────────────────────── */
.footer{
  text-align:center;padding:2.5rem 1.5rem;
  border-top:1px solid var(--c-border);
  color:var(--c-text2);font-size:.78rem;
}

/* ── RESPONSIVE ───────────────────────────────── */
@media(max-width:600px){
  section{padding:3.5rem 0}
  .facts-inner{gap:1.2rem}
  .fact-v{font-size:1.4rem}
  .loc-grid{grid-template-columns:1fr}
  .exp-grid{grid-template-columns:1fr}
}
