/*
Theme Name: AV Ghost
Theme URI: https://av-ghost.com/
Author: Ralphie + Lamar Brantley
Author URI: https://av-ghost.com/
Description: Custom landing-page theme for AV Ghost, a portable AV device simulator that works like gear, not like software.
Version: 0.1.1
License: Proprietary
Text Domain: av-ghost
*/
:root {
  --bg: #091015;
  --panel: #111a22;
  --panel-2: #162331;
  --text: #f2f7fb;
  --muted: #a8b6c2;
  --line: rgba(255,255,255,.13);
  --blue: #7cc7ff;
  --cyan: #56e1ff;
  --green: #38d878;
  --shadow: 0 24px 70px rgba(0,0,0,.35);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 20% 0%, rgba(86,225,255,.16), transparent 32rem),
    radial-gradient(circle at 90% 8%, rgba(56,216,120,.12), transparent 26rem),
    var(--bg);
}
a { color: inherit; text-decoration: none; }
.site-header {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  padding: 1rem clamp(1rem, 4vw, 3rem);
  background: rgba(9,16,21,.84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}
.brand img { width: min(270px, 48vw); display: block; border-radius: 14px; }
nav { display: flex; gap: .55rem; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
nav a { color: var(--muted); font-size: .92rem; padding: .55rem .7rem; border-radius: 999px; }
nav a:hover, .nav-cta { color: var(--text); background: rgba(255,255,255,.07); }
.hero {
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr); gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
  min-height: 760px;
  padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 5vw, 5rem);
}
.eyebrow { color: var(--cyan); text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; font-weight: 800; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(3.2rem, 8vw, 7.2rem); line-height: .9; letter-spacing: -.07em; margin-bottom: 1.3rem; max-width: 900px; }
h2 { font-size: clamp(2rem, 4vw, 4rem); line-height: 1; letter-spacing: -.045em; margin-bottom: 1rem; }
h3 { font-size: 1.18rem; margin-bottom: .45rem; }
.lede { color: #d6e3ec; font-size: clamp(1.12rem, 2vw, 1.42rem); line-height: 1.55; max-width: 780px; }
.microcopy { color: var(--muted); max-width: 720px; line-height: 1.65; }
.actions { display: flex; gap: .8rem; flex-wrap: wrap; margin: 2rem 0 1.25rem; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: .8rem 1.05rem; border-radius: 12px; font-weight: 800; border: 1px solid var(--line); }
.button.primary { background: linear-gradient(135deg, var(--blue), var(--green)); color: #061016; border: 0; }
.button.ghost { background: rgba(255,255,255,.055); color: var(--text); }
.hero-device { position: relative; display: grid; place-items: center; min-height: 440px; }
.device-shell {
  position: relative; width: min(520px, 92vw); aspect-ratio: 1.55;
  background: linear-gradient(145deg, #222f3a, #0d141b 54%, #05090d);
  border: 1px solid rgba(255,255,255,.18); border-radius: 42px; box-shadow: var(--shadow);
  padding: 2rem;
  transform: perspective(850px) rotateX(8deg) rotateY(-13deg);
}
.device-shell:before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255,255,255,.06); border-radius: 28px; pointer-events: none; }
.screen { position: absolute; left: 2rem; top: 2rem; width: 58%; height: 58%; border-radius: 24px; background: linear-gradient(145deg,#071015,#142535); border: 1px solid rgba(124,199,255,.35); padding: 1.1rem; display: flex; flex-direction: column; justify-content: center; box-shadow: inset 0 0 35px rgba(86,225,255,.08); }
.screen img { width: 54px; margin-bottom: .8rem; }
.screen span { color: var(--cyan); font-size: .7rem; letter-spacing: .12em; font-weight: 900; }
.screen strong { font-size: 1.35rem; margin: .2rem 0; }
.screen small { color: var(--muted); }
.knob { position: absolute; right: 4rem; top: 4.2rem; width: 82px; height: 82px; border-radius: 50%; background: radial-gradient(circle at 35% 28%, #4d5e69, #0b1014 65%); border: 10px solid #1b2630; box-shadow: inset 0 0 16px rgba(255,255,255,.13), 0 18px 35px rgba(0,0,0,.42); }
.ports { position: absolute; bottom: 2.4rem; left: 2.3rem; right: 2.3rem; display: flex; gap: .7rem; }
.ports i { display: block; width: 54px; height: 18px; border-radius: 6px; background: #020508; border: 1px solid rgba(255,255,255,.18); }
.network-lines span { position: absolute; border: 1px solid rgba(86,225,255,.28); border-radius: 999px; inset: 15%; animation: pulse 3.8s infinite ease-out; }
.network-lines span:nth-child(2){ inset: 7%; animation-delay: .45s; }
.network-lines span:nth-child(3){ inset: 0; animation-delay: .9s; }
@keyframes pulse { 0% { opacity: .4; transform: scale(.92); } 70% { opacity: .05; transform: scale(1.08); } 100% { opacity: 0; } }
.section { padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 5vw, 5rem); }
.split-section { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.copy-card, .feature-grid article, .problem-grid article, .cta-panel { background: rgba(255,255,255,.055); border: 1px solid var(--line); border-radius: 24px; box-shadow: 0 18px 55px rgba(0,0,0,.18); }
.copy-card { padding: clamp(1.4rem, 3vw, 2.2rem); color: #d9e5ec; font-size: 1.08rem; line-height: 1.7; }
.problem-grid, .feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; padding: 0 clamp(1rem, 5vw, 5rem) clamp(4rem, 7vw, 6rem); }
.problem-grid article, .feature-grid article { padding: 1.35rem; }
.problem-grid strong { display: block; margin-bottom: .4rem; color: var(--text); }
.problem-grid span, .feature-grid p, .dark-band p, .workflow p, .cta-panel p { color: var(--muted); line-height: 1.62; }
.dark-band { display: grid; grid-template-columns: 1fr .7fr; gap: 2rem; background: linear-gradient(135deg, rgba(124,199,255,.09), rgba(56,216,120,.07)); border-block: 1px solid var(--line); }
.check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .7rem; }
.check-list li { background: rgba(0,0,0,.18); border: 1px solid var(--line); border-radius: 14px; padding: .9rem 1rem; }
.check-list li:before { content: "✓"; color: var(--green); font-weight: 900; margin-right: .6rem; }
.workflow ol { list-style: none; padding: 0; margin: 2rem 0 0; display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem; }
.workflow li { background: var(--panel); border: 1px solid var(--line); border-radius: 22px; padding: 1.2rem; }
.workflow li span { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg,var(--blue),var(--green)); color: #061016; font-weight: 900; margin-bottom: 1rem; }
.workflow li strong { display: block; margin-bottom: .5rem; }
.cta-panel { margin: 0 clamp(1rem, 5vw, 5rem) clamp(4rem, 7vw, 6rem); padding: clamp(1.4rem, 4vw, 2.6rem); display: grid; grid-template-columns: 90px 1fr auto; gap: 1.4rem; align-items: center; }
.cta-panel img { width: 90px; }
footer { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding: 2rem clamp(1rem, 5vw, 5rem); color: var(--muted); border-top: 1px solid var(--line); }
@media (max-width: 980px) {
  .hero, .split-section, .dark-band, .cta-panel { grid-template-columns: 1fr; }
  .problem-grid, .feature-grid, .workflow ol { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .site-header { align-items: flex-start; flex-direction: column; }
  nav { justify-content: flex-start; }
}
@media (max-width: 640px) {
  h1 { font-size: 3.4rem; }
  .problem-grid, .feature-grid, .workflow ol { grid-template-columns: 1fr; }
  .device-shell { transform: none; }
}
