/* --- Tokens / variables --- */
:root{
  --bg:#fdfdfd;
  --text:#333;
  --muted:#666;
  --brand:#ff4da6;
  --brand-2:#ff99cc;
  --card:#fff;
  --border:#eee;
  --shadow:0 8px 24px rgba(0,0,0,.06);
  --radius:14px;
}

/* --- Global Reset --- */
*{ margin:0; padding:0; box-sizing:border-box; }
html,body{ height:100%; }
body{
  font-family: Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* --- Layout helpers --- */
.container{
  width:min(1100px, 92vw);
  margin-inline:auto;
  padding:16px 0;
}
.stack > * + *{ margin-top:16px; }

/* --- Header / Nav --- */
header{
  background:var(--brand);
  color:#fff;
  border-bottom:5px solid var(--brand-2);
  box-shadow:var(--shadow);
}
header .container{ padding:18px 0; }

header h1{
  font-size:clamp(20px, 4.2vw, 28px);
  letter-spacing:.3px;
  text-align:center;
  margin-bottom:10px;
}

/* nav: mobile-first: wrap to multiple lines gracefully */
nav ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px 16px;
  padding-bottom:4px;
}
nav a{
  color:#fff;
  text-decoration:none;
  font-weight:bold;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
  transition:all .18s ease;
  white-space:nowrap;
}
nav a:hover{ background:rgba(255,255,255,.15); transform:translateY(-1px); }

/* --- Main content --- */
main{ padding:22px 0 28px; }

/* section titles */
h2{
  font-size:clamp(18px, 3.6vw, 24px);
  margin-bottom:10px;
}
.lead{
  color:var(--muted);
  font-size:clamp(14px, 3.2vw, 16px);
}

/* --- Cards Grid (for categories / products) --- */
.grid{
  display:grid;
  grid-template-columns:repeat(1, 1fr);
  gap:16px;
  margin-top:14px;
}
@media (min-width:520px){ .grid{ grid-template-columns:repeat(2, 1fr);} }
@media (min-width:860px){ .grid{ grid-template-columns:repeat(3, 1fr);} }

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{ transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,0,0,.08); }
.card h3{ margin-bottom:8px; font-size:18px; }
.card p{ color:var(--muted); font-size:14px; }

/* optional image block if/when you add images */
.card .img{
  width:100%; aspect-ratio: 16/10; border-radius:10px; background:#fafafa; border:1px solid var(--border);
  margin-bottom:10px;
}

/* badges & buttons (for CTAs/links) */
.badge{
  display:inline-block; font-size:12px; padding:4px 8px; border-radius:999px;
  background:#fff0f6; color:#cc2e72; border:1px solid #ffd6e7; margin-bottom:8px;
}
.btn{
  display:inline-block; background:var(--brand); color:#fff; text-decoration:none;
  padding:10px 14px; border-radius:10px; font-weight:bold; border:1px solid var(--brand-2);
  transition:all .18s ease;
}
.btn:hover{ filter:brightness(1.05); transform:translateY(-1px); }

/* --- Footer --- */
footer{
  margin-top:30px;
  background:#fff;
  border-top:1px solid var(--border);
  color:var(--muted);
  padding:18px 0;
  text-align:center;
  font-size:14px;
}

/* --- Utilities --- */
.m-t-8{ margin-top:8px; } .m-t-16{ margin-top:16px; } .m-t-24{ margin-top:24px; }
.center{ text-align:center; }
/* ==== THEME OVERRIDES (Green) ==== */
:root{
  --brand: #2e7d32;        /* grønn */
  --brand-dark: #1b5e20;
  --brand-light: #e8f5e9;
  --text: #222;
  --muted: #555;
  --border: #e5e7eb;
}

header{
  background: linear-gradient(180deg, var(--brand), var(--brand-dark));
  color:#fff;
  border-bottom:5px solid #a5d6a7; /* lys grønn kant */
}

nav a{ color:#fff; }
nav a:hover,
nav a[aria-current="page"]{ 
  background: rgba(255,255,255,.18);
  border-radius: 999px;
}

a{ color: var(--brand-dark); }
a:hover{ color: var(--brand); }

.btn{
  background: var(--brand);
  color:#fff;
  border: none;
}
.btn:hover{ background: var(--brand-dark); }

.card{ border:1px solid var(--border); background:#fff; }
.lead a{ color: var(--brand); }
/* Contact layout */
.contact main,
main.contact{ padding: 20px; }
.contact .wrap{ max-width: 720px; margin: 0 auto; }
.contact form{ max-width: 560px; margin: 0 auto; }
.contact label{ display:block; margin:12px 0 6px; font-weight:600; }
.contact input, .contact textarea{
  width:100%; padding:12px 14px; border:1px solid var(--border);
  border-radius:12px; font: inherit;
}
.contact .btn{ margin-top: 14px; }