:root{
  --bg:#050816;
  --bg2:#0b1234;
  --text:#eef2ff;
  --muted:#b8bfd9;
  --line:rgba(255,255,255,.1);
  --glass:rgba(255,255,255,.07);
  --glass2:rgba(255,255,255,.12);
  --cyan:#78b8cf;
  --violet:#7d6fb0;
  --pink:#b97aa9;
  --amber:#d9bc73;
  --shadow:0 20px 60px rgba(0,0,0,.35);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background:
    radial-gradient(70rem 40rem at -10% -10%, rgba(89,212,255,.20), transparent 60%),
    radial-gradient(50rem 35rem at 110% 15%, rgba(255,79,207,.20), transparent 55%),
    radial-gradient(40rem 30rem at 50% 80%, rgba(139,92,246,.18), transparent 55%),
    linear-gradient(180deg, #070b1d 0%, #060914 55%, #04070f 100%);
  color:var(--text);
  overflow-x:hidden;
}
body::before, body::after{
  content:"";
  position:fixed;
  inset:auto;
  width:42vw;
  height:42vw;
  pointer-events:none;
  filter:blur(26px);
  opacity:.32;
  z-index:0;
  border-radius:50%;
}
body::before{
  top:-12vw; left:-10vw;
  background:conic-gradient(from 180deg, rgba(89,212,255,.95), rgba(139,92,246,.8), rgba(255,79,207,.7), transparent 70%);
}
body::after{
  right:-10vw; top:18rem;
  background:conic-gradient(from 20deg, rgba(255,79,207,.8), rgba(89,212,255,.75), rgba(139,92,246,.6), transparent 72%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1200px, calc(100% - 32px)); margin:auto; position:relative; z-index:1}
.header{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(18px);
  background:linear-gradient(180deg, rgba(4,7,15,.78), rgba(4,7,15,.42));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:16px 0}
.logo{
  display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.02em; font-size:1.05rem;
}
.logo-mark{
  width:42px; height:42px; border-radius:14px;
  background:linear-gradient(135deg, rgba(89,212,255,.95), rgba(139,92,246,.95) 55%, rgba(255,79,207,.9));
  box-shadow:0 0 0 1px rgba(255,255,255,.16) inset, 0 12px 30px rgba(108,110,255,.4);
  display:grid; place-items:center; font-weight:900; color:white;
}
.logo span small{display:block; color:var(--muted); font-size:.76rem; font-weight:500}
.nav-links{display:flex; gap:24px; align-items:center}
.nav-links a{color:var(--muted); font-size:.95rem}
.nav-links a:hover{color:var(--text)}
.cta-top{
  padding:12px 18px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(135deg, rgba(120,184,207,.50), rgba(125,111,176,.50));
  box-shadow:0 6px 16px rgba(0,0,0,.16);
  backdrop-filter:blur(6px);
}
.cta-top:hover{
  background:linear-gradient(135deg, rgba(120,184,207,.62), rgba(125,111,176,.62));
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.hero{padding:78px 0 32px}
.hero-grid{display:grid; grid-template-columns:1.08fr .92fr; gap:28px; align-items:center}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:10px 14px; border-radius:999px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.045);
  color:#dfe6ff; font-size:.88rem; letter-spacing:.02em;
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 20px var(--cyan)}
.hero h1{
  margin:18px 0 14px;
  font-size:clamp(3.5rem, 9vw, 7.2rem);
  line-height:.92;
  letter-spacing:-.05em;
  font-weight:850;
}
.hero h1 .muted{color:transparent; -webkit-text-stroke:1px rgba(238,242,255,.45)}
.hero-lead{
  font-size:1.12rem; line-height:1.8; color:var(--muted);
  max-width:64ch;
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:26px}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 24px; border-radius:999px; font-weight:700;
  border:1px solid rgba(255,255,255,.12);
  transition:background .2s ease, box-shadow .2s ease, transform .2s ease, border-color .2s ease;
  backdrop-filter:blur(6px);
}
.btn:hover{
  transform:translateY(-1px);
}
.btn-primary{
  background:linear-gradient(90deg, rgba(120,184,207,.50), rgba(125,111,176,.50), rgba(185,122,169,.50));
  color:white;
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.btn-primary:hover{
  background:linear-gradient(90deg, rgba(120,184,207,.62), rgba(125,111,176,.62), rgba(185,122,169,.62));
  box-shadow:0 10px 22px rgba(0,0,0,.2);
}
.btn-secondary{
  background:rgba(255,255,255,.05); color:var(--text);
  box-shadow:0 6px 14px rgba(0,0,0,.12);
}
.btn-secondary:hover{
  background:rgba(255,255,255,.08);
  box-shadow:0 8px 18px rgba(0,0,0,.16);
}
.hero-card{
  position:relative;
  border-radius:36px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05)),
    linear-gradient(135deg, rgba(89,212,255,.16), rgba(139,92,246,.12) 55%, rgba(255,79,207,.14));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow);
  padding:30px;
  overflow:hidden;
}
.hero-card::before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(18rem 10rem at 0% 0%, rgba(89,212,255,.25), transparent 60%),
    radial-gradient(18rem 12rem at 100% 100%, rgba(255,79,207,.25), transparent 60%);
  pointer-events:none;
}
.quote{
  font-size:clamp(1.2rem, 3vw, 2.2rem);
  line-height:1.05; letter-spacing:-.03em; font-weight:800;
}
.quote em{font-style:normal; color:var(--amber)}
.panel{
  margin-top:22px;
  display:grid; gap:14px;
}
.mini-card{
  padding:18px 18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(6,10,28,.58);
  display:flex; justify-content:space-between; gap:14px; align-items:center;
}
.mini-card strong{display:block; font-size:1.02rem}
.mini-card span{color:var(--muted); font-size:.92rem}
.stats{
  margin:26px auto 10px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.stat{
  padding:18px 20px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  text-align:center;
}
.stat b{display:block; font-size:1.55rem}
.stat span{color:var(--muted); font-size:.95rem}
.marquee{
  margin:18px 0 20px;
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.03);
}
.marquee-track{
  display:flex; gap:34px; white-space:nowrap;
  padding:14px 0; animation:scroll 24s linear infinite;
  color:#d9e1ff;
}
.marquee-track span{opacity:.88}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
section{padding:78px 0}
.section-head{display:grid; gap:10px; margin-bottom:28px}
.kicker{
  color:#dfe6ff;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.8rem;
}
h2{
  font-size:clamp(2rem, 5vw, 4.4rem);
  line-height:.96;
  letter-spacing:-.04em;
  margin:0;
}
.section-copy{
  color:var(--muted);
  max-width:70ch;
  line-height:1.8;
}
.about-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:22px}
.glass{
  border-radius:30px;
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow:var(--shadow);
}
.about-copy{padding:28px}
.about-copy p{color:var(--muted); line-height:1.9; margin:0 0 18px}
.about-copy strong{color:var(--text)}
.skills{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:10px;
}
.skill{
  padding:10px 14px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#e7ebff; font-size:.92rem;
}
.timeline{padding:20px}
.timeline-item{
  display:grid; grid-template-columns:84px 1fr; gap:16px;
  padding:18px 6px; border-bottom:1px solid rgba(255,255,255,.08);
}
.timeline-item:last-child{border-bottom:0}
.year{
  color:var(--cyan); font-weight:800; font-size:1.05rem;
}
.timeline-item h3{margin:0 0 6px; font-size:1.05rem}
.timeline-item p{margin:0; color:var(--muted); line-height:1.7}
.projects-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:18px;
}
.project-card{
  position:relative;
  min-height:250px;
  padding:24px;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(16rem 10rem at 0% 0%, rgba(89,212,255,.15), transparent 55%),
    radial-gradient(14rem 10rem at 100% 100%, rgba(255,79,207,.15), transparent 55%),
    rgba(255,255,255,.045);
  box-shadow:var(--shadow);
  display:flex; flex-direction:column; justify-content:space-between;
}
.project-card::after{
  content:"";
  position:absolute; inset:auto -18% -30% auto; width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.12), transparent 65%);
  filter:blur(20px);
}
.project-top{display:flex; justify-content:space-between; gap:12px; align-items:flex-start}
.num{
  color:rgba(255,255,255,.5); font-weight:800; font-size:.9rem; letter-spacing:.12em;
}
.tag{
  font-size:.78rem; text-transform:uppercase; letter-spacing:.12em;
  color:#d9e1ff;
}
.project-card h3{
  margin:22px 0 10px; font-size:1.6rem; line-height:1.02; letter-spacing:-.03em;
}
.project-card p{color:var(--muted); margin:0 0 16px; line-height:1.7}
.project-link{
  margin-top:auto; color:white; font-weight:700;
}
.project-flagship{
  grid-column:span 3;
  min-height:300px;
  background:
    radial-gradient(25rem 16rem at 0% 0%, rgba(89,212,255,.18), transparent 55%),
    radial-gradient(28rem 16rem at 100% 100%, rgba(255,79,207,.18), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
}
.project-flagship .columns{
  display:grid; grid-template-columns:1.15fr .85fr; gap:22px; align-items:end;
}
.metric-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:12px;
}
.metric{
  padding:16px; border-radius:20px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1)
}
.metric b{display:block; font-size:1rem}
.metric span{color:var(--muted); font-size:.9rem}
.services-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.service{
  padding:24px;
  border-radius:28px; border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.045);
  box-shadow:var(--shadow);
}
.service .icon{font-size:1.6rem; margin-bottom:10px}
.service h3{margin:0 0 10px; font-size:1.1rem}
.service p{margin:0; color:var(--muted); line-height:1.75}
.contact-grid{
  display:grid; grid-template-columns:1fr .9fr; gap:20px;
}
.contact-card,.form-card{
  padding:28px; border-radius:30px; border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:var(--shadow);
}
.contact-lead{color:var(--muted); line-height:1.8; max-width:52ch}
.contact-links{display:grid; gap:10px; margin:22px 0 26px}
.contact-links a{
  font-size:clamp(1.25rem, 3vw, 2rem); font-weight:800; letter-spacing:-.03em;
}
.contact-meta{
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:12px;
}
.meta{
  padding:14px 16px; border-radius:18px; background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.08);
}
.meta small{display:block; color:var(--muted); margin-bottom:4px}
.form-card form{display:grid; gap:14px}
.field{display:grid; gap:8px}
label{font-size:.92rem; color:#dfe6ff}
input, textarea{
  width:100%; padding:16px 16px; border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(6,10,28,.55); color:var(--text);
  font:inherit;
}
textarea{min-height:150px; resize:vertical}
.footer{
  padding:34px 0 60px; color:var(--muted); text-align:center
}
.reveal{opacity:0; transform:translateY(24px); transition:all .8s ease}
.reveal.in{opacity:1; transform:none}
@media (max-width: 1100px){
  .hero-grid,.about-grid,.contact-grid,.project-flagship .columns{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr 1fr}
  .project-flagship{grid-column:span 2}
  .services-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  .nav{padding:14px 0}
  .nav-links{display:none}
  .hero{padding:42px 0 18px}
  .stats{grid-template-columns:1fr 1fr}
  .projects-grid,.services-grid,.metric-grid,.contact-meta{grid-template-columns:1fr}
  .project-flagship{grid-column:span 1}
  .hero-card{padding:22px}
  .project-card{min-height:220px}
  section{padding:62px 0}
}


/* Nedtonade knappar: mjukare färger + 50% transparens */
