/* ============================================================
   Verkstaden Selskapslokale — styles
   Design-tokens fra README/prototype, samlet som CSS-variabler
   slik at hele paletten kan byttes ett sted (se :root nederst).
   ============================================================ */

/* ---------- Design tokens ---------- */
:root {
  /* Bakgrunner */
  --bg:            #F4EEE3; /* warm cream */
  --bg-alt:        #EBE3D3; /* meny-seksjon */
  --bg-card:       #FBF7EF; /* private kort */
  --bg-input:      #FBF8F1;
  --dark:          #272019; /* bedrift + kontakt */
  --footer:        #1F1914;

  /* Tekst (lys bakgrunn) */
  --text:          #2A2620;
  --heading:       #241F19;
  --muted:         #5B5142;
  --muted-2:       #6B6052;
  --subtle:        #8A7C6A;

  /* Tekst (mørk bakgrunn) */
  --on-dark-h:     #EDE5D7;
  --on-dark-h2:    #F2EADC;
  --on-dark:       #B7AB99;
  --on-dark-2:     #A99D8B;
  --on-dark-3:     #C9BDAB;
  --on-dark-4:     #D8CCB9;
  --footer-text:   #9C9082;
  --footer-muted:  #6E645A;

  /* Aksent — terrakotta */
  --accent:        #C45D33; /* primær CTA, eyebrow */
  --accent-light:  #E08A5B; /* eyebrow på mørk / tall */
  --accent-dark:   #A0552F; /* eyebrow på lys */
  --accent-hover:  #AE4F28; /* CTA hover (litt mørkere) */
  --cta-text:      #F8F4EC;

  /* Hairlines */
  --line-light:    rgba(42,38,32,0.12);
  --line-light-2:  rgba(42,38,32,0.10);
  --line-light-3:  rgba(42,38,32,0.08);
  --line-light-22: rgba(42,38,32,0.22);
  --line-input:    rgba(42,38,32,0.20);
  --line-dark:     rgba(237,229,215,0.14);
  --line-dark-2:   rgba(237,229,215,0.16);
  --line-dark-3:   rgba(237,229,215,0.12);

  /* Layout */
  --maxw:          1240px;
  --pad-x:         32px;
  --radius:        3px;

  /* Fonter */
  --serif: 'Spectral', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', system-ui, -apple-system, sans-serif;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
::selection { background: var(--accent); color: var(--bg); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- Helpers ---------- */
.container { max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad-x); padding-right: var(--pad-x); }
.section   { padding-top: 96px; padding-bottom: 96px; }
.section-lg { padding-top: 104px; padding-bottom: 104px; }

.eyebrow {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-dark);
  font-weight: 600;
  margin-bottom: 22px;
}
.eyebrow--dark { color: var(--accent-light); }
.eyebrow--line { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 28px; }
.eyebrow--line::before { content: ""; width: 26px; height: 1px; background: var(--accent); display: inline-block; }

h1, h2, h3 { font-family: var(--serif); font-weight: 600; color: var(--heading); letter-spacing: -0.01em; }
h1 { font-size: 60px; line-height: 1.04; }
h2 { font-size: 42px; line-height: 1.1; }
.h2--lg { font-size: 44px; line-height: 1.08; }
h3 { font-size: 24px; line-height: 1.2; }

.lead { font-size: 19px; line-height: 1.6; color: var(--muted); }
.body { font-size: 17px; line-height: 1.7; color: var(--muted); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-block;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  padding: 15px 28px;
  border-radius: 2px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.btn--primary { background: var(--accent); color: var(--cta-text); }
.btn--primary:hover { background: var(--accent-hover); }
.btn--ghost { border-color: var(--line-light-22); color: var(--text); }
.btn--ghost:hover { border-color: var(--text); }
.btn--sm { font-size: 15px; padding: 14px 26px; white-space: nowrap; }

/* ============================================================
   Header / nav
   ============================================================ */
.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244,238,227,0.88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line-light-3);
}
.header__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad-x);
  height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.wordmark { text-decoration: none; color: var(--text); display: flex; flex-direction: column; line-height: 1; }
.wordmark__name { font-family: var(--serif); font-weight: 700; font-size: 24px; letter-spacing: 0.02em; }
.wordmark__kicker { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--subtle); margin-top: 4px; }

.nav { display: flex; align-items: center; gap: 30px; }
.nav__link { text-decoration: none; color: var(--muted); font-size: 15px; font-weight: 500; transition: color 0.15s ease; }
.nav__link:hover { color: var(--accent-dark); }
.nav__cta { text-decoration: none; background: var(--accent); color: var(--cta-text); font-size: 14px; font-weight: 600; padding: 11px 20px; border-radius: 2px; transition: background-color 0.18s ease; }
.nav__cta:hover { background: var(--accent-hover); }

/* Hamburger */
.nav-toggle {
  display: none; background: none; border: 0; cursor: pointer;
  width: 44px; height: 44px; padding: 10px; margin-right: -10px;
}
.nav-toggle span { display: block; height: 2px; background: var(--text); border-radius: 2px; transition: transform 0.25s ease, opacity 0.2s ease; }
.nav-toggle span + span { margin-top: 5px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   Hero
   ============================================================ */
.hero { max-width: var(--maxw); margin: 0 auto; padding: 84px var(--pad-x) 72px; }
.hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; align-items: center; }
.hero__title { margin-top: 0; }
.hero__lead { margin-top: 26px; max-width: 520px; }
.hero__cta { display: flex; gap: 14px; margin-top: 38px; flex-wrap: wrap; }
.hero__img { width: 100%; height: 560px; object-fit: cover; border-radius: var(--radius); }

.stats {
  margin-top: 64px;
  border-top: 1px solid var(--line-light);
  border-bottom: 1px solid var(--line-light);
  display: grid; grid-template-columns: repeat(4, 1fr);
}
.stats__cell { padding: 28px 24px; border-right: 1px solid var(--line-light-2); }
.stats__cell:last-child { border-right: 0; }
.stats__num { font-family: var(--serif); font-size: 30px; font-weight: 600; color: var(--heading); }
.stats__label { font-size: 13px; color: var(--subtle); margin-top: 4px; letter-spacing: 0.04em; }

/* ============================================================
   Om oss
   ============================================================ */
.about__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 64px; align-items: center; }
.about__img { width: 100%; height: 480px; object-fit: cover; border-radius: var(--radius); }
.about__p2 { margin-top: 18px; }
.about__stats { display: flex; gap: 36px; margin-top: 36px; }
.about__stat-num { font-family: var(--serif); font-size: 34px; font-weight: 600; color: var(--accent); }
.about__stat-label { font-size: 14px; color: var(--subtle); margin-top: 2px; }

/* ============================================================
   Bedrift (dark)
   ============================================================ */
.dark { background: var(--dark); color: var(--on-dark-h); }
.dark h2, .dark h3 { color: var(--on-dark-h2); }
.bedrift__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; flex-wrap: wrap; margin-bottom: 56px; }
.bedrift__head-text { max-width: 640px; }
.bedrift__intro { margin-top: 22px; color: var(--on-dark); }
.cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--line-dark); border: 1px solid var(--line-dark);
}
.card { background: var(--dark); padding: 34px 30px; }
.card__title { font-family: var(--serif); font-size: 22px; font-weight: 600; color: var(--on-dark-h2); }
.card__text { font-size: 15px; line-height: 1.6; color: var(--on-dark-2); margin-top: 12px; }

.bedrift__cols { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; margin-top: 64px; }
.setup-list { border-top: 1px solid var(--line-dark-2); }
.setup-row { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; border-bottom: 1px solid var(--line-dark-3); }
.setup-row__name { font-size: 16px; color: var(--on-dark-4); }
.setup-row__num { font-family: var(--serif); font-size: 18px; font-weight: 600; color: var(--accent-light); }
.setup-note { font-size: 13px; color: var(--subtle); margin-top: 14px; }

.kit { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; }
.kit__item { display: flex; align-items: center; gap: 11px; font-size: 15px; color: var(--on-dark-3); }
.kit__item::before { content: ""; width: 6px; height: 6px; background: var(--accent-light); border-radius: 50%; flex-shrink: 0; }

/* ============================================================
   Private fester
   ============================================================ */
.center { text-align: center; }
.privat__head { margin-bottom: 56px; }
.privat__intro { margin: 22px auto 0; max-width: 560px; }
.privat__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.privat-card { background: var(--bg-card); border: 1px solid var(--line-light-2); border-radius: var(--radius); overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.privat-card:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(42,38,32,0.10); }
.privat-card__img { width: 100%; height: 220px; object-fit: cover; }
.privat-card__body { padding: 24px 26px 28px; }
.privat-card__title { font-family: var(--serif); font-size: 22px; font-weight: 600; color: var(--heading); }
.privat-card__text { font-size: 15px; line-height: 1.6; color: var(--muted-2); margin-top: 10px; }

/* ============================================================
   Servering / meny
   ============================================================ */
.meny { background: var(--bg-alt); }
.meny__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.meny__list { margin-top: 32px; border-top: 1px solid rgba(42,38,32,0.14); }
.meny-row { padding: 18px 0; border-bottom: 1px solid var(--line-light-2); }
.meny-row--feature {
  background: var(--bg-card);
  border-left: 3px solid var(--accent);
  border-bottom: 1px solid var(--line-light-2);
  padding: 18px 18px 18px 18px;
  margin-bottom: 2px;
}
.meny-row--feature .meny-row__tag { color: var(--cta-text); background: var(--accent); padding: 3px 10px; border-radius: 2px; }
.meny-row__head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.meny-row__title { font-family: var(--serif); font-size: 19px; font-weight: 600; color: var(--heading); }
.meny-row__tag { font-size: 13px; color: var(--accent-dark); letter-spacing: 0.04em; white-space: nowrap; }
.meny-row__text { font-size: 14px; color: var(--muted-2); margin-top: 5px; }
.meny__imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.meny__imgs img { width: 100%; height: 300px; object-fit: cover; border-radius: var(--radius); }
.meny__imgs img:nth-child(2) { margin-top: 36px; }

/* ============================================================
   Galleri
   ============================================================ */
.galleri__head { margin-bottom: 48px; }
.galleri__grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; gap: 14px; }
.galleri__grid img { width: 100%; height: 100%; object-fit: cover; border-radius: 2px; }
.gallery-feature { grid-column: span 2; grid-row: span 2; }
.gallery-wide { grid-column: span 2; }

/* ============================================================
   Kontakt (dark)
   ============================================================ */
.kontakt__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 72px; }
.kontakt__intro { margin-top: 22px; color: var(--on-dark); max-width: 420px; }
.kontakt__details { margin-top: 44px; display: flex; flex-direction: column; gap: 24px; }
.detail__label { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--subtle); }
.detail__value { font-family: var(--serif); font-size: 22px; color: var(--on-dark-h2); margin-top: 5px; text-decoration: none; display: inline-block; transition: color 0.15s ease; }
a.detail__value:hover { color: var(--accent-light); }

.form-card { background: var(--bg); border-radius: 4px; padding: 38px 36px; color: var(--text); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 7px; font-size: 13px; font-weight: 600; color: var(--muted); }
.field--full { grid-column: span 2; }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: 15px; padding: 12px 14px;
  border: 1px solid var(--line-input); border-radius: 2px;
  background: var(--bg-input); color: var(--text);
}
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); }
.form__submit { grid-column: span 2; margin-top: 4px; width: 100%; }
.form__error { grid-column: span 2; color: var(--accent); font-size: 14px; font-weight: 600; display: none; }
.form__error.is-visible { display: block; }
/* honeypot (skjult for mennesker) */
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.thanks { min-height: 420px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.thanks__check { width: 56px; height: 56px; border-radius: 50%; background: var(--accent); color: var(--cta-text); display: flex; align-items: center; justify-content: center; font-size: 28px; font-family: var(--serif); }
.thanks__title { font-family: var(--serif); font-size: 26px; font-weight: 600; margin-top: 22px; color: var(--heading); }
.thanks__text { font-size: 16px; color: var(--muted-2); margin-top: 10px; max-width: 320px; }
[hidden] { display: none !important; }

/* ============================================================
   Footer
   ============================================================ */
.footer { background: var(--footer); color: var(--footer-text); }
.footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 48px var(--pad-x); display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer__brand { display: flex; flex-direction: column; line-height: 1; }
.footer__name { font-family: var(--serif); font-weight: 700; font-size: 22px; color: var(--on-dark-h); }
.footer__kicker { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; margin-top: 5px; }
.footer__contact { font-size: 14px; }
.footer__contact a { text-decoration: none; transition: color 0.15s ease; }
.footer__contact a:hover { color: var(--on-dark-h); }
.footer__meta { font-size: 13px; color: var(--footer-muted); display: flex; align-items: center; gap: 16px; }
.footer__fb { text-decoration: none; color: var(--footer-text); transition: color 0.15s ease; }
.footer__fb:hover { color: var(--on-dark-h); }

/* ============================================================
   Responsivt
   ============================================================ */
@media (max-width: 980px) {
  h1 { font-size: 46px; }
  h2, .h2--lg { font-size: 34px; }

  .hero__grid, .about__grid, .meny__grid, .kontakt__grid { grid-template-columns: 1fr; gap: 40px; }
  .about__grid .about__img-wrap { order: -1; }
  .hero__img { height: 380px; }
  .about__img { height: 360px; }

  .cards { grid-template-columns: repeat(2, 1fr); }
  .bedrift__cols { grid-template-columns: 1fr; gap: 40px; }
  .privat__grid { grid-template-columns: repeat(2, 1fr); }

  .meny__imgs img:nth-child(2) { margin-top: 0; }

  /* Galleri: 2 kolonner, dropp span-triks for jevnt rutenett */
  .galleri__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
  .gallery-feature, .gallery-wide { grid-column: auto; grid-row: auto; }

  /* Mobil-nav */
  .nav-toggle { display: block; }
  .nav {
    position: absolute; top: 76px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--bg); border-bottom: 1px solid var(--line-light);
    padding: 8px var(--pad-x) 20px;
    box-shadow: 0 12px 24px rgba(42,38,32,0.08);
    display: none;
  }
  .nav.is-open { display: flex; }
  .nav__link { padding: 14px 0; border-bottom: 1px solid var(--line-light-3); font-size: 17px; }
  .nav__cta { margin-top: 14px; text-align: center; font-size: 16px; padding: 14px 20px; }
}

@media (max-width: 620px) {
  :root { --pad-x: 20px; }
  h1 { font-size: 38px; }
  h2, .h2--lg { font-size: 28px; }
  .lead { font-size: 17px; }
  .section, .section-lg { padding-top: 64px; padding-bottom: 64px; }
  .hero { padding-top: 48px; padding-bottom: 48px; }

  .stats { grid-template-columns: repeat(2, 1fr); }
  .stats__cell:nth-child(2) { border-right: 0; }
  .stats__cell:nth-child(1), .stats__cell:nth-child(2) { border-bottom: 1px solid var(--line-light-2); }

  .cards { grid-template-columns: 1fr; }
  .privat__grid { grid-template-columns: 1fr; }
  .meny__imgs { grid-template-columns: 1fr; }
  .galleri__grid { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .kit { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .field--full, .form__submit, .form__error { grid-column: auto; }
  .btn { width: 100%; text-align: center; }
  .hero__cta { flex-direction: column; }

  .bedrift__head { flex-direction: column; align-items: flex-start; }
  .footer__inner { flex-direction: column; align-items: flex-start; }
}
