:root{
  --bg:#0a0c12;
  --bg-2:#0f1219;
  --bg-3:#161a24;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.14);
  --ink:#f4f3ee;
  --ink-2:#c9c8c1;
  --ink-3:#7e7d75;
  --accent:#7c5cff;
  --accent-2:#a190ff;
  --accent-soft:rgba(124,92,255,0.12);
  --serif:'Instrument Serif', 'Times New Roman', serif;
  --sans:'Geist', system-ui, -apple-system, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--accent);color:#fff}

/* ---- background atmosphere ---- */
.atmosphere{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(700px 500px at 80% -10%, rgba(124,92,255,0.18), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(124,92,255,0.07), transparent 70%);
}
.grid-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0.35;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 50% 0%, black 30%, transparent 75%);
}
main{position:relative;z-index:1}

/* ---- nav ---- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 32px;
  transition:background .3s ease, backdrop-filter .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,12,18,0.7);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;letter-spacing:0.02em}
.brand-mark{
  width:30px;height:30px;border-radius:50%;overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow:0 6px 18px -6px rgba(124,92,255,0.4);
}
.brand-mark img{width:100%;height:100%;object-fit:cover;display:block}
.nav-links{display:flex;align-items:center;gap:28px;font-size:13.5px;color:var(--ink-2)}
.nav-links a{transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  font-family:var(--sans);font-size:13px;font-weight:500;
  padding:9px 16px;border-radius:999px;
  background:var(--ink);color:#0a0c12;
  transition:transform .15s ease, background .2s;
}
.nav-cta:hover{background:var(--accent);color:#fff}
@media (max-width:760px){
  .nav-links{display:none}
  .nav{padding:16px 20px}
}

/* ---- shared ---- */
.section{padding:120px 32px;position:relative}
.wrap{max-width:var(--maxw);margin:0 auto}
.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent-2);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
.section-title{
  font-family:var(--serif);font-weight:400;font-size:clamp(40px,5.5vw,72px);
  line-height:1.02;letter-spacing:-0.02em;margin-top:18px;
}
.section-title em{font-style:italic;color:var(--accent-2)}
.section-lede{
  margin-top:22px;font-size:18px;color:var(--ink-2);max-width:600px;line-height:1.55;
}

/* ---- HERO ---- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:140px 32px 80px;position:relative;
}
.hero-stack{
  max-width:var(--maxw);margin:0 auto;width:100%;
  display:flex;flex-direction:column;align-items:flex-start;
}
.hero-intro{
  margin-top:36px;
  display:flex;align-items:center;gap:28px;
  max-width:780px;
}
.intro-portrait{display:flex;align-items:center;gap:14px;flex-shrink:0}
.intro-portrait .portrait-frame{width:72px;aspect-ratio:1/1;border-radius:50%}
.intro-portrait .portrait-frame::after{border-radius:50%;inset:-4px}
.intro-portrait .portrait-tag{
  background:transparent;border:0;padding:0;text-align:left;
  font-family:var(--mono);font-size:11px;letter-spacing:0.04em;color:var(--ink-3);
  display:flex;flex-direction:column;gap:2px;
}
.intro-portrait .portrait-tag .name{color:var(--ink);font-size:13px;letter-spacing:0;font-family:var(--sans);font-weight:500}
@media (max-width:680px){
  .hero-intro{flex-direction:column;align-items:flex-start;gap:20px}
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:0.1em;
  padding:7px 14px;border:1px solid var(--line-2);border-radius:999px;
  color:var(--ink-2);background:rgba(255,255,255,0.02);
}
.dot{width:6px;height:6px;border-radius:50%;background:#3ecf8e;box-shadow:0 0 8px #3ecf8e}
.hero-h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(40px,5.6vw,76px);
  line-height:1.02;letter-spacing:-0.02em;
  margin-top:28px;max-width:920px;
}
.hero-h1 em{font-style:italic;color:var(--accent-2)}
.hero-sub{
  font-size:17px;line-height:1.6;color:var(--ink-2);margin:0;
}
.hero-cta-row{
  margin-top:36px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;
}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14.5px;font-weight:500;padding:14px 22px;border-radius:999px;
  transition:transform .15s ease, background .2s, border-color .2s, color .2s;
  cursor:pointer;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(255,255,255,0.03)}
.btn-arrow{
  display:inline-block;width:14px;height:14px;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12h14m-6-6 6 6-6 6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat center / contain;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12h14m-6-6 6 6-6 6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat center / contain;
}

.hero-meta{
  margin-top:56px;display:flex;flex-wrap:wrap;gap:48px;
  padding-top:28px;border-top:1px solid var(--line);width:100%;max-width:640px;
}
.meta-item .n{font-family:var(--serif);font-size:36px;line-height:1;color:var(--ink)}
.meta-item .n em{font-style:italic;color:var(--accent-2)}
.meta-item .l{margin-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3)}

/* portrait */
.portrait{
  position:relative;justify-self:end;
}
.portrait-frame{
  position:relative;width:200px;max-width:100%;aspect-ratio:198/226;
  border-radius:10px;overflow:hidden;
  background:linear-gradient(160deg,#1a1d28,#0f1219);
  border:1px solid var(--line-2);
}
.portrait-frame img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center;
  filter:contrast(1.05) saturate(0.92);
}
.portrait{display:flex;flex-direction:column;align-items:flex-end;gap:18px}
.portrait-frame::after{
  content:"";position:absolute;inset:-5px;border-radius:12px;
  border:1px solid var(--accent);opacity:0.35;pointer-events:none;
}
.portrait-tag{
  background:var(--bg-2);border:1px solid var(--line-2);
  padding:10px 14px;border-radius:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.05em;color:var(--ink-2);
  display:flex;flex-direction:column;gap:4px;text-align:right;
}
.portrait-tag .name{color:var(--ink);font-size:13px;letter-spacing:0}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .portrait{justify-self:start;flex-direction:row;align-items:center}
  .portrait-tag{text-align:left}
  .portrait-frame{width:150px}
}

/* ---- SERVICES ---- */
.services{background:linear-gradient(180deg,transparent,rgba(255,255,255,0.012) 50%,transparent)}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px;margin-bottom:60px}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.svc{
  background:var(--bg);padding:36px 32px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;transition:background .25s ease;
  min-height:280px;
}
.svc:hover{background:var(--bg-2)}
.svc-num{font-family:var(--mono);font-size:11px;letter-spacing:0.15em;color:var(--ink-3)}
.svc-title{font-family:var(--serif);font-size:28px;line-height:1.05;letter-spacing:-0.01em}
.svc-desc{color:var(--ink-2);font-size:14.5px;line-height:1.6;flex:1}
.svc-tag{
  font-family:var(--mono);font-size:11px;letter-spacing:0.08em;
  color:var(--accent-2);text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
}
.svc-tag::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent)}
@media (max-width:920px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:600px){
  .services-grid{grid-template-columns:1fr}
}

/* ---- TIMELINE ---- */
.timeline{position:relative}
.tl-head{margin-bottom:80px;max-width:680px}
.tl-stage{
  position:relative;
}
.tl-axis{
  position:absolute;left:140px;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,var(--line-2) 8%,var(--line-2) 92%,transparent);
}
.tl-row{
  display:grid;grid-template-columns:120px 1fr;gap:60px;align-items:flex-start;
  padding:36px 0;
  position:relative;
}
.tl-row + .tl-row{border-top:1px dashed var(--line)}
.tl-year{
  font-family:var(--serif);font-size:32px;line-height:1;color:var(--ink-3);
  letter-spacing:-0.01em;padding-top:6px;
  transition:color .25s;
  font-feature-settings:"tnum";
}
.tl-row:hover .tl-year{color:var(--accent-2)}
.tl-row::before{
  content:"";position:absolute;left:138px;top:50px;width:9px;height:9px;border-radius:50%;
  background:var(--bg);border:1px solid var(--line-2);
  transition:background .25s, border-color .25s, box-shadow .25s;
}
.tl-row:hover::before{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.tl-content{padding-left:40px}
.tl-role{font-family:var(--serif);font-size:26px;line-height:1.15;letter-spacing:-0.01em}
.tl-role em{font-style:italic;color:var(--ink-2)}
.tl-company{
  margin-top:6px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;letter-spacing:0.06em;color:var(--ink-3);text-transform:uppercase;
}
.tl-company .sep{opacity:0.6}
.tl-desc{margin-top:14px;color:var(--ink-2);font-size:15px;line-height:1.6;max-width:680px}
.tl-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}
.tl-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;
  padding:4px 9px;border:1px solid var(--line);border-radius:4px;color:var(--ink-3);
}
@media (max-width:760px){
  .tl-axis{left:60px}
  .tl-row{grid-template-columns:60px 1fr;gap:20px}
  .tl-row::before{left:58px;top:46px}
  .tl-content{padding-left:20px}
  .tl-year{font-size:22px;padding-top:8px}
  .tl-role{font-size:22px}
}

/* ---- MEDIA ---- */
.media-head{margin-bottom:60px;max-width:680px}
.media-feature{
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;
  margin-bottom:60px;align-items:center;
}
.video-card{
  position:relative;border-radius:10px;overflow:hidden;
  border:1px solid var(--line-2);
  background:var(--bg-2);
  cursor:pointer;
  transition:transform .25s ease, border-color .25s;
}
.video-card:hover{border-color:var(--accent)}
.video-card .thumb{
  position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg-3);
}
.video-card .thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease, filter .25s;
}
.video-card:hover .thumb img{transform:scale(1.04);filter:brightness(0.85)}
.video-card .play{
  position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;
}
.play-btn{
  width:64px;height:64px;border-radius:50%;
  background:rgba(10,12,18,0.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.25);
  display:grid;place-items:center;color:#fff;
  transition:background .25s, transform .25s;
}
.video-card:hover .play-btn{background:var(--accent);transform:scale(1.06);border-color:var(--accent)}
.play-btn svg{width:22px;height:22px;margin-left:3px}
.video-meta{padding:22px}
.video-stat{
  font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:var(--accent-2);text-transform:uppercase;
}
.video-title{
  font-family:var(--serif);font-size:26px;line-height:1.15;letter-spacing:-0.01em;margin-top:10px;
}
.video-sub{margin-top:8px;font-size:14px;color:var(--ink-3)}
.feature-side .video-stat{font-size:12px}
.feature-side .video-title{font-size:36px;line-height:1.1;margin-top:14px}
.feature-side .video-sub{font-size:15px;color:var(--ink-2);margin-top:14px;line-height:1.55;max-width:440px}
.feature-side .btn{margin-top:24px}

.media-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:920px){
  .media-feature{grid-template-columns:1fr;gap:32px}
  .media-grid{grid-template-columns:1fr}
}

/* ---- ABOUT ---- */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
}
.about-head .section-title{font-size:clamp(36px,4.8vw,60px)}
.about-body{font-size:17px;line-height:1.7;color:var(--ink-2);display:flex;flex-direction:column;gap:18px}
.about-body p:first-child::first-letter{
  font-family:var(--serif);font-size:64px;line-height:1;float:left;padding:6px 14px 0 0;color:var(--accent-2);
}
.about-meta-grid{
  margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:16px;
  border-top:1px solid var(--line);padding-top:32px;
}
.am{}
.am-l{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3)}
.am-v{margin-top:6px;font-size:15px;color:var(--ink)}
.am-v a:hover{color:var(--accent-2)}
@media (max-width:920px){
  .about-grid{grid-template-columns:1fr;gap:40px}
}

/* ---- CONTACT ---- */
.contact{
  border-top:1px solid var(--line);
  background:linear-gradient(180deg,transparent, rgba(124,92,255,0.04));
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
}
.contact-title{
  font-family:var(--serif);font-size:clamp(48px,7vw,96px);line-height:0.98;letter-spacing:-0.02em;
}
.contact-title em{font-style:italic;color:var(--accent-2)}
.contact-lede{margin-top:24px;color:var(--ink-2);font-size:17px;line-height:1.6;max-width:480px}
.contact-channels{margin-top:36px;display:flex;flex-direction:column;gap:14px}
.channel{
  display:flex;align-items:center;gap:14px;
  padding:18px 20px;border:1px solid var(--line);border-radius:8px;
  transition:border-color .2s, background .2s;
}
.channel:hover{border-color:var(--accent);background:rgba(124,92,255,0.04)}
.channel-icon{
  width:36px;height:36px;border-radius:8px;background:var(--bg-3);
  display:grid;place-items:center;color:var(--accent-2);
}
.channel-icon svg{width:18px;height:18px}
.channel-text{display:flex;flex-direction:column;gap:2px}
.channel-l{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3)}
.channel-v{font-size:15px}

.contact-form{
  background:var(--bg-2);
  border:1px solid var(--line-2);border-radius:12px;
  padding:32px;
}
.form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.form-row label{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3)}
.form-row input, .form-row textarea, .form-row select{
  background:transparent;border:0;border-bottom:1px solid var(--line-2);
  padding:10px 0;color:var(--ink);font-family:var(--sans);font-size:15px;
  transition:border-color .2s;
}
.form-row textarea{resize:vertical;min-height:90px;font-family:var(--sans)}
.form-row select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'><path d='m6 9 6 6 6-6' stroke='%237e7d75' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 0 center;padding-right:20px}
.form-row select option{background:var(--bg-2);color:var(--ink)}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus{outline:0;border-color:var(--accent)}
.form-row input::placeholder, .form-row textarea::placeholder{color:var(--ink-3)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-submit{width:100%;justify-content:center;margin-top:8px}
.form-success{
  padding:24px;border:1px solid var(--accent);border-radius:8px;background:var(--accent-soft);
  font-size:15px;color:var(--ink);
}
@media (max-width:920px){
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .form-grid-2{grid-template-columns:1fr;gap:18px}
}

/* ---- FOOTER ---- */
footer{
  border-top:1px solid var(--line);
  padding:36px 32px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:0.08em;color:var(--ink-3);
  text-transform:uppercase;
}
footer a:hover{color:var(--ink-2)}

/* ---- video modal ---- */
.modal-bg{
  position:fixed;inset:0;z-index:100;
  background:rgba(5,7,11,0.85);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:grid;place-items:center;padding:32px;
  animation:fadein .25s ease;
}
.modal-inner{
  width:min(1000px,100%);aspect-ratio:16/9;
  border-radius:10px;overflow:hidden;background:#000;
  position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,0.6);
}
.modal-inner iframe{width:100%;height:100%;border:0}
.modal-close{
  position:absolute;top:-44px;right:0;color:var(--ink);font-family:var(--mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.modal-close:hover{color:var(--accent-2)}
@keyframes fadein{from{opacity:0}to{opacity:1}}

/* ---- tiny reveal animation ---- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* a11y */
:focus-visible{outline:2px solid var(--accent-2);outline-offset:3px;border-radius:4px}
