:root{
  --bg:#000000;--card:#1a1a1a;--muted:#9aa4b2;--accent:#B87333;--accent-2:#D4A574;
  --max-width:1080px;
  --font-heading:'Space Grotesk',Futura,Trebuchet MS,system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:Futura,Trebuchet MS,Segoe UI,system-ui,Arial,sans-serif;background:#000000;color:#e6eef6;line-height:1.45}
h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:-0.02em}

/* ── Film-grain overlay ── */
body::after{
  content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px 256px;
}

.container{width:90%;max-width:var(--max-width);margin:0 auto}

/* ── Hero with starfield ── */
.hero{padding:64px 0;position:relative;overflow:hidden;background:#000}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(1.2px 1.2px at 10% 20%,rgba(255,255,255,0.7),transparent),
    radial-gradient(1px 1px at 25% 55%,rgba(255,255,255,0.5),transparent),
    radial-gradient(1.5px 1.5px at 40% 15%,rgba(255,255,255,0.6),transparent),
    radial-gradient(1px 1px at 55% 70%,rgba(255,255,255,0.4),transparent),
    radial-gradient(1.3px 1.3px at 70% 35%,rgba(255,255,255,0.55),transparent),
    radial-gradient(0.8px 0.8px at 82% 80%,rgba(255,255,255,0.35),transparent),
    radial-gradient(1px 1px at 90% 10%,rgba(255,255,255,0.45),transparent),
    radial-gradient(1.1px 1.1px at 15% 85%,rgba(255,255,255,0.3),transparent),
    radial-gradient(0.9px 0.9px at 60% 45%,rgba(255,255,255,0.4),transparent),
    radial-gradient(1.4px 1.4px at 35% 90%,rgba(255,255,255,0.5),transparent);
  background-size:200px 200px;
  animation:drift 90s linear infinite;
  z-index:0;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(0.8px 0.8px at 5% 40%,rgba(184,115,51,0.5),transparent),
    radial-gradient(1px 1px at 30% 75%,rgba(255,255,255,0.3),transparent),
    radial-gradient(1.2px 1.2px at 50% 25%,rgba(212,165,116,0.35),transparent),
    radial-gradient(0.7px 0.7px at 75% 60%,rgba(255,255,255,0.25),transparent),
    radial-gradient(1px 1px at 95% 45%,rgba(184,115,51,0.3),transparent),
    radial-gradient(0.9px 0.9px at 20% 10%,rgba(255,255,255,0.35),transparent),
    radial-gradient(1.1px 1.1px at 65% 85%,rgba(255,255,255,0.2),transparent),
    radial-gradient(0.8px 0.8px at 45% 55%,rgba(212,165,116,0.25),transparent);
  background-size:300px 300px;
  animation:drift 120s linear infinite reverse;
  z-index:0;
}
@keyframes drift{
  from{transform:translateY(0)}
  to{transform:translateY(-200px)}
}
.hero>*{position:relative;z-index:1}

.hero-inner{display:flex;align-items:center;gap:28px}
.avatar{
  width:110px;height:110px;border-radius:12px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 8px 24px rgba(0,0,0,0.6), 0 0 20px rgba(184,115,51,0.4), 0 0 40px rgba(184,115,51,0.15);
  animation:avatar-pulse 4s ease-in-out infinite;
}
@keyframes avatar-pulse{
  0%,100%{box-shadow:0 8px 24px rgba(0,0,0,0.6), 0 0 20px rgba(184,115,51,0.4), 0 0 40px rgba(184,115,51,0.15)}
  50%{box-shadow:0 8px 24px rgba(0,0,0,0.6), 0 0 30px rgba(184,115,51,0.6), 0 0 60px rgba(184,115,51,0.25)}
}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.intro h1{margin:0;font-size:34px}
.tagline{color:var(--accent);margin:8px 0}
.bio{color:var(--muted);max-width:60ch}
.btn{display:inline-block;padding:10px 14px;border-radius:8px;background:#0b2026;color:#ffffff;text-decoration:none;font-weight:700;font-family:var(--font-heading)}
.btn-outline{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--accent)}

/* ── Section divider ── */
section+section{border-top:1px solid rgba(184,115,51,0.12)}

.books{padding:48px 0}
.books h2{margin-top:0}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.card{background:linear-gradient(180deg,rgba(255,255,255,0.02), rgba(255,255,255,0.01));padding:16px;border-radius:10px;transition:transform 0.2s ease,box-shadow 0.2s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(184,115,51,0.1)}
.cover{height:480px;border-radius:6px;margin-bottom:12px;background-size:cover;background-position:center}
.cover-1{background-image:url('assets/dick-ubik.jpg');background-size:cover;background-position:center;background-color:#000}
.cover-2{background-image:url('assets/Lem-Solarisl.jpg');background-size:cover;background-position:center;background-color:#000}
.cover-3{background-image:url('assets/Ballard-TheDrownedWorld.jpg');background-size:cover;background-position:center;background-color:#000}
.muted{color:var(--muted);font-size:14px}
.link{color:var(--accent-2);text-decoration:none;transition:color 0.2s}
.link:hover{color:var(--accent)}

.about,.contact{padding:28px 0}
.site-footer{border-top:1px solid rgba(255,255,255,0.03);padding:20px 0;color:var(--muted)}

@media (max-width:720px){.hero-inner{flex-direction:column;align-items:flex-start}.avatar{width:92px;height:92px;font-size:28px}}

/* ── Reduced motion ── */
@media (prefers-reduced-motion:reduce){
  .hero::before,.hero::after{animation:none}
  .avatar{animation:none}
}
