/* ==========================================================================
   NOVISEC — Novi Security Systems
   Design system with DUAL THEME (dark default + light)
   Colors are RGB channel triplets in CSS vars so Tailwind utilities
   (mapped to rgb(var(--c-x) / <alpha-value>)) and component CSS both theme.
   The accent ("gold") becomes blue in light mode.
   Type: Clash Display (headlines) + Satoshi (body)
   Motion: hand-crafted easing, JS is enhancement only.
   ========================================================================== */

:root {
  /* ---- DARK THEME (default) — channel triplets "R G B" ---- */
  --c-ink:       10 12 16;
  --c-ink2:      13 16 22;
  --c-surface:   19 23 31;
  --c-surface2:  26 32 43;
  --c-cloud:     242 244 247;   /* primary text  */
  --c-mist:      174 183 196;   /* secondary     */
  --c-fog:       129 139 154;   /* muted         */
  --c-gold:      201 164 97;    /* accent (gold) */
  --c-gold-soft: 216 189 138;
  --c-gold-600:  184 146 63;
  --c-line:      255 255 255;   /* hairlines / "white/X" base */
  --c-on-accent: 20 17 10;      /* text on accent buttons */

  --shadow-card: 0 26px 50px -22px rgba(0,0,0,.85);
  --shadow-nav:  0 18px 40px -28px rgba(0,0,0,.9);

  /* legacy full-colour aliases (so existing component CSS themes too) */
  --ink:        rgb(var(--c-ink));
  --ink-2:      rgb(var(--c-ink2));
  --surface:    rgb(var(--c-surface));
  --surface-2:  rgb(var(--c-surface2));
  --cloud:      rgb(var(--c-cloud));
  --mist:       rgb(var(--c-mist));
  --fog:        rgb(var(--c-fog));
  --gold:       rgb(var(--c-gold));
  --gold-soft:  rgb(var(--c-gold-soft));
  --hair:       rgb(var(--c-line) / .09);
  --hair-2:     rgb(var(--c-line) / .14);

  --ease-out:  cubic-bezier(0.16, 1, 0.30, 1);
  --ease-soft: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ---- LIGHT THEME — white background, blue accent, navy text ---- */
[data-theme="light"] {
  --c-ink:       255 255 255;
  --c-ink2:      244 247 251;
  --c-surface:   255 255 255;
  --c-surface2:  248 250 252;
  --c-cloud:     12 27 51;       /* deep navy headings/text */
  --c-mist:      48 64 92;       /* slate-blue body */
  --c-fog:       100 116 139;    /* muted */
  --c-gold:      37 99 235;      /* accent becomes BLUE */
  --c-gold-soft: 59 130 246;
  --c-gold-600:  29 78 216;
  --c-line:      15 23 42;       /* dark hairlines on light */
  --c-on-accent: 255 255 255;    /* white text on blue buttons */

  --shadow-card: 0 22px 45px -24px rgba(15,23,42,.18);
  --shadow-nav:  0 14px 34px -22px rgba(15,23,42,.13);
}

* { box-sizing: border-box; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

html { scroll-behavior: smooth; scroll-padding-top: 6rem; }

body {
  font-family: 'Satoshi', system-ui, -apple-system, sans-serif;
  background: var(--ink);
  color: var(--mist);
  overflow-x: hidden;
  line-height: 1.6;
  transition: background-color .35s ease, color .35s ease;
}

/* Ambient top glow + film grain */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 42% at 72% -6%, rgb(var(--c-gold) / .10), transparent 70%),
    radial-gradient(48% 38% at 8% 4%, rgb(80 110 160 / .07), transparent 70%);
}
body > * { position: relative; z-index: 1; }

.grain::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; opacity: .035; z-index: 2;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-theme="light"] .grain::after { opacity: .025; mix-blend-mode: multiply; }

h1, h2, h3, h4, .font-display {
  font-family: 'Clash Display', 'Satoshi', system-ui, sans-serif;
  color: var(--cloud);
  letter-spacing: -0.02em;
  line-height: 1.04;
  font-weight: 600;
}

::selection { background: rgb(var(--c-gold) / .24); color: var(--cloud); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 4px; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* --------------------------------------------------------------------------
   Tokens
   -------------------------------------------------------------------------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: 'Satoshi', sans-serif; font-size: .72rem; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold);
}
.eyebrow::before { content: ''; width: 26px; height: 1px; background: var(--gold); opacity: .7; }
.eyebrow.no-rule::before { display: none; }

.rule-gold { height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: .5; }

/* --------------------------------------------------------------------------
   Motion system (reveals additive — JS adds .in; failsafe forces it)
   -------------------------------------------------------------------------- */
.reveal, .reveal-l, .reveal-r, .reveal-scale {
  transition: opacity .85s var(--ease-out), transform .85s var(--ease-out);
  transition-delay: var(--delay, 0ms);
  will-change: opacity, transform;
}
.js .reveal       { opacity: 0; transform: translateY(26px); }
.js .reveal-l     { opacity: 0; transform: translateX(-34px); }
.js .reveal-r     { opacity: 0; transform: translateX(34px); }
.js .reveal-scale { opacity: 0; transform: scale(.96); }
.reveal.in, .reveal-l.in, .reveal-r.in, .reveal-scale.in { opacity: 1; transform: none; }

.wipe { transition: clip-path .9s var(--ease-out), opacity .9s var(--ease-out); transition-delay: var(--delay,0ms); }
.js .wipe { clip-path: inset(0 0 100% 0); opacity: 0; }
.wipe.in  { clip-path: inset(0 0 -8% 0); opacity: 1; }

/* --------------------------------------------------------------------------
   Navbar
   -------------------------------------------------------------------------- */
.nav-shell {
  background: rgb(var(--c-ink) / .62);
  backdrop-filter: saturate(150%) blur(12px);
  -webkit-backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: background-color .4s var(--ease-soft), border-color .4s var(--ease-soft), box-shadow .4s var(--ease-soft);
}
.nav-shell.scrolled {
  background: rgb(var(--c-ink) / .88);
  border-bottom-color: var(--hair);
  box-shadow: var(--shadow-nav);
}
.nav-link { position: relative; color: var(--mist); transition: color .25s var(--ease-soft); }
.nav-link:hover { color: var(--cloud); }
.nav-link::after {
  content: ''; position: absolute; left: 0; bottom: -6px; height: 1.5px; width: 0;
  background: var(--gold); transition: width .3s var(--ease-out);
}
.nav-link:hover::after, .nav-link[aria-current="page"]::after { width: 100%; }
.nav-link[aria-current="page"] { color: var(--cloud); }

.mobile-menu { transition: opacity .35s var(--ease-soft), transform .35s var(--ease-out); }
.mobile-menu.closed { opacity: 0; transform: translateY(-10px); pointer-events: none; }

/* Theme toggle icon swap (pure CSS, driven by data-theme) */
.t-moon { display: none; }
[data-theme="light"] .t-sun { display: none; }
[data-theme="light"] .t-moon { display: block; }

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.btn {
  position: relative; display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-family: 'Satoshi', sans-serif; font-weight: 600; font-size: .98rem;
  border-radius: 999px; padding: .92rem 1.6rem; cursor: pointer; overflow: hidden;
  transition: transform .3s var(--ease-out), box-shadow .3s var(--ease-soft), background-color .3s, color .3s, border-color .3s;
}
.btn svg { transition: transform .3s var(--ease-out); }
.btn:hover svg.arrow { transform: translateX(3px); }

.btn-gold { background: var(--gold); color: rgb(var(--c-on-accent)); box-shadow: 0 14px 34px -14px rgb(var(--c-gold) / .55); }
.btn-gold::before {
  content: ''; position: absolute; top: 0; left: -130%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.55), transparent);
  transform: skewX(-18deg); transition: left .6s var(--ease-out);
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 20px 42px -14px rgb(var(--c-gold) / .7); background: var(--gold-soft); }
.btn-gold:hover::before { left: 130%; }

.btn-ghost { background: transparent; color: var(--cloud); border: 1px solid var(--hair-2); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

.btn-line { background: transparent; color: var(--cloud); border: 1px solid var(--hair-2); }
.btn-line:hover { background: rgb(var(--c-line) / .05); }

/* --------------------------------------------------------------------------
   Cards
   -------------------------------------------------------------------------- */
.panel {
  position: relative; background: var(--surface); border: 1px solid var(--hair);
  border-radius: 18px; transition: transform .4s var(--ease-out), border-color .4s, background-color .4s, box-shadow .4s;
}
.panel-hover { cursor: default; }
.panel-hover::after {
  content: ''; position: absolute; left: 24px; right: 24px; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  transform: scaleX(0); transform-origin: center; transition: transform .5s var(--ease-out); opacity: .8;
}
.panel-hover:hover {
  transform: translateY(-6px); border-color: var(--hair-2); background: var(--surface-2);
  box-shadow: var(--shadow-card);
}
.panel-hover:hover::after { transform: scaleX(1); }

.icon-frame {
  display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px;
  border-radius: 13px; color: var(--gold);
  background: linear-gradient(155deg, rgb(var(--c-gold) / .16), rgb(var(--c-gold) / .04));
  border: 1px solid rgb(var(--c-gold) / .22);
  transition: transform .4s var(--ease-out), box-shadow .4s;
}
.panel-hover:hover .icon-frame { transform: translateY(-2px) rotate(-3deg); box-shadow: 0 12px 24px -10px rgb(var(--c-gold) / .4); }

.chip {
  display: inline-flex; align-items: center; gap: .55rem;
  border: 1px solid var(--hair); border-radius: 10px; padding: .55rem .85rem;
  color: var(--mist); background: rgb(var(--c-line) / .03);
  transition: border-color .3s, color .3s, background-color .3s;
}
.chip:hover { border-color: rgb(var(--c-gold) / .4); color: var(--cloud); }
.chip svg { color: var(--gold); }

/* --------------------------------------------------------------------------
   Hero atmosphere
   -------------------------------------------------------------------------- */
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgb(var(--c-line) / .05) 1px, transparent 1px),
    linear-gradient(to bottom, rgb(var(--c-line) / .05) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 70% 60% at 60% 30%, #000 25%, transparent 72%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 60% 30%, #000 25%, transparent 72%);
}
.glow { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; }
.glow-gold { background: radial-gradient(circle, rgb(var(--c-gold) / .20), transparent 65%); animation: drift 24s var(--ease-soft) infinite alternate; }
.glow-cool { background: radial-gradient(circle, rgb(90 130 180 / .16), transparent 65%); animation: drift 30s var(--ease-soft) infinite alternate-reverse; }
@keyframes drift { from { transform: translate3d(0,0,0); } to { transform: translate3d(-34px,26px,0); } }

@keyframes float-soft { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.float-soft { animation: float-soft 7s ease-in-out infinite; }

@keyframes scan { 0% { transform: translateY(0); opacity:0; } 12%{opacity:1;} 88%{opacity:1;} 100% { transform: translateY(150px); opacity:0; } }
.scan-line { animation: scan 4.8s var(--ease-soft) infinite; }

@keyframes ping { 0%{transform:scale(.7);opacity:.8;} 70%{transform:scale(2.4);opacity:0;} 100%{opacity:0;} }
.ping::after { content:''; position:absolute; inset:0; border-radius:50%; background: var(--gold); animation: ping 2.8s var(--ease-out) infinite; }

.marquee-track { display: flex; gap: 4rem; width: max-content; animation: marquee 38s linear infinite; }
.marquee-mask:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }

.numeral { font-family: 'Clash Display', sans-serif; font-weight: 600; letter-spacing: -0.03em; color: var(--cloud); }

.step { position: relative; }
.step::before { content:''; position:absolute; left: 25px; top: 56px; bottom: -30px; width:1px; background: linear-gradient(var(--gold), transparent); opacity:.4; }
.step:last-child::before { display:none; }

/* --------------------------------------------------------------------------
   Form
   -------------------------------------------------------------------------- */
.field {
  width: 100%; background: rgb(var(--c-line) / .03); border: 1px solid var(--hair);
  border-radius: 12px; padding: .9rem 1.05rem; font-size: 1rem; color: var(--cloud);
  font-family: 'Satoshi', sans-serif; transition: border-color .25s, box-shadow .25s, background-color .25s;
}
.field::placeholder { color: var(--fog); }
.field:focus { outline: none; border-color: var(--gold); background: rgb(var(--c-line) / .05); box-shadow: 0 0 0 4px rgb(var(--c-gold) / .14); }
select.field { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%23818b9a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 8 4 4 4-4'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.6rem; }
select.field option { background-color: rgb(var(--c-surface2)); color: rgb(var(--c-cloud)); }
label { color: var(--cloud); }

.arrow-link svg { transition: transform .28s var(--ease-out); }
.arrow-link:hover svg { transform: translateX(4px); }

/* --------------------------------------------------------------------------
   Reduced motion
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  body { transition: none; }
  .reveal, .reveal-l, .reveal-r, .reveal-scale, .wipe { opacity: 1 !important; transform: none !important; clip-path: none !important; transition: none !important; }
  .glow-gold, .glow-cool, .float-soft, .scan-line, .ping::after, .marquee-track { animation: none !important; }
  .btn, .panel, .icon-frame, .nav-link::after, .arrow-link svg, .btn svg { transition: none !important; }
  .btn-gold::before { display: none; }
}

/* Navbar logo: the reversed (white-text) logo needs a dark backing in light mode
   so the wordmark stays legible. No effect in dark mode. */
[data-theme="light"] a[aria-label="NoviSec, til forsiden"] {
  background: #0a0c10;
  box-shadow: 0 0 0 6px #0a0c10;
  border-radius: 9px;
}

/* Cursor-following accent glow — uses --c-gold (gold in dark, blue in light).
   JS sets --mx / --my. Fine pointers only; hidden under reduced motion. */
.cursor-glow {
  position: fixed; inset: 0; z-index: 40; pointer-events: none;
  background: radial-gradient(circle at var(--mx, -300px) var(--my, -300px), rgb(var(--c-gold) / .13), transparent 240px);
  opacity: 0; transition: opacity .55s ease;
}
.cursor-glow.on { opacity: 1; }
@media (prefers-reduced-motion: reduce) { .cursor-glow { display: none !important; } }

/* --------------------------------------------------------------------------
   Contact form success overlay
   On a successful submit the success state blooms out from the centre of the
   form card (a circular reveal), the check and text rise and scale in, it
   holds ~5s, then the whole thing fades out and is removed (built + torn down
   in js/main.js). Greens read on both themes. Under reduced motion it just
   appears statically: no bloom, no draw-in, no rise.
   -------------------------------------------------------------------------- */
.form-success {
  position: absolute; inset: 0; z-index: 6; border-radius: inherit;
  display: flex; align-items: center; justify-content: center; padding: 1.5rem;
  opacity: 1; transition: opacity .5s var(--ease-out);
}
/* The opaque wash lives on ::before so it can grow from the centre without
   clipping the check + text that sit above it. */
.form-success::before {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background:
    radial-gradient(125% 90% at 50% 42%, rgb(34 197 94 / .16), transparent 60%),
    var(--surface);
  clip-path: circle(0% at 50% 42%);
  transition: clip-path .9s var(--ease-out);
  will-change: clip-path;
}
[data-theme="light"] .form-success::before {
  background:
    radial-gradient(125% 90% at 50% 42%, rgb(22 163 74 / .13), transparent 60%),
    var(--surface);
}
.form-success.in::before { clip-path: circle(145% at 50% 42%); }
.form-success.leaving { opacity: 0; }

.form-success .fs-inner {
  position: relative; z-index: 1; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: .15rem;
  opacity: 0; transform: translateY(10px) scale(.95);
  transition: opacity .5s var(--ease-out) .28s, transform .6s var(--ease-out) .24s;
}
.form-success.in .fs-inner { opacity: 1; transform: none; }

.form-success .check { width: 92px; height: 92px; color: #22c55e; }
[data-theme="light"] .form-success .check { color: #16a34a; }
.form-success .check circle,
.form-success .check path {
  stroke-dasharray: var(--len);
  stroke-dashoffset: 0;                /* resting = fully drawn (reduced-motion fallback) */
}
.form-success .check circle { --len: 152; }
.form-success .check path    { --len: 40; }
.form-success.in .check circle { animation: suc-draw .55s var(--ease-out) .38s both; }
.form-success.in .check path   { animation: suc-draw .4s  var(--ease-out) .85s both; }
@keyframes suc-draw { from { stroke-dashoffset: var(--len); } to { stroke-dashoffset: 0; } }

@media (prefers-reduced-motion: reduce) {
  .form-success, .form-success::before, .form-success .fs-inner { transition: none; }
  .form-success::before { clip-path: circle(145% at 50% 42%); }
  .form-success .fs-inner { opacity: 1; transform: none; }
  .form-success.in .check circle,
  .form-success.in .check path { animation: none; }
}
