/* === Scandinavian Hay Days === */

:root{
  --rod:#c0322b;
  --rod-mork:#8e1f1a;
  --gul:#f5b800;
  --gul-djup:#e89c00;
  --bla:#2c6fa6;
  --bla-djup:#1d4f7a;
  --gron:#3a7a3a;
  --tra:#7a4a25;
  --tra-mork:#4a2c14;
  --tra-ljus:#a0673a;
  --kram:#fbf3e2;
  --kram-mork:#f1e3c1;
  --himmel:#bfdcef;
  --solskygga:#fff7e3;
  --svart:#1d130b;
  --skugga: 0 6px 0 rgba(0,0,0,.18), 0 14px 30px rgba(0,0,0,.18);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Work Sans',system-ui,sans-serif;
  color:var(--svart);
  background:var(--kram);
  line-height:1.55;
  font-size:17px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--rod-mork);text-decoration-thickness:2px;text-underline-offset:3px}
a:hover{color:var(--rod)}

/* === Topbar === */
.topbar{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px;
  background:linear-gradient(180deg,#3a2412 0%,#5a3620 100%);
  border-bottom:4px solid var(--gul);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
.brand{
  display:flex; align-items:center; gap:10px;
  color:var(--solskygga); text-decoration:none;
  font-family:'Alfa Slab One',serif;
  letter-spacing:.5px;
}
.brand-mark{
  display:inline-grid; place-items:center;
  width:38px; height:38px; border-radius:8px;
  background:var(--gul); color:var(--tra-mork);
  font-size:14px;
  box-shadow:inset 0 -3px 0 var(--gul-djup);
}
.brand-logo{
  height:46px; width:auto; display:block;
  background:#fff; border-radius:9px; padding:3px;
  box-shadow:0 2px 6px rgba(0,0,0,.25);
}
.brand-text{font-size:18px}
.nav{display:flex; gap:6px; align-items:center}
.nav a{
  color:var(--solskygga); text-decoration:none;
  padding:8px 12px; border-radius:6px;
  font-weight:500; font-size:15px;
  transition:background .15s;
}
.nav a:hover{background:rgba(255,255,255,.08)}
.nav-cta{
  background:var(--rod); color:#fff !important;
  box-shadow:inset 0 -3px 0 var(--rod-mork);
}
.nav-cta:hover{background:var(--rod-mork) !important}
.menu-toggle{
  display:none;
  background:transparent; border:0; padding:6px; cursor:pointer;
}
.menu-toggle span{
  display:block; width:26px; height:3px; margin:5px 0;
  background:var(--solskygga); border-radius:2px;
  transition:transform .2s, opacity .2s;
}

@media (max-width:880px){
  .menu-toggle{display:block}
  .brand-text{font-size:15px}
}
@media (max-width:420px){
  .brand-text{display:none}
}
@media (max-width:880px){
  .nav{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#3a2412; padding:10px;
    border-bottom:4px solid var(--gul);
    transform:translateY(-110%); transition:transform .25s;
  }
  .nav.open{transform:translateY(0)}
  .nav a{padding:14px}
}

/* === Hero === */
.hero{
  position:relative;
  background:
    radial-gradient(circle at 70% 20%, #d8edfb 0%, transparent 60%),
    linear-gradient(180deg, var(--himmel) 0%, var(--solskygga) 70%, var(--kram) 100%);
  padding:30px 18px 60px;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background-image:
    radial-gradient(2px 2px at 10% 30%, rgba(255,255,255,.7), transparent),
    radial-gradient(2px 2px at 80% 15%, rgba(255,255,255,.7), transparent),
    radial-gradient(2px 2px at 40% 70%, rgba(255,255,255,.4), transparent);
  pointer-events:none;
}
.hero-inner{
  position:relative;
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:40px;
  align-items:center;
}
.vimplar{
  position:absolute; top:-10px; left:-30px; right:-30px;
  display:flex; justify-content:space-between;
  pointer-events:none;
}
.vimplar span{
  width:30px; height:42px;
  clip-path:polygon(0 0,100% 0,50% 100%);
  transform-origin:top center;
  animation:sway 3s ease-in-out infinite;
}
.vimplar span:nth-child(1){background:var(--rod); animation-delay:.0s}
.vimplar span:nth-child(2){background:var(--gul); animation-delay:.2s}
.vimplar span:nth-child(3){background:var(--bla); animation-delay:.4s}
.vimplar span:nth-child(4){background:var(--gron); animation-delay:.6s}
.vimplar span:nth-child(5){background:var(--rod); animation-delay:.8s}
.vimplar span:nth-child(6){background:var(--gul); animation-delay:1.0s}
.vimplar span:nth-child(7){background:var(--bla); animation-delay:1.2s}
.vimplar span:nth-child(8){background:var(--gron); animation-delay:1.4s}
.vimplar span:nth-child(9){background:var(--rod); animation-delay:1.6s}
.vimplar span:nth-child(10){background:var(--gul); animation-delay:1.8s}
@keyframes sway{
  0%,100%{transform:rotate(-3deg)}
  50%{transform:rotate(3deg)}
}

.hero-content{padding-top:30px}
.kicker{
  display:inline-block;
  font-family:'Caveat',cursive; font-size:24px;
  color:var(--rod-mork);
  background:var(--solskygga);
  padding:2px 14px; border-radius:20px;
  transform:rotate(-2deg);
  margin:0 0 12px;
}
.hero h1{
  font-family:'Alfa Slab One',serif;
  font-size:clamp(48px, 9vw, 96px);
  line-height:.95; margin:0 0 12px;
  color:var(--tra-mork);
  text-shadow: 4px 4px 0 var(--gul), 8px 8px 0 rgba(0,0,0,.1);
  letter-spacing:.5px;
}
.hero h1 em{
  font-style:normal;
  color:var(--rod);
  text-shadow: 4px 4px 0 var(--gul), 8px 8px 0 rgba(0,0,0,.1);
}
.tagline{
  font-family:'Caveat',cursive; font-weight:700;
  font-size:32px; color:var(--bla-djup);
  margin:0 0 28px;
  transform:rotate(-1deg);
}
.hero-meta{
  display:flex; gap:20px; align-items:center;
  margin:0 0 28px; flex-wrap:wrap;
}
.datum{
  background:var(--svart); color:var(--gul);
  padding:14px 20px; border-radius:8px;
  font-family:'Alfa Slab One',serif;
  display:flex; align-items:baseline; gap:8px;
  box-shadow:var(--skugga);
  border:3px solid var(--gul);
}
.datum-num{font-size:34px; line-height:1}
.datum-sep{font-size:24px; color:var(--solskygga)}
.datum-ar{font-size:18px; color:var(--solskygga); margin-left:6px}
.plats{
  font-size:17px; line-height:1.3;
  background:var(--kram); padding:10px 16px;
  border:3px dashed var(--tra);
  border-radius:6px;
  color:var(--tra-mork);
}
.plats strong{font-family:'Alfa Slab One',serif; font-size:20px}
.hero-ctas{display:flex; gap:14px; flex-wrap:wrap}

.btn{
  display:inline-block;
  font-family:'Work Sans',sans-serif; font-weight:700;
  text-decoration:none;
  padding:14px 26px; border-radius:8px;
  transition:transform .1s, box-shadow .1s;
  font-size:17px;
}
.btn-primary{
  background:var(--rod); color:#fff !important;
  box-shadow:0 4px 0 var(--rod-mork), 0 8px 16px rgba(0,0,0,.2);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 0 var(--rod-mork), 0 12px 22px rgba(0,0,0,.25);
}
.btn-primary:active{
  transform:translateY(2px);
  box-shadow:0 2px 0 var(--rod-mork);
}
.btn-ghost{
  background:transparent; color:var(--tra-mork) !important;
  border:3px solid var(--tra-mork);
  box-shadow:0 4px 0 rgba(0,0,0,.1);
}
.btn-ghost:hover{
  background:var(--tra-mork); color:var(--solskygga) !important;
}

.hero-affisch{
  position:relative;
  transform:rotate(2deg);
  filter:drop-shadow(0 20px 30px rgba(0,0,0,.25));
}
.hero-affisch img{
  width:100%; border-radius:6px;
  border:8px solid var(--solskygga);
  box-shadow:0 0 0 2px var(--tra);
}
.hero-affisch::before{
  content:""; position:absolute;
  top:-18px; left:50%; transform:translateX(-50%) rotate(-4deg);
  width:80px; height:24px;
  background:rgba(245,184,0,.7);
  border:1px solid rgba(0,0,0,.15);
  z-index:2;
}

@media (max-width:880px){
  .hero-inner{grid-template-columns:1fr; gap:30px}
  .hero h1{text-shadow: 3px 3px 0 var(--gul), 5px 5px 0 rgba(0,0,0,.1)}
  .hero h1 em{text-shadow: 3px 3px 0 var(--gul), 5px 5px 0 rgba(0,0,0,.1)}
  .hero-affisch{transform:rotate(0)}
}

/* === Sektioner === */
.section{padding:80px 18px; position:relative}
.wrap{max-width:1100px; margin:0 auto}
.wrap.centered{text-align:center; max-width:760px}
.eyebrow{
  font-family:'Caveat',cursive; font-weight:700;
  color:var(--rod); font-size:26px;
  margin:0 0 6px; transform:rotate(-1deg);
  display:inline-block;
}
.section h2{
  font-family:'Alfa Slab One',serif;
  font-size:clamp(32px, 5vw, 52px);
  line-height:1.05; margin:0 0 32px;
  color:var(--tra-mork);
}
.hl{
  background:linear-gradient(180deg, transparent 60%, var(--gul) 60%);
  padding:0 4px;
}
.lead{font-size:19px; line-height:1.65; margin:0 0 18px}
.lead-grid{display:grid; grid-template-columns:1fr 1fr; gap:30px}
@media (max-width:760px){.lead-grid{grid-template-columns:1fr}}

.section-event{
  background:var(--kram-mork);
  background-image:
    repeating-linear-gradient(45deg, transparent 0 24px, rgba(122,74,37,.04) 24px 25px);
  border-top:6px solid var(--rod);
  border-bottom:6px solid var(--rod);
}

/* === Historien === */
.section-historien{
  background:var(--tra-mork);
  color:var(--kram);
  border-top:6px solid var(--gul);
  border-bottom:6px solid var(--gul);
}
.historien-grid{
  display:grid; grid-template-columns:1fr auto; gap:50px;
  align-items:center;
}
@media (max-width:820px){
  .historien-grid{grid-template-columns:1fr; gap:30px}
}
.section-historien .eyebrow{color:var(--gul)}
.section-historien h2{color:var(--kram)}
.section-historien .hl{
  background:linear-gradient(180deg, transparent 60%, var(--rod) 60%);
  color:var(--kram);
}
.section-historien .lead{color:var(--kram)}
.historien-text p{color:rgba(251,243,226,.9); margin:0 0 16px; line-height:1.65}
.historien-text strong{color:var(--gul)}
.historien-avslut{
  font-family:'Caveat',cursive; font-weight:700;
  font-size:30px; color:var(--gul) !important;
  margin-top:8px !important;
}
.historien-stamp{display:flex; justify-content:center}
.stamp{
  width:200px; height:200px;
  border-radius:50%;
  background:radial-gradient(circle at 50% 40%, var(--rod) 0%, var(--rod-mork) 100%);
  border:6px double var(--gul);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; color:var(--kram);
  font-family:'Alfa Slab One',serif;
  transform:rotate(-8deg);
  box-shadow:0 14px 30px rgba(0,0,0,.4);
}
.stamp-sedan{font-size:18px; letter-spacing:2px; text-transform:uppercase; opacity:.9}
.stamp-ar{font-size:56px; line-height:1; color:var(--gul); margin:2px 0}
.stamp-jub{font-size:18px; line-height:1.1; letter-spacing:1px}
@media (max-width:820px){
  .stamp{width:160px; height:160px}
  .stamp-ar{font-size:44px}
}

/* === Aktiviteter (kort) === */
.section-grid{background:var(--kram)}
.aktiviteter{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:22px;
}
.kort{
  background:#fff;
  padding:28px 24px;
  border-radius:10px;
  border:3px solid var(--svart);
  box-shadow:6px 6px 0 var(--svart);
  transition:transform .15s, box-shadow .15s;
  position:relative;
}
.kort:hover{
  transform:translate(-2px,-2px);
  box-shadow:8px 8px 0 var(--svart);
}
.kort-ikon{
  font-size:42px; margin-bottom:10px;
  display:inline-block;
  line-height:1;
}
.kort.has-bild{
  padding:0; overflow:hidden;
}
.kort-bild{
  width:100%; height:180px;
  background-size:cover;
  background-position:center;
  border-bottom:3px solid var(--svart);
}
.kort-text{padding:24px 24px 28px}
.kort.has-bild h3{margin-top:0}
.kort h3{
  font-family:'Alfa Slab One',serif;
  font-size:22px; margin:0 0 8px;
  color:var(--tra-mork);
}
.kort p{margin:0; line-height:1.5}
.kort-rod{background:#fff5f4}
.kort-rod h3{color:var(--rod-mork)}
.kort-bla{background:#eff6fc}
.kort-bla h3{color:var(--bla-djup)}
.kort-gul{background:#fff8dd}
.kort-gul h3{color:var(--gul-djup)}
.kort-gron{background:#eef7ee}
.kort-gron h3{color:var(--gron)}

/* === Tävling === */
.section-tavling{background:var(--kram)}
.lead-bred{max-width:820px}
.tavling-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:20px; margin:36px 0 24px;
}
.tavling-kort{
  background:#fff;
  border:3px solid var(--svart);
  border-left:8px solid var(--rod);
  border-radius:10px;
  padding:24px;
  box-shadow:5px 5px 0 var(--svart);
}
.tavling-kort h3{
  font-family:'Alfa Slab One',serif;
  font-size:20px; margin:0 0 10px;
  color:var(--rod-mork);
}
.tavling-kort p{margin:0; line-height:1.5}
.tavling-note{margin-top:10px}
.klasser-block{
  background:var(--svart);
  border-radius:12px;
  padding:30px 34px;
  margin:36px 0 28px;
  border:3px solid var(--gul);
  box-shadow:6px 6px 0 rgba(0,0,0,.25);
}
.klasser-rubrik{
  font-family:'Alfa Slab One',serif;
  color:var(--gul); font-size:24px;
  margin:0 0 20px;
}
.klasser-lista{
  list-style:none; padding:0; margin:0;
  counter-reset:klass;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:10px 30px;
}
.klasser-lista li{
  counter-increment:klass;
  display:flex; align-items:baseline; gap:12px;
  padding:12px 0;
  border-bottom:1px dashed rgba(255,255,255,.18);
  color:var(--kram);
}
.klasser-lista li::before{
  content:counter(klass);
  flex:0 0 auto;
  width:30px; height:30px;
  display:inline-grid; place-items:center;
  background:var(--rod); color:#fff;
  border-radius:50%;
  font-family:'Alfa Slab One',serif; font-size:14px;
}
.klass-namn{
  font-weight:700; font-size:18px;
  color:var(--solskygga);
  flex:1;
}
.klass-spec{
  font-size:15px; color:var(--gul);
  text-align:right;
}

/* === Besökare === */
.section-besokare{
  background:var(--bla-djup);
  color:var(--solskygga);
}
.section-besokare h2{color:var(--solskygga)}
.section-besokare .eyebrow{color:var(--gul)}
.info-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:24px;
  align-items:start;
}
.info-block{
  background:rgba(255,255,255,.06);
  padding:24px;
  border-radius:8px;
  border-left:5px solid var(--gul);
}
.info-block h3{
  font-family:'Alfa Slab One',serif;
  margin:0 0 10px; color:var(--gul);
  font-size:20px;
}
.info-block p{margin:0 0 10px; line-height:1.55}
.liten{font-size:14px; opacity:.75}
.btn-mini{
  display:inline-block;
  background:var(--gul); color:var(--tra-mork) !important;
  font-weight:700; font-size:15px;
  padding:10px 16px; border-radius:6px;
  text-decoration:none;
  box-shadow:0 3px 0 var(--gul-djup);
  transition:transform .1s;
}
.btn-mini:hover{transform:translateY(-1px); color:var(--tra-mork) !important}

/* === Utställare === */
.section-utstallare{
  background:var(--kram);
  background-image:
    radial-gradient(circle at 20% 80%, rgba(245,184,0,.15) 0, transparent 40%),
    radial-gradient(circle at 80% 20%, rgba(192,50,43,.10) 0, transparent 40%);
}
.utstallare-spar{
  display:grid; grid-template-columns:1fr 1fr; gap:30px;
  margin-top:40px;
}
@media (max-width:760px){.utstallare-spar{grid-template-columns:1fr}}
.spar{
  background:#fff;
  padding:36px 30px;
  border-radius:12px;
  border:3px solid var(--svart);
  box-shadow:8px 8px 0 var(--svart);
  display:flex; flex-direction:column;
  align-items:flex-start;
}
.spar h3{
  font-family:'Alfa Slab One',serif;
  font-size:26px; margin:0 0 12px;
  color:var(--tra-mork);
}
.spar p{margin:0 0 16px; line-height:1.55}
.spar .checks{flex:1}
.spar-skylt{align-self:center; margin-bottom:20px}
.spar-ikon{font-size:64px; line-height:1; margin-bottom:10px}
.spar-sloj{background:#fff8dd}
.spar-marknad{background:#eff6fc}
.checks{
  list-style:none; padding:0; margin:0 0 24px;
}
.checks li{
  padding:10px 0 10px 30px;
  position:relative;
  border-bottom:1px dashed rgba(0,0,0,.15);
  font-size:17px;
}
.checks li::before{
  content:"✓"; position:absolute; left:0; top:8px;
  color:var(--gron); font-weight:700; font-size:20px;
}
.utstallare-skylt{display:flex; justify-content:center}
.skylt{
  background:linear-gradient(180deg, #f5b800 0%, #e89c00 100%);
  border:6px solid var(--tra-mork);
  border-radius:14px;
  padding:30px 36px;
  text-align:center;
  font-family:'Alfa Slab One',serif;
  color:var(--tra-mork);
  transform:rotate(-3deg);
  box-shadow:0 18px 0 rgba(0,0,0,.12), 0 28px 40px rgba(0,0,0,.18);
  position:relative;
}
.skylt::before, .skylt::after{
  content:""; position:absolute; top:-12px;
  width:14px; height:14px; border-radius:50%;
  background:var(--tra-mork);
}
.skylt::before{left:14px}
.skylt::after{right:14px}
.skylt-rad-1{display:block; font-size:54px; line-height:1}
.skylt-rad-2{display:block; font-size:22px; margin-top:6px}
.skylt-rad-3{
  display:block; font-size:18px; margin-top:14px;
  background:var(--tra-mork); color:var(--gul);
  padding:6px 12px; border-radius:6px;
}

/* === Hitta hit === */
.section-hitta{background:var(--kram-mork)}
.hitta-grid{
  display:grid; grid-template-columns:1fr 1.2fr; gap:30px;
  align-items:start;
}
@media (max-width:760px){.hitta-grid{grid-template-columns:1fr}}
.hitta-karta{
  border-radius:10px; overflow:hidden;
  border:4px solid var(--tra-mork);
  box-shadow:var(--skugga);
  aspect-ratio:4/3;
}
.hitta-karta iframe{width:100%; height:100%; border:0}

/* === Sponsorer === */
.section-sponsorer{
  background:linear-gradient(180deg, var(--rod) 0%, var(--rod-mork) 100%);
  color:#fff;
}
.section-sponsorer h2{color:var(--solskygga)}
.section-sponsorer .eyebrow{color:var(--gul)}
.section-sponsorer .lead{color:#fff}
.section-sponsorer .btn-primary{
  background:var(--gul); color:var(--tra-mork) !important;
  box-shadow:0 4px 0 var(--gul-djup);
}
.partners{
  list-style:none; padding:0; margin:40px 0;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:18px;
}
.partners li{
  background:#fff;
  border-radius:12px;
  border:3px solid var(--tra-mork);
  box-shadow:6px 6px 0 rgba(0,0,0,.25);
  overflow:hidden;
  transition:transform .15s, box-shadow .15s;
}
.partners li:hover{
  transform:translate(-2px,-2px);
  box-shadow:8px 8px 0 rgba(0,0,0,.3);
}
.partners a, .partners .partner-link{
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-decoration:none; color:var(--tra-mork);
  padding:24px 18px;
  min-height:160px;
  gap:14px;
}
.partner-logo{
  width:120px; height:60px;
  display:flex; align-items:center; justify-content:center;
}
.partner-logo-wide{width:160px}
.partner-logo img{
  max-width:100%; max-height:60px;
  width:auto; height:auto;
  object-fit:contain;
  filter:saturate(.95);
}
.logo-fallback{display:none}
.partner-logo.no-logo{
  background:var(--gul);
  border-radius:50%;
  width:64px; height:64px;
  box-shadow:inset 0 -3px 0 var(--gul-djup);
}
.partner-logo.no-logo img{display:none}
.partner-logo.no-logo .logo-fallback{
  display:flex; align-items:center; justify-content:center;
  width:100%; height:100%;
  font-family:'Alfa Slab One',serif;
  color:var(--tra-mork); font-size:22px;
  letter-spacing:.5px;
}
.partner-name{
  font-weight:600; font-size:14px;
  text-align:center; line-height:1.3;
  color:var(--tra-mork);
}
.sponsor-cta{margin-top:40px}
@media (max-width:480px){
  .partners{grid-template-columns:repeat(2, 1fr); gap:12px}
  .partners a, .partners .partner-link{padding:18px 12px; min-height:140px}
  .partner-logo{width:90px; height:48px}
  .partner-name{font-size:13px}
}

/* === Kontakt === */
.section-kontakt{
  background:var(--svart); color:var(--solskygga);
  text-align:center;
}
.section-kontakt h2{color:var(--solskygga)}
.section-kontakt .eyebrow{color:var(--gul)}
.kontakt-mail{
  font-family:'Alfa Slab One',serif;
  font-size:clamp(24px, 4vw, 36px);
  margin:20px 0;
}
.kontakt-mail a{color:var(--gul); text-decoration:none}
.kontakt-mail a:hover{text-decoration:underline}
.arrangorer{margin-top:50px; padding-top:30px; border-top:1px solid rgba(255,255,255,.15)}
.arrangorer-rubrik{
  font-family:'Caveat',cursive; font-weight:700;
  font-size:22px; color:var(--gul); margin:0 0 18px;
}
.arrangorer-logos{
  display:flex; align-items:center; justify-content:center;
  gap:30px; flex-wrap:wrap;
}
.arrangorer-logos img{
  height:90px; width:auto; border-radius:10px;
  border:2px solid rgba(255,255,255,.15);
}
.arrangor-text{
  font-family:'Alfa Slab One',serif;
  font-size:22px; color:var(--solskygga);
}

/* === Hero-logga (sticker uppe till höger) === */
.hero-logo-badge{
  position:absolute; top:74px; right:24px; z-index:8;
  width:148px; background:#fff; padding:8px;
  border-radius:14px; transform:rotate(-4deg);
  border:3px solid var(--gul);
  box-shadow:0 10px 26px rgba(0,0,0,.28);
}
.hero-logo-badge img{width:100%; border-radius:8px; border:0; box-shadow:none}
@media (max-width:980px){.hero-logo-badge{width:104px; top:64px; right:14px; padding:6px; border-width:2px}}
@media (max-width:520px){.hero-logo-badge{width:78px; top:60px; right:10px}}

/* === Utställar-bilder + tredje spår === */
.utstallare-spar{grid-template-columns:repeat(auto-fit, minmax(300px, 1fr))}
.spar-bild{
  align-self:stretch; width:100%; margin:0 0 22px;
  border-radius:8px; overflow:hidden;
  border:3px solid var(--svart);
  box-shadow:4px 4px 0 var(--svart);
}
.spar-bild img{width:100%; display:block}
.spar-loppis{background:#eef7ee}

/* === Camping === */
.camping-block{margin-top:44px}
.camping-rubrik{
  font-family:'Alfa Slab One',serif;
  color:var(--gul); font-size:24px; margin:0 0 20px;
}
.camping-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:20px;
}
.camping-kort{
  background:rgba(255,255,255,.06);
  border-radius:8px;
  border-left:5px solid var(--gron);
  padding:20px 22px;
  display:flex; flex-direction:column;
}
.camping-head{
  display:flex; align-items:baseline; justify-content:space-between;
  gap:10px; margin-bottom:8px;
}
.camping-kort h4{
  font-family:'Alfa Slab One',serif;
  font-size:17px; margin:0; color:var(--solskygga); line-height:1.2;
}
.camping-dist{
  flex:0 0 auto;
  font-size:13px; font-weight:700; color:var(--tra-mork);
  background:var(--gul); padding:3px 10px; border-radius:20px;
  white-space:nowrap;
}
.camping-kort p{margin:0 0 8px; font-size:15px; line-height:1.5}
.camping-ort{
  font-size:13px; color:var(--gul); opacity:.85;
  margin-bottom:12px;
}
.camping-kort a{
  margin-top:auto;
  color:var(--gul); font-weight:600; font-size:14px;
}
.camping-kort a:hover{color:#fff}

/* === Regler & trygghet === */
.regler-block{margin-top:44px}
.regler-intro{margin:0 0 20px; opacity:.9}
.regler-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:20px;
}
.regler-kort{
  background:rgba(255,255,255,.06);
  border-radius:8px;
  border-left:5px solid var(--gul);
  padding:22px 24px;
}
.regler-forbjudet{border-left-color:var(--rod)}
.regler-kort h4{
  font-family:'Alfa Slab One',serif;
  font-size:18px; margin:0 0 12px; color:var(--solskygga);
}
.forbud-lista, .info-lista{list-style:none; padding:0; margin:0}
.forbud-lista li, .info-lista li{
  position:relative; padding:9px 0 9px 30px;
  border-bottom:1px dashed rgba(255,255,255,.15);
  font-size:15px; line-height:1.45;
}
.forbud-lista li:last-child, .info-lista li:last-child{border-bottom:0}
.forbud-lista li::before{
  content:"✕"; position:absolute; left:2px; top:9px;
  color:var(--rod); font-weight:700; font-size:16px;
}
.info-lista li::before{
  content:"ℹ"; position:absolute; left:2px; top:9px;
  color:var(--gul); font-weight:700; font-size:16px;
}

/* === Footer === */
.footer{
  background:var(--tra-mork); color:var(--solskygga);
  padding:30px 18px;
  border-top:4px solid var(--gul);
}
.footer-inner{
  display:flex; justify-content:space-between;
  align-items:center; gap:20px; flex-wrap:wrap;
}
.footer-links{display:flex; gap:18px; flex-wrap:wrap}
.footer-links a{color:var(--solskygga); opacity:.85}
.footer-links a:hover{opacity:1; color:var(--gul)}
