*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root { --green: #5C7A4E; }
html { scroll-behavior: smooth; }
body { font-family: 'Barlow', sans-serif; background: #fff; color: #1a1a18; font-size: 15px; font-weight: 300; }

/* NAV */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; justify-content: space-between; align-items: stretch;
  background: rgba(255,255,255,0.96);
  border-bottom: 0.5px solid #f0f0ec;
  height: 72px;
}
.nav-logo { display: flex; align-items: stretch; text-decoration: none; }
.nav-logo img { display: block; height: 72px; width: 72px; object-fit: contain; object-position: left center; background: #5C7A4E; }
.nav-links { display: flex; gap: 2rem; list-style: none; align-items: center; padding-right: 2rem; }
.nav-links a { font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: #888; text-decoration: none; font-weight: 300; transition: color 0.2s; }
.nav-links a:hover, .nav-links a.active { color: #1a1a18; }

/* FOOTER */
footer { padding: 2.5rem 2rem; display: flex; justify-content: space-between; align-items: center; border-top: 0.5px solid #e8e8e4; }
.footer-copy { font-size: 0.68rem; letter-spacing: 0.1em; color: #bbb; font-weight: 300; text-transform: uppercase; }
.footer-links { display: flex; gap: 2rem; }
.footer-links a { font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: #888; text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: #1a1a18; }

/* GALLERY FORSIDE */
.grid-wrap { padding-top: 72px; }

/* PROSJEKTSIDE */
.project-wrap { padding-top: 72px; }
.project-hero-img { display: block; width: 100%; aspect-ratio: 16/7; object-fit: cover; }

.project-info {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 4rem; padding: 3.5rem 2rem;
  border-bottom: 0.5px solid #e8e8e4;
}
.project-meta { display: flex; flex-direction: column; gap: 1.5rem; }
.meta-label { font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: #bbb; font-weight: 300; margin-bottom: 0.2rem; }
.meta-val { font-size: 0.88rem; color: #1a1a18; font-weight: 300; }
.project-desc { font-size: 0.95rem; color: #444; line-height: 1.95; font-weight: 300; max-width: 56ch; }
.project-desc p { margin-bottom: 1.25rem; }
.project-desc p:last-child { margin-bottom: 0; }

/* Masonry på prosjektside */
.project-masonry { columns: 2; column-gap: 0; }
.project-masonry-item { break-inside: avoid; overflow: hidden; display: block; }
.project-masonry-item img { display: block; width: 100%; height: auto; }

.project-nav-bar { display: flex; justify-content: space-between; align-items: center; padding: 2rem; border-top: 0.5px solid #e8e8e4; }
.project-nav-bar a { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: #888; text-decoration: none; transition: color 0.2s; }
.project-nav-bar a:hover { color: #1a1a18; }

/* OM-SIDE */
.page-wrap { padding-top: 72px; min-height: 80vh; }
.page-inner { max-width: 580px; margin: 0 auto; padding: 5rem 2rem; }
.about-img { width: 100%; height: auto; display: block; margin-bottom: 3.5rem; }
.page-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: #bbb; font-weight: 300; margin-bottom: 2.5rem; display: block; }
.page-body { font-size: 1rem; color: #444; line-height: 1.9; font-weight: 300; margin-bottom: 1.5rem; }
.contact-row { display: flex; flex-direction: column; margin-top: 3rem; padding-top: 2.5rem; border-top: 0.5px solid #e8e8e4; }
.contact-item { margin-bottom: 1rem; }
.contact-label { font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: #bbb; font-weight: 300; margin-bottom: 0.2rem; display: block; }
.contact-row a { font-size: 0.88rem; color: #1a1a18; text-decoration: none; transition: color 0.2s; }
.contact-row a:hover { color: var(--green); }

@media (max-width: 600px) {
  nav { height: 60px; }
  .nav-logo img { height: 60px; width: 60px; }
  .grid-wrap { padding-top: 60px; }
  .project-wrap { padding-top: 60px; }
  .page-wrap { padding-top: 60px; }
  .project-info { grid-template-columns: 1fr; gap: 2rem; }
  footer { flex-direction: column; gap: 1rem; align-items: flex-start; }
}
