
/* Voryn Landing — Rockstar-inspired, professional */
:root{
  --bg:#0a0a0a; --bg-soft:#101010; --ink:#eaeaea; --muted:#a1a1aa;
  --accent:#f8d23c; --accent-2:#ffd84d; --line:#1e1e1e;
  --maxw:1280px; --radius:18px; --shadow:0 10px 30px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);
     font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
     overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* NAV */
.nav{position:fixed;inset:0 0 auto 0;height:72px;display:flex;align-items:center;z-index:1000;
     transition:transform .35s ease, background .35s ease;backdrop-filter:saturate(120%) blur(6px)}
.nav.bg{background:rgba(0,0,0,.55);border-bottom:1px solid var(--line)}
.nav.hide{transform:translateY(-100%)}
.nav .inner{display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:900;letter-spacing:.5px}
.brand img{height:28px}
.spacer{flex:1}
.nav-links{display:flex;gap:18px}
.btn{padding:.7rem 1rem;border-radius:12px;background:#1c1c1c;border:1px solid #2a2a2a}
.btn.cta{background:var(--accent);color:#000;font-weight:800;border-color:transparent}
.btn.cta:hover{background:var(--accent-2)}

/* HERO */
header.hero{position:relative;min-height:100svh;display:grid;place-items:end center;overflow:hidden}
.hero video.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
               filter:grayscale(.2) contrast(1.1) brightness(.5)}
.hero .overlay{position:absolute;inset:0;
   background:radial-gradient(1200px 600px at 20% 20%, rgba(248,210,60,.18), transparent 50%),
               linear-gradient(180deg, rgba(0,0,0,.4), rgba(0,0,0,.85))}
.hero .content{position:relative;z-index:1;width:100%;padding:120px 0 64px}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.9rem;color:#111;background:var(--accent);
         padding:.4rem .7rem;border-radius:999px;font-weight:900;width:max-content}
h1.title{font-weight:900;font-size:clamp(2.4rem, 6.2vw, 5rem);line-height:1.02;letter-spacing:.3px;margin:10px 0 12px}
.subtitle{font-size:1.15rem;color:var(--muted);max-width:780px}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.btn-lg{background:var(--accent);color:#000;border:none;border-radius:12px;padding:14px 18px;font-weight:800;letter-spacing:.2px;cursor:pointer}
.btn-lg:hover{background:var(--accent-2)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid #2a2a2a;border-radius:12px;padding:14px 18px;font-weight:700}

/* MARQUEE */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#0c0c0c}
.marquee .track{display:flex;gap:48px;white-space:nowrap;overflow:hidden}
.marquee .inner{display:inline-flex;gap:48px;animation:scroll 22s linear infinite;padding:14px 0;color:#cfcfcf}
.tag{display:inline-flex;align-items:center;gap:.5rem}
.dot{width:8px;height:8px;border-radius:999px;background:var(--accent);display:inline-block}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section.section{padding:80px 0}
h2.sec{font-family:Montserrat, sans-serif;margin:0 0 18px 0}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.card{grid-column:span 4;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:24px;
      box-shadow:var(--shadow);transform:translateY(20px);opacity:0;
      transition:transform .6s ease, opacity .6s ease, border-color .2s}
.card.reveal{transform:translateY(0);opacity:1}
.card:hover{border-color:#2a2a2a}
.icon{width:36px;height:36px;display:inline-grid;place-items:center;background:#1c1c1c;border:1px solid #2a2a2a;border-radius:12px;font-size:18px}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.panel{background:linear-gradient(180deg,#0d0d0d,#090909);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:transparent;border:1px dashed #232323;border-radius:12px;padding:18px}
.num{font-weight:900;color:#111;background:var(--accent);display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:10px;margin-bottom:10px}

.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.shot{grid-column:span 4;position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--line)}
.shot img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform .5s ease, filter .5s}
.shot:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent, rgba(0,0,0,.5));opacity:.4;transition:opacity .4s}
.shot:hover img{transform:scale(1.12);filter:grayscale(.1)}
.shot:hover:after{opacity:.6}

/* FORM BAND */
.cta-band{background:linear-gradient(180deg,#0d0d0d,#090909);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band .box{padding:48px 0;display:grid;gap:14px;align-items:center}
.form-wrap{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;align-items:start}
form[name="audit"]{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:0 10px 30px rgba(0,0,0,.45)}
label{display:block;font-weight:700;margin:.25rem 0 .35rem}
input, textarea{width:100%;background:#0f0f10;color:var(--ink);border:1px solid #222;border-radius:10px;padding:12px;font-family:inherit}
textarea{min-height:120px}
.hint{color:#8d8d94;font-size:.95rem}

/* FOOTER */
footer{border-top:1px solid var(--line);background:#0a0a0a}
.foot-wrap{padding:26px 0;display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;color:#9b9b9b}
.foot-links{display:flex;gap:16px}

/* === Reveal on Scroll === */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms ease, transform 700ms ease;
  will-change: opacity, transform;
}

.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* Variantes rápidas por data-attr */
[data-reveal="fade-up"]     { transform: translateY(24px); }
[data-reveal="fade-left"]   { transform: translateX(24px); }
[data-reveal="fade-right"]  { transform: translateX(-24px); }
[data-reveal="zoom-in"]     { transform: scale(.98); }

.reveal.in[data-reveal="fade-left"],
.reveal.in[data-reveal="fade-right"] { transform: translateX(0); }

.reveal.in[data-reveal="zoom-in"] { transform: scale(1); }

/* Stagger opcional por data-delay (ms) */
.reveal[data-delay] { transition-delay: var(--reveal-delay, 0ms); }

/* Espaciado solo para las páginas secundarias */
body.page-secondary {
  padding-top: 90px; /* ajusta según el alto del nav */
}

/* RESPONSIVE */
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.in,
  [data-reveal], [data-reveal].in {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}
@media (max-width: 1024px){
  .card{grid-column:span 6}
  .split{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .gallery .shot{grid-column:span 6}
}
@media (max-width: 640px){
  .card{grid-column:span 12}
  .gallery .shot{grid-column:span 12}
  .nav-links{display:none}
  .form-wrap{grid-template-columns:1fr}
}
