*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:#1a1a1a;overflow-x:hidden;background:#fff}
a{text-decoration:none;color:inherit}
img{max-width:100%}

:root{
  --red:#c8312a;
  --cream:#f5ede0;
  --dark:#1a1a1a;
  --gold:#f5c518;
  --border:2px solid #1a1a1a;
  --radius:16px;
}

/* ── BANNER ── */
.top-banner{
  background:var(--red);color:#fff;text-align:center;
  padding:10px 20px;font-size:.85rem;font-weight:600;letter-spacing:.03em;
}

/* ── NAV ── */
nav{
  background:var(--cream);border-bottom:var(--border);
  padding:0 48px;display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;height:68px;
  position:sticky;top:0;z-index:200;
}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.88rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--dark);transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--red)}
.nav-logo{
  font-family:'Oswald',sans-serif;font-weight:700;font-size:1.9rem;
  color:var(--red);letter-spacing:.04em;text-transform:uppercase;text-align:center;
}
.nav-right{display:flex;justify-content:flex-end;gap:12px;align-items:center}
.nav-btn{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;
  background:var(--red);color:#fff;
  padding:10px 22px;border-radius:50px;border:var(--border);
  cursor:pointer;transition:all .2s;
  box-shadow:3px 3px 0 var(--dark);
  display:inline-block;
}
.nav-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--dark)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(0,7px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(0,-7px)}

/* ── HERO ── */
#hero{
  background:
    linear-gradient(rgba(200,49,42,.78),rgba(200,49,42,.78)),
    url('https://images.unsplash.com/photo-1433757741270-94a3bcadc2f3?w=1600&q=80&auto=format&fit=crop') center/cover fixed;
  min-height:82vh;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;padding:80px 72px 0;
  position:relative;overflow:hidden;
}
.hero-text{color:#fff}
.hero-eyebrow{
  font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;opacity:.8;
  margin-bottom:18px;display:flex;align-items:center;gap:12px;
}
.hero-eyebrow::before{content:'';display:inline-block;width:32px;height:2px;background:#fff;flex-shrink:0}
h1{
  font-family:'Oswald',sans-serif;font-size:clamp(2.8rem,5.5vw,5rem);
  font-weight:700;text-transform:uppercase;line-height:1.0;
  letter-spacing:.02em;margin-bottom:24px;
}
.hero-sub{font-size:1rem;line-height:1.75;opacity:.9;max-width:440px;margin-bottom:36px}
.hero-sub strong{font-weight:700;opacity:1}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  padding:14px 30px;border-radius:50px;border:var(--border);
  cursor:pointer;transition:all .2s;box-shadow:3px 3px 0 var(--dark);
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--dark)}
.btn-white{background:#fff;color:var(--dark)}
.btn-gold{background:var(--gold);color:var(--dark)}
.btn-dark{background:var(--dark);color:#fff}
.btn-red{background:var(--red);color:#fff}

/* ── LAPTOP MOCKUP ── */
.hero-visual{display:flex;justify-content:center;align-items:flex-end;padding-bottom:0}
.laptop-wrap{width:460px;max-width:100%}
.laptop-screen{background:var(--dark);border-radius:14px 14px 0 0;padding:8px;border:3px solid var(--dark)}
.laptop-screen-inner{background:#fff;border-radius:8px;overflow:hidden;aspect-ratio:16/10;display:flex;flex-direction:column}
.screen-bar{background:#f0f0f0;padding:7px 10px;display:flex;gap:5px;align-items:center;border-bottom:1px solid #ddd}
.sd{width:9px;height:9px;border-radius:50%}
.sd1{background:#ff5f57}.sd2{background:#febc2e}.sd3{background:#28c840}
.screen-url{flex:1;background:#fff;border-radius:4px;height:16px;margin-left:8px;border:1px solid #e0e0e0}
.screen-content{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:10px;padding:20px;
  background:linear-gradient(135deg,#c8312a 0%,#a01e18 100%);
}
.sc-logo{font-family:'Oswald',sans-serif;font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:.08em}
.sc-line{height:6px;background:rgba(255,255,255,.35);border-radius:3px;width:72%}
.sc-line.s{width:52%}
.sc-btn{
  margin-top:4px;background:#fff;color:var(--red);
  font-family:'Oswald',sans-serif;font-size:.6rem;font-weight:700;
  padding:5px 14px;border-radius:20px;letter-spacing:.06em;
}
.laptop-base{background:var(--dark);height:14px;border-radius:0 0 4px 4px;margin:0 -4px}
.laptop-foot{width:110px;height:8px;background:var(--dark);margin:0 auto;border-radius:0 0 8px 8px}

/* ── STATS ── */
.stats-bar{
  background:var(--dark);padding:40px 60px;
  display:flex;justify-content:center;gap:80px;flex-wrap:wrap;
}
.stat-item{text-align:center;color:#fff}
.stat-num{
  font-family:'Oswald',sans-serif;font-size:3rem;font-weight:700;
  line-height:1;margin-bottom:8px;color:var(--gold);
}
.stat-lbl{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;opacity:.65;font-weight:600}

/* ── DIVIDER ── */
.divider{height:2px;background:var(--dark)}

/* ── SHARED SECTION STYLES ── */
.sec-tag{
  font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:10px;
}
h2{
  font-family:'Oswald',sans-serif;font-size:clamp(1.8rem,3.2vw,2.7rem);
  font-weight:700;text-transform:uppercase;letter-spacing:.02em;
  color:var(--red);line-height:1.1;
}
.sec-sub{color:#555;font-size:.95rem;line-height:1.7;max-width:580px;margin:12px auto 0}
.sec-header{text-align:center;margin-bottom:52px}
section{padding:80px 60px}

/* ── PAGE HERO (interior pages) ── */
.page-hero{
  background:var(--red);padding:72px 60px 64px;text-align:center;color:#fff;
}
.page-hero .sec-tag{color:rgba(255,255,255,.7);margin-bottom:12px}
.page-hero h1{
  font-family:'Oswald',sans-serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:700;
  text-transform:uppercase;letter-spacing:.02em;line-height:1.1;color:#fff;margin-bottom:16px;
}
.page-hero p{font-size:.95rem;line-height:1.75;opacity:.85;max-width:520px;margin:0 auto}

/* ── SERVICES ── */
#tjenester{background:var(--cream)}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:960px;margin:0 auto}
.srv-card{
  background:#fff;border:var(--border);border-radius:var(--radius);
  padding:36px 28px;text-align:center;
  transition:transform .2s,box-shadow .2s;position:relative;
}
.srv-card:hover{transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--dark)}
.srv-icon-big{font-size:2.5rem;margin-bottom:14px;display:block}
.srv-price{font-family:'Oswald',sans-serif;font-size:2.2rem;font-weight:700;color:var(--dark);margin-bottom:4px}
.srv-name{
  font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:600;
  text-transform:uppercase;color:var(--red);letter-spacing:.08em;margin-bottom:12px;
}
.srv-desc{font-size:.875rem;color:#555;line-height:1.65;margin-bottom:20px}
.srv-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--dark);border:var(--border);
  font-family:'Oswald',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;padding:4px 14px;border-radius:50px;
  white-space:nowrap;
}
.srv-feats{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:22px;text-align:left}
.srv-feats li{display:flex;align-items:center;gap:10px;font-size:.875rem;color:var(--dark)}
.srv-feats li::before{
  content:'✓';flex-shrink:0;width:18px;height:18px;border-radius:50%;
  background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:700;text-align:center;line-height:18px;
}

/* ── PORTFOLIO ── */
#portfolio{background:#fff;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.port-cell{
  aspect-ratio:1;border-radius:10px;border:var(--border);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;text-align:center;
  transition:transform .2s,box-shadow .2s;
}
.port-cell:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--dark)}
.port-text .sec-tag{text-align:left}
.port-text h2{text-align:left;margin-bottom:20px}
.port-text p{font-size:.95rem;color:#444;line-height:1.75;margin-bottom:28px}

/* ── GALLERY ── */
#gallery{background:#fff}
.gallery-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:240px 240px;
  gap:10px;
}
.gallery-img{
  border-radius:10px;border:var(--border);
  overflow:hidden;transition:transform .2s,box-shadow .2s;
}
.gallery-img:hover{transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--dark)}
.gallery-img.tall{grid-row:span 2}
.gallery-img img{width:100%;height:100%;object-fit:cover;display:block}

/* ── REVIEWS (marquee) ── */
@keyframes marqueeLeft{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@keyframes marqueeRight{
  0%{transform:translateX(-50%)}
  100%{transform:translateX(0)}
}
#reviews{background:var(--cream);padding:80px 0}
#reviews .sec-header{padding:0 60px;margin-bottom:52px}
.reviews-marquee{
  display:flex;flex-direction:column;gap:18px;overflow:hidden;
  mask-image:linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%);
}
.reviews-marquee:hover .rev-track{animation-play-state:paused}
.rev-track{display:flex;gap:18px;width:max-content}
.rev-track--left{animation:marqueeLeft 40s linear infinite}
.rev-track--right{animation:marqueeRight 48s linear infinite}
.rev-card{
  width:320px;flex-shrink:0;
  background:#fff;border:var(--border);border-radius:var(--radius);
  padding:26px;position:relative;
  transition:transform .25s,box-shadow .25s;
  cursor:default;
}
.rev-card:hover{transform:translateY(-8px);box-shadow:5px 5px 0 var(--dark)}
.rev-author{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rev-avatar{
  width:42px;height:42px;border-radius:50%;
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-weight:700;font-size:.82rem;
  flex-shrink:0;border:var(--border);
}
.rev-author-name{
  font-family:'Oswald',sans-serif;font-weight:600;
  font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;
}
.rev-author-date{font-size:.74rem;color:#999;margin-top:3px}
.rev-stars{font-size:.95rem;color:#f59e0b;letter-spacing:3px;margin-bottom:10px}
.rev-text{font-size:.875rem;color:#333;line-height:1.7}
.rev-company{font-size:.78rem;color:#888;margin-top:4px}

/* ── CONTACT ── */
#kontakt{background:var(--red);padding:80px 60px;text-align:center}
.kontakt-inner{max-width:560px;margin:0 auto}
#kontakt h2{color:#fff;margin-bottom:16px}
#kontakt .sec-tag{color:rgba(255,255,255,.7)}
#kontakt p{color:rgba(255,255,255,.85);font-size:.95rem;line-height:1.75;margin-bottom:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.inp{
  width:100%;padding:13px 18px;border:var(--border);border-radius:50px;
  font-family:'Inter',sans-serif;font-size:.9rem;color:var(--dark);
  background:#fff;outline:none;
}
.inp:focus{box-shadow:0 0 0 3px rgba(245,197,24,.4)}
textarea.inp{border-radius:14px;height:110px;resize:vertical;margin-bottom:12px}
.contact-links{margin-top:24px;color:rgba(255,255,255,.7);font-size:.875rem}
.contact-links a{color:#fff;font-weight:600}
.contact-info-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  max-width:560px;margin:40px auto 0;text-align:left;
}
.contact-info-card{
  background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.25);
  border-radius:var(--radius);padding:24px 22px;color:#fff;
}
.contact-info-card h4{
  font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;opacity:.65;margin-bottom:8px;
}
.contact-info-card a,.contact-info-card p{color:#fff;font-size:.95rem;font-weight:500}

/* ── FOOTER ── */
footer{background:var(--dark);color:rgba(255,255,255,.6);padding:64px 60px 40px}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:48px}
.ft-logo{font-family:'Oswald',sans-serif;font-size:1.7rem;font-weight:700;color:var(--red);letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.ft-tag{font-size:.85rem;line-height:1.7;color:rgba(255,255,255,.4)}
.ft-col h5{font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.35);margin-bottom:18px}
.ft-col ul{list-style:none}
.ft-col ul li{margin-bottom:10px}
.ft-col ul a{font-size:.875rem;color:rgba(255,255,255,.5);transition:color .2s}
.ft-col ul a:hover{color:#fff}
.ft-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ft-copy{font-size:.8rem;color:rgba(255,255,255,.3)}
.ft-link{font-size:.8rem;color:rgba(255,255,255,.35);transition:color .2s}
.ft-link:hover{color:#fff}

/* ── PHOTO BREAK ── */
.photo-break{
  min-height:380px;
  background-color:var(--dark);
  background-size:cover;background-position:center;
  background-attachment:fixed;
  position:relative;display:flex;align-items:center;justify-content:center;
}
.photo-break::before{
  content:'';position:absolute;inset:0;
  background:rgba(26,26,26,.5);
}
.photo-break-inner{
  position:relative;z-index:1;
  text-align:center;color:#fff;padding:48px 40px;max-width:680px;
}
.photo-break-inner h3{
  font-family:'Oswald',sans-serif;font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  line-height:1.05;margin-bottom:16px;
}
.photo-break-inner p{font-size:.95rem;opacity:.85;line-height:1.75;margin-bottom:28px}

/* ── SPLIT SECTION ── */
.split-section{display:grid;grid-template-columns:1fr 1fr}
.split-img{
  background-color:var(--dark);
  background-size:cover;background-position:center top;
  min-height:520px;border-right:var(--border);
}
.split-text{
  background:var(--cream);padding:72px 60px;
  display:flex;flex-direction:column;justify-content:center;gap:18px;
}
.split-text .sec-tag{text-align:left}
.split-text h2{text-align:left}
.split-text p{font-size:.95rem;color:#444;line-height:1.75}

/* ── MOBILE ── */
@media(max-width:900px){
  nav{grid-template-columns:auto 1fr;padding:0 20px}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;position:fixed;top:0;left:0;right:0;bottom:0;
    background:var(--cream);flex-direction:column;align-items:center;
    justify-content:center;gap:40px;z-index:199;list-style:none;
  }
  .nav-links.open a{font-size:1.4rem}
  .nav-logo{text-align:left;padding-left:8px}
  .nav-right{gap:8px}
  .hamburger{display:flex}
  #hero{grid-template-columns:1fr;padding:60px 28px 40px}
  .hero-visual{display:none}
  .stats-bar{gap:32px;padding:40px 28px}
  section{padding:60px 28px}
  #portfolio{grid-template-columns:1fr;gap:40px;padding:60px 28px}
  #reviews{padding:60px 20px}
  .rev-stack{max-width:100%}
  .rev-card{padding:24px;margin-top:-28px}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gallery-img.tall{grid-row:auto}
  .gallery-img img{height:190px}
  .photo-break{background-attachment:scroll;min-height:260px}
  .split-section{grid-template-columns:1fr}
  .split-img{min-height:280px;border-right:none;border-bottom:var(--border)}
  .split-text{padding:48px 28px;gap:14px}
  .srv-grid{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr;gap:32px}
  footer{padding:48px 28px 32px}
  .form-row{grid-template-columns:1fr}
  .contact-info-grid{grid-template-columns:1fr}
  #kontakt{padding:60px 28px}
  .page-hero{padding:52px 28px 44px}
}
@media(max-width:480px){
  .stats-bar{gap:24px}
  .stat-num{font-size:2.4rem}
  .port-grid{grid-template-columns:repeat(3,1fr)}
  .rev-card{width:100%}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-img img{height:220px}
}
