*{box-sizing:border-box}html{scroll-behavior:smooth}
:root{--bg:#141212;--fg:#f4f4f4;--muted:#c9c9c9;--acc:#ffb347;--maxw:1200px}
body{margin:0;background:var(--bg);color:var(--fg);font:400 18px/1.7 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif}
/* Links with warm glow */
a{color:var(--acc);text-decoration:none}
a:hover{color:var(--acc);text-decoration:none;text-shadow:0 0 6px rgba(255,179,71,.35)}
a:focus-visible{outline:2px solid var(--acc);outline-offset:3px}

.site-header{position:sticky;top:0;display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:14px 20px;background:rgba(20,18,18,.78);backdrop-filter:saturate(130%) blur(8px);border-bottom:1px solid #2a2525;z-index:40}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700;letter-spacing:.3px}
.brand img{height:28px;width:auto;display:block}
nav a{margin-left:16px}

/* HERO */  
.hero{position:relative;isolation:isolate;max-width:var(--maxw);margin:0 auto;padding:0 20px;z-index:0}
.hero-wrap{position:relative;border-radius:16px;overflow:hidden;border:1px solid #2a2525;margin-top:24px;z-index:1;background:#0e0d0d;width:100%;padding-bottom:48.5%;height:0}
.hero-wrap > .bg, .hero-wrap > iframe{position:absolute;top:0;left:0;width:100%;height:100%;display:block;border:0;z-index:0}
.hero-wrap > .bg{object-fit:cover;filter:saturate(1.02) contrast(1.02)}
.hero-wrap > iframe{z-index:6}
/* gradient overlay to protect hero title & caption */
.hero-wrap::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to bottom, rgba(20,18,18,0) 60%, rgba(20,18,18,.55) 100%);z-index:2}
.hero.hero--video .hero-wrap::after{display:none}
/* Subtle atmospheric pulse for hero */
.hero-wrap.pulse{position:relative}
.hero-wrap.pulse::before{content:"";position:absolute;inset:-10%;background:radial-gradient(60% 60% at 50% 50%, rgba(255,179,71,.08), rgba(255,179,71,0) 60%);opacity:.45;filter:blur(22px);animation:heroPulse 6s ease-in-out infinite;pointer-events:none;z-index:-1}
@keyframes heroPulse{0%{transform:scale(1);opacity:.38}50%{transform:scale(1.06);opacity:.55}100%{transform:scale(1);opacity:.38}}

/* Featured video section */
.featured-video iframe{display:block;width:100%;max-width:100%;aspect-ratio:16/9;height:auto;max-height:68vh;border:0}
.hero-caption{position:absolute;right:16px;bottom:16px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);padding:8px 10px;border-radius:10px;font-size:.95rem;border:1px solid #2a2525;z-index:3}
.hero-title{position:relative;z-index:5;display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.hero-title h1{font-size:clamp(28px,4.2vw,52px);line-height:1.15;margin:.3em 0;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.hero-title p{color:var(--muted);margin:0}
@media (max-width:700px){
  .hero-title h1{font-size:clamp(26px,6vw,44px)}
  .hero-caption{font-size:.9rem}
}

/* Play button (subtle, pulsing) */
.play-overlay{position:absolute;inset:0;display:grid;place-items:center;z-index:4;pointer-events:auto}
.play-btn{width:84px;height:84px;border-radius:999px;border:2px solid #fff;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);display:grid;place-items:center;opacity:.92;transition:transform .2s ease, opacity .2s ease, background .2s ease;box-shadow:0 0 0 0 rgba(255,255,255,.18);animation:pulse 2.6s ease-in-out infinite;cursor:pointer}
.play-btn:hover{background:rgba(0,0,0,.55);transform:scale(1.04);opacity:1}
.play-tri{width:0;height:0;border-left:18px solid #fff;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:2px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.18)} 70%{box-shadow:0 0 0 16px rgba(255,255,255,0)} 100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}


/* Sections */
.lead{max-width:var(--maxw);margin:28px auto 0;padding:0 20px}
.lead .text{max-width:72ch}
.section{max-width:var(--maxw);margin:0 auto;padding:52px 20px}
.section.alt{background:#191515;border-top:1px solid #2a2525;border-bottom:1px solid #2a2525}
.section-head{display:flex;justify-content:space-between;align-items:last baseline;gap:1rem;margin-bottom:1rem}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:.5rem}
.filters button{background:#161212;border:1px solid #2d2828;color:var(--fg);padding:.45em .8em;border-radius:999px;cursor:pointer;transition:transform .08s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease}
.filters button:hover{transform:translateY(-1px);border-color:var(--acc);box-shadow:0 0 0 2px rgba(255,179,71,.15),0 0 22px rgba(255,179,71,.22)}
.filters button[aria-pressed="true"]{background:var(--acc);color:#0f0f0f;border-color:var(--acc);box-shadow:0 0 0 2px rgba(255,179,71,.18),0 0 26px rgba(255,179,71,.28)}

/* Project cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.card{background:#171313;border:1px solid #2a2525;border-radius:14px;overflow:hidden;transform:translateY(8px) scale(.996);opacity:0;transition:transform .5s cubic-bezier(.2,.6,.2,1), opacity .5s ease, border-color .2s ease, box-shadow .2s ease}
.card.appear{transform:translateY(0) scale(1);opacity:1}
.card:hover{transform:translateY(-3px) scale(1.012);border-color:#3a312f;box-shadow:0 6px 28px rgba(0,0,0,.35),0 0 28px rgba(255,179,71,.14)}
.card figure{margin:0;position:relative}
.card img{display:block;width:100%;height:200px;object-fit:cover;filter:saturate(1.02)}
.card-body{padding:14px}
.card-body h3{margin:.2em 0}
.card-body p { color: var(--fg); }
.card a:focus-visible{outline:2px solid var(--acc);outline-offset:4px;border-radius:10px}
.card .logos{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap}
.card .logos img{height:18px;width:auto;opacity:.85;filter:grayscale(1) contrast(1.05);}
.card .logos img:hover{opacity:1}
.muted{color:var(--muted)}

/* Dialog / case study */
dialog::backdrop{background:rgba(0,0,0,.6)}
dialog{border:none;border-radius:14px;padding:0;max-width:min(980px,92vw)}
.project-detail{background:#171313;border:1px solid #2a2525;border-radius:14px;overflow:hidden;animation:pop .14s ease}
@keyframes pop{from{transform:translateY(8px);opacity:.7}to{transform:none;opacity:1}}
.project-detail header{padding:18px 20px;border-bottom:1px solid #2a2525;display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.project-detail .poetic{padding:0 20px 6px;font-style:italic;color:#e7e7e7}
.detail-figure{position:relative}
.detail-figure iframe,
.detail-figure video{display:block;width:100%;max-width:100%;aspect-ratio:16/9;height:auto;max-height:70vh}
.detail-figure iframe[src*="soundcloud.com"]{aspect-ratio:auto;height:120px;max-height:120px}
.detail-figure img{display:block;width:100%;height:auto}.case-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;padding:12px 20px 4px}
.case-cols h4{margin:.4em 0; color: var(--acc);}
.case-cols p, .case-cols ul{margin:.2em 0 1em}
.case-cols ol li .ts{font-size:.85em;color:var(--acc);margin-left:.3em}
.case-cols ol li .ts:hover{text-shadow:0 0 6px rgba(255,179,71,.35)}
.project-detail,
.project-detail p,
.project-detail li,
.case-cols p,
.case-cols ul,
.case-cols li,
.specs dd { color: var(--fg); }
.specs{padding:0 20px 18px;border-top:1px solid #2a2525;margin-top:6px}
.specs dl{display:grid;grid-template-columns:max-content 1fr;gap:.4rem .8rem;margin:0}
.specs dt{color:var(--acc)}
.supporters{padding:0 20px 20px;display:flex;flex-wrap:wrap;gap:.6rem}
.supporters .chip{border:1px solid #2f2929;border-radius:10px;padding:6px 10px;background:#191515}
.supporters .logos{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:6px}
.supporters .logos img{height:22px;width:auto;opacity:.9;filter:grayscale(1) contrast(1.05);}
.supporters .logos img:hover{opacity:1}
.copy-placeholder{padding:0 20px 12px;color:#d0d0d0;font-style:italic}

.site-footer{max-width:var(--maxw);margin:0 auto;padding:30px 20px;color:var(--muted);border-top:1px solid #2a2525}

/* About layout */
.about-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:1.4rem;align-items:start}
.about-photo{border:1px solid #2a2525;border-radius:14px;overflow:hidden;background:#0e0d0d}
.about-photo img{display:block;width:100%;height:auto}
.about-text h2{margin-top:0}
.about-text p{margin:.4em 0 1em}
@media (max-width:900px){.about-wrap{grid-template-columns:1fr}}

/* CV layout */
.cv{max-width:var(--maxw);margin:0 auto;padding:52px 20px}
.cv h3{margin-top:1.2em;color:var(--acc)}
.cv .cols{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.cv ul{list-style:none;padding-left:0;margin:.4em 0}
.cv li{margin:.25em 0}
.cv .label{color:var(--muted)}
@media (max-width:900px){.cv .cols{grid-template-columns:1fr}}

/* CTA */
.cta{display:inline-block;margin-top:.3rem;border:1px solid rgba(255,179,71,.4);padding:.4em .7em;border-radius:10px}
.cta:hover{box-shadow:0 0 0 2px rgba(255,179,71,.15),0 0 22px rgba(255,179,71,.22)}


#emailLink {
  display: inline-block;
  border: 1px solid rgba(255, 179, 71, 0.4);
  padding: 0.3em 0.7em;
  border-radius: 8px;
  transition: background 0.2s ease;
}
#emailLink:hover {
  background: rgba(255, 179, 71, 0.1);
}