
:root{
  --c-primary:#6C4A3D;
  --c-secondary:#E5E5C9;
  --c-accent:#7C9B6E;
  --c-bg:#F2EDDE;
  --c-text:#2E241D;
  --c-line:#A8896F;
  --thread-w:2px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Fraunces',Georgia,serif;
  font-weight:400;
  background:var(--c-bg);
  color:var(--c-text);
  line-height:1.6;
  font-size:18px;
  counter-reset:section;
  overflow-x:hidden;
}

/* PAPPERSGRAIN — turbulens via SVG */
body::before{
  content:'';
  position:fixed;inset:0;pointer-events:none;opacity:0.30;z-index:9999;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.17 0 0 0 0 0.15 0 0 0 0 0.13 0 0 0 0.30 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* VARP-mönster — den vertikala bakgrundsväven över hela sidan */
body::after{
  content:'';
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0.10;
  background:repeating-linear-gradient(90deg,
    var(--c-primary) 0, var(--c-primary) 1px,
    transparent 1px, transparent 14px);
}

main, header, footer{position:relative;z-index:1}

h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,serif;
  color:var(--c-primary);
  line-height:1.1;
  letter-spacing:-0.01em;
}
h1{
  font-size:clamp(2.6rem,7vw,5.4rem);
  font-variation-settings:"SOFT" 70,"opsz" 144;
  font-weight:400;
  text-shadow:4px 4px 0 var(--c-secondary);
}
h2{
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  font-variation-settings:"SOFT" 30,"opsz" 72;
  font-weight:500;
  text-shadow:3px 3px 0 var(--c-secondary);
}
h3{
  font-size:1.35rem;
  font-weight:500;
  font-variation-settings:"opsz" 36;
}
p{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.18rem;line-height:1.7}

/* ============= HEADER / HERO ============= */
.site-header{
  padding:1.4rem 2rem;
  border-bottom:1px solid var(--c-line);
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:'Fraunces',serif;
  font-size:0.85rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--c-primary);
}
.site-header .mark{font-weight:500}
.site-header nav a{
  color:var(--c-primary);
  text-decoration:none;
  margin-left:1.8rem;
  border-bottom:1px solid transparent;
  padding-bottom:2px;
  transition:border-color 0.3s;
}
.site-header nav a:hover{border-bottom-color:var(--c-primary)}

.hero{
  padding:6rem 2rem 5rem;
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:5rem;
  align-items:center;
}
.hero-text .eyebrow{
  font-family:'Fraunces',serif;
  font-size:0.82rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--c-accent);
  margin-bottom:1.6rem;
  display:block;
}
.hero-text h1{margin-bottom:1.4rem}
.hero-text .tagline{
  font-style:italic;
  font-size:1.35rem;
  color:var(--c-primary);
  font-family:'Cormorant Garamond',serif;
  margin-bottom:2rem;
  max-width:36ch;
}
.hero-meta{
  display:flex;
  gap:2.5rem;
  border-top:2px solid var(--c-primary);
  border-bottom:2px solid var(--c-primary);
  padding:1rem 0;
  font-family:'Fraunces',serif;
  font-size:0.78rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--c-primary);
  max-width:30rem;
}
.hero-meta span strong{display:block;font-size:1.1rem;letter-spacing:0;margin-top:0.2rem;text-transform:none;font-weight:500}

/* ============= VÄVSTOL — signaturelement (SVG inline i HTML får CSS-stöd här) ============= */
.vavstol{
  width:100%;
  max-width:380px;
  margin:0 auto;
  position:relative;
  aspect-ratio:1/1.15;
  border:3px double var(--c-primary);
  padding:1.6rem;
  background:var(--c-secondary);
  box-shadow:8px 8px 0 var(--c-primary);
}
.vavstol::before{
  content:'';
  position:absolute;
  left:-12px;right:-12px;top:0.8rem;
  height:14px;
  background:var(--c-primary);
  border:2px solid var(--c-text);
}
.vavstol::after{
  content:'';
  position:absolute;
  left:-12px;right:-12px;bottom:0.8rem;
  height:14px;
  background:var(--c-primary);
  border:2px solid var(--c-text);
}
.vavstol-varp{
  position:absolute;
  inset:1.6rem;
  background:repeating-linear-gradient(90deg,
    var(--c-primary) 0, var(--c-primary) var(--thread-w),
    transparent var(--thread-w), transparent 9px);
}
.vavstol-inslag{
  position:absolute;
  left:1.6rem;right:1.6rem;
  top:50%;
  height:42%;
  transform:translateY(-50%);
  background:repeating-linear-gradient(0deg,
    var(--c-accent) 0, var(--c-accent) 3px,
    var(--c-primary) 3px, var(--c-primary) 5px,
    var(--c-secondary) 5px, var(--c-secondary) 11px);
  opacity:0.88;
  border-top:1px solid var(--c-primary);
  border-bottom:1px solid var(--c-primary);
}
.vavstol-skytt{
  position:absolute;
  right:-2.2rem;
  top:48%;
  width:3.2rem;
  height:0.9rem;
  background:var(--c-primary);
  border:1.5px solid var(--c-text);
  border-radius:50% 0 0 50%;
  box-shadow:2px 2px 0 var(--c-text);
}

/* ============= SEKTIONSNUMRERING ============= */
section{
  max-width:1180px;
  margin:0 auto;
  padding:5rem 2rem;
  position:relative;
}
.sektionsnumrering{
  counter-increment:section;
  font-family:'Fraunces',serif;
  font-size:0.82rem;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--c-accent);
  margin-bottom:1.2rem;
  display:block;
  text-shadow:2px 2px 0 var(--c-secondary);
}
.sektionsnumrering::before{
  content:"— 0" counter(section) " · ";
  font-family:'Courier New',monospace;
  color:var(--c-primary);
}

/* ============= OM-SEKTION ============= */
.om{
  display:grid;
  grid-template-columns:1fr 1.5fr;
  gap:4rem;
  align-items:start;
}
.om h2{margin-bottom:0}
.om-text p + p{margin-top:1.2rem}
.om-text p:first-of-type::first-letter{
  float:left;
  font-family:'Fraunces',serif;
  font-size:4.2em;
  line-height:0.85;
  margin:0.08em 0.12em 0 0;
  color:var(--c-primary);
  font-weight:400;
}

/* ============= AKTIVITETER ============= */
.aktiviteter-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:2.5rem;
}
.aktivitet-kort{
  border:1px solid var(--c-line);
  background:var(--c-secondary);
  padding:2rem 1.6rem;
  position:relative;
  box-shadow:6px 6px 0 var(--c-primary);
}
.aktivitet-kort .nr{
  font-family:'Courier New',monospace;
  font-size:0.75rem;
  letter-spacing:0.2em;
  color:var(--c-accent);
  display:block;
  margin-bottom:0.6rem;
}
.aktivitet-kort h3{
  text-transform:capitalize;
  margin-bottom:0.8rem;
}
.aktivitet-kort p{font-size:1rem;font-style:italic;color:var(--c-text)}

/* ============= VÄVNADSUTRUSTNING ============= */
.utrustning{
  background:var(--c-secondary);
  border-top:3px double var(--c-primary);
  border-bottom:3px double var(--c-primary);
  margin:4rem 0;
  padding:3rem 2rem;
}
.utrustning-inner{
  max-width:1180px;
  margin:0 auto;
}
.utrustning h2{font-size:1.6rem;margin-bottom:0.5rem}
.utrustning .lead{
  font-style:italic;
  margin-bottom:2.4rem;
  max-width:50ch;
  color:var(--c-primary);
}
.verktyg-rad{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1.5rem;
  align-items:end;
}
.verktyg{
  text-align:center;
  font-family:'Fraunces',serif;
  font-size:0.75rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--c-primary);
}
.verktyg-form{
  height:110px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  margin-bottom:0.8rem;
}
.verktyg-sked{
  width:90%;height:80%;
  border:2px solid var(--c-primary);
  background:repeating-linear-gradient(90deg,
    var(--c-primary) 0, var(--c-primary) 2px,
    var(--c-bg) 2px, var(--c-bg) 6px);
}
.verktyg-skyttel{
  width:90%;height:24px;
  background:var(--c-primary);
  border:2px solid var(--c-text);
  border-radius:50%;
  box-shadow:3px 3px 0 var(--c-text);
}
.verktyg-harva{
  width:72px;height:72px;
  border-radius:50%;
  border:2px solid var(--c-primary);
  background:
    repeating-linear-gradient(45deg,
      var(--c-accent) 0, var(--c-accent) 2px,
      var(--c-secondary) 2px, var(--c-secondary) 5px);
}
.verktyg-solv{
  width:80%;height:90%;
  background:repeating-linear-gradient(90deg,
    var(--c-primary) 0, var(--c-primary) 1.5px,
    transparent 1.5px, transparent 7px);
  border-top:2px solid var(--c-primary);
  border-bottom:2px solid var(--c-primary);
  position:relative;
}
.verktyg-solv::before{
  content:'';position:absolute;
  left:0;right:0;top:50%;
  height:8px;transform:translateY(-50%);
  background:var(--c-bg);
  border-top:1.5px solid var(--c-primary);
  border-bottom:1.5px solid var(--c-primary);
}
.verktyg-trampa{
  width:90%;height:70%;
  display:flex;gap:4px;
  align-items:flex-end;
}
.verktyg-trampa span{
  flex:1;
  background:var(--c-primary);
  border:1.5px solid var(--c-text);
}
.verktyg-trampa span:nth-child(1){height:60%}
.verktyg-trampa span:nth-child(2){height:90%}
.verktyg-trampa span:nth-child(3){height:75%}
.verktyg-trampa span:nth-child(4){height:50%}

/* ============= TRÅDAR ============= */
.tradar{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:4rem;
  align-items:center;
}
.trad-provkarta{
  border:3px double var(--c-primary);
  background:var(--c-secondary);
  padding:2rem;
  box-shadow:8px 8px 0 var(--c-primary);
}
.trad-provkarta h3{
  text-align:center;
  font-size:0.8rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--c-primary);
  margin-bottom:1.8rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--c-line);
}
.trad-rad{
  display:flex;
  align-items:center;
  gap:1.2rem;
  margin-bottom:1.1rem;
  font-family:'Fraunces',serif;
  font-size:0.85rem;
  letter-spacing:0.1em;
  color:var(--c-primary);
}
.trad-rad:last-child{margin-bottom:0}
.trad-prov{
  flex:0 0 90px;
  height:14px;
  border:1px solid var(--c-text);
}
.trad-prov.ull{
  background:repeating-linear-gradient(90deg,
    #6C4A3D 0, #6C4A3D 2px,
    #8a6451 2px, #8a6451 4px);
}
.trad-prov.lin{
  background:repeating-linear-gradient(90deg,
    #E5E5C9 0, #E5E5C9 2px,
    #c4c4a3 2px, #c4c4a3 4px);
}
.trad-prov.bomull{
  background:repeating-linear-gradient(90deg,
    #F2EDDE 0, #F2EDDE 2px,
    #d4cfb9 2px, #d4cfb9 4px);
}
.trad-prov.vall{
  background:repeating-linear-gradient(90deg,
    #7C9B6E 0, #7C9B6E 2px,
    #5e7a51 2px, #5e7a51 4px);
}
.trad-rad .nr{
  font-family:'Courier New',monospace;
  font-size:0.72rem;
  color:var(--c-accent);
  margin-left:auto;
}

/* ============= SCHEMA ============= */
.schema-list{
  margin-top:2.5rem;
  border-top:2px solid var(--c-primary);
}
.schema-rad{
  display:grid;
  grid-template-columns:0.6fr 1.4fr 1fr;
  gap:2rem;
  padding:1.6rem 0;
  border-bottom:1px solid var(--c-line);
  align-items:baseline;
}
.schema-rad .dag{
  font-family:'Fraunces',serif;
  text-transform:uppercase;
  letter-spacing:0.18em;
  color:var(--c-primary);
  font-size:0.95rem;
  font-weight:500;
}
.schema-rad .typ{
  font-size:1.3rem;
  color:var(--c-text);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
}
.schema-rad .plats{
  font-family:'Courier New',monospace;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--c-accent);
  text-align:right;
}

/* ============= HISTORIK ============= */
.historik-tidslinje{
  position:relative;
  margin-top:3rem;
  padding-left:3rem;
}
.historik-tidslinje::before{
  content:'';
  position:absolute;
  left:8px;top:8px;bottom:8px;
  width:0;
  border-left:3px double var(--c-primary);
}
.tidslinje-punkt{
  position:relative;
  padding-bottom:2.4rem;
}
.tidslinje-punkt::before{
  content:'';
  position:absolute;
  left:-3rem;top:0.4rem;
  width:18px;height:18px;
  background:var(--c-primary);
  border:3px solid var(--c-bg);
  box-shadow:0 0 0 2px var(--c-primary);
  border-radius:50%;
}
.tidslinje-punkt .ar{
  font-family:'Courier New',monospace;
  font-size:0.85rem;
  letter-spacing:0.2em;
  color:var(--c-accent);
  display:block;
  margin-bottom:0.3rem;
}
.tidslinje-punkt h3{
  font-size:1.3rem;
  color:var(--c-primary);
}

/* ============= FOOTER ============= */
.site-footer{
  border-top:3px double var(--c-primary);
  margin-top:5rem;
  padding:3rem 2rem 2rem;
  background:var(--c-secondary);
  text-align:center;
  font-family:'Fraunces',serif;
}
.site-footer .stämpel{
  display:inline-block;
  border:2px solid var(--c-primary);
  padding:0.8rem 1.6rem;
  font-size:0.8rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--c-primary);
  transform:rotate(-3deg);
  box-shadow:4px 4px 0 var(--c-primary);
  text-shadow:2px 2px 0 var(--c-secondary);
  margin-bottom:1.5rem;
}
.site-footer p{
  font-size:0.95rem;
  color:var(--c-primary);
  font-family:'Cormorant Garamond',serif;
}

/* ============= REVEAL ============= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.8s ease,transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.reveal.visible{opacity:1;transform:none}

/* ============= MOBIL ============= */
@media (max-width:768px){
  body{font-size:16px}
  .site-header{flex-direction:column;gap:0.8rem;padding:1rem;font-size:0.72rem}
  .site-header nav a{margin:0 0.6rem}
  .hero{grid-template-columns:1fr;gap:3rem;padding:3rem 1.3rem 2rem}
  .vavstol{max-width:280px}
  section{padding:3.5rem 1.3rem}
  .om{grid-template-columns:1fr;gap:2rem}
  .aktiviteter-grid{grid-template-columns:1fr;gap:1rem}
  .verktyg-rad{grid-template-columns:repeat(2,1fr);gap:2rem}
  .tradar{grid-template-columns:1fr;gap:2rem}
  .schema-rad{grid-template-columns:1fr;gap:0.4rem}
  .schema-rad .plats{text-align:left}
  .historik-tidslinje{padding-left:2rem}
  .tidslinje-punkt::before{left:-2rem}
  h1{text-shadow:3px 3px 0 var(--c-secondary)}
  h2{text-shadow:2px 2px 0 var(--c-secondary)}
}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
  html{scroll-behavior:auto}
}
