/* Film Creator Illusion — Modern, interactive palette with theming */
:root{
  /* Neon theme (default) */
  --bg: #07080c;
  --card: #0f1420;
  --text: #e9eef7;
  --muted: #b6c0d4;
  --brand: #7cf0ff;
  --brand-2: #c08cff;
  --accent: linear-gradient(90deg, var(--brand), var(--brand-2));
  --ring: rgba(124,240,255,.35);
  --radius: 14px;
  --shadow: 0 10px 30px rgba(0,0,0,.45);
}
/* Gold Noir theme */
[data-theme="gold"]{
  --bg:#0a0a0a;
  --card:#141414;
  --text:#fff6e8;
  --muted:#cfc7b8;
  --brand:#ff9a3c;
  --brand-2:#ffd166;
  --accent: linear-gradient(90deg, var(--brand), var(--brand-2));
  --ring: rgba(255,209,102,.35);
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.6;scroll-behavior:smooth}
a{color:var(--brand)}
.container{width:min(1100px,92%);margin-inline:auto}

/* Header */
.site-header{
  position:sticky;top:0;z-index:10;
  background:rgba(6,7,10,.7);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:600}
.logo{font-size:1.3rem}
nav a{margin-left:1rem;text-decoration:none;color:var(--text);opacity:.9;position:relative}
nav a:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);transform:scaleX(0);transition:.25s transform}
nav a:hover:after{transform:scaleX(1)}
.button{display:inline-block;text-decoration:none;border-radius:999px;padding:.7rem 1rem;border:1px solid rgba(255,255,255,.14);cursor:pointer;background:transparent;color:var(--text)}
.button.small{padding:.5rem .8rem;font-size:.9rem}
.button.primary{background:var(--accent);border:none;color:#0b0d12;font-weight:700}

/* Hero with animated glow + canvas FX */
.hero{position:relative;overflow:hidden;padding:100px 0 84px;text-align:center}
.hero:before{
  content:"";position:absolute;inset:-20% -10% auto -10%;height:120%;
  background:radial-gradient(800px 300px at 20% -10%, rgba(124,240,255,.25), transparent 60%),
             radial-gradient(800px 300px at 80% -10%, rgba(192,140,255,.25), transparent 60%);
  animation: floatGlow 10s ease-in-out infinite alternate;
  pointer-events:none;z-index:-1;
}
@keyframes floatGlow{
  from{transform:translateY(-8px)} to{transform:translateY(8px)}
}
#fx{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.4}

/* Sections */
.section{padding:64px 0}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));}
h2{font-size:clamp(1.6rem,3.6vw,2.2rem);margin:0 0 18px}
.tagline{color:var(--muted);max-width:800px;margin:0 auto}
.cta{margin-top:22px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Cards */
.cards{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;padding:0;margin:0}
.card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);transition:transform .2s, box-shadow .2s}
.card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 20px 40px rgba(0,0,0,.55)}
.card h3{margin:.2rem 0 .3rem;font-size:1.05rem}
.card p{color:var(--muted);margin:.2rem 0 0}

/* Work grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.tile{position:relative;aspect-ratio:16/9;display:grid;place-items:center;text-decoration:none;
      color:var(--text);font-weight:600;background:linear-gradient(135deg, rgba(124,240,255,.15), rgba(192,140,255,.15));
      border:1px dashed rgba(255,255,255,.18);border-radius:12px;box-shadow:var(--shadow);
      transition:transform .25s ease, box-shadow .25s ease; will-change:transform}
.tile:hover{transform:perspective(800px) rotateX(4deg) rotateY(-4deg) translateY(-2px)}
.tile span{background:rgba(0,0,0,.35);padding:.35rem .6rem;border-radius:999px}

/* Split + info */
.split{display:grid;grid-template-columns:1.2fr .8fr;gap:26px}
@media (max-width: 860px){.split{grid-template-columns:1fr}}
.info{background:var(--card);border-radius:var(--radius);padding:18px;border:1px solid rgba(255,255,255,.06)}
dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;margin:0}
dt{color:var(--muted)} dd{margin:0}
.bullets{margin:12px 0 0; padding-left:18px} .bullets li{margin:6px 0}

/* Contact form */
.contact-form{display:grid;gap:12px;max-width:680px}
.contact-form label{display:grid;gap:6px}
input, textarea{
  background:#0f1320;color:var(--text);border:1px solid rgba(255,255,255,.12);
  border-radius:10px;padding:.9rem 1rem;font:inherit;transition:border-color .2s, box-shadow .2s
}
input:focus, textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}

.social{display:flex;gap:14px;margin-top:16px;flex-wrap:wrap}
.social a{background:#0f1320;border:1px solid rgba(255,255,255,.12);padding:.5rem .8rem;border-radius:999px;text-decoration:none}

.site-footer{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;text-align:center;color:var(--muted)}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1;transform:none}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}

/* Modal */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center}
.modal.open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7)}
.modal__content{position:relative;width:min(1000px,92%);background:var(--card);border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:var(--shadow);padding:10px}
.modal__frame{position:relative;aspect-ratio:16/9}
.modal__frame iframe{position:absolute;inset:0;width:100%;height:100%}
.modal__close{position:absolute;top:6px;right:10px;background:transparent;border:none;color:var(--text);font-size:28px;cursor:pointer}

/* Showreel */
.reel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.reel{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow)}

/* Gallery images */
.grid .shot{position:relative;display:block;overflow:hidden;border-radius:12px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow)}
.grid .shot img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;display:block;aspect-ratio:16/10}
.grid .shot:hover img{transform:scale(1.05)}
.grid .shot figcaption{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.45);padding:.25rem .5rem;border-radius:8px;font-size:.85rem}
