/* Color system */
:root{
  --bg:#0b1020;
  --bg-alt:#0f152a;
  --bg-tint:#121a35;
  --panel:#0d1126;
  --card:#121a35;
  --text:#e9eefb;
  --muted:#a8b3cf;
  --brand:#5aa2ff;
  --brand-2:#7cffd9;
  --accent:#ffd166;
  --border:rgba(255,255,255,0.08);
  --shadow:0 10px 30px rgba(0,0,0,0.35);
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(122,255,217,0.08), transparent 60%),
    radial-gradient(1200px 800px at -10% 10%, rgba(90,162,255,0.12), transparent 60%),
    var(--bg);
}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:80px 0}
.bg-alt{background:var(--bg-alt)}
.bg-tint{background:var(--bg-tint)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:20;
  background:linear-gradient(to bottom, rgba(11,16,32,0.95), rgba(11,16,32,0.6));
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(140%) blur(8px);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;height:64px
}
.logo{
  font-weight:800;letter-spacing:.3px;color:#fff
}
.nav a{margin-left:16px;color:var(--text);padding:8px 10px;border-radius:8px}
.nav a.btn{margin-left:20px}

/* Buttons */
.btn{display:inline-block;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--panel);color:#fff;box-shadow:var(--shadow)}
.btn:hover{transform:translateY(-1px)}
.btn-sm{padding:8px 12px}
.btn-lg{padding:14px 20px;font-weight:600}
.btn-ghost{background:transparent;border-color:#2a355b}
.btn-contrast{background:var(--brand);border-color:rgba(255,255,255,0.15);color:#061025}

/* Hero */
.hero{position:relative;padding:110px 0 80px;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(800px 400px at 70% 10%, rgba(122,255,217,0.15), transparent 60%),
    radial-gradient(900px 500px at 10% 0%, rgba(90,162,255,0.18), transparent 60%);
  filter:blur(20px);
}
.hero-inner{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:36px}
.hero-copy h1{font-size:44px;line-height:1.1;margin:0 0 14px}
.lead{font-size:18px;color:var(--muted);max-width:58ch}
.hero-ctas{display:flex;gap:12px;margin:20px 0 14px}
.bullet-list{margin:14px 0 0;padding:0;list-style:none;color:var(--muted)}
.bullet-list li{padding-left:20px;position:relative;margin:6px 0}
.bullet-list li::before{
  content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
}
.hero-card{
  align-self:start;background:linear-gradient(180deg,rgba(18,26,53,0.8),rgba(13,17,38,0.8));
  border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow)
}
.kpi{display:flex;align-items:baseline;justify-content:space-between;padding:14px 10px;border-bottom:1px solid var(--border)}
.kpi:last-child{border-bottom:0}
.kpi-num{font-size:28px;font-weight:800;background:linear-gradient(135deg,var(--brand),var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.kpi-label{color:var(--muted);font-size:13px}

/* Cards and grids */
.section-title{font-size:28px;margin:0 0 20px}
.grid-3{display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:20px;box-shadow:var(--shadow);min-height:220px
}
.card h3{margin:0 0 8px}
.card p{color:var(--muted);margin:0 0 12px}
.checklist{margin:0;padding:0;list-style:none}
.checklist li{padding-left:24px;position:relative;margin:6px 0}
.checklist li::before{
  content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:4px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
}

/* Proof strip */
.proof{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  background:linear-gradient(180deg,rgba(18,26,53,.6),rgba(18,26,53,.2));
  border:1px solid var(--border);border-radius:14px;padding:18px
}
.proof-stat{text-align:center}
.proof-num{font-size:26px;font-weight:800}
.proof-cap{color:var(--muted);font-size:13px}

/* Quote */
.quote{
  margin:0; padding:26px; font-size:18px; line-height:1.55;
  border:1px solid var(--border); border-radius:14px; background:var(--card); box-shadow:var(--shadow)
}
.quote cite{display:block;margin-top:10px;color:var(--muted);font-style:normal}

/* CTA */
.cta{padding:70px 0;background:
  linear-gradient(180deg,rgba(122,255,217,0.08),rgba(90,162,255,0.06)),
  var(--bg-alt)}
.cta-inner{text-align:center}
.cta h2{margin:0 0 6px;font-size:28px}
.cta p{color:var(--muted);margin:0 0 16px}

/* Footer */
.site-footer{border-top:1px solid var(--border);background:rgba(13,17,38,0.8)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;padding:20px 0}
.footer-nav a{margin-left:14px;color:var(--muted)}
.footer-brand small{color:var(--muted)}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card{order:-1;margin-bottom:12px}
  .grid-3{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;gap:12px}
}

/* Typography pairing */
body{font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.logo,.hero-title,h1,h2,h3{font-family:"Poppins","Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}

/* Big gradient wordmark hero */
.hero-surface{
  position:relative; text-align:center; padding:160px 20px 120px;
  background: radial-gradient(1000px 600px at 70% 10%, rgba(122,255,217,0.12), transparent 60%),
             linear-gradient(180deg,#0d1429 0%,#0b1020 80%);
  overflow:hidden;
}
.hero-centered{max-width:900px;margin:0 auto}
.hero-title{
  font-size:92px; font-weight:800; line-height:1.03; margin:0 0 14px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-subtitle{font-size:20px; color:var(--muted); margin:0 auto 22px; max-width:720px}

/* Floating animated background orbs */
.bg-orb{
  position:absolute; border-radius:50%; filter:blur(24px); opacity:.35; pointer-events:none;
  background:radial-gradient(closest-side, rgba(122,255,217,.6), rgba(122,255,217,0));
  animation: floatY 10s ease-in-out infinite;
}
.orb-a{width:420px; height:420px; top:-60px; left:8%; animation-delay:.2s}
.orb-b{width:520px; height:520px; bottom:-120px; right:6%; animation-delay:1.1s}

/* Subtle animated gradient sweep */
.hero-animated{
  background-size: 120% 120%;
  animation: bgShift 18s ease-in-out infinite;
}

/* Cards hover */
.anim-card{transition:transform .25s ease, box-shadow .25s ease}
.anim-card:hover{transform:translateY(-4px) scale(1.01); box-shadow:0 18px 40px rgba(0,0,0,.35)}

/* Simple fade-up on load */
.anim-fade-up{opacity:0; transform:translateY(12px); animation:fadeUp .7s ease forwards}
.anim-delay-1{animation-delay:.15s}
.anim-delay-2{animation-delay:.30s}

/* Timeline look */
.timeline ol{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:0;padding-left:18px}
.timeline li{margin:4px 0}

/* Keyframes */
@keyframes bgShift{
  0%{background-position: 50% 0%}
  50%{background-position: 50% 100%}
  100%{background-position: 50% 0%}
}
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-18px)}
}
@keyframes fadeUp{
  to{opacity:1; transform:translateY(0)}
}

/* Motion reduce */
@media (prefers-reduced-motion: reduce){
  .hero-animated,.bg-orb,.anim-fade-up{animation:none}
}

/* Force scrollbar always visible (prevents layout shift) */
html {
  overflow-y: scroll;
}

/* Make KLOKWYS hero even larger */
.hero-title {
  font-size: 120px; /* bigger gradient wordmark */
  letter-spacing: -2px;
  line-height: 1;
}

/* Keep text readable on smaller screens */
@media (max-width: 980px) {
  .hero-title { font-size: 70px; }
  .hero-subtitle { font-size: 18px; }
}

/* Forms */
.form{display:grid;gap:14px;margin-top:6px}
.form-row{display:grid;gap:8px}
.form label{font-weight:600}
.form input,.form textarea{
  appearance:none; width:100%; padding:12px 12px; border-radius:10px;
  border:1px solid var(--border); background:rgba(255,255,255,0.02); color:var(--text)
}
.form input::placeholder,.form textarea::placeholder{color:var(--muted)}
.form input:focus,.form textarea:focus{
  outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(90,162,255,.25)
}
.form-actions{margin-top:6px}
.form-note{color:var(--muted); font-size:.9rem; margin:8px 0 0}
.hidden{display:none}

/* Contact layout */
.contact-grid{
  display:grid; gap:18px;
  grid-template-columns:2fr 1fr;
}
.contact-card{padding:22px}
.contact-info{padding:22px}
@media (max-width: 980px){
  .contact-grid{grid-template-columns:1fr}
}

/* Scroll reveal states */
[data-reveal]{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease}
[data-reveal].is-visible{opacity:1; transform:translateY(0)}
[data-reveal^="stagger"] .card{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
[data-reveal^="stagger"].is-visible .card{opacity:1; transform:translateY(0)}
[data-reveal^="stagger"].is-visible .card:nth-child(2){transition-delay:.08s}
[data-reveal^="stagger"].is-visible .card:nth-child(3){transition-delay:.16s}

/* Mobile-first hero fixes */
.hero-surface{padding:132px 20px 96px}
.hero-title{font-size:110px; letter-spacing:-2px; line-height:1}
@media (max-width: 980px){
  .hero-title{font-size:64px; letter-spacing:-1px}
  .hero-subtitle{font-size:18px; margin-bottom:18px}
  .hero-surface{padding:96px 16px 72px}
  .hero-centered{max-width:640px}
  .proof{grid-template-columns:1fr; row-gap:10px}
}

/* Contact page hero variant (not the giant KLOKWYS) */
.hero-contact{
  text-align:center;
  padding:120px 20px 90px;
  background:
    radial-gradient(900px 540px at 85% -10%, rgba(255,209,102,.10), transparent 60%),
    radial-gradient(700px 520px at 10% 10%, rgba(90,162,255,.12), transparent 60%),
    linear-gradient(180deg, #0e1530 0%, #0b1020 80%);
}
.hero-contact .hero-title{
  font-size:44px;
  background:none;
  -webkit-text-fill-color:inherit;
  color:var(--text);
}
.hero-contact .hero-subtitle{max-width:700px; margin:10px auto 0}

/* Ensure always-visible vertical scrollbar */
html{overflow-y:scroll}