/* ===== Fonts ===== */
@font-face { font-family: "BrunoAce"; src: url("content/BrunoAce-Regular.ttf") format("truetype"); font-display: swap; }
@font-face { font-family: "CodecProNews"; src: url("content/codec-pro-news.ttf") format("truetype"); font-display: swap; }

/* ===== Reset/Base ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body { margin: 0; background: #000; }
img { display: block; max-width: 100%; }
[hidden]{ display: none !important; }

:root{
  --text: #eaeaee;
  --muted: #b9bbc4;
  --card: #ffffff;
  --blue: #2b6ad0;
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.25);
  --blur: 8px;
}

body{
  font-family: "CodecProNews", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  min-height: 100dvh;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

/* ===== Video background ===== */
.bg{ position: fixed; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.bg-video{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; filter: saturate(0.95); }
.bg-dim{ position: absolute; inset: 0; background: rgba(0,0,0,.42); }

/* ===== Header ===== */
.site-header{
  position: fixed; top: 0; left: 0; right: 0;
  height: 64px; display: flex; align-items: center;
  background: transparent; z-index: 50;
  pointer-events: none;
}
.hamburger{
  pointer-events: auto;
  margin-left: 12px;
  width: 46px; height: 46px;
  border: none; background: transparent; cursor: pointer;
  display: grid; place-items: center;
}
.hamburger span{ width: 24px; height: 2px; background: var(--text); display: block; border-radius: 2px; transition: transform .25s ease, opacity .25s ease; }
.hamburger span:nth-child(2){ margin: 6px 0; }

/* ===== Overlay ===== */
.overlay{ position: fixed; inset: 0; z-index: 40; background: rgba(0,0,0,.35); backdrop-filter: blur(var(--blur)); }

/* ===== Menu (LEFT slide on desktop, TOP drop on mobile) ===== */
.menu-panel{
  position: fixed; top: 0; bottom: 0; left: 0;
  width: min(25vw, 420px);
  transform: translateX(-100%);
  transition: transform .35s ease;
  z-index: 60;
  background: rgba(18,20,25,.8);
  backdrop-filter: blur(var(--blur));
  border-right: 1px solid rgba(255,255,255,.08);
}
.menu-open .menu-panel{ transform: none; }
.menu-inner{ height: 100%; display:flex; flex-direction: column; padding: 18px; }
.menu-top{ position: relative; display:flex; align-items:center; justify-content:center; padding-right: 56px; min-height: 56px; }
.menu-logo{ height: 42px; width: auto; filter: drop-shadow(0 2px 8px rgba(0,0,0,.45)); }
.menu-close{
  position: absolute; right: 10px; top: 9px;
  width: 38px; height: 38px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  cursor: pointer; transition: transform .18s ease, background .18s ease;
}
.menu-close:active{ transform: scale(.92) rotate(90deg); }
.menu-close .close-line{ position: absolute; left: 50%; top: 50%; width: 18px; height: 2px; background: #fff; border-radius: 2px; }
.menu-close .close-line:first-child{ transform: translate(-50%,-50%) rotate(45deg); }
.menu-close .close-line:last-child{ transform: translate(-50%,-50%) rotate(-45deg); }
.menu-nav{ display: grid; gap: 10px; padding: 18px 6px; }
.menu-link{
  color: #fff; text-decoration: none; font-size: 18px;
  padding: 10px 12px; border-radius: 12px;
  transition: background .2s ease, transform .2s ease;
  font-family: "BrunoAce", sans-serif; letter-spacing: .2px;
}
.menu-link:hover{ background: rgba(255,255,255,.08); transform: translateX(2px); }
.menu-link[aria-current="page"]{ background: rgba(255,255,255,.12); }

/* Mobile: drop from top */
@media (max-width: 768px){
  .menu-panel{
    right: 0; width: 100%;
    height: auto; max-height: 85vh;
    border-right: none; border-bottom: 1px solid rgba(255,255,255,.1);
    transform: translateY(-100%);
  }
  .menu-open .menu-panel{ transform: none; }
}

/* ===== Single centered section ===== */
.single-centered{
  position: relative; z-index: 10;
  min-height: 100vh; min-height: 100dvh; min-height: 100svh;
  display: grid; place-content: center;
  padding: 64px 18px 60px;
}

/* ===== Card/Form ===== */
.card{
  background: var(--card);
  color: #0e1220;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  width: min(720px, 92vw);
  padding: 28px;
  margin: 0 auto;
}

.form-title{ font-family: "BrunoAce", sans-serif; font-size: clamp(26px, 3.3vw, 36px); line-height: 1.1; margin: 4px 0 8px; }
.form-subtitle{ color: #4b5160; margin: 0 0 22px; }
.center{ text-align: center; }
.tight{ letter-spacing: .1px; }
.hidden{ display: none !important; }

.field{ display: grid; gap: 6px; margin: 10px 0; }
.field > span{ font-size: 14px; color: #2a2f3d; }
input, select, textarea{
  font: inherit; color: #0e1220; background: #fff;
  border: 1px solid #d8dbe3; border-radius: 12px;
  padding: 12px 14px; outline: none; width: 100%;
  transition: border-color .15s ease, box-shadow .15s ease;
}
select{ appearance: none; background: #fff; }
.select-wrap{ position: relative; }
.select-wrap::after{
  content: ""; position: absolute; right: 12px; top: 50%; width: 8px; height: 8px;
  border-right: 2px solid #65708a; border-bottom: 2px solid #65708a; transform: translateY(-60%) rotate(45deg);
  pointer-events: none;
}
input:focus, select:focus, textarea:focus{ border-color: var(--blue); box-shadow: 0 0 0 3px rgba(43,106,208,.16); }

/* CTA button */
.btn-primary{
  display: inline-block;
  background: var(--blue); color: #fff; border: none;
  border-radius: 14px; padding: 14px 22px;
  font-weight: 700; cursor: pointer;
  transition: transform .12s ease, filter .15s ease, box-shadow .2s ease;
  box-shadow: 0 8px 18px rgba(43,106,208,.35);
}
.big{ font-size: 18px; }
.center-btn{ display: block; margin: 10px auto 0; min-width: 240px; }
.btn-primary:hover{ transform: translateY(-1px) scale(1.015); filter: brightness(1.05); }
.btn-primary:active{ transform: translateY(0) scale(.99); box-shadow: 0 4px 12px rgba(43,106,208,.28); }
.btn-primary[disabled]{ filter: grayscale(.35) brightness(.85); cursor: not-allowed; box-shadow: none; opacity: .7; }

/* Contact grid */
.grid-2{ display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-span-2{ grid-column: span 2; }
@media (max-width: 640px){ .grid-2{ grid-template-columns: 1fr; } .grid-span-2{ grid-column: span 1; } }

/* ===== Footer ===== */
.site-footer{ position: fixed; left: 0; right: 0; bottom: 10px; display: grid; place-items: center; z-index: 30; background: transparent; }
.ig-link{ display: inline-grid; place-items: center; width: 44px; height: 44px; border-radius: 999px; text-decoration: none; }
.ig{ width: 26px; height: 26px; fill: none; stroke: #ffffff; stroke-width: 1.6; }

/* ===== Preloader base ===== */
:is(html, body).is-loading { overflow: hidden; } /* prevent scroll while preloading */

#preloader{
  position: fixed; inset: 0; z-index: 1000;
  display: grid; place-items: center;
  background: radial-gradient(1200px 800px at 50% 40%, rgba(255,255,255,.06), rgba(0,0,0,.82) 60%),
              #0b0e14;
  transition: opacity .45s ease, visibility .45s ease;
  opacity: 1; visibility: visible;
}

.preloader-inner{
  display: grid; justify-items: center; gap: 14px;
  padding: 20px 26px; border-radius: 20px;
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.preloader-logo{
  width: clamp(140px, 32vw, 220px); height: auto;
  filter: drop-shadow(0 4px 18px rgba(0,0,0,.5));
}

body.preloader-done #preloader{
  opacity: 0; visibility: hidden;
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  #preloader{ transition: opacity .01s linear, visibility .01s linear; }
}

/* ===== Brand preloader (elegant) ===== */
#preloader{
  background:
    radial-gradient(1200px 800px at 50% 40%, rgba(255,255,255,.08), rgba(0,0,0,.86) 60%),
    conic-gradient(from 200deg at 50% 20%, rgba(255,255,255,.05), rgba(0,0,0,0) 30%);
}

/* inner card – slightly sleeker */
.preloader-inner{
  gap: 10px;
  padding: 22px 26px 18px;
  background: rgba(20,24,31,.48);
  border: 1px solid rgba(255,255,255,.08);
}

/* tagline */
.preloader-tagline{
  margin: 2px 0 0;
  font-size: 13px;
  letter-spacing: .22px;
  color: #e7ebf5;
  opacity: 0;
  animation: preloader-fade-in .5s ease .35s forwards;
}

/* — Flake shimmer field — */
.flakes{
  position: absolute; inset: 0; overflow: hidden; z-index: 0;
  pointer-events: none;
  opacity: .75;
}
.flake{
  position: absolute; width: 6px; height: 3px; border-radius: 2px;
  background: linear-gradient(90deg, #ffffff, rgba(255,255,255,.1));
  filter: blur(.4px);
  opacity: .0;
  transform: translate3d(0,0,0) rotate(var(--r,0deg)) scale(var(--s,1));
  animation: flake-drift var(--dur, 4s) linear var(--delay, 0s) infinite;
  mix-blend-mode: screen;
}
.flake.mint { background: linear-gradient(90deg, #ffffff, #cfe8e5); } /* hint of mint */
.flake.char { background: linear-gradient(90deg, #e6e9ef, #9aa3b3); } /* charcoal silver */

/* Drift animation */
@keyframes flake-drift{
  0%   { transform: translate3d(var(--x0,0), -8%, 0) rotate(var(--r)) scale(var(--s)); opacity: 0; }
  12%  { opacity: .5; }
  85%  { opacity: .5; }
  100% { transform: translate3d(var(--x1,0), 108%, 0) rotate(calc(var(--r) + 20deg)) scale(var(--s)); opacity: 0; }
}

/* — Logo glint sweep — */
.preloader-logo-wrap{
  position: relative; display: grid; place-items: center;
  animation: logo-rise .5s cubic-bezier(.2,.7,.2,1) .05s both;
}
.preloader-logo-wrap::after{
  content: "";
  position: absolute; inset: -6% -10%;
  background:
    linear-gradient(115deg,
      rgba(255,255,255,0) 10%,
      rgba(255,255,255,.85) 14%,
      rgba(255,255,255,0) 18%);
  transform: translateX(-120%) skewX(-12deg);
  filter: blur(1px);
  mix-blend-mode: screen;
  animation: glint-sweep 1.1s ease .25s forwards;
}

@keyframes glint-sweep{
  0%   { transform: translateX(-120%) skewX(-12deg); opacity: .0; }
  12%  { opacity: .7; }
  60%  { opacity: .9; }
  100% { transform: translateX(120%) skewX(-12deg); opacity: 0; }
}

@keyframes logo-rise{
  from { transform: translateY(8px) scale(.98); filter: blur(.6px); opacity: 0; }
  to   { transform: translateY(0)   scale(1);    filter: blur(0);    opacity: 1; }
}

@keyframes preloader-fade-in{
  to { opacity: .92; }
}

/* Reduce motion: keep the look, remove motion */
@media (prefers-reduced-motion: reduce){
  .flake{ animation: none; opacity: .2; }
  .preloader-logo-wrap::after{ animation: none; opacity: 0; }
  .preloader-logo-wrap{ animation: none; }
  .preloader-tagline{ animation: none; opacity: .92; }
}

/* ===== A11y ===== */
.menu-link:focus, .hamburger:focus, .menu-close:focus, .ig-link:focus { outline: 3px solid rgba(43,106,208,.45); outline-offset: 3px; }
