/* Fjeldberg Tech — modern, lightweight static site */
:root{--bg:#fff;--fg:#0f172a;--muted:#475569;--card:#f8fafc;--border:rgba(15,23,42,.12);--shadow:0 10px 30px rgba(2,6,23,.08);--accent:#2563eb;--accent2:#0ea5e9;--radius:16px;--container:1120px;--focus:0 0 0 4px rgba(37,99,235,.25);--headerH:74px}
@media (prefers-color-scheme:dark){:root{--bg:#0b1020;--fg:#e5e7eb;--muted:#a3b1c6;--card:rgba(255,255,255,.05);--border:rgba(255,255,255,.14);--shadow:0 10px 30px rgba(0,0,0,.25);--accent:#60a5fa;--accent2:#22d3ee}}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;background:var(--bg);color:var(--fg);line-height:1.5}
img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.skip-link{position:absolute;left:12px;top:-80px;padding:10px 14px;background:var(--fg);color:var(--bg);border-radius:10px;z-index:9999}
.skip-link:focus{top:12px;outline:none;box-shadow:var(--focus)}
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 84%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.header-inner{height:var(--headerH);display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px;min-width:220px}
.brand-logo{width:40px;height:40px;border-radius:10px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-weight:700;letter-spacing:.2px}
.brand-tagline{font-size:12px;color:var(--muted);margin-top:2px}
.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--border);border-radius:12px;background:transparent;cursor:pointer;align-items:center;justify-content:center;gap:4px}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--fg);border-radius:2px;opacity:.9}
.site-nav{display:flex;align-items:center;gap:16px}
.site-nav a{font-weight:600;font-size:14px;color:color-mix(in srgb,var(--fg) 92%,var(--muted));padding:10px 10px;border-radius:10px}
.site-nav a:hover{background:color-mix(in srgb,var(--card) 70%,transparent);text-decoration:none}
.lang-switch{display:flex;gap:6px;margin-left:6px}
.chip{border:1px solid var(--border);background:color-mix(in srgb,var(--card) 65%,transparent);color:var(--fg);border-radius:999px;padding:8px 10px;font-weight:700;font-size:12px;cursor:pointer}
.chip.active{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 18%,var(--card))}
.chip:focus{outline:none;box-shadow:var(--focus)}
.hero{padding:34px 0 10px;border-bottom:1px solid var(--border);background:radial-gradient(900px 360px at 14% -10%,color-mix(in srgb,var(--accent2) 26%,transparent),transparent 60%),radial-gradient(900px 360px at 88% 10%,color-mix(in srgb,var(--accent) 22%,transparent),transparent 60%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center;padding:14px 0 26px}
.eyebrow{color:var(--muted);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px}
h1{font-size:clamp(30px,3.8vw,46px);line-height:1.08;margin:0 0 12px;letter-spacing:-.02em}
.lead{color:var(--muted);font-size:16px;margin:0 0 18px;max-width:58ch}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 14px;font-weight:800;font-size:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--card) 70%,transparent);cursor:pointer;text-decoration:none!important}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:color-mix(in srgb,var(--accent) 40%,var(--border));color:#fff}
.btn:focus{outline:none;box-shadow:var(--focus)}.btn:hover{filter:brightness(1.03)}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.badge{border:1px solid var(--border);background:color-mix(in srgb,var(--card) 65%,transparent);padding:8px 10px;border-radius:999px;color:var(--muted);font-size:13px;font-weight:700}
.hero-media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);background:color-mix(in srgb,var(--card) 75%,transparent)}
.slider{position:relative;aspect-ratio:16/11}
.slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease}
.slider img.active{opacity:1}
.slider-dots{position:absolute;left:12px;bottom:12px;display:flex;gap:6px}
.slider-dots button{width:10px;height:10px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 40%,transparent);cursor:pointer}
.slider-dots button.active{background:color-mix(in srgb,var(--accent) 70%,var(--bg));border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}
.section{padding:64px 0}
.section.subtle{background:color-mix(in srgb,var(--card) 55%,transparent);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-head{max-width:72ch;margin-bottom:22px}
.section-head h2{font-size:28px;margin:0 0 8px;letter-spacing:-.02em}
.section-head p{margin:0;color:var(--muted)}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kpi{padding:18px;border-radius:var(--radius);border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 40%,var(--card))}
.kpi-title{font-weight:900;margin-bottom:4px}.kpi-text{color:var(--muted);font-size:14px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 40%,var(--card));border-radius:var(--radius);padding:18px}
.card h3{margin:0 0 6px;font-size:16px;letter-spacing:-.01em}.card p{margin:0;color:var(--muted);font-size:14px}
.callout{margin-top:18px;border:1px dashed color-mix(in srgb,var(--border) 80%,var(--accent2));border-radius:var(--radius);padding:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;background:color-mix(in srgb,var(--bg) 30%,var(--card))}
.steps{margin:0;padding-left:18px;color:var(--muted);font-weight:700;max-width:52ch}.steps li{margin:6px 0}
.deliverables{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checklist{list-style:none;padding:0;margin:0}
.checklist li{padding:10px 10px 10px 34px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 40%,var(--card));border-radius:14px;position:relative;margin-bottom:10px;color:var(--muted);font-weight:700;font-size:14px}
.checklist li::before{content:"✓";position:absolute;left:12px;top:8px;font-weight:900;color:var(--accent2)}
.mini-cta{margin-top:12px;border:1px solid var(--border);background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,var(--card)),color-mix(in srgb,var(--accent2) 10%,var(--card)));border-radius:var(--radius);padding:16px;display:flex;justify-content:space-between;align-items:center;gap:14px}
.muted{color:var(--muted)}.small{font-size:12px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.project{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:color-mix(in srgb,var(--bg) 40%,var(--card));cursor:pointer}
.project img{width:100%;height:150px;object-fit:cover;background:#111}
.project-body{padding:12px 12px 14px}
.project-title{font-weight:900;letter-spacing:-.01em;margin:0 0 6px}
.project-text{margin:0;color:var(--muted);font-size:13px}
.project-tags{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.tag{font-size:11px;font-weight:900;color:color-mix(in srgb,var(--muted) 90%,var(--fg));padding:6px 8px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--card) 75%,transparent)}
.about{display:grid;grid-template-columns:.45fr .55fr;gap:18px;align-items:start}
.about-photo{border-radius:var(--radius);border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 40%,var(--card));box-shadow:var(--shadow)}
.skills{margin-top:14px}.skills-title{font-weight:900;margin-bottom:8px}
.skill-tags{display:flex;flex-wrap:wrap;gap:8px}
.skill-tags span{border:1px solid var(--border);background:color-mix(in srgb,var(--card) 65%,transparent);border-radius:999px;padding:8px 10px;font-weight:900;font-size:12px;color:var(--muted)}
.about-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.contact-card{border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--bg) 40%,var(--card));padding:16px}
.contact-label{color:var(--muted);font-weight:900;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.contact-value{font-weight:900;margin-top:8px;display:block}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.footer-cta{margin-top:18px;border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:color-mix(in srgb,var(--card) 70%,transparent);display:flex;justify-content:space-between;align-items:center;gap:12px}
.site-footer{border-top:1px solid var(--border);padding:30px 0 18px;background:color-mix(in srgb,var(--card) 60%,transparent)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:14px;align-items:start}
.footer-brand{display:flex;gap:12px;align-items:center}
.footer-logo{width:44px;height:44px;border-radius:12px}
.footer-name{font-weight:900}.footer-title{font-weight:900;margin-bottom:8px}
.footer-links{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-weight:700}
.footer-bottom{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:color-mix(in srgb,var(--muted) 90%,var(--fg))}
.modal{position:fixed;inset:0;display:none;z-index:100}.modal.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.modal-panel{position:relative;width:min(980px,calc(100% - 24px));margin:42px auto;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.modal-close{position:absolute;right:10px;top:10px;width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 70%,var(--card));font-size:22px;cursor:pointer}
.modal-image{width:100%;max-height:520px;object-fit:contain;background:#0b1020}
.modal-body{padding:14px 16px 18px}.modal-body h3{margin:0 0 6px}.modal-body p{margin:0 0 12px}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr}.grid{grid-template-columns:repeat(2,1fr)}.kpis{grid-template-columns:1fr}.cards{grid-template-columns:1fr}.deliverables{grid-template-columns:1fr}.about{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.callout{flex-direction:column}.nav-toggle{display:flex}.site-nav{position:absolute;right:16px;top:calc(var(--headerH) + 10px);flex-direction:column;align-items:stretch;width:min(340px,calc(100% - 32px));padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--bg) 86%,transparent);box-shadow:var(--shadow);display:none}.site-nav.open{display:flex}.lang-switch{margin-left:0;justify-content:flex-start}}
/* Modal carousel */
.modal-media{
  position: relative;
  background: #0b1020;
}
.carousel{
  display: grid;
  place-items: center;
  width: 100%;
  max-height: 520px;
  overflow: hidden;
}
.carousel img{
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  display: none;
}
.carousel img.active{ display: block; }

.carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  z-index: 2;
}
.carousel-btn:hover{ background: rgba(0,0,0,.5); }
.carousel-btn.prev{ left: 10px; }
.carousel-btn.next{ right: 10px; }

.carousel-dots{
  position: absolute;
  left: 12px;
  bottom: 12px;
  display: flex;
  gap: 6px;
  z-index: 2;
}
.carousel-dots button{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.12);
  cursor: pointer;
}
.carousel-dots button.active{
  background: rgba(255,255,255,.8);
}
