/* ============================================================
   CRANEPARTNER · V3 — KATALOGEN (röd + svart)
   Magni-katalogens omslag som poster. Vit yta = aktiv komponent.
   Tokens: #AE171A (Magni-röd) · #2F383C (Magni-grå/"svart") · #FFFFFF
   ============================================================ */

:root{
  --red:#AE171A;
  --ink:#2F383C;
  --paper:#FFFFFF;
  --ink-08:rgba(47,56,60,.08);
  --ink-14:rgba(47,56,60,.14);
  --ink-65:rgba(47,56,60,.72); /* AA: 5.04:1 on white */
  --red-08:rgba(174,23,26,.08);

  --maxw:1320px;
  --gut:clamp(1.25rem, 4vw, 4rem);
  --rail:clamp(28px, 4.5vw, 72px);

  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --s5:64px; --s6:96px; --s7:128px;

  --mono:"IBM Plex Mono", ui-monospace, monospace;
  --sans:"Open Sans", system-ui, sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; }

::selection{ background:var(--red); color:#fff; }

:focus-visible{
  outline:3px solid var(--red);
  outline-offset:3px;
  border-radius:2px;
}

.mono{ font-family:var(--mono); font-feature-settings:"tnum" 1; letter-spacing:.01em; }

/* ---------- shared layout ---------- */
main > section,
.records,
.footer{
  padding-left:var(--gut);
  padding-right:var(--gut);
}
.sec-head,
.tiles,
.svc-grid,
.stock,
.records__row,
.cta__head,
.doors{
  max-width:var(--maxw);
  margin-left:auto;
  margin-right:auto;
}

/* ============================================================
   SIGNATURE — CHEVRONMARSCHEN
   fixed left rail of red chevrons pointing DOWN through scroll.
   ============================================================ */
.chevron-rail{
  position:fixed;
  top:0; left:0;
  width:var(--rail);
  height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:clamp(6px,1.4vh,18px);
  z-index:40;
  pointer-events:none;
  mix-blend-mode:multiply;
}
.chevron-rail .cv{
  font-family:var(--sans);
  font-weight:800;
  color:var(--red);
  font-size:clamp(18px,2.4vw,30px);
  line-height:.7;
  transform:rotate(-90deg);     /* ‹ rotated to point DOWN */
  opacity:.18;
  will-change:opacity,transform;
}
/* progress: filled chevrons get strong; driven by JS --march (0..1) */
.chevron-rail .cv.lit{ opacity:1; }

/* divider chevrons between sections — also point down */
.chev-divide{
  display:flex;
  justify-content:center;
  gap:clamp(8px,1.6vw,18px);
  padding:var(--s5) 0 var(--s4);
  color:var(--red);
  font-weight:800;
  font-size:clamp(22px,3vw,40px);
  line-height:.7;
}
.chev-divide span{ transform:rotate(-90deg); display:inline-block; }
.chev-divide--down{ padding-bottom:0; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--s3);
  padding:var(--s2) var(--gut);
  padding-left:calc(var(--rail) + var(--s2));
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.4) blur(8px);
  border-bottom:1px solid var(--ink-14);
}
.nav__brand img{ height:26px; width:auto; }
.nav__links{ display:flex; align-items:center; gap:clamp(10px,2vw,28px); }
.nav__links a{
  text-decoration:none; font-weight:700; font-size:.82rem;
  letter-spacing:.04em; text-transform:uppercase; color:var(--ink);
}
.nav__links a:hover{ color:var(--red); }
.nav__call{
  font-family:var(--mono);
  background:var(--red); color:#fff !important;
  padding:8px 14px; border-radius:2px; letter-spacing:0;
  text-transform:none !important;
}
@media (max-width:768px){
  .nav{ padding-left:var(--gut); }   /* rail hidden <768, reclaim margin */
}
@media (max-width:680px){
  .nav__links a:not(.nav__call){ display:none; }
}

/* ============================================================
   1. HERO — staplad jättedisplay + frilagd render
   ============================================================ */
.hero{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:var(--s5);
  align-items:center;
  padding-top:clamp(var(--s5),9vh,var(--s7));
  padding-bottom:var(--s5);
  padding-left:calc(var(--rail) + var(--gut));
  max-width:calc(var(--maxw) + var(--rail));
  margin-inline:auto;
}
.kicker{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  color:var(--red);
  font-weight:600;
  margin-bottom:var(--s3);
}

/* the poster display: full-width stacked, words alternate red/black */
.display{
  font-weight:800;
  text-transform:uppercase;
  line-height:.86;
  letter-spacing:-.02em;
  font-size:clamp(3rem,9.5vw,7rem);
}
.display .ln{ display:block; }
.display .w{ display:inline-block; }
.display .w.red{ color:var(--red); }
.display .w.blk{ color:var(--ink); }
.display .w.white{ color:#fff; }
.display .w.wk{ color:rgba(255,255,255,.72); }   /* weak white for rhythm */

.hero__lede{
  max-width:42ch;
  font-size:clamp(1.05rem,1.4vw,1.3rem);
  line-height:1.5;
  margin:var(--s4) 0 var(--s4);
  color:var(--ink);
}
.hero__sub{
  margin-top:var(--s3);
  font-family:var(--mono);
  font-size:.84rem;
  color:var(--ink-65);
  letter-spacing:.02em;
}

/* render plate — katalogplansch */
.hero__plate{ position:relative; }
.hero__plate img{
  width:100%;
  max-height:78vh;
  object-fit:contain;
  filter:drop-shadow(0 30px 50px rgba(47,56,60,.18));
}
.plate__tag{
  position:absolute; bottom:0; left:0;
  display:flex; flex-direction:column; gap:2px;
  background:var(--ink); color:#fff;
  padding:10px 14px;
  font-size:.78rem;
}
.plate__tag .mono:first-child{ color:#fff; font-weight:600; }
.plate__tag .mono:last-child{ color:var(--red); }
.plate__tag .mono:last-child{ filter:brightness(1.9); }

/* hero responsive collapse — stack render under type, no overflow */
@media (max-width:900px){
  .hero{
    grid-template-columns:1fr;
    gap:var(--s4);
    padding-left:calc(var(--rail) + var(--gut));
  }
  .hero__plate{ order:3; }
  .hero__plate img{ max-height:60vh; margin-inline:auto; }
  .plate__tag{ left:50%; transform:translateX(-50%); }
}
@media (max-width:768px){
  .hero{ padding-left:var(--gut); }   /* rail hidden <768, reclaim margin */
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:700; text-decoration:none;
  padding:15px 26px; border-radius:2px;
  font-size:1rem; letter-spacing:.01em;
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.btn--red{ background:var(--red); color:#fff; }
.btn--red:hover{ transform:translateY(-2px); background:#8f1316; }
.btn__chev{ font-weight:800; letter-spacing:-2px; transition:transform .25s var(--ease); }
.btn--red:hover .btn__chev{ transform:translateX(-4px); }

/* ============================================================
   RECORD STRIP
   ============================================================ */
.records{ padding-top:var(--s4); padding-bottom:var(--s4); border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); }
.records__row{
  list-style:none; display:grid; grid-template-columns:repeat(4,1fr);
  gap:var(--s3);
}
.records__row li{ display:flex; flex-direction:column; gap:6px; }
.records .num{ font-size:clamp(2rem,4.5vw,3.4rem); font-weight:600; color:var(--red); line-height:1; }
.records .lbl{ font-size:.8rem; color:var(--ink-65); text-transform:uppercase; letter-spacing:.06em; }
@media (max-width:680px){ .records__row{ grid-template-columns:1fr 1fr; gap:var(--s4) var(--s3); } }

/* ============================================================
   SECTION HEADS
   ============================================================ */
.sec-head{ padding-top:var(--s4); padding-bottom:var(--s4); }
.display--sm{ font-size:clamp(2.2rem,6vw,4.6rem); }
.sec-lede{
  max-width:54ch; margin-top:var(--s3);
  font-size:clamp(1.02rem,1.3vw,1.2rem); color:var(--ink);
}

/* ---------- banner bands (smal banderoll — verkligt foto) ---------- */
.band{ position:relative; overflow:hidden; border-radius:3px; margin-inline:auto; max-width:var(--maxw); }
.band--catalog{ display:none; }            /* RTH lead also lives in tiles */
.band--photo{ height:clamp(180px,28vw,300px); border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); }
.band--photo img{ width:100%; height:100%; object-fit:cover; object-position:center 38%; }
.band--portrait{ height:clamp(220px,34vw,380px); }
.band--portrait img{ object-position:center 30%; }

/* ============================================================
   2. PRODUKTBLAD — katalogtiles
   ============================================================ */
.catalog{ padding-top:var(--s5); }
.tiles{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:var(--ink);                  /* hairline grid = ink lines */
  border:2px solid var(--ink);
  margin-top:var(--s4);
}
.tile{ display:flex; flex-direction:column; background:var(--paper); }
.tile__plate{
  background:var(--paper);
  aspect-ratio:4/4.2;
  display:grid; place-items:center;
  padding:var(--s3);
  border-bottom:1px solid var(--ink-14);
}
.tile__plate img{ max-height:100%; width:auto; object-fit:contain; }
.tile__body{ padding:var(--s3) var(--s3) var(--s4); display:flex; flex-direction:column; gap:8px; flex:1; }
.tile__fam{
  font-size:1.5rem; font-weight:600; color:var(--red); line-height:1;
  letter-spacing:.02em;
}
.tile__name{ font-size:1.15rem; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; color:var(--ink); }
.tile__lead{ font-size:.9rem; color:var(--ink-65); }

/* tvåtals-spec — datablads-disciplin */
.spec{ margin-top:auto; border-top:1px solid var(--ink); }
.spec > div{
  display:flex; justify-content:space-between; gap:var(--s2);
  padding:7px 0; border-bottom:1px dashed var(--ink-14);
  font-size:.82rem;
}
.spec dt{ color:var(--ink-65); text-transform:uppercase; letter-spacing:.04em; font-size:.74rem; padding-top:2px; }
.spec dd{ font-weight:600; color:var(--ink); text-align:right; }

.pdf{
  display:inline-flex; align-items:center; gap:6px;
  margin-top:10px; text-decoration:none;
  font-weight:700; font-size:.85rem; color:var(--red);
  border-bottom:1px solid transparent; align-self:flex-start;
}
.pdf span{ font-weight:800; transition:transform .2s var(--ease); }
.pdf:hover{ border-bottom-color:var(--red); }
.pdf:hover span{ transform:translateX(-3px); }
.pdf--alt{ margin-top:4px; font-size:.78rem; color:var(--ink); font-weight:600; }
.pdf--alt:hover{ border-bottom-color:var(--ink); }
.pdf--req{ color:var(--ink); }

.catalog__foot{
  max-width:var(--maxw); margin:var(--s4) auto 0;
  font-size:.95rem; color:var(--ink-65);
  border-left:3px solid var(--red); padding-left:var(--s2);
}
.catalog__foot strong{ color:var(--ink); letter-spacing:.04em; }

@media (max-width:900px){ .tiles{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .tiles{ grid-template-columns:1fr; } }

/* ============================================================
   3. SERVICE
   ============================================================ */
.service{ padding-top:var(--s5); }
.service .band{ margin-bottom:var(--s4); }
.svc-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
  border:2px solid var(--ink); background:var(--ink);
  margin-top:var(--s3);
}
.svc-card{ background:var(--paper); padding:var(--s4) var(--s3); display:flex; flex-direction:column; gap:10px; }
.svc-card--big{ background:var(--ink); color:#fff; }
.svc-num{ font-size:clamp(3rem,7vw,5rem); font-weight:600; color:var(--red); line-height:.85; filter:brightness(1.6); }
.svc-card--big .svc-card__lbl{ color:rgba(255,255,255,.8); font-size:.9rem; text-transform:uppercase; letter-spacing:.05em; }
.svc-list{ list-style:none; margin-top:auto; display:flex; flex-direction:column; gap:5px; }
.svc-list li{ font-size:.85rem; color:rgba(255,255,255,.85); padding-left:16px; position:relative; }
.svc-list li::before{ content:"‹"; position:absolute; left:0; color:var(--red); filter:brightness(1.6); font-weight:800; transform:rotate(0deg); }
.svc-card__h{ font-size:1.05rem; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; }
.svc-card p{ font-size:.9rem; color:var(--ink-65); }
.svc-card--depot{ grid-column:span 1; }
.depot{ font-style:normal; font-size:.86rem; line-height:1.5; margin-top:6px; }
.depot__city{ display:block; color:var(--red); font-weight:600; font-size:.78rem; text-transform:uppercase; }
.depot a{ color:var(--ink); font-weight:700; text-decoration:none; border-bottom:1px solid var(--ink-14); }
.depot a:hover{ border-bottom-color:var(--red); color:var(--red); }
.depot small{ color:var(--ink-65); }

@media (max-width:960px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .svc-grid{ grid-template-columns:1fr; } }

/* jourlinjen-style call bar (red — allowed: jour) */
.jour{
  display:flex; align-items:center; justify-content:center; gap:14px;
  margin:var(--s4) auto 0; max-width:var(--maxw);
  background:var(--red); color:#fff; text-decoration:none;
  padding:18px var(--s3); border-radius:2px;
  font-weight:800; text-transform:uppercase; letter-spacing:.04em;
  font-size:clamp(.95rem,2vw,1.3rem); text-align:center;
}
.jour .mono{ font-weight:600; letter-spacing:0; }
.jour__chev{ letter-spacing:-2px; transition:transform .25s var(--ease); }
.jour:hover .jour__chev{ transform:translateX(-5px); }

/* ============================================================
   4. BEGAGNAT & DEMO — återförsäljningshyllan
   ============================================================ */
.begagnat{ padding-top:var(--s5); }
.begagnat .band{ margin-bottom:var(--s4); }

/* aggregate stats row — verified numbers only */
.agg{
  list-style:none;
  max-width:var(--maxw); margin:var(--s3) auto 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  border:2px solid var(--ink); background:var(--ink);
}
.agg li{
  background:var(--paper); padding:var(--s4) var(--s3);
  display:flex; flex-direction:column; gap:6px;
}
.agg .num{ font-size:clamp(2rem,4.5vw,3.4rem); font-weight:600; color:var(--red); line-height:1; }
.agg .lbl{ font-size:.8rem; color:var(--ink-65); text-transform:uppercase; letter-spacing:.06em; }
@media (max-width:560px){ .agg{ grid-template-columns:1fr; } }

/* representative machine cards — family name + type badge, NO per-machine numbers */
.stock{
  list-style:none;
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  border:2px solid var(--ink); background:var(--ink);
  margin-top:var(--s4);
}
.stock__card{ display:flex; flex-direction:column; background:var(--paper); }
.stock__plate{
  background:var(--paper);
  aspect-ratio:4/4.2;
  display:grid; place-items:center;
  padding:var(--s3);
  border-bottom:1px solid var(--ink-14);
}
.stock__plate img{ max-height:100%; width:auto; object-fit:contain; }
.stock__body{ padding:var(--s3) var(--s3) var(--s4); display:flex; flex-direction:column; gap:8px; flex:1; }
.stock__name{ font-size:1.25rem; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; color:var(--ink); }
.stock__lead{ font-size:.9rem; color:var(--ink-65); }
.stock__agg{
  margin-top:auto; padding-top:10px; border-top:1px dashed var(--ink-14);
  font-size:.76rem; color:var(--ink-65); letter-spacing:0;
}

/* type badge — Begagnad / Demo */
.badge{
  align-self:flex-start;
  font-family:var(--mono); font-size:.7rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.08em;
  padding:4px 10px; border-radius:2px;
}
.badge--used{ background:var(--ink); color:#fff; }
.badge--demo{ background:var(--red); color:#fff; }

@media (max-width:900px){ .stock{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .stock{ grid-template-columns:1fr; } }

/* dual CTA — Se hela lagret + Värdera ditt inbyte */
.begagnat__cta{
  max-width:var(--maxw); margin:var(--s4) auto 0;
  display:flex; flex-wrap:wrap; gap:var(--s2);
}
.btn--ghost{
  background:transparent; color:var(--ink);
  border:2px solid var(--ink);
}
.btn--ghost:hover{ transform:translateY(-2px); background:var(--ink); color:#fff; }
.btn--ghost .btn__chev{ color:var(--red); }
.btn--ghost:hover .btn__chev{ transform:translateX(-4px); }

/* ============================================================
   5. CTA — röd panel, tre dörrar (chevron growing into doors)
   ============================================================ */
.cta{
  background:var(--red); color:#fff;
  margin-top:var(--s6);
  padding-top:var(--s6) !important; padding-bottom:var(--s6);
  position:relative;
}
.cta__head{ }
.display--cta{ font-size:clamp(2.4rem,6.5vw,5.2rem); }
.cta__lede{ max-width:50ch; margin-top:var(--s4); color:rgba(255,255,255,.9); font-size:clamp(1.05rem,1.4vw,1.3rem); }

.doors{
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s2);
  margin-top:var(--s5);
}
.door{
  background:var(--paper); color:var(--ink);
  border-radius:3px; padding:var(--s4) var(--s3);
  text-decoration:none;
  display:flex; flex-direction:column; gap:10px;
  position:relative; overflow:hidden;
  transition:transform .3s var(--ease);
  border-top:6px solid var(--ink);
}
.door:hover{ transform:translateY(-4px); border-top-color:var(--red); }
.door__chev{
  position:absolute; top:14px; right:14px;
  color:var(--red); font-weight:800; font-size:1.3rem; letter-spacing:-2px;
  opacity:.5; transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.door:hover .door__chev{ opacity:1; transform:translateY(6px); }
.door__k{ font-size:1.6rem; font-weight:600; color:var(--red); letter-spacing:.04em; }
.door__h{ font-size:1.15rem; font-weight:800; line-height:1.2; text-transform:none; color:var(--ink); }
.door__d{ font-size:.86rem; color:var(--ink); font-weight:600; }
.door__d2{ font-size:.78rem; color:var(--ink-65); margin-top:auto; }

/* offert form door */
.door--form{ cursor:default; }
.fld{ display:flex; flex-direction:column; gap:3px; }
.fld span{ font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-65); font-weight:700; }
.fld input{
  font-family:var(--sans); font-size:.92rem; color:var(--ink);
  padding:9px 11px; border:1px solid var(--ink-14); border-radius:2px;
  background:#fff; width:100%;
}
.fld input:focus{ outline:none; border-color:var(--red); box-shadow:0 0 0 2px var(--red-08); }
.door__send{
  margin-top:6px; cursor:pointer;
  background:var(--red); color:#fff; border:none; border-radius:2px;
  font-family:var(--sans); font-weight:700; font-size:.92rem;
  padding:11px 16px; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition:background .25s var(--ease);
}
.door__send:hover{ background:#8f1316; }

@media (max-width:840px){ .doors{ grid-template-columns:1fr; } }

/* photo strip in CTA (smal banderoll) */
.band--strip{
  display:flex; align-items:center; gap:var(--s3);
  max-width:var(--maxw); margin:var(--s5) auto 0;
  background:#fff; padding:var(--s3); border-radius:3px;
}
.band--strip img{ width:96px; height:96px; object-fit:cover; border-radius:50%; flex:none; }
.strip__cap{ font-size:clamp(1rem,2vw,1.3rem); font-weight:700; color:var(--ink); font-style:italic; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ padding-top:var(--s6); padding-bottom:calc(var(--s6) + 60px); background:var(--paper); }
.footer__brand img{ height:46px; width:auto; }
.footer__cols{
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s4);
  max-width:var(--maxw); margin:var(--s5) auto 0;
  border-top:2px solid var(--ink); padding-top:var(--s4);
}
.footer__col{ font-style:normal; font-size:.92rem; line-height:1.7; }
.footer__city{ display:block; color:var(--red); font-weight:600; text-transform:uppercase; font-size:.78rem; margin-bottom:6px; letter-spacing:.04em; }
.footer__col a{ color:var(--ink); text-decoration:none; border-bottom:1px solid var(--ink-14); font-weight:600; }
.footer__col a:hover{ color:var(--red); border-bottom-color:var(--red); }
.footer__legal{ max-width:var(--maxw); margin:var(--s5) auto 0; font-size:.8rem; color:var(--ink-65); font-family:var(--mono); }
@media (max-width:680px){ .footer__cols{ grid-template-columns:1fr; gap:var(--s4); } }

/* ============================================================
   STICKY MOBILE RING-BAR (<768px, tumzon)
   ============================================================ */
.ringbar{ display:none; }
@media (max-width:768px){
  .ringbar{
    display:grid; grid-template-columns:1fr 1fr; gap:1px;
    position:fixed; left:0; right:0; bottom:0; z-index:60;
    background:var(--ink);
    box-shadow:0 -6px 18px rgba(47,56,60,.18);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .ringbar__btn{
    display:flex; align-items:center; justify-content:center; gap:6px;
    padding:15px 8px; text-decoration:none; color:#fff;
    font-weight:800; text-transform:uppercase; font-size:.82rem; letter-spacing:.03em;
  }
  .ringbar__btn span{ font-weight:800; }
  .ringbar__btn--mats{ background:var(--red); }
  .ringbar__btn--albin{ background:var(--ink); }
  .chevron-rail{ display:none; }   /* rail off on small screens; dividers carry the motif */
}

/* ============================================================
   MOTION CHOREO (initial states — GSAP reveals; visible on no-JS)
   ============================================================ */
.is-anim .reveal{ opacity:0; transform:translateY(22px); }
.is-anim .reveal-word{ opacity:0; transform:translateY(18px); }

/* ============================================================
   REDUCED MOTION — everything static & visible, Lenis off (JS-side)
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal,.reveal-word{ opacity:1 !important; transform:none !important; }
  .chevron-rail .cv{ opacity:.6; }
}
