/* Home page specific styles: Hyper Light Drifter PL
   Note: Namespaced classes to avoid conflicts with base.css */
:root {
  --hl-cyan: #39d5ff;
  --hl-magenta: #ff3ea5;
  --hl-violet: #8a5cff;
  --hl-deep: #0b0f16;
  --hl-surface: #121824;
  --neon-intensity: 0.7; /* dynamic, controlled by JS */
}

/* Utilities */
.sr-only { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.neon-text { color: #fff; text-shadow: 0 0 calc(6px * var(--neon-intensity)) var(--hl-cyan), 0 0 calc(14px * var(--neon-intensity)) var(--hl-violet); }
.neon-link { color: var(--hl-cyan); text-decoration: none; border-bottom: 1px dotted rgba(57,213,255,0.4); }
.neon-link:hover { color: #fff; border-color: rgba(255,62,165,0.6); }

/* Hero */
.home-hero { background: radial-gradient(1200px 600px at 10% 10%, rgba(138,92,255,0.25), transparent), radial-gradient(800px 400px at 90% 20%, rgba(57,213,255,0.2), transparent), var(--hl-deep); padding: 4rem 1rem; }
.home-hero__wrap { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 2rem; align-items: center; }
.home-hero__title { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.1; margin: 0 0 1rem; }
.home-hero__lead { color: #cfd7ff; max-width: 60ch; margin-bottom: 1.5rem; }
.home-hero__visual img { width: 100%; height: auto; border-radius: 12px; box-shadow: 0 10px 40px rgba(0,0,0,0.6); }
.home-hero__cta { display: flex; gap: 0.75rem; flex-wrap: wrap; margin: 1rem 0 0.5rem; }
.home-hero__quick { list-style: none; padding: 0; margin: 1rem 0 0; display: flex; gap: 1rem; flex-wrap: wrap; }

/* Search */
.home-search { display: grid; grid-template-columns: 1fr auto; gap: 0.75rem; max-width: 720px; }
.home-search input[type="search"] { background: var(--hl-surface); border: 1px solid rgba(255,255,255,0.08); color: #e8eeff; padding: 0.85rem 1rem; border-radius: 10px; outline: none; }
.home-search input[type="search"]:focus { border-color: rgba(57,213,255,0.7); box-shadow: 0 0 0 3px rgba(57,213,255,0.25); }
.home-search__hint { color: #93a0d1; font-size: 0.85rem; grid-column: 1 / -1; margin: 0; }

/* Buttons */
.home-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.8rem 1.1rem; border-radius: 10px; font-weight: 600; text-decoration: none; cursor: pointer; transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease; border: 1px solid transparent; }
.home-btn:hover { transform: translateY(-1px); }
.home-btn--primary { background: linear-gradient(135deg, var(--hl-cyan), var(--hl-violet)); color: #0b0f16; box-shadow: 0 8px 28px rgba(57,213,255,0.25); }
.home-btn--primary:hover { box-shadow: 0 10px 36px rgba(138,92,255,0.35); }
.home-btn--ghost { background: transparent; color: #e8eeff; border-color: rgba(255,255,255,0.12); }
.home-btn--ghost:hover { background: rgba(255,255,255,0.04); }

/* Sections */
.home-section { background: var(--hl-deep); padding: 3.5rem 1rem; }
.home-section--alt { background: linear-gradient(180deg, var(--hl-surface), var(--hl-deep)); }
.home-section__wrap { max-width: 1100px; margin: 0 auto; }
.home-section__title { color: #fff; font-size: clamp(1.4rem, 2.5vw, 2rem); margin: 0 0 0.75rem; }
.home-section__text { color: #cfd7ff; margin: 0 0 1rem; max-width: 70ch; }
.home-list { color: #dbe3ff; padding-left: 1.1rem; margin: 0.5rem 0 1.25rem; }
.home-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* Split layout */
.home-split { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; align-items: center; }
.home-split__visual img { width: 100%; height: auto; border-radius: 12px; box-shadow: 0 10px 40px rgba(0,0,0,0.6); }

/* Cards */
.home-section--grid .home-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; margin-top: 1rem; }
.home-card { background: rgba(18,24,36,0.8); border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; padding: 1rem; backdrop-filter: blur(4px); }
.home-card__title { color: #fff; margin: 0 0 0.5rem; font-size: 1.1rem; }
.home-card__text { color: #cfd7ff; margin: 0 0 0.75rem; }
.home-card__link { font-weight: 600; }

/* FAQ */
.faq { display: grid; gap: 0.5rem; margin: 1rem 0; }
.faq-question { width: 100%; text-align: left; background: rgba(18,24,36,0.9); color: #e8eeff; border: 1px solid rgba(255,255,255,0.08); border-radius: 10px; padding: 0.9rem 1rem; cursor: pointer; }
.faq-question:hover { border-color: rgba(57,213,255,0.5); }
.faq-answer { border-left: 2px solid var(--hl-cyan); padding: 0.75rem 1rem; margin: 0.25rem 0 0.5rem; background: rgba(11,15,22,0.8); color: #cfd7ff; border-radius: 0 10px 10px 0; }

/* Neon section */
.home-neon { position: relative; overflow: hidden; }
.neon-control { display: flex; align-items: center; gap: 0.75rem; margin: 0.5rem 0 1rem; color: #cfd7ff; }
.neon-control input[type="range"] { width: 260px; accent-color: var(--hl-cyan); }
.neon-demo { position: relative; border-radius: 12px; overflow: hidden; background: radial-gradient(600px 300px at 20% 20%, rgba(57,213,255,0.15), transparent), radial-gradient(600px 300px at 80% 60%, rgba(255,62,165,0.18), transparent), #0a0f18; border: 1px solid rgba(255,255,255,0.06); height: 180px; display: grid; place-items: center; margin-bottom: 1rem; }
.neon-demo__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.06), rgba(255,255,255,0.06)), linear-gradient(90deg, rgba(255,255,255,0.06), rgba(255,255,255,0.06)); background-size: 100% 1px, 1px 100%; background-repeat: repeat; background-position: center; filter: drop-shadow(0 0 calc(10px * var(--neon-intensity)) rgba(57,213,255,0.45)); mask-image: radial-gradient(90% 90% at 50% 50%, black 65%, transparent 100%); }
.neon-demo__text { font-weight: 800; letter-spacing: 0.04em; font-size: clamp(1.1rem, 3vw, 1.6rem); }
.home-neon__image img { width: 100%; height: auto; border-radius: 12px; box-shadow: 0 10px 40px rgba(0,0,0,0.6); }

/* Responsive */
@media (max-width: 960px) {
  .home-hero__wrap { grid-template-columns: 1fr; }
  .home-split { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .home-btn { transition: none; }
}
