:root{
  --bg:#0d0a09; --panel:#151110; --ink:#f4f2f1; --muted:#b9b2ad;
  --accent:#ff3b30; --accent2:#ff8a00; --line:rgba(255,255,255,.12);
  --r:16px; --shadow:0 16px 50px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%; background:var(--bg); color:var(--ink)}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; line-height:1.6; overflow-x:hidden}

/* Orbs add fullness */
.orb{position:fixed; filter:blur(60px); opacity:.45; pointer-events:none; z-index:0}
.orb-a{width:380px;height:380px;left:-120px;top:120px;background:radial-gradient(circle at 30% 30%, rgba(255,138,0,.6), transparent 60%)}
.orb-b{width:420px;height:420px;right:-160px;top:40px;background:radial-gradient(circle at 70% 40%, rgba(255,59,48,.6), transparent 60%)}
.orb-c{width:360px;height:360px;right:-80px;bottom:-120px;background:radial-gradient(circle at 50% 60%, rgba(255,120,40,.5), transparent 60%)}

/* Top bar */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(13,10,9,.65); backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line);
}
.topbar__wrap{
  max-width:1160px; margin:0 auto; padding:10px 16px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.brand{display:flex; align-items:center; gap:10px}
.pfp{
  width:34px; height:34px; border-radius:10px; object-fit:cover;
  box-shadow: 0 0 16px rgba(255,120,40,.35);
  border:1px solid var(--line);
}
.brand__name{font-family:Sora,Inter,sans-serif; font-weight:800; letter-spacing:.14em; font-size:12px; color:var(--muted)}
.topnav{display:flex; gap:8px; flex-wrap:wrap}
.navbtn{all:unset; cursor:pointer; color:var(--muted); padding:8px 12px; border-radius:10px; border:1px solid transparent;}
.navbtn:hover,.navbtn.active{background:rgba(255,255,255,.06); color:#fff; border-color:var(--line)}

/* Splash */
.splash{
  position:fixed; inset:0; z-index:9999; display:grid; place-items:center;
  background: radial-gradient(1200px 700px at 15% -10%, rgba(255,59,48,.18), transparent 60%),
              radial-gradient(1000px 700px at 110% -10%, rgba(255,138,0,.20), transparent 60%),
              var(--bg);
  transition: opacity .7s ease, visibility .7s ease;
  opacity:1; visibility:visible;
}
.splash.hide{opacity:0; visibility:hidden; pointer-events:none}
.splash-inner{ width:min(80vw,820px); text-align:center; filter: drop-shadow(0 10px 30px rgba(255,90,32,.25)); }
.splash-logo-img{ width:min(90vw,800px); height:auto; object-fit:contain; animation: pop .9s ease both; }
@keyframes pop{ 0%{transform:scale(.92);opacity:0} 70%{transform:scale(1.04);opacity:1} 100%{transform:scale(1)} }
@media (prefers-reduced-motion: reduce){ .splash, .splash *{ animation:none !important; transition:none !important } }

/* Page fade after splash */
.page{ opacity:0; transition:opacity .8s ease; position:relative; z-index:0; }
.page.show{ opacity:1; }

/* Sections */
main{isolation:isolate}
section{padding:56px 24px; border-bottom:1px solid var(--line)}
.wrap{max-width:1160px; margin:0 auto}
.h{font-family:Sora,Inter,sans-serif; font-weight:800; font-size:28px; margin:0 0 10px; position:relative; display:inline-block}
.h::after{content:""; position:absolute; left:0; bottom:-6px; height:3px; width:52%; border-radius:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent2)); transform:scaleX(.4); transform-origin:left; transition:.6s}
.reveal .h::after{transform:scaleX(1)}
.lead{color:var(--muted); max-width:780px}

/* Hero + rotated vertical video (fixed orientation) */
.hero-section{position:relative;}
.hero{display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; align-items:center; padding-top:28px}
.hero-left{position:relative; isolation:isolate;}
.hero-video-bg{
  position:absolute; inset:-12px -12px -12px -12px; z-index:-1; overflow:hidden; border-radius:16px;
  border:1px solid var(--line);
}
.hero-video-frame{
  position:absolute; top:50%; left:50%;
  transform: translate(-50%,-50%) rotate(-90deg);
  width:140vh; height:140vw;
}
.hero-video-frame iframe{
  width:100%; height:100%; border:0; display:block; filter:brightness(.6) saturate(1.05);
  pointer-events:none;
}
.hero-video-scrim{
  position:absolute; inset:0;
  background:radial-gradient(120% 100% at 0% 0%, rgba(255,120,40,.18), transparent 60%),
             linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55));
}

.title{font-family:Sora,Inter,sans-serif; font-weight:800; line-height:1.05; font-size:clamp(34px,6vw,64px); margin:6px 0 10px}
.grad{background:linear-gradient(90deg,var(--accent),var(--accent2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.pills{display:flex; gap:10px; flex-wrap:wrap}
.pill{border:1px solid var(--line); padding:6px 10px; border-radius:999px; color:var(--muted); backdrop-filter: blur(6px); background:rgba(255,255,255,.04)}
.cta{display:flex; gap:12px; margin-top:12px; flex-wrap:wrap}
.btn{position:relative; overflow:hidden; text-decoration:none; color:#101; font-weight:800; border-radius:12px; padding:12px 16px; border:1px solid var(--line); background:rgba(255,255,255,.06)}
.btn.primary{border:none; color:#1b100e; background:linear-gradient(135deg,var(--accent),var(--accent2)); box-shadow:0 14px 36px rgba(255,120,40,.22)}
.btn.white{color:#fff; border-color:var(--line); background:rgba(255,255,255,.10)}
.btn:hover{filter:brightness(1.02)}
.magnet{transition: transform .12s ease}
.btn .rip{position:absolute; inset:auto auto 0 0; width:12px; height:12px; border-radius:50%; background:rgba(255,255,255,.6); transform:translate(-50%,-50%); animation:r .5s ease-out forwards}
@keyframes r{to{opacity:0; transform:translate(-50%,-50%) scale(18)}}

.poster{aspect-ratio: 4/5; border-radius:18px; overflow:hidden; border:1px solid var(--line); background:#120e0c; position:relative; box-shadow:var(--shadow);}
.poster img{width:100%; height:100%; object-fit:cover; filter:contrast(1.05) saturate(1.05)}
.poster::after{content:""; position:absolute; inset:0; background:radial-gradient(100% 80% at 0% 0%, rgba(255,120,40,.16), transparent 60%)}

.ticker{margin-top:14px; border:1px solid var(--line); border-radius:12px; overflow:hidden; background:rgba(255,255,255,.04)}
.marq{display:flex; gap:28px; padding:10px 14px; white-space:nowrap; animation:slide 22s linear infinite}
.marq span{color:var(--muted); font-size:14px; letter-spacing:.06em}
@keyframes slide{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* Tools row */
.tools{border:1px solid var(--line); border-radius:14px; overflow:hidden; background:rgba(255,255,255,.04)}
.tools-row{display:flex; gap:20px; padding:12px 16px; white-space:nowrap; animation:slide 26s linear infinite}
.tool{border:1px solid var(--line); padding:6px 10px; border-radius:999px; color:var(--muted); backdrop-filter: blur(6px); background:rgba(255,255,255,.04); font-size:14px}

/* Gallery */
.carousel{margin-top:16px; border:1px solid var(--line); border-radius:16px; background:#120e0c; overflow:auto;
  scroll-snap-type:x mandatory; display:flex; gap:10px; padding:10px}
.cap{flex:0 0 auto; width:min(86vw,520px); aspect-ratio:16/9; scroll-snap-align:center; position:relative; border-radius:12px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); cursor:zoom-in}
.cap img{width:100%; height:100%; object-fit:cover}
.cap::after{content:""; position:absolute; inset:0; background:radial-gradient(120% 120% at 0% 0%, rgba(255,120,40,.18), transparent 60%)}

/* Services grid */
.grid{display:grid; gap:16px; grid-template-columns:repeat(12,1fr); margin-top:16px}
.card{grid-column:span 6; padding:18px; border-radius:16px; border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03)); box-shadow:var(--shadow);
  transform-style:preserve-3d; transition:transform .18s ease, box-shadow .18s ease, border .18s ease; position:relative}
.card:hover{box-shadow:0 20px 60px rgba(0,0,0,.55); border-color:rgba(255,255,255,.18)}
.shine{position:absolute; inset:0; border-radius:inherit; pointer-events:none; mix-blend-mode:screen; opacity:0;
  background:radial-gradient(420px 260px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.22), transparent 60%); transition:.2s}
.card:hover .shine{opacity:.9}
.ico{width:38px; height:38px; display:grid; place-items:center; border-radius:10px; margin-bottom:8px;
  background:radial-gradient(120% 120% at 10% 0%, rgba(255,59,48,.7), rgba(255,138,0,.6)); box-shadow:0 10px 22px rgba(255,120,40,.22)}
.card h3{margin:6px 0 6px; font-weight:800}
.card p{margin:0; color:var(--muted)}
@media (max-width:860px){.card{grid-column:span 12}}

/* Banner fill */
.banner{
  margin-top:14px; border:1px solid var(--line); border-radius:14px; padding:18px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  background:rgba(255,255,255,.03)
}
.banner p{margin:0}
@media (max-width:720px){ .banner{flex-direction:column; align-items:flex-start} }

/* Contact */
#contact .form{display:grid; grid-template-columns:1fr 1fr; gap:12px}
#contact .form input, #contact .form textarea{background:var(--panel); color:var(--ink); border:1px solid var(--line); border-radius:12px; padding:12px 12px; width:100%;}
#contact .form textarea{grid-column:1/-1; resize:vertical; min-height:120px}
#contact .form button{justify-self:start}
.note{color:var(--muted); font-size:.95rem}

/* Footer */
.footer{padding:26px 0; border-top:1px solid var(--line); color:var(--muted)}
.footgrid{display:grid; grid-template-columns:1fr auto auto; gap:18px; align-items:center}
.socials{display:flex; gap:12px}
.socials a{border:1px solid var(--line); padding:8px 10px; border-radius:12px; color:var(--ink); background:rgba(255,255,255,.05)}

/* Toast */
.toast{position:fixed; left:50%; bottom:22px; transform:translateX(-50%); background:linear-gradient(135deg,var(--accent),var(--accent2)); color:#1b100e; padding:10px 14px; border-radius:12px; box-shadow:0 10px 26px rgba(0,0,0,.35); display:none; z-index:80}
.toast.show{display:block; animation:fade 2.5s ease both}
@keyframes fade{0%{opacity:0; transform:translate(-50%,10px)} 10%,90%{opacity:1; transform:translate(-50%,0)} 100%{opacity:0; transform:translate(-50%,10px)}}

/* Lightbox */
.light{position:fixed; inset:0; display:none; place-items:center; background:rgba(0,0,0,.75); z-index:60}
.light.open{display:grid; animation:f .2s ease both}
@keyframes f{from{opacity:0} to{opacity:1}}
.light img{max-width:92vw; max-height:86vh; border-radius:16px; border:1px solid var(--line); box-shadow:var(--shadow)}
.x{position:absolute; top:14px; right:14px; padding:6px 10px; border-radius:10px; border:1px solid var(--line); background:rgba(255,255,255,.08); cursor:pointer}

/* Reveal */
.reveal-item{transform:translateY(16px); opacity:0; transition:.6s ease}
.reveal .reveal-item{transform:none; opacity:1}

/* Responsive */
@media (max-width:960px){
  .hero{grid-template-columns:1fr;}
  .poster{order:-1}
  #contact .form{grid-template-columns:1fr}
}
