/* ============================================================
   Privion + Omnia · Lean lead-gen page
   ============================================================ */

:root {
  /* Brand */
  --omnia-cyan:#0090d9;
  --omnia-cyan-dark:#006dae;
  --omnia-pale:#e5f4fc;
  --privion-teal:#007a7b;
  --privion-teal-hover:#006566;

  /* Surface + ink */
  --ink:#051c2c;
  --ink-2:#0a2333;
  --ink-3:#163a5c;
  --body:#41546b;
  --body-soft:rgba(255,255,255,.72);
  --line:rgba(13,33,55,.10);
  --line-light:rgba(255,255,255,.12);
  --bg:#ffffff;
  --bg-soft:#f5f7fb;

  /* Hero gradient */
  --hero-grad:radial-gradient(120% 80% at 80% 10%, rgba(0,144,217,.35) 0%, rgba(0,109,174,0) 55%),
              linear-gradient(135deg, #061b2c 0%, #0a2942 55%, #0a2333 100%);
  --form-grad:linear-gradient(135deg, #051c2c 0%, #0a2942 60%, #06283f 100%);

  /* Type */
  --serif:'Fraunces',ui-serif,Georgia,serif;
  --sans:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,sans-serif;

  /* Radii / shadow */
  --r:8px;
  --r-lg:12px;
  --r-xl:16px;
  --shadow:0 8px 32px rgba(5,28,44,.12);
  --shadow-lg:0 30px 80px rgba(5,28,44,.22);
  --tr:.25s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--sans);
  color:var(--body);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; border:0; background:none; color:inherit; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  *,*::before,*::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  video[autoplay] { display:none; }
}

.skip-link {
  position:absolute; left:-9999px; top:12px; z-index:2000;
  padding:12px 20px; background:var(--privion-teal); color:#fff;
  font-weight:700; border-radius:8px;
}
.skip-link:focus { left:12px; }

.visually-hidden {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.container { max-width:1200px; margin:0 auto; padding:0 28px; }

/* ============================================================
   Typography
   ============================================================ */
h1,h2,h3 { font-family:var(--serif); color:var(--ink); line-height:1.08; letter-spacing:-.02em; font-weight:600; text-wrap:balance; }
h1 { font-size:clamp(2.2rem, 4.6vw, 4rem); font-weight:600; }
h1 em { font-style:italic; color:var(--omnia-cyan); font-weight:500; }
h2 { font-size:clamp(1.9rem, 3.6vw, 2.8rem); }
h3 { font-size:1.25rem; line-height:1.25; }
p { line-height:1.7; }

.eyebrow {
  display:inline-block;
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--omnia-cyan-dark);
  margin-bottom:18px;
}
.eyebrow--light { color:#6cd1ff; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--sans); font-weight:700; font-size:.95rem;
  padding:14px 24px; border-radius:10px;
  transition:transform var(--tr), box-shadow var(--tr), background var(--tr), color var(--tr), border-color var(--tr);
  white-space:nowrap; line-height:1;
}
.btn-lg { padding:17px 30px; font-size:1.02rem; }
.btn-block { width:100%; }

.btn-primary {
  background:var(--privion-teal); color:#fff;
  box-shadow:0 6px 24px rgba(0,172,173,.4);
}
.btn-primary:hover { background:var(--privion-teal-hover); transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,172,173,.5); }

.btn-ghost {
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover { background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.45); }

.btn-outline {
  background:transparent; color:var(--ink);
  border:1.5px solid var(--ink);
}
.btn-outline:hover { background:var(--ink); color:#fff; }

.play-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--privion-teal);
  box-shadow:0 0 0 6px rgba(0,172,173,.25);
}

.btn:focus-visible { outline:2px solid var(--privion-teal); outline-offset:3px; }

/* ============================================================
   Nav
   ============================================================ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-row { display:flex; align-items:center; justify-content:space-between; height:72px; gap:20px; }
.nav-brand { display:flex; align-items:center; gap:14px; min-width:0; }
.nav-logo { display:block; height:auto; width:auto; }
.nav-logo--privion { height:30px; }
.nav-logo--omnia { height:26px; }
.nav-x {
  font-size:1.05rem; font-weight:300; color:rgba(5,28,44,.3);
  margin:0 -2px;
}
.nav-tag {
  font-size:.72rem; font-weight:600; letter-spacing:.06em;
  color:var(--body); padding:5px 10px; border-radius:99px;
  background:var(--bg-soft); border:1px solid var(--line);
  margin-left:6px;
}
.nav-actions { display:flex; align-items:center; gap:18px; }
.nav-phone {
  font-weight:600; font-size:.92rem; color:var(--ink);
  letter-spacing:.01em;
}
.nav-phone:hover { color:var(--privion-teal); }

@media (max-width:760px) {
  .nav-row { height:64px; }
  .nav-tag, .nav-phone { display:none; }
  .nav-logo--privion { height:26px; }
  .nav-logo--omnia { height:22px; }
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
  position:relative;
  padding:148px 0 100px;
  color:#fff;
  isolation:isolate;
  overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; z-index:-1;
  background:var(--hero-grad);
}
.hero-bg::after {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(1000px 500px at 90% -10%, rgba(0,144,217,.18), transparent 60%),
    radial-gradient(800px 400px at 0% 100%, rgba(0,172,173,.10), transparent 60%);
}
.hero-row {
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(0, 1fr);
  gap:64px;
  align-items:center;
}
.hero-copy h1 { color:#fff; margin:6px 0 20px; }
.lede {
  color:var(--body-soft);
  font-size:clamp(1.05rem, 1.4vw, 1.2rem);
  max-width:560px;
  margin-bottom:32px;
}
.lede strong { color:#fff; font-weight:700; }
.cta-row {
  display:flex; flex-wrap:wrap; gap:14px;
  margin-bottom:36px;
}
.trust-line {
  list-style:none;
  display:flex; flex-wrap:wrap;
  gap:14px 28px;
  font-size:.86rem; color:var(--body-soft);
}
.trust-line li {
  display:flex; align-items:center; gap:6px;
  position:relative;
}
.trust-line li + li::before {
  content:''; width:4px; height:4px; border-radius:50%;
  background:rgba(255,255,255,.3);
  position:absolute; left:-16px; top:50%; transform:translateY(-50%);
}
.trust-line strong { color:#fff; font-weight:700; }

.hero-visual {
  position:relative;
  aspect-ratio:16/10;
  width:100%;
}
.hero-frame {
  position:absolute; inset:0;
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg), 0 0 0 1px rgba(255,255,255,.06);
  background:#0a2942;
  transform:perspective(1400px) rotateY(-4deg) rotateX(2deg);
}
.hero-poster,
.hero-poster img,
.hero-video {
  width:100%; height:100%; object-fit:cover; object-position:center;
}
.hero-video[hidden] { display:none; }
.hero-poster { display:block; width:100%; height:100%; }
.hero-chip {
  position:absolute;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);
  border-radius:14px;
  padding:14px 18px;
  box-shadow:var(--shadow);
  color:var(--ink);
}
.hero-chip .chip-n { font-family:var(--serif); font-size:1.4rem; font-weight:600; color:var(--omnia-cyan-dark); line-height:1; }
.hero-chip .chip-l { font-size:.72rem; color:var(--body); margin-top:4px; line-height:1.3; }
.hero-chip--1 { left:-22px; top:-22px; }
.hero-chip--2 { right:-22px; bottom:-22px; }

@media (max-width:980px) {
  .hero { padding:120px 0 80px; }
  .hero-row { grid-template-columns:1fr; gap:48px; }
  .hero-frame { transform:none; }
  .hero-chip--1 { left:12px; top:16px; }
  .hero-chip--2 { right:12px; bottom:16px; }
}
@media (max-width:560px) {
  .hero { padding:110px 0 64px; }
  .hero-chip { padding:10px 14px; }
  .hero-chip .chip-n { font-size:1.1rem; }
  .hero-chip .chip-l { font-size:.66rem; }
}

/* ============================================================
   Logo strip
   ============================================================ */
.logos {
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--bg);
}
.logos-inner {
  display:flex; align-items:center; gap:32px;
  padding:28px 0;
  flex-wrap:wrap;
}
.logos-label {
  font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--body);
  flex-shrink:0;
}
.logos-list {
  display:flex; flex-wrap:wrap; gap:8px 28px;
  flex:1;
}
.logos-list span {
  font-family:var(--serif);
  font-size:1.05rem; font-weight:600;
  color:var(--ink-3);
  opacity:.78;
  letter-spacing:-.01em;
}

/* ============================================================
   Section heads
   ============================================================ */
.section-head {
  text-align:center;
  max-width:680px;
  margin:0 auto 56px;
}

/* ============================================================
   Pillars
   ============================================================ */
.pillars { padding:110px 0; background:var(--bg); }
.pillars-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.pillar {
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:0 0 28px;
  overflow:hidden;
  transition:transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}
.pillar:hover {
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:transparent;
}
.pillar-media {
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:4/3;
  background:var(--bg-soft);
  border:0;
  padding:0;
  overflow:hidden;
  cursor:pointer;
  font:inherit;
  color:inherit;
}
.pillar-media video, .pillar-media img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s cubic-bezier(.2,.9,.25,1);
}
.pillar-media:hover video,
.pillar-media:focus-visible video,
.pillar-media:hover img,
.pillar-media:focus-visible img { transform:scale(1.04); }
.pillar-play {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(5,28,44,0) 30%, rgba(5,28,44,.45));
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
}
.pillar-play svg {
  width:64px; height:64px;
  padding:18px;
  border-radius:50%;
  background:rgba(255,255,255,.96);
  color:var(--ink);
  box-shadow:0 8px 24px rgba(0,0,0,.25);
  transform:scale(.92);
  transition:transform .25s ease;
}
.pillar-media:hover .pillar-play,
.pillar-media:focus-visible .pillar-play { opacity:1; }
.pillar-media:hover .pillar-play svg,
.pillar-media:focus-visible .pillar-play svg { transform:scale(1); }
.pillar-media:focus-visible { outline:3px solid var(--privion-teal); outline-offset:-3px; }
.pillar h3 { padding:24px 28px 10px; }
.pillar p { padding:0 28px; font-size:.96rem; color:var(--body); }

@media (max-width:880px) {
  .pillars { padding:80px 0; }
  .pillars-grid { grid-template-columns:1fr; gap:20px; }
}

/* ============================================================
   Proof / ClearBox
   ============================================================ */
.proof { padding:60px 0 110px; background:var(--bg); }
.proof-card {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
  background:linear-gradient(135deg, var(--bg-soft), #ecf3fa);
  border-radius:var(--r-xl);
  padding:48px;
  border:1px solid var(--line);
}
.proof-cover {
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.proof-cover img {
  width:100%; height:auto; aspect-ratio:1200/628;
  object-fit:cover;
}
.proof-text h2 { margin-bottom:18px; }
.proof-text p { margin-bottom:24px; font-size:1rem; }
.proof-text strong { color:var(--ink); }

@media (max-width:880px) {
  .proof { padding:40px 0 80px; }
  .proof-card { grid-template-columns:1fr; gap:32px; padding:32px; }
}

/* ============================================================
   Form / Final CTA
   ============================================================ */
.cta-form {
  position:relative;
  padding:110px 0;
  isolation:isolate;
  color:#fff;
  overflow:hidden;
}
.cta-form-bg {
  position:absolute; inset:0; z-index:-1;
  background:var(--form-grad);
}
.cta-form-bg::after {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(800px 500px at 0% 0%, rgba(0,144,217,.18), transparent 55%),
    radial-gradient(600px 400px at 100% 100%, rgba(0,172,173,.12), transparent 55%);
}

.form-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.form-pitch h2 { color:#fff; margin-bottom:18px; }
.form-pitch p {
  color:var(--body-soft);
  font-size:1.05rem;
  max-width:480px;
  margin-bottom:24px;
}
.form-brands {
  display:flex; align-items:center; gap:14px;
  margin-bottom:24px;
}
.form-logo { width:auto; height:auto; }
.form-logo--privion { height:30px; }
.form-logo--omnia { height:24px; }
.form-brand-x {
  color:rgba(255,255,255,.4); font-weight:300; font-size:1.05rem;
}
.form-promises {
  list-style:none;
  display:flex; flex-direction:column; gap:10px;
}
.form-promises li {
  position:relative;
  padding-left:28px;
  color:var(--body-soft);
  font-size:.95rem;
}
.form-promises li::before {
  content:'';
  position:absolute; left:0; top:8px;
  width:14px; height:8px;
  border-left:2px solid var(--omnia-cyan);
  border-bottom:2px solid var(--omnia-cyan);
  transform:rotate(-45deg);
}

.form-card {
  background:#fff; color:var(--ink);
  border-radius:var(--r-xl);
  padding:36px;
  box-shadow:var(--shadow-lg);
}
.form-card h3 { font-size:1.5rem; }
.form-card-sub { color:var(--body); font-size:.92rem; margin:6px 0 24px; }

.field-row {
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
  margin-bottom:14px;
}
.field { display:block; margin-bottom:14px; }
.field span {
  display:block;
  font-size:.78rem; font-weight:600;
  color:var(--ink-3); margin-bottom:6px;
  letter-spacing:.02em;
}
.field input, .field select {
  width:100%;
  padding:12px 14px;
  border:1.5px solid var(--line);
  border-radius:8px;
  font-family:var(--sans);
  font-size:.95rem;
  color:var(--ink);
  background:var(--bg);
  transition:border-color var(--tr), box-shadow var(--tr);
}
.field input:focus, .field select:focus {
  outline:none;
  border-color:var(--privion-teal);
  box-shadow:0 0 0 3px rgba(0,172,173,.15);
}
.field select {
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%23051c2c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}

.form-card .btn-block { margin-top:8px; }
.form-privacy {
  font-size:.78rem;
  color:var(--body);
  text-align:center;
  margin-top:14px;
}

@media (max-width:880px) {
  .cta-form { padding:80px 0; }
  .form-row { grid-template-columns:1fr; gap:40px; }
}

/* ============================================================
   Footer
   ============================================================ */
.footer {
  background:#020e16;
  color:rgba(255,255,255,.6);
  padding:36px 0;
  font-size:.86rem;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-inner {
  display:flex; flex-wrap:wrap; align-items:center;
  justify-content:space-between; gap:20px;
}
.footer-brand { display:flex; align-items:center; gap:12px; }
.footer-logo { width:auto; height:auto; }
.footer-logo--privion { height:24px; }
.footer-logo--omnia { height:20px; }
.footer-x { color:rgba(255,255,255,.3); font-weight:300; }
.footer-links {
  display:flex; gap:8px 22px; flex-wrap:wrap;
}
.footer-links a:hover { color:#fff; }
.footer-meta { font-size:.78rem; color:rgba(255,255,255,.58); }

@media (max-width:760px) {
  .footer-inner { flex-direction:column; align-items:flex-start; }
}

/* ============================================================
   Video modal
   ============================================================ */
.video-modal {
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  padding:24px;
}
.video-modal[hidden] { display:none; }
.video-modal-backdrop {
  position:absolute; inset:0;
  background:rgba(2,14,22,.85);
  backdrop-filter:blur(8px);
  cursor:pointer;
  opacity:0;
  transition:opacity .3s ease;
}
.video-modal:not([hidden]) .video-modal-backdrop { opacity:1; }
.video-modal-dialog {
  position:relative;
  width:100%;
  max-width:1100px;
  background:#000;
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  transform-origin:center center;
  will-change:transform, opacity;
}
.video-modal-frame { aspect-ratio:16/9; }
.video-modal-frame video { width:100%; height:100%; object-fit:contain; background:#000; }
.video-modal-close {
  position:absolute; top:14px; right:14px; z-index:2;
  width:42px; height:42px;
  border-radius:50%;
  background:rgba(0,0,0,.55);
  color:#fff; font-size:1.6rem; line-height:1;
  display:flex; align-items:center; justify-content:center;
  transition:background var(--tr);
}
.video-modal-close:hover { background:rgba(0,0,0,.85); }

/* ============================================================
   Reveal on scroll
   ============================================================ */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .6s ease, transform .6s ease; }
.reveal.is-visible { opacity:1; transform:none; }
