/* ============================================================
   WEDEVÅG SWEDEN AB — stilmall
   Identitet: kunglig kronblå · mässing · pappersvit · järnsvart
   ============================================================ */

:root{
  --ink:#16191d;
  --ink-soft:#3b424b;
  --blue-900:#0a2c4d;
  --blue-700:#0f4170;
  --blue:#1366ab;          /* kronans blå */
  --brass:#b07d24;
  --brass-light:#d2a44a;
  --paper:#f4efe5;
  --paper-2:#ebe4d4;
  --white:#ffffff;
  --line:rgba(22,25,29,.14);
  --line-soft:rgba(22,25,29,.08);
  --shadow:0 18px 50px -22px rgba(10,44,77,.45);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;

  --wrap:1180px;
  --pad:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
h2{font-size:clamp(2rem,4.4vw,3.3rem)}
h3{font-size:1.35rem;font-weight:600}
.lead{font-size:clamp(1.06rem,1.8vw,1.3rem);color:var(--ink-soft);max-width:62ch}

.kicker{
  font-family:var(--mono);
  font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--brass);margin-bottom:1.1rem;font-weight:700;
}
.kicker--light{color:var(--brass-light)}

/* ---------- knappar ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.95em 1.5em;border-radius:2px;
  transition:transform .25s ease, background .25s ease, color .25s ease;
  border:1.5px solid transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn--brass{background:var(--brass);color:#fff}
.btn--brass:hover{background:var(--brass-light)}
.btn--ghost{border-color:rgba(255,255,255,.5);color:#fff}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem var(--pad);
  background:rgba(244,239,229,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:padding .3s ease, background .3s ease, border-color .3s ease;
}
.site-header.scrolled{padding:.45rem var(--pad);border-color:var(--line-soft);box-shadow:0 6px 24px -18px rgba(10,44,77,.6)}
.brand{display:flex;align-items:center}
.brand__logo{height:46px;width:auto;display:block;transition:height .3s ease}
.site-header.scrolled .brand__logo{height:38px}

.site-nav{display:flex;align-items:center;gap:2rem}
.site-nav a{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;transition:color .2s}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--brass);transition:width .25s ease}
.site-nav a:hover{color:var(--ink)}
.site-nav a:hover:not(.nav-cta)::after{width:100%}
.nav-cta{background:var(--blue);color:#fff;padding:.6em 1.2em;border-radius:2px}
.nav-cta:hover{background:var(--blue-700);color:#fff}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,28,48,.45) 0%,rgba(8,28,48,.15) 35%,rgba(8,28,48,.78) 100%),
    linear-gradient(90deg,rgba(8,28,48,.7) 0%,rgba(8,28,48,0) 55%);
}
.hero__inner{position:relative;z-index:2;max-width:var(--wrap);width:100%;margin:0 auto;padding:0 var(--pad) clamp(3.5rem,8vh,7rem)}
.hero h1{font-size:clamp(2.5rem,6.2vw,5rem);color:#fff;max-width:16ch}
.hero h1 span{color:var(--brass-light)}
.hero__lead{font-size:clamp(1.1rem,2vw,1.4rem);margin:1.4rem 0 2.2rem;max-width:46ch;color:rgba(255,255,255,.9)}
.hero__lead strong{color:#fff}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem}
.hero__year{
  position:absolute;top:clamp(80px,14vh,140px);right:var(--pad);z-index:2;
  font-family:var(--serif);font-size:clamp(3.5rem,9vw,7.5rem);font-weight:500;
  color:rgba(255,255,255,.13);line-height:.8;text-align:right;letter-spacing:-.02em;
}
.hero__year span{display:block;font-family:var(--mono);font-size:.85rem;letter-spacing:.4em;color:var(--brass-light);margin-bottom:.4rem}

/* ============================================================
   FAKTASTRIP
   ============================================================ */
.facts{
  background:var(--blue-900);color:#fff;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.facts__item{padding:clamp(1.8rem,4vw,2.8rem) var(--pad);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.5rem}
.facts__item:last-child{border-right:0}
.facts__big{font-family:var(--serif);font-size:clamp(1.7rem,3.4vw,2.5rem);color:var(--brass-light);font-weight:600;line-height:1}
.facts__label{font-size:.86rem;color:rgba(255,255,255,.72);line-height:1.4}

/* ============================================================
   INTRO
   ============================================================ */
.intro{padding:clamp(4.5rem,9vw,8rem) var(--pad)}
.intro__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.intro__head h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
.intro__body p{margin-bottom:1.2rem;font-size:1.06rem;color:var(--ink-soft)}
.intro__body p:last-child{margin-bottom:0}
.intro__body strong{color:var(--ink)}

/* ============================================================
   HISTORIA
   ============================================================ */
.history{background:var(--blue-900);color:#fff;padding:clamp(4.5rem,9vw,8rem) var(--pad)}
.history__intro{max-width:760px}
.history__intro h2{color:#fff}
.history__intro .lead{color:rgba(255,255,255,.82)}
.history__hero{margin:clamp(2.5rem,5vw,4rem) 0;border-radius:4px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.history__hero img{width:100%;height:clamp(260px,42vw,520px);object-fit:cover}
.history__hero figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:1.6rem;
  background:linear-gradient(180deg,transparent,rgba(8,28,48,.85));
  font-size:.9rem;color:rgba(255,255,255,.85);font-style:italic;
}

.timeline{max-width:760px;margin:0 auto;position:relative;padding-left:2.2rem}
.timeline::before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--brass-light),rgba(210,164,74,.15))}
.tl{position:relative;padding:0 0 2.4rem .4rem}
.tl::before{content:"";position:absolute;left:-2.2rem;top:6px;width:14px;height:14px;border-radius:50%;background:var(--blue-900);border:2px solid var(--brass-light)}
.tl--mark::before{background:var(--brass-light);box-shadow:0 0 0 5px rgba(210,164,74,.2)}
.tl__year{font-family:var(--mono);font-size:1.05rem;font-weight:700;color:var(--brass-light);letter-spacing:.05em}
.tl__body h3{color:#fff;margin:.2rem 0 .35rem;font-size:1.2rem}
.tl__body p{color:rgba(255,255,255,.74);font-size:.98rem;max-width:54ch}

.pullquote{max-width:760px;margin:clamp(2.5rem,5vw,4rem) auto 0;text-align:center;border-top:1px solid rgba(255,255,255,.15);padding-top:clamp(2rem,4vw,3rem)}
.pullquote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.6vw,2.4rem);color:#fff;line-height:1.3}
.pullquote cite{display:block;margin-top:1rem;font-family:var(--mono);font-style:normal;font-size:.82rem;letter-spacing:.12em;color:var(--brass-light)}

/* ============================================================
   DRAGBROTSCHNING
   ============================================================ */
.broach{padding:clamp(4.5rem,9vw,8rem) var(--pad);max-width:var(--wrap);margin:0 auto}
.broach__head{max-width:720px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.broach__head h2{font-size:clamp(2.4rem,5.5vw,4rem)}
.broach__feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.broach__img{border-radius:4px;overflow:hidden;box-shadow:var(--shadow)}
.broach__img img{width:100%;height:clamp(220px,30vw,360px);object-fit:cover}
.broach__why h3{font-size:1.6rem;margin-bottom:1.4rem}
.ticklist{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.ticklist li{position:relative;padding-left:2rem;font-size:1.05rem;color:var(--ink-soft)}
.ticklist li::before{content:"";position:absolute;left:0;top:.55em;width:11px;height:11px;background:var(--brass);transform:rotate(45deg)}

.broach__types{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:clamp(2rem,4vw,3rem)}
.bt{background:var(--white);border:1px solid var(--line-soft);border-radius:4px;padding:clamp(1.6rem,3vw,2.2rem);border-top:3px solid var(--blue)}
.bt h4{font-size:1.25rem;margin-bottom:.7rem;color:var(--blue-700)}
.bt p{color:var(--ink-soft)}

.broach__grid-label{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1rem}
.chips{display:flex;flex-wrap:wrap;gap:.7rem}
.chips span{background:var(--paper-2);border:1px solid var(--line);padding:.6em 1.1em;border-radius:2px;font-size:.92rem;font-weight:500}

/* ============================================================
   TJÄNSTER
   ============================================================ */
.services{background:var(--paper-2);padding:clamp(4.5rem,9vw,8rem) var(--pad)}
.services__head{max-width:var(--wrap);margin:0 auto clamp(2.5rem,5vw,3.5rem)}
.services__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc{background:var(--white);padding:clamp(1.8rem,3vw,2.4rem);border-radius:4px;border:1px solid var(--line-soft);transition:transform .3s ease, box-shadow .3s ease;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brass);transform:scaleY(0);transform-origin:top;transition:transform .3s ease}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.svc:hover::before{transform:scaleY(1)}
.svc h3{margin-bottom:.6rem}
.svc p{color:var(--ink-soft);font-size:.98rem}

/* ============================================================
   MASKINPARK
   ============================================================ */
.machine{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--blue-900);color:#fff}
.machine__media{position:relative;min-height:420px}
.machine__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.machine__content{padding:clamp(3rem,6vw,6rem) var(--pad)}
.machine__content h2{color:#fff}
.machine__content .lead{color:rgba(255,255,255,.82)}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin:2.4rem 0 1.6rem}
.stat{border-top:2px solid var(--brass-light);padding-top:.9rem}
.stat__num{font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:600;color:#fff;display:block;line-height:1}
.stat__txt{font-size:.88rem;color:rgba(255,255,255,.72);display:block;margin-top:.4rem}
.machine__note{font-size:.88rem;color:rgba(255,255,255,.6);border-top:1px solid rgba(255,255,255,.12);padding-top:1.2rem}

/* ============================================================
   KVALITET
   ============================================================ */
.quality{padding:clamp(4rem,8vw,7rem) var(--pad);background:var(--paper)}
.quality__inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:clamp(2rem,5vw,4rem)}
.quality__badge{
  flex:none;width:130px;height:130px;border-radius:50%;
  display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-weight:600;font-size:1.5rem;line-height:1;
  color:var(--blue);border:3px solid var(--blue);background:var(--white);
  box-shadow:var(--shadow);
}
.quality h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:.8rem}
.quality p{color:var(--ink-soft);font-size:1.06rem;max-width:55ch}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact{padding:clamp(4.5rem,9vw,8rem) var(--pad);background:var(--paper-2)}
.contact__head{max-width:var(--wrap);margin:0 auto clamp(2.5rem,5vw,3.5rem)}
.contact__grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1.3fr;gap:2rem}
.contact__col h3{font-size:1.05rem;color:var(--blue-700);margin-bottom:.5rem;font-family:var(--sans);font-weight:700;letter-spacing:.02em}
.contact__col h3:not(:first-child){margin-top:1.8rem}
.contact__col p{color:var(--ink-soft);line-height:1.8}
.contact__col a{border-bottom:1px solid var(--line);transition:border-color .2s,color .2s}
.contact__col a:hover{color:var(--blue);border-color:var(--blue)}
.people{display:flex;flex-direction:column;gap:.4rem;font-size:.94rem}
.contact__map{border-radius:4px;overflow:hidden;box-shadow:var(--shadow);min-height:340px}
.contact__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:clamp(2.5rem,5vw,3.5rem) var(--pad);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem}
.site-footer__brand{display:flex;flex-direction:column;align-items:flex-start;gap:.7rem}
.footer-logo{height:42px;width:auto;display:block}
.footer-tagline{font-size:.74rem;font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--brass-light)}
.site-footer__meta{font-size:.86rem;text-align:right;line-height:1.7}
.site-footer__copy{flex-basis:100%;border-top:1px solid rgba(255,255,255,.12);padding-top:1.4rem;font-size:.8rem;color:rgba(255,255,255,.45)}

/* ============================================================
   SCROLL-REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVT
   ============================================================ */
@media (max-width:900px){
  .facts{grid-template-columns:1fr 1fr}
  .facts__item:nth-child(2){border-right:0}
  .facts__item:nth-child(1),.facts__item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.1)}
  .intro__grid{grid-template-columns:1fr}
  .broach__feature{grid-template-columns:1fr}
  .broach__types{grid-template-columns:1fr}
  .services__grid{grid-template-columns:1fr 1fr}
  .machine{grid-template-columns:1fr}
  .machine__media{min-height:300px}
  .contact__grid{grid-template-columns:1fr 1fr}
  .contact__map{grid-column:1/-1}
}
@media (max-width:680px){
  .site-nav{
    position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;
    background:var(--paper);padding:1rem var(--pad) 1.5rem;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .35s ease;align-items:stretch;
  }
  .site-nav.open{transform:translateY(0)}
  .site-nav a{padding:.9rem 0;border-bottom:1px solid var(--line-soft);width:100%}
  .nav-cta{text-align:center;margin-top:.8rem}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .facts{grid-template-columns:1fr}
  .facts__item{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}
  .services__grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .contact__grid{grid-template-columns:1fr}
  .quality__inner{flex-direction:column;text-align:center}
  .quality p{margin:0 auto}
  .site-footer__meta{text-align:left}
}
