*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:"Montserrat",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#14212a;background:#f5f1e9;line-height:1.6}img{max-width:100%;display:block}a{color:inherit}.site-header{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:1rem clamp(1rem,4vw,4rem);background:rgba(12,24,32,.92);color:#fff;backdrop-filter:blur(12px)}.brand{font-weight:800;text-decoration:none;letter-spacing:.03em}.site-header nav{display:flex;gap:1rem;flex-wrap:wrap;font-size:.9rem}.site-header nav a{text-decoration:none;opacity:.82}.site-header nav a:hover{opacity:1}.hero{min-height:78vh;display:grid;align-items:end;padding:clamp(2rem,6vw,6rem);color:#fff;background:linear-gradient(180deg,rgba(12,24,32,.12),rgba(12,24,32,.88)),url("../img/hero-boat.jpg") center/cover}.hero__content{max-width:880px}.eyebrow{margin:0 0 .75rem;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:#444444}.hero .eyebrow{color:#ffffff}h1,h2,h3{margin:0 0 1rem;line-height:1.1}h1{font-size:clamp(2.5rem,7vw,5.9rem);letter-spacing:-.06em}h2{font-size:clamp(2rem,4vw,3.7rem);letter-spacing:-.045em}h3{font-size:1.2rem}.lead{max-width:680px;font-size:clamp(1.05rem,2vw,1.35rem)}.price-pill{display:inline-flex;margin:1.1rem 0 0;padding:.65rem 1rem;border:1px solid rgba(255,255,255,.38);border-radius:999px;background:rgba(255,255,255,.12);font-weight:800}.hero__actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}.button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.75rem 1.15rem;border-radius:999px;background:#fff;color:#14212a;text-decoration:none;font-weight:800}.button--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.72)}.section{padding:clamp(3rem,7vw,6rem) clamp(1rem,4vw,4rem)}.intro-grid,.two-col,.contact{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.75fr);gap:clamp(2rem,5vw,4rem);align-items:start}.quote-card,.notice-card,.contact-card,.feature-grid article,.spec-grid div{background:#fff;border-radius:24px;box-shadow:0 18px 45px rgba(20,33,42,.08)}.quote-card{padding:2rem;min-height:260px;display:flex;flex-direction:column;justify-content:flex-end;background:#14212a;color:#fff}.quote-card span{opacity:.7}.quote-card strong{font-size:clamp(2rem,4vw,4rem);line-height:1;font-weight:800;letter-spacing:-.05em}.feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;padding-top:0}.feature-grid article,.notice-card,.contact-card{padding:1.5rem}.specs-section{background:#ebe4d7}.section-header{max-width:780px;margin-bottom:2rem}.spec-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.spec-grid div{padding:1.2rem}.spec-grid .wide{grid-column:span 2}dt{font-weight:800;margin-bottom:.35rem}dd{margin:0}.gallery{columns:4 260px;column-gap:1rem}.gallery figure{break-inside:avoid;margin:0 0 1rem;overflow:hidden;border-radius:22px;background:#fff;box-shadow:0 12px 30px rgba(20,33,42,.08)}.gallery img{width:100%;height:auto;background:#ded8cc}.gallery figcaption{padding:.8rem 1rem;font-size:.9rem;font-weight:700}.viewer-section{background:#14212a;color:#fff}.viewer-section .eyebrow{color:#ddc8a4}.viewer-frame{width:100%;height:min(76vh,760px);min-height:420px;border-radius:26px;overflow:hidden;background:#07090c;box-shadow:0 25px 70px rgba(0,0,0,.35)}.viewer-frame iframe{width:100%;height:100%;border:0;display:block}.contact-card a{font-weight:800}.site-footer{padding:2rem;text-align:center;color:#fff;background:#0c1820}code{padding:.12rem .3rem;border-radius:4px;background:rgba(20,33,42,.08)}@media(max-width:1100px){.feature-grid,.spec-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:850px){.intro-grid,.two-col,.contact{grid-template-columns:1fr}.site-header{align-items:flex-start;flex-direction:column}.hero{min-height:70vh}.viewer-frame{height:70vh}}@media(max-width:560px){.feature-grid,.spec-grid{grid-template-columns:1fr}.spec-grid .wide{grid-column:auto}.gallery{columns:1}.site-header nav{gap:.65rem}.viewer-frame{min-height:360px;height:62vh}}

/* Klickbart galleri + lightbox */
.gallery a.gallery-link {
  display: block;
  color: inherit;
  text-decoration: none;
  cursor: zoom-in;
}

.gallery figure {
  position: relative;
}

.gallery img {
  width: 100%;
  max-height: 520px;
  object-fit: cover;
}

/* Hjälper ett blandat galleri med både stående och liggande bilder */
.gallery figure:nth-child(3n) {
  grid-row: span 2;
}

.gallery figure:nth-child(3n) img {
  aspect-ratio: 3 / 4;
}

.gallery figure:nth-child(4n) img {
  aspect-ratio: 16 / 10;
}

.viewer-shell--iframe {
  padding: 0;
  overflow: hidden;
  border-radius:26px;
}

.viewer-iframe {
  display: block;
  width: 100%;
  min-height: min(72vh, 760px);
  border: 0;
  background: #172026;
  border-radius:26px;
}

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  grid-template-columns: 72px minmax(0, 1fr) 72px;
  grid-template-rows: 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: clamp(1rem, 3vw, 2rem);
  background: rgba(9, 13, 16, 0.92);
  color: #fff;
}

.lightbox.is-open {
  display: grid;
}

.lightbox__image {
  grid-column: 2;
  max-width: 100%;
  max-height: 82vh;
  margin: auto;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 20px 70px rgba(0,0,0,0.45);
}

.lightbox__caption {
  grid-column: 2;
  margin: 0;
  text-align: center;
  color: rgba(255,255,255,0.82);
}

.lightbox__close,
.lightbox__nav {
  border: 0;
  color: #fff;
  background: rgba(255,255,255,0.12);
  cursor: pointer;
}

.lightbox__close:hover,
.lightbox__nav:hover {
  background: rgba(255,255,255,0.22);
}

.lightbox__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  font-size: 2rem;
  line-height: 1;
}

.lightbox__nav {
  width: 56px;
  height: 72px;
  border-radius: 999px;
  font-size: 3rem;
  line-height: 1;
}

.lightbox__nav--prev {
  grid-column: 1;
  justify-self: center;
}

.lightbox__nav--next {
  grid-column: 3;
  justify-self: center;
}

body.lightbox-open {
  overflow: hidden;
}

@media (max-width: 700px) {
  .lightbox {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr auto auto;
  }

  .lightbox__image,
  .lightbox__caption {
    grid-column: 1 / -1;
  }

  .lightbox__nav {
    grid-row: 3;
    width: 100%;
    height: 48px;
    font-size: 2rem;
  }

  .lightbox__nav--prev {
    grid-column: 1;
  }

  .lightbox__nav--next {
    grid-column: 2;
  }

  .viewer-iframe {
    min-height: 520px;
  }
}
