/* ============ HERO ============ */
.hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;text-align:center;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(circle at center,transparent 0%,rgba(8,9,12,0.7) 70%,var(--bg) 100%),
    linear-gradient(180deg,rgba(8,9,12,0.4) 0%,rgba(8,9,12,0.85) 100%);
}
.hero-content{position:relative;z-index:2;padding:0 24px;max-width:900px}
.hero-tag{
  font-family:'Orbitron',sans-serif;font-size:.85rem;letter-spacing:4px;
  color:var(--cyan);margin-bottom:20px;text-transform:uppercase;
}
.hero-title{
  font-family:'Orbitron',sans-serif;font-weight:900;
  font-size:clamp(2.5rem,7vw,5.5rem);line-height:1.05;letter-spacing:-2px;
  margin-bottom:24px;
}
.hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:var(--muted);max-width:640px;margin:0 auto 36px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}

.hero-stats{display:flex;justify-content:center;gap:50px;flex-wrap:wrap}
.hero-stats div{text-align:center}
.hero-stats strong{
  display:block;font-family:'Orbitron',sans-serif;font-size:2.2rem;
  color:var(--accent);font-weight:900;
}
.hero-stats span{color:var(--muted);font-size:.85rem;letter-spacing:2px;text-transform:uppercase}

.scroll-indicator{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  width:24px;height:40px;border:2px solid var(--muted);border-radius:20px;
}
.scroll-indicator span{
  display:block;width:4px;height:8px;margin:6px auto 0;
  background:var(--accent);border-radius:2px;
  animation:scroll 1.6s infinite;
}
@keyframes scroll{
  0%{transform:translateY(0);opacity:1}
  100%{transform:translateY(16px);opacity:0}
}

/* ============ SEARCH ============ */
.search-section{padding:60px 0 20px}
.search-box{
  position:relative;max-width:720px;margin:0 auto 24px;
  background:var(--surface);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:60px;
  display:flex;align-items:center;gap:12px;
  padding:6px 6px 6px 22px;
  transition:.3s;
}
.search-box:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(255,138,0,.12), var(--shadow);
}
.search-icon{color:var(--muted);flex-shrink:0}
.search-box input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--text);font-size:1rem;padding:14px 0;font-family:inherit;
}
.search-box input::placeholder{color:var(--muted)}

.autocomplete{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:var(--surface-solid);border:1px solid var(--border);
  border-radius:16px;overflow:hidden;
  max-height:340px;overflow-y:auto;
  display:none;z-index:50;box-shadow:var(--shadow);
}
.autocomplete.open{display:block}
.autocomplete-item{
  padding:14px 22px;cursor:pointer;display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--border);transition:.2s;
}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover{background:rgba(255,138,0,.08);color:var(--accent)}
.autocomplete-item small{color:var(--muted);margin-left:auto;font-size:.8rem}

.quick-filters{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
  max-width:900px;margin:0 auto;
}
.chip{
  padding:10px 20px;border:1px solid var(--border);border-radius:30px;
  background:transparent;color:var(--muted);
  font-size:.85rem;font-weight:500;letter-spacing:.5px;
  transition:.25s;text-transform:capitalize;
}
.chip:hover{border-color:var(--accent);color:var(--text)}
.chip.active{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#000;border-color:transparent;font-weight:700;
}

/* ============ SECTIONS ============ */
.section-head{text-align:center;margin-bottom:50px}
.section-head h2{
  font-family:'Orbitron',sans-serif;font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:900;margin-bottom:14px;letter-spacing:-1px;
}
.section-sub{color:var(--muted);max-width:560px;margin:0 auto}

/* ============ SPOTS GRID ============ */
.spots-section{padding:80px 0}
.spots-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:24px;
}
.spot-card-link{display:block;color:inherit}
.spot-card{
  background:var(--surface);backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:18px;
  overflow:hidden;transition:all .4s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;height:100%;
}
.spot-card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,138,0,.4);
  box-shadow:0 20px 50px rgba(0,0,0,.5), 0 0 30px rgba(255,138,0,.15);
}
.spot-img{position:relative;overflow:hidden;aspect-ratio:16/10;background:#111}
.spot-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.spot-card:hover .spot-img img{transform:scale(1.08)}
.spot-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.6));
  pointer-events:none;
}
.spot-diff{
  position:absolute;top:12px;right:12px;z-index:2;
  padding:4px 10px;border-radius:20px;font-size:.7rem;
  font-weight:700;text-transform:uppercase;letter-spacing:1px;
  backdrop-filter:blur(8px);background:rgba(0,0,0,.5);
}
.spot-diff.easy{color:#4ade80;border:1px solid #4ade80}
.spot-diff.medium{color:var(--accent);border:1px solid var(--accent)}
.spot-diff.hard{color:var(--danger);border:1px solid var(--danger)}

.spot-body{padding:20px;flex:1;display:flex;flex-direction:column}
.spot-cat{
  display:inline-block;font-family:'Orbitron',sans-serif;font-size:.7rem;
  letter-spacing:2px;color:var(--cyan);text-transform:uppercase;
  margin-bottom:8px;
}
.spot-body h3{
  font-family:'Orbitron',sans-serif;font-size:1.15rem;
  margin-bottom:8px;font-weight:700;
}
.spot-body p{
  color:var(--muted);font-size:.9rem;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;margin-bottom:14px;
}
.spot-stats{
  display:flex;gap:14px;margin-top:auto;
  padding-top:14px;border-top:1px solid var(--border);
  color:var(--muted);font-size:.85rem;
}
.spot-stats span{display:inline-flex;align-items:center;gap:5px}

/* ============ CATEGORIES ============ */
.categories-section{padding:80px 0;background:var(--bg-2)}
.categories-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:18px;
}
.cat-card{
  position:relative;aspect-ratio:1/1;border-radius:18px;overflow:hidden;
  background:var(--surface-solid);border:1px solid var(--border);
  display:flex;align-items:flex-end;padding:18px;
  transition:all .35s ease;cursor:pointer;
}
.cat-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--accent),var(--cyan));
  opacity:0;transition:.35s;
}
.cat-card:hover{transform:translateY(-4px);border-color:transparent}
.cat-card:hover::before{opacity:.15}
.cat-card .cat-icon{
  position:absolute;top:18px;right:18px;font-size:1.8rem;
  opacity:.6;transition:.35s;
}
.cat-card:hover .cat-icon{opacity:1;transform:scale(1.2) rotate(-8deg)}
.cat-card h3{
  position:relative;z-index:1;
  font-family:'Orbitron',sans-serif;font-size:1.05rem;
  text-transform:uppercase;letter-spacing:2px;
}
.cat-card small{position:relative;z-index:1;color:var(--muted);font-size:.75rem}

/* ============ CTA ============ */
.cta-section{padding:80px 0}
.cta-box{
  background:linear-gradient(135deg,rgba(255,138,0,.08),rgba(0,229,255,.05));
  border:1px solid var(--border);border-radius:24px;
  padding:50px;display:flex;justify-content:space-between;align-items:center;
  gap:40px;flex-wrap:wrap;position:relative;overflow:hidden;
}
.cta-box::before{
  content:'';position:absolute;top:-50%;right:-10%;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,138,0,.2),transparent 70%);
  pointer-events:none;
}
.cta-box h2{
  font-family:'Orbitron',sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);
  margin:10px 0 12px;line-height:1.1;
}
.cta-box p{color:var(--muted);max-width:480px}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
