/* ============================================================
   DJ WERNER · djwerner.dk
   Mørkt, premium design inspireret af Apple: stor typografi,
   meget luft, scroll-reveals og fuldbredde-medier.
   ============================================================ */
:root{
  --bg:#0A0C12;
  --bg-soft:#10131C;
  --card:#141826;
  --text:#F5F6F8;
  --muted:#9AA3B5;
  --accent:#4D6BFF;
  --accent-soft:rgba(77,107,255,.14);
  --line:rgba(255,255,255,.09);
  --radius:20px;
  --max:1140px;
  --display:'Archivo',sans-serif;
  --body:'Instrument Sans',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--text);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
h1,h2,h3{font-family:var(--display);line-height:1.08;letter-spacing:-.02em;font-weight:800}
h2{font-size:clamp(1.9rem,4vw,3rem);margin:.6rem 0 1.1rem}
section{padding:110px 0}
.muted{color:var(--muted)}
.lead{font-size:1.18rem;color:var(--muted);max-width:36rem}

/* ---------- knapper ---------- */
.btn{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;font-family:var(--display);font-weight:700;font-size:.98rem;padding:15px 30px;border-radius:999px;border:none;cursor:pointer;transition:transform .18s,background .18s}
.btn:hover{background:#3a55e8;transform:translateY(-2px)}
.btn.ghost{background:rgba(255,255,255,.08);color:var(--text);backdrop-filter:blur(6px)}
.btn.ghost:hover{background:rgba(255,255,255,.16)}

/* ---------- equalizer-signatur ---------- */
.eq{display:inline-flex;align-items:flex-end;gap:4px;height:18px}
.eq span{width:3.5px;background:var(--accent);border-radius:2px;animation:eq 1.1s ease-in-out infinite}
.eq span:nth-child(1){height:40%}
.eq span:nth-child(2){height:90%;animation-delay:.15s}
.eq span:nth-child(3){height:60%;animation-delay:.3s}
.eq span:nth-child(4){height:100%;animation-delay:.45s}
.eq span:nth-child(5){height:50%;animation-delay:.6s}
@keyframes eq{0%,100%{transform:scaleY(.45)}50%{transform:scaleY(1)}}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .25s,border-color .25s;border-bottom:1px solid transparent}
header.scrolled{background:rgba(10,12,18,.78);backdrop-filter:blur(16px);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:1.08rem;text-decoration:none;letter-spacing:.01em}
nav ul{display:flex;gap:30px;list-style:none;align-items:center}
nav a{text-decoration:none;font-weight:500;font-size:.94rem;color:var(--muted);transition:color .15s}
nav a:hover,nav a.active{color:var(--text)}
nav a.active{color:var(--accent)}
.nav .btn{padding:10px 22px;font-size:.9rem}
.nav .btn:hover{transform:none}
.menu-btn{display:none;background:none;border:none;color:var(--text);font-size:1.7rem;cursor:pointer}

/* ---------- scroll-reveals (Apple-agtigt) ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.media-reveal{opacity:0;transform:scale(.96);transition:opacity .9s ease,transform 1.1s cubic-bezier(.2,.7,.2,1)}
.media-reveal.in{opacity:1;transform:scale(1)}

/* ---------- hero (forside: video i fuld skærm) ---------- */
.hero-video{position:relative;height:100svh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}
.hero-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,12,18,.95) 0%,rgba(10,12,18,.25) 45%,rgba(10,12,18,.35) 100%)}
.hero-content{position:relative;z-index:2;padding-bottom:90px;width:100%}
.hero-content h1{font-size:clamp(2.8rem,7vw,5.2rem);max-width:14ch}
.hero-content .lead{margin-top:18px}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:var(--muted);font-size:1.4rem;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- sidehero (undersider) ---------- */
.page-hero{padding:180px 0 60px}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);max-width:18ch}

/* ---------- statement (stor centreret tekst) ---------- */
.statement{padding:130px 0}
.statement p{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.25;letter-spacing:-.015em;max-width:24ch;margin:0 auto;text-align:center}
.statement .accent{color:var(--accent)}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:center}
.stat{padding:42px 20px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}
.stat strong{display:block;font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,4.5vw,3.4rem);color:var(--accent);letter-spacing:-.02em}
.stat span{color:var(--muted);font-size:.95rem}

/* ---------- fuldbredde-medie ---------- */
.media-full{border-radius:calc(var(--radius) + 6px);overflow:hidden;position:relative}
.media-full img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/8.5}
.media-caption{position:absolute;left:28px;bottom:24px;background:rgba(10,12,18,.6);backdrop-filter:blur(10px);padding:9px 18px;border-radius:999px;font-size:.85rem;color:var(--text)}

/* ---------- splitsektion (tekst + billede) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split .media-side{border-radius:var(--radius);overflow:hidden}
.split .media-side img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split.flip .media-side{order:-1}

/* ---------- kort ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:46px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:38px 32px;text-decoration:none;display:block;transition:transform .2s,border-color .2s}
.card:hover{transform:translateY(-4px);border-color:rgba(77,107,255,.5)}
.card h3{font-size:1.3rem;margin:14px 0 10px}
.card p{font-size:.97rem;color:var(--muted)}
.card .tag{font-family:var(--display);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.card .more{display:inline-block;margin-top:18px;font-weight:600;font-size:.9rem;color:var(--accent)}

/* ---------- klient-strip ---------- */
.clients{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.clients span{border:1px solid var(--line);border-radius:999px;padding:9px 20px;font-size:.9rem;color:var(--muted)}

/* ---------- genre-chips ---------- */
.chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.chips span{background:var(--accent-soft);color:#ABB9FF;border-radius:999px;padding:9px 20px;font-size:.92rem;font-weight:600}

/* ---------- galleri ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:46px}
.g-item{border-radius:var(--radius);overflow:hidden;position:relative}
.g-item img,.g-item video{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .5s ease}
.g-item:hover img{transform:scale(1.04)}
.g-item.tall img{aspect-ratio:3/4}
.g-item figcaption{position:absolute;left:18px;bottom:16px;background:rgba(10,12,18,.65);backdrop-filter:blur(10px);padding:7px 16px;border-radius:999px;font-size:.82rem}

/* ---------- FAQ ---------- */
details{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px 26px;margin-bottom:12px}
summary{font-family:var(--display);font-weight:700;cursor:pointer;font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:1.4rem;color:var(--accent);transition:transform .18s;flex-shrink:0}
details[open] summary::after{transform:rotate(45deg)}
details p{margin-top:12px;color:var(--muted);font-size:.96rem}

/* ---------- kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.contact-direct{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.contact-direct a{display:flex;align-items:center;gap:14px;text-decoration:none;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 22px;font-weight:600;transition:border-color .18s}
.contact-direct a:hover{border-color:var(--accent)}
.contact-direct .ico{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:36px}
label{display:block;font-weight:600;font-size:.88rem;margin:18px 0 7px}
form label:first-of-type{margin-top:0}
input,select,textarea{width:100%;font:inherit;font-size:.96rem;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:var(--bg-soft);color:var(--text)}
input::placeholder,textarea::placeholder{color:#5d6575}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239AA3B5' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
form .btn{width:100%;margin-top:26px}
.form-note{font-size:.83rem;color:var(--muted);margin-top:14px;text-align:center}

/* ---------- CTA-banner ---------- */
.cta-banner{background:linear-gradient(135deg,#1A2240,#10131C);border-top:1px solid var(--line);text-align:center}
.cta-banner h2{max-width:18ch;margin:14px auto 18px}
.cta-banner .lead{margin:0 auto 32px}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);padding:40px 0;font-size:.88rem;color:var(--muted)}
footer.site .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}
footer.site a{color:var(--muted);text-decoration:none}
footer.site a:hover{color:var(--text)}

:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---------- reduceret bevægelse ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .eq span,.scroll-hint{animation:none}
  .reveal,.media-reveal{opacity:1;transform:none;transition:none}
}

/* ---------- responsivt ---------- */
@media (max-width:900px){
  section{padding:80px 0}
  .split,.contact-grid{grid-template-columns:1fr}
  .split.flip .media-side{order:0}
  .cards,.gallery-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:14px}
  nav ul{display:none}
  .menu-btn{display:block}
  nav.open ul{display:flex;flex-direction:column;position:fixed;top:72px;left:0;right:0;background:rgba(10,12,18,.97);backdrop-filter:blur(16px);padding:26px 24px;border-bottom:1px solid var(--line);align-items:flex-start;gap:22px}
  header{background:rgba(10,12,18,.78);backdrop-filter:blur(16px)}
}
