:root{
  --bg0:#f6f1e8;
  --bg1:#efe7db;
  --bg2:#e6dccf;
  --card:#ffffff;
  --card2:#fbf7f1;
  --text:#2b2118;
  --muted:#6f665f;
  --muted2:#8a8076;
  --accent:#b87333;
  --accent2:#d29a5a;
  --glow: rgba(184,115,51,.18);
  --glow2: rgba(210,154,90,.12);
  --shadow: 0 20px 60px rgba(0,0,0,.08);
  --shadow2: 0 10px 30px rgba(0,0,0,.06);
  --shadow3: 0 4px 14px rgba(0,0,0,.05);
  --r2:24px;
  --partner-color: #2a1a12;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg2);
  color: var(--text);
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
.container{ width:min(1180px, 90%); margin:0 auto; }
.pad{ padding: 50px 0 40px; }
::selection{ background: rgba(196,122,44,.35); }

/* ========== FLOATING ORBS ========== */
.orb{
  position:fixed;
  border-radius:50%;
  pointer-events:none;
  z-index:0;
  filter:blur(80px);
}
.orb-1{
  width:600px;height:600px;
  top:-200px;right:-100px;
  background:rgba(184,115,51,.08);
  animation: orbFloat 20s ease-in-out infinite;
}
.orb-2{
  width:400px;height:400px;
  bottom:20%;left:-100px;
  background:rgba(210,154,90,.06);
  animation: orbFloat 25s ease-in-out infinite reverse;
}
.orb-3{
  width:300px;height:300px;
  top:50%;right:10%;
  background:rgba(184,115,51,.05);
  animation: orbFloat 18s ease-in-out infinite 5s;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0)}
  33%{transform:translate(30px,-40px)}
  66%{transform:translate(-20px,30px)}
}

/* ========== DECORATIVE ELEMENTS ========== */
.section-bg-warm{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1200px 700px at 70% -10%, rgba(196,122,44,.14), transparent 55%),
    radial-gradient(900px 600px at 10% 40%, rgba(224,153,70,.08), transparent 55%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
}
.section-bg-warm.alt{
  background:
    radial-gradient(1000px 600px at 20% 80%, rgba(196,122,44,.12), transparent 50%),
    radial-gradient(800px 500px at 80% 10%, rgba(224,153,70,.10), transparent 50%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

.deco-ring{
  position:absolute;border-radius:50%;pointer-events:none;z-index:0;
  border:1px solid rgba(184,115,51,.12);
}
.deco-ring-1{ width:500px;height:500px;top:-140px;right:-120px;border-width:2px;border-color:rgba(184,115,51,.08); }
.deco-ring-2{ width:300px;height:300px;bottom:60px;left:-80px;border-style:dashed;border-color:rgba(184,115,51,.10); }
.deco-ring-3{ width:420px;height:420px;top:80px;right:-160px;border-width:2px;border-color:rgba(184,115,51,.07); }
.deco-ring-4{ width:600px;height:600px;top:-200px;left:-200px;border-color:rgba(184,115,51,.06); }
.deco-ring-5{ width:280px;height:280px;bottom:40px;right:-60px;border-style:dashed;border-color:rgba(184,115,51,.10); }
.deco-ring-6{ width:380px;height:380px;top:40px;left:-120px;border-width:2px;border-color:rgba(184,115,51,.07); }

.deco-stripe{
  position:absolute;top:0;left:0;bottom:0;width:140px;z-index:0;pointer-events:none;
  background:repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 18px,
    rgba(184,115,51,.04) 18px,
    rgba(184,115,51,.04) 19px
  );
  mask-image:linear-gradient(to right,rgba(0,0,0,.6),transparent);
  -webkit-mask-image:linear-gradient(to right,rgba(0,0,0,.6),transparent);
}
.deco-stripe.right{
  left:auto;right:0;
  mask-image:linear-gradient(to left,rgba(0,0,0,.6),transparent);
  -webkit-mask-image:linear-gradient(to left,rgba(0,0,0,.6),transparent);
}

.deco-dots{
  position:absolute;top:60px;left:40px;width:200px;height:200px;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(184,115,51,.12) 1.5px,transparent 1.5px);
  background-size:20px 20px;
  mask-image:radial-gradient(ellipse 100% 100% at 50% 50%,black,transparent);
  -webkit-mask-image:radial-gradient(ellipse 100% 100% at 50% 50%,black,transparent);
}
.deco-dots.right{
  left:auto;right:40px;top:auto;bottom:80px;
}

/* ========== SECTION LINES ========== */
.section-line{
  position:absolute;
  top:0;left:50%;
  width:1px;height:80px;
  background:linear-gradient(to bottom, var(--accent), transparent);
  opacity:.3;
  z-index:2;
}

/* ========== SEPARATORS ========== */
.section{ position:relative; overflow:hidden; z-index:1; }
.section::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:120px;
  background:linear-gradient(to bottom,transparent,rgba(0,0,0,.06));
  pointer-events:none;z-index:1;
}
.section.alt::after{
  background:linear-gradient(to bottom,transparent,rgba(0,0,0,.04));
}
section{ padding-top:clamp(36px,4vw,56px); padding-bottom:clamp(36px,4vw,56px); }

.soft-top{
  position:absolute;width:720px;height:720px;
  background:radial-gradient(circle,var(--glow),transparent 60%);
  opacity:.75;pointer-events:none;z-index:0;
}
.soft-top.r{ width:860px;height:860px; background:radial-gradient(circle,var(--glow2),transparent 60%); }

.topo{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 50c10-20 30-20 40 0s30 20 40 0' fill='none' stroke='%23b87333' stroke-width='.5' opacity='.15'/%3E%3Cpath d='M0 30c15-15 35-15 50 0s35 15 50 0' fill='none' stroke='%23b87333' stroke-width='.3' opacity='.1'/%3E%3Cpath d='M10 80c12-18 28-18 40 0s28 18 40 0' fill='none' stroke='%23b87333' stroke-width='.4' opacity='.12'/%3E%3C/svg%3E");
  background-size:400px;
  opacity:.16;mix-blend-mode:overlay;pointer-events:none;z-index:0;
}

.hairline{
  position:absolute;inset:auto 0 0 0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  opacity:.55;
}

/* ========== HEADER ========== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;
  background:linear-gradient(to bottom,rgba(0,0,0,.68),rgba(0,0,0,.12));
  transition:background .4s ease, backdrop-filter .4s ease;
}
.header.scrolled{
  background:rgba(11,6,4,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
.header-glow{
  position:absolute;bottom:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(184,115,51,.3),transparent);
  opacity:0;transition:opacity .4s ease;
}
.header.scrolled .header-glow{ opacity:1; }

.header .row{ display:flex;align-items:flex-start;justify-content:space-between;gap:16px; }
.brand{ font-weight:900;letter-spacing:.16em;font-size:14px;opacity:.95; }
.nav{ display:flex;gap:22px;align-items:flex-start;justify-content:center; }
.nav a{
  font-size:13px;color:rgba(243,238,232,.78);letter-spacing:.06em;
  position:relative;transition:color .2s ease;
}
.nav a::after{
  content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--accent);transition:width .3s ease;
}
.nav a:hover{ color:rgba(243,238,232,.98); }
.nav a:hover::after{ width:100%; }

.btn{
  appearance:none;border:none;border-radius:14px;padding:14px 18px;
  font-weight:900;letter-spacing:.08em;cursor:pointer;font-size:13px;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
  position:relative;overflow:hidden;display:inline-flex;align-items:center;
}
.btn::after{
  content:"";position:absolute;inset:-2px;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.22),transparent 55%);
  opacity:0;transition:opacity .22s ease;
}
.btn:hover{ transform:translateY(-3px); }
.btn:hover::after{ opacity:1; }

.btn-primary{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  color:#1a0f0a;
  box-shadow:0 16px 44px rgba(196,122,44,.28),0 10px 26px rgba(0,0,0,.35);
}
.btn-primary:hover{ box-shadow:0 22px 60px rgba(196,122,44,.34),0 14px 30px rgba(0,0,0,.45); }
.btn-ghost{
  background:rgba(255,255,255,.06);color:rgba(243,238,232,.9);
  border:1px solid rgba(255,255,255,.12);
}
.btn-ghost:hover{ background:rgba(255,255,255,.10); }
.header-cta{ display:flex;align-items:flex-start;gap:10px; }

/* ========== HERO ========== */
.hero{
  min-height:100svh;display:flex;align-items:flex-start;
  position:relative;padding-top:84px;padding-bottom:28px;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:-6%;
  background:
    linear-gradient(180deg,rgba(18,10,6,.25),rgba(11,6,4,.92)),
    radial-gradient(900px 520px at 65% 12%,rgba(196,122,44,.28),transparent 60%),
    radial-gradient(700px 520px at 15% 55%,rgba(224,153,70,.16),transparent 60%),
    url("assets/images/hero.jpg");
  background-size:cover;background-position:center;
  transform:translate3d(0,0,0) scale(1.06);will-change:transform;z-index:-3;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(60,35,15,.55),rgba(60,35,15,.65));
}
.hero .topo{ opacity:.14; }

.hero-grid-pattern{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(184,115,51,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(184,115,51,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black,transparent);
  -webkit-mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black,transparent);
}

.hero .grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.25fr .75fr;
  grid-template-rows:auto 1fr;gap:34px;align-items:start;
  min-height:calc(100svh - 84px - 28px);
}

.hero-badge-line{ margin-bottom:12px; }
.hero-micro-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;font-size:11px;font-weight:900;
  letter-spacing:.14em;color:rgba(243,238,232,.8);
  background:rgba(184,115,51,.15);border:1px solid rgba(184,115,51,.25);
  backdrop-filter:blur(8px);
}

.hero-left{ grid-column:1;grid-row:1/span 2;display:grid;grid-template-rows:auto 1fr;align-items:start;align-content:start; }
.hero-copy{ grid-row:1;margin-bottom:28px; }

.hero h1{
  margin-top:14px;font-family:'Alfa Slab One',serif;
  font-size:clamp(56px,6.4vw,104px);line-height:.9;letter-spacing:.02em;
  text-shadow:0 40px 90px rgba(0,0,0,.55);color:#f3ebe4;text-transform:uppercase;
}
.hero .accent{ color:var(--accent2); }
.hero .sub{
  margin-top:16px;max-width:720px;font-size:18px;line-height:1.7;
  color:rgba(243,238,232,.82);
}
.hero .hero-cta{ margin-top:26px;display:flex;gap:12px;flex-wrap:wrap; }

.trust-strip{
  grid-row:2;align-self:start;margin-top:0;
  display:flex;flex-direction:column;gap:22px;max-width:520px;
}
.trust-pill{
  display:flex;gap:12px;align-items:flex-start;padding:18px 16px;
  border-radius:999px;background:rgba(0,0,0,.30);
  border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow3);
  transition:transform .3s ease,border-color .3s ease;
}
.trust-pill:hover{
  transform:translateX(6px);
  border-color:rgba(184,115,51,.3);
}
.badge{
  width:40px;height:40px;border-radius:999px;display:grid;place-items:center;
  background:rgba(196,122,44,.18);border:1px solid rgba(196,122,44,.22);
  color:var(--accent);flex-shrink:0;
}
.trust-pill .t1{ font-weight:900;color:var(--accent); }
.trust-pill .t2{ font-size:12px;color:rgba(243,238,232,.72);margin-top:2px; }

/* Hero panel */
.hero-panel{
  grid-column:2;grid-row:2;align-self:end;justify-self:end;
  width:min(380px,100%);border-radius:18px;
  background:linear-gradient(180deg,rgba(36,21,14,.72),rgba(18,10,6,.72));
  border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow2);
  overflow:hidden;position:relative;
}
.hero-panel::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 10%,rgba(196,122,44,.22),transparent 55%);opacity:.9;
}
.panel-shine{
  position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.05) 45%,transparent 50%);
  animation:panelShine 4s ease-in-out infinite;
}
@keyframes panelShine{
  0%,100%{transform:translateX(-100%)}
  50%{transform:translateX(100%)}
}
.hero-panel .inner{ position:relative;padding:18px 18px 16px; }
.panel-title{ font-weight:900;letter-spacing:.12em;font-size:11px;color:rgba(243,238,232,.72); }
.panel-big{ margin-top:10px;font-family:'Alfa Slab One',serif;font-size:28px;line-height:1.1; }
.panel-list{ margin-top:14px;display:grid;gap:10px;color:rgba(243,238,232,.82); }
.panel-item{ display:flex;gap:10px;align-items:flex-start;font-size:13px;line-height:1.45; }
.dot{
  width:10px;height:10px;border-radius:999px;background:var(--accent);margin-top:5px;
  box-shadow:0 0 0 7px rgba(196,122,44,.14);flex-shrink:0;
}

.panel-stats{
  margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:16px;
}
.stat{ text-align:center;flex:1; }
.stat-num{
  font-family:'Alfa Slab One',serif;font-size:32px;font-weight:400;
  color:var(--accent2);
}
.stat-label{ font-size:11px;letter-spacing:.08em;color:rgba(243,238,232,.6);margin-top:2px; }
.stat-divider{ width:1px;height:36px;background:rgba(255,255,255,.1); }

/* Scroll indicator */
.scroll-indicator{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  color:rgba(243,238,232,.4);animation:scrollBounce 2s ease-in-out infinite;
  z-index:3;
}
@keyframes scrollBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}

/* ========== CARDS ========== */
.card{
  border-radius:var(--r2);
  background:rgba(42,23,16,.72);
  box-shadow:var(--shadow2);position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.15);
  transition:transform .25s ease,box-shadow .25s ease;
}
.card::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url("assets/images/frystork.jpg") center/cover;
  filter:blur(28px) brightness(.35) saturate(.7);
  transform:scale(1.3);
  opacity:.55;
}
/* Section-specific card blur backgrounds */
#om-oss .card::before{ background-image:url("assets/images/Frystorkjordgubb.jpg"); }
#varfor .card::before{ background-image:url("assets/images/chiliconcarne.jpg"); }
#b2b .mini-grid .card:nth-child(1)::before{ background-image:url("assets/images/mat.jpg"); }
#b2b .mini-grid .card:nth-child(2)::before{ background-image:url("assets/images/special.jpg"); }
#b2b .mini-grid .card:nth-child(3)::before{ background-image:url("assets/images/frukt.jpg"); }
#b2b .mini-grid .card:nth-child(4)::before{ background-image:url("assets/images/varumarke.jpg"); }
#b2b > .container > .b2b > div > .card::before{ background-image:url("assets/images/process-4.jpg"); }
#freezerjoes .card::before{ background-image:url("assets/images/godis.jpg"); }
.track .card::before{ background-image:url("assets/images/glass.jpg"); }
.card::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(circle at 20% 0%,rgba(196,122,44,.14),transparent 45%),
    linear-gradient(180deg,rgba(42,23,16,.5),rgba(18,10,6,.6));
}
.card:hover{ transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.2); }
@keyframes sheen{ from{transform:translateX(-60%);opacity:.10} to{transform:translateX(60%);opacity:.28} }

.card .c{ position:relative;z-index:1;padding:22px;display:flex;flex-direction:column;gap:10px; }
.card h3{ font-size:18px;letter-spacing:.06em;line-height:1.15;color:#f3ebe4; }
.card p{ color:rgba(243,238,232,.72);line-height:1.7;font-size:14px;overflow-wrap:break-word; }

.icon{
  width:44px;height:44px;border-radius:14px;
  background:rgba(196,122,44,.18);border:1px solid rgba(196,122,44,.22);
  display:grid;place-items:center;color:var(--accent);flex-shrink:0;
}

.grid-4{ display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px; }
.grid-3{ display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px; }
.grid-4 .card h3{ font-size:14px;line-height:1.2;letter-spacing:.03em; }
.grid-4 .card:nth-child(2) h3{ font-size:13px; }

/* ========== HEAD / TYPOGRAPHY ========== */
.head{ display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap; }
.eyebrow{ color:var(--accent);font-weight:900;letter-spacing:.18em;font-size:11px;text-transform:uppercase; }
.h2{
  margin-top:10px;font-family:'Alfa Slab One',serif;
  font-size:clamp(34px,3.2vw,52px);line-height:1.05;color:var(--text);text-transform:uppercase;
}
.h2 .accent{ color:var(--accent); }
.lead{ margin-top:14px;color:var(--muted);line-height:1.8;max-width:720px;font-size:15px; }
p{ line-height:1.7; }
h1,h2,h3{ letter-spacing:.02em;color:var(--text); }

/* ========== SPLIT LAYOUT ========== */
.split{ margin-top:22px;display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:stretch; }
.media{
  border-radius:var(--r2);overflow:hidden;box-shadow:var(--shadow);
  position:relative;min-height:420px;
}
.media::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(18,10,6,.20),rgba(11,6,4,.92)),
    radial-gradient(700px 420px at 70% 10%,rgba(196,122,44,.20),transparent 55%),
    url("assets/images/Frystorkjordgubb.jpg");
  background-size:cover;background-position:center;transform:scale(1.02);
  transition:transform .6s ease;
}
.media:hover::before{ transform:scale(1.05); }
.media-shimmer{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.03) 45%,transparent 50%);
  animation:panelShine 6s ease-in-out infinite;
}
.media .cap{
  position:absolute;left:16px;right:16px;bottom:16px;z-index:2;
  border-radius:18px;background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.10);padding:16px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.media .cap .t{ font-weight:900;letter-spacing:.12em;font-size:11px;color:rgba(243,238,232,.72);text-transform:uppercase; }
.media .cap .b{ margin-top:8px;font-size:16px;line-height:1.5;color:rgba(243,238,232,.88); }

.checks{ margin-top:18px;list-style:none;display:grid;gap:10px; }
.checks li{
  padding-left:28px;position:relative;color:rgba(243,238,232,.82);line-height:1.6;
}
.checks li::before{
  content:"";position:absolute;left:0;top:6px;width:14px;height:14px;
  background:#E09946;
  mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4L19 7' stroke='black' stroke-width='3' fill='none'/%3E%3C/svg%3E") center/contain no-repeat;
  -webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4L19 7' stroke='black' stroke-width='3' fill='none'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ========== PROCESS STEPS ========== */
.process-steps{
  display:flex;align-items:center;gap:12px;margin:24px 0;
  padding:20px;border-radius:var(--r2);
  background:rgba(184,115,51,.08);border:1px solid rgba(184,115,51,.15);
}
.process-step{ text-align:center;flex:1; }
.process-icon{
  width:48px;height:48px;border-radius:50%;margin:0 auto 8px;
  background:rgba(184,115,51,.15);border:1px solid rgba(184,115,51,.25);
  display:grid;place-items:center;color:var(--accent);
}
.process-label{ font-weight:900;font-size:12px;letter-spacing:.08em;color:var(--accent); }
.process-desc{ font-size:11px;color:var(--muted);margin-top:4px; }
.process-connector{ flex-shrink:0;color:var(--accent);opacity:.5; }

/* ========== SERVICE CARDS ========== */
.service-card{ min-height:150px;position:relative;overflow:hidden;border-radius:26px; }
.service-card .tag{
  display:inline-flex;gap:10px;align-items:center;
  font-weight:900;letter-spacing:.12em;font-size:11px;text-transform:uppercase;
  color:rgba(243,238,232,.80);
}
.service-card .tag .pill{
  width:38px;height:38px;border-radius:14px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);
  color:var(--accent);
}
.service-card h3{ margin-top:14px; }

#tjanster{
  background:radial-gradient(900px 560px at 15% 15%,rgba(196,122,44,.18),transparent 60%),
    linear-gradient(180deg,#0f0704,#090402);
}
#tjanster .service-card{ background:none;position:relative;overflow:hidden; }
#tjanster .service-card::before{
  content:"";position:absolute;inset:0;background-size:cover;background-position:center;
  filter:blur(6px) brightness(.55);transform:scale(1.08);z-index:0;
  transition:transform .5s ease;
}
#tjanster .service-card:hover::before{ transform:scale(1.14); }
#tjanster .service-card::after{
  content:"";position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:1;
  background-image:none;filter:none;
}
#tjanster .service-card .c{ position:relative;z-index:2; }
#tjanster .service-card:nth-child(1)::before{ background-image:url("assets/images/godis.jpg"); }
#tjanster .service-card:nth-child(2)::before{ background-image:url("assets/images/frukt.jpg"); }
#tjanster .service-card:nth-child(3)::before{ background-image:url("assets/images/glass.jpg"); }
#tjanster .service-card:nth-child(4)::before{ background-image:url("assets/images/mat.jpg"); }
#tjanster .service-card:nth-child(5)::before{ background-image:url("assets/images/special.jpg"); }
#tjanster .service-card:nth-child(6)::before{ background-image:url("assets/images/varumarke.jpg"); }

#tjanster .lead{ color:rgba(243,238,232,.78); }
#tjanster .head .h2{ color:#f3ebe4; }
#tjanster .head .h2 .accent{ color:var(--accent2); }
#tjanster .eyebrow{ color:var(--accent2); }

/* ========== VARFÖR ========== */
#varfor .varfor-grid{ display:grid;grid-template-columns:1fr 1fr; }
#varfor .varfor-img{ min-height:380px;background-size:cover;background-position:center; }
#varfor .top{ background-image:url("assets/images/chiliconcarne.jpg");border-radius:26px;border-bottom-right-radius:0; }
#varfor .bottom{ background-image:url("assets/images/frystork.jpg");border-radius:26px;border-top-left-radius:0; }
#varfor .varfor-head{ padding:40px;text-align:right; }
#varfor .varfor-text{ padding:40px; }
#varfor .lead{ color:var(--text); }
#varfor h2.h2{ color:#1a0f0a; }
#varfor h2.h2 .accent{ color:var(--accent2); }
#varfor .varfor-text .card p{ color:rgba(243,238,232,.72); }

.varfor-marquee{
  margin-top:24px;overflow:hidden;
  width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
}
.track{
  display:flex;gap:18px;width:max-content;animation:scroll 35s linear infinite;
}
@keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
.track .card{ min-width:220px;border-radius:18px; }
.track .card .c{
  flex-direction:row;align-items:center;
  color:rgba(243,238,232,.72);font-weight:600;
}

/* ========== B2B ========== */
.b2b{ margin-top:18px;display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start; }
.b2b-right{ display:grid;gap:12px; }
.b2b-hero{
  border-radius:var(--r2);overflow:hidden;box-shadow:var(--shadow);
  position:relative;min-height:220px;
}
.b2b-hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(18,10,6,.10),rgba(11,6,4,.88)),
    radial-gradient(700px 320px at 70% 0%,rgba(196,122,44,.22),transparent 55%),
    url("assets/images/process-4.jpg");
  background-size:cover;background-position:center;
  transition:transform .5s ease;
}
.b2b-hero:hover::before{ transform:scale(1.03); }
.b2b-hero .cap{
  position:absolute;left:16px;right:16px;bottom:16px;
  border-radius:18px;background:rgba(0,0,0,.42);
  border:1px solid rgba(255,255,255,.10);padding:16px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.mini-grid{ display:grid;grid-template-columns:1fr 1fr;gap:12px; }
.banner-accent{
  border-radius:var(--r2);
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  color:#1a0f0a;
  box-shadow:0 22px 70px rgba(196,122,44,.28),0 14px 30px rgba(0,0,0,.45);
}
.banner-accent .c{ padding:22px; }
.banner-accent h3{ letter-spacing:.10em;font-size:18px;color:#1a0f0a; }
.banner-accent p{ margin-top:10px;color:rgba(26,15,10,.88);line-height:1.7;font-size:14px; }

/* B2B dark-bg card overrides */
#b2b .mini-grid .card h3{ color:rgba(243,238,232,.92); }
#b2b .mini-grid .card p{ color:rgba(243,238,232,.72); }
#b2b .b2b-hero .cap .t{ color:rgba(243,238,232,.92); }
#b2b .b2b-hero .cap .b{ color:rgba(243,238,232,.72); }

/* ========== CONTACT ========== */
.contact{
  background:radial-gradient(900px 560px at 15% 15%,rgba(196,122,44,.18),transparent 60%),
    linear-gradient(180deg,#0f0704,#090402);
}
.contact .split{ grid-template-columns:1.05fr .95fr; }
.form{ display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px; }
.form .full{ grid-column:1/-1; }
.input{
  width:100%;padding:16px;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06);
  color:rgba(243,238,232,.92);outline:none;font-family:inherit;font-size:14px;
  transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease;
}
.input:focus{
  border-color:rgba(196,122,44,.40);
  box-shadow:0 0 0 8px rgba(196,122,44,.12);
  transform:translateY(-1px);
}
textarea.input{ min-height:150px;resize:vertical; }

#kontakt .head .h2{ color:#f3ebe4; }
#kontakt .head .h2 .accent{ color:var(--accent2); }
#kontakt .lead{ color:rgba(243,238,232,.78); }
#kontakt .form label{ color:var(--accent2); }
#kontakt .info-card .k{ color:var(--accent2); }
#kontakt .eyebrow{ color:var(--accent2); }

.info-stack{ display:grid;gap:12px; }
.info-card{
  border-radius:var(--r2);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow3);padding:18px;
  transition:transform .2s ease,border-color .2s ease;
}
.info-card:hover{ transform:translateY(-2px);border-color:rgba(184,115,51,.25); }
.info-card .row{ display:flex;gap:12px;align-items:flex-start; }
.info-card .k{ font-weight:900;letter-spacing:.10em;font-size:12px; }
.info-card .v{ margin-top:6px;color:rgba(243,238,232,.75);line-height:1.6; }

.map{
  border-radius:var(--r2);overflow:hidden;min-height:190px;position:relative;
}
.map::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(18,10,6,.18),rgba(11,6,4,.92)),
    radial-gradient(700px 420px at 70% 20%,rgba(196,122,44,.20),transparent 60%),
    url("assets/images/hero.jpg");
  background-size:cover;background-position:center;
}
.map .pin{
  position:absolute;left:18px;bottom:18px;border-radius:18px;padding:12px 14px;
  background:rgba(0,0,0,.44);border:1px solid rgba(255,255,255,.10);
  color:rgba(243,238,232,.86);font-size:13px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}

/* ========== FOOTER ========== */
.footer{
  padding:40px 0 30px;
  background:
    radial-gradient(800px 400px at 30% 20%, rgba(196,122,44,.08), transparent 55%),
    linear-gradient(180deg, var(--bg2), var(--bg2));
  position:relative;
}
.footer .topo{ opacity:.12; }
.footer .cols{ display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:18px; }
.footer h4{ font-weight:900;letter-spacing:.10em;font-size:12px; }
.footer p,.footer a{ margin-top:10px;line-height:1.7;font-size:13px; }
.footer a:hover{ opacity:.75; }
.footer .bottom{
  margin-top:34px;padding-top:18px;border-top:1px solid rgba(255,255,255,.10);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:12px;
}
.footer,.footer p,.footer a,.footer li,.footer h4,.footer .bottom,.footer .bottom *{
  color:var(--muted2);
}
.footer h4{ color:var(--accent); }
.footer .brand{ color:var(--accent); }

/* ========== REVEAL ========== */
.reveal{
  opacity:0;transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);
}
.reveal.visible{ opacity:1;transform:translateY(0); }

.accent-text{ color:var(--accent) !important; }

/* ========== MOBILE MENU ========== */
.mobile-menu-btn{
  display:none;appearance:none;border:none;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:10px;color:rgba(243,238,232,.9);cursor:pointer;
  transition:background .2s ease;
}
.mobile-menu-btn:hover{ background:rgba(255,255,255,.14); }

.mobile-nav{
  display:none;flex-direction:column;gap:0;
  max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;
  border-top:1px solid rgba(255,255,255,.08);margin-top:12px;
}
.mobile-nav.open{
  display:flex;max-height:400px;padding:12px 0 4px;
}
.mobile-nav a{
  display:block;padding:14px 0;font-size:15px;font-weight:600;
  color:rgba(243,238,232,.82);letter-spacing:.04em;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:color .2s ease,padding-left .2s ease;
}
.mobile-nav a:last-child{ border-bottom:none; }
.mobile-nav a:hover,.mobile-nav a:active{ color:var(--accent2);padding-left:8px; }

/* ========== RESPONSIVE ========== */
@media (max-width:1100px){
  .hero .grid{ grid-template-columns:1fr;grid-template-rows:auto auto;min-height:auto; }
  .hero-left{ grid-row:auto; }
  .trust-strip{ flex-direction:column;gap:14px;max-width:none; }
  .hero-panel{ grid-column:1;grid-row:auto;width:min(520px,100%); }
  .grid-4{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .split{ grid-template-columns:1fr; }
  .b2b{ grid-template-columns:1fr; }
  .contact .split{ grid-template-columns:1fr; }
  .footer .cols{ grid-template-columns:1fr 1fr; }
  .process-steps{ flex-wrap:wrap;justify-content:center; }
  .process-connector{ display:none; }
}

@media (max-width:720px){
  /* Header */
  .nav{ display:none; }
  .btn-header-cta{ display:none; }
  .mobile-menu-btn{ display:grid;place-items:center; }
  .header .row{ gap:10px; }
  .header{ padding:14px 0; }

  /* General spacing */
  .container{ width:92%; }
  .pad{ padding:36px 0 28px; }
  section{ padding-top:32px;padding-bottom:32px; }

  /* Hero */
  .hero{ min-height:auto;padding-top:74px;padding-bottom:60px; }
  .hero h1{ font-size:clamp(38px,10vw,56px);letter-spacing:.01em;line-height:.92; }
  .hero .sub{ font-size:15px;margin-top:12px; }
  .hero .hero-cta{ flex-direction:column;gap:10px; }
  .hero .hero-cta .btn{ width:100%;justify-content:center;padding:16px 20px; }
  .hero .grid{ gap:24px;min-height:auto; }
  .hero-left{ grid-column:1;grid-row:auto; }
  .hero-panel{ grid-column:1;grid-row:auto;width:100%; }
  .hero-micro-badge{ font-size:10px;padding:6px 12px; }
  .trust-strip{ gap:10px; }
  .trust-pill{ padding:14px 14px;border-radius:18px;gap:10px; }
  .trust-pill .t1{ font-size:13px; }
  .trust-pill .t2{ font-size:11px; }
  .badge{ width:36px;height:36px; }
  .panel-big{ font-size:22px; }
  .stat-num{ font-size:26px; }
  .scroll-indicator{ display:none; }

  /* Typography */
  .h2{ font-size:clamp(28px,7vw,40px); }
  .lead{ font-size:14px;margin-top:10px; }
  .eyebrow{ font-size:10px; }

  /* Cards */
  .grid-3{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr; }
  .card .c{ padding:18px; }
  .card h3{ font-size:16px; }
  .grid-4 .card h3{ font-size:15px; }
  .grid-4 .card:nth-child(2) h3{ font-size:15px; }

  /* Service cards */
  .service-card{ min-height:120px; }

  /* Varför section */
  #varfor .varfor-grid{ grid-template-columns:1fr; }
  #varfor .varfor-img{ min-height:220px;border-radius:18px !important; }
  #varfor .varfor-head{ padding:20px 0;text-align:left; }
  #varfor .varfor-text{ padding:20px 0; }
  .process-steps{ flex-direction:column;padding:16px;gap:16px; }
  .process-step{ width:100%; }
  .process-connector{ display:none; }

  /* B2B */
  .b2b{ grid-template-columns:1fr;gap:14px; }
  .b2b-hero{ min-height:180px; }
  .mini-grid{ grid-template-columns:1fr;gap:10px; }
  .banner-accent .c{ padding:18px; }
  .banner-accent h3{ font-size:15px; }

  /* Split / Media */
  .split{ grid-template-columns:1fr;gap:16px; }
  .media{ min-height:280px !important; }
  .media .cap{ left:10px;right:10px;bottom:10px;padding:14px; }
  .media .cap .b{ font-size:14px; }

  /* Freezer Joe's banner */
  #freezerjoes{ overflow:hidden; }
  .fj-banner-wrap{
    width:92%;margin-left:4%;margin-right:4%;
    transform:none;margin-bottom:20px;margin-top:30px;
    padding-top:50px;
  }
  .fj-banner{ border-radius:24px;flex-direction:column;min-height:auto;overflow:visible; }
  .fj-banner-bg{ border-radius:24px; }
  .fj-banner-img{
    position:relative;left:auto;bottom:auto;
    transform:translateY(-40px);margin-bottom:-30px;
    width:180px;margin-left:auto;margin-right:auto;z-index:3;
  }
  .fj-banner-content{ margin-left:0;max-width:100%;padding:0 20px 20px;text-align:center; }
  #freezerjoes .fj-media{ min-height:220px; }

  /* Improved mobile spacing & readability */
  .head{ flex-direction:column;align-items:flex-start; }
  .checks{ gap:8px; }
  .checks li{ font-size:14px; }

  /* Hero improvements */
  .hero-copy{ margin-bottom:20px; }
  .trust-pill .t1{ font-size:14px; }
  .panel-list{ gap:8px; }
  .panel-item{ font-size:12px; }

  /* Card spacing */
  .card .c{ padding:16px; }
  .icon{ width:38px;height:38px;border-radius:12px; }

  /* Section backgrounds - soften on mobile */
  .section::after{ height:60px; }

  /* Info cards on contact */
  .info-card{ padding:16px; }
  .info-card .k{ font-size:11px; }
  .info-card .v{ font-size:13px; }

  /* Footer mobile */
  .footer .bottom{ flex-direction:column;gap:6px;text-align:center; }
  .footer p,.footer a{ font-size:12px; }

  /* Contact */
  .contact .split{ grid-template-columns:1fr; }
  .form{ grid-template-columns:1fr;gap:10px; }
  .input{ padding:14px;border-radius:14px;font-size:15px; }
  textarea.input{ min-height:120px; }
  .info-card{ padding:14px; }
  .map{ min-height:160px; }

  /* Footer */
  .footer .cols{ grid-template-columns:1fr;gap:24px; }
  .footer{ padding:50px 0 30px; }

  /* Buttons */
  .btn{ padding:14px 16px;font-size:12px;border-radius:12px; }
  .btn-primary{ width:100%;justify-content:center; }

  /* Decorative - tone down for performance */
  .deco-ring{ display:none; }
  .deco-stripe{ display:none; }
  .deco-dots{ display:none; }
  .orb{ opacity:.4; }
  .orb-1{ width:300px;height:300px; }
  .orb-2{ width:200px;height:200px; }
  .orb-3{ display:none; }

  /* Marquee */
  .varfor-marquee{ margin-top:30px; }
  .track .card{ min-width:180px; }
}

/* ========== SCROLLBAR ========== */
::-webkit-scrollbar{ width:8px; }
::-webkit-scrollbar-track{ background:rgba(0,0,0,.1); }
::-webkit-scrollbar-thumb{ background:rgba(184,115,51,.3);border-radius:4px; }
::-webkit-scrollbar-thumb:hover{ background:rgba(184,115,51,.5); }

/* ========== FREEZER JOE'S BANNER ========== */
#freezerjoes .fj-media{ min-height:240px; }
.fj-media-col{ display:flex;flex-direction:column;margin-top:-80px; }

#freezerjoes .split{ align-items:start; }

.fj-banner-wrap{
  transform:translateY(-160px);
  margin-bottom:-160px;
  margin-left:50%;
  width:50vw;
  position:relative;
  z-index:5;
}
.fj-banner{
  position:relative;
  border-radius:9999px 0 0 9999px;
  min-height:160px;
  overflow:visible;
  display:flex;
  align-items:center;
  padding:30px 40px 30px 460px;
}
.fj-banner-bg{
  position:absolute;inset:0;z-index:0;
  border-radius:inherit;overflow:hidden;
  background:linear-gradient(135deg,rgba(42,26,18,.98),rgba(18,10,6,.95));
  border:1px solid rgba(184,115,51,.25);border-right:none;
  box-shadow:0 20px 50px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.08);
}
.fj-banner-img{
  position:absolute;
  left:-40px;
  bottom:0;
  width:500px;height:auto;
  z-index:3;
  pointer-events:none;
  filter:drop-shadow(0 14px 40px rgba(0,0,0,.5));
}
.fj-banner-content{
  position:relative;z-index:2;
}
.fj-banner-content .eyebrow{ color:var(--accent2); }
.fj-banner-content p{
  margin-top:8px;color:rgba(243,238,232,.78);font-size:14px;line-height:1.7;
}

/* Allow banner to break out */
#freezerjoes{ overflow:visible; }
#freezerjoes::after{ display:none; }

/* ========== LIGHT SECTION TEXT FIXES ========== */
#om-oss .lead{ color:var(--muted); }
#om-oss .h2{ color:var(--partner-color); }
#om-oss .h2 .accent{ color:var(--accent); }

/* Dark-bg section overrides for card/heading text */
.hero h1,.hero h2,.hero h3{ color:#f3ebe4; }
.hero .h2{ color:#f3ebe4; }
.card h3{ color:#f3ebe4; }
.card p{ color:rgba(243,238,232,.72); }
.panel-big{ color:#f3ebe4; }

/* B2B and Freezer Joe's on light bg */
#b2b .head .h2{ color:var(--partner-color); }
#b2b .head .h2 .accent{ color:var(--accent); }
#b2b .b2b > div.reveal > p.lead{ color:var(--muted); }
#freezerjoes .head .h2{ color:var(--partner-color); }
#freezerjoes .head .h2 .accent{ color:var(--accent); }
#freezerjoes .lead{ color:var(--muted); }
#freezerjoes .checks li{ color:var(--text); }

/* Contact section dark bg */
.contact .card h3,.contact .card p{ color:rgba(243,238,232,.82); }
.contact .info-card .v{ color:rgba(243,238,232,.75); }

/* ========== MOBILE BANNER OVERRIDE (must come after desktop banner rules) ========== */
@media (max-width:720px){
  #freezerjoes{ overflow:hidden !important; }
  .fj-banner-wrap{
    width:88% !important;margin-left:6% !important;margin-right:6% !important;
    transform:none !important;margin-bottom:20px !important;margin-top:30px !important;
    padding-top:50px;
  }
  .fj-banner{ border-radius:24px !important;flex-direction:column !important;min-height:auto !important; }
  .fj-banner-bg{ border-radius:24px !important; }
  .fj-banner-img{
    position:relative !important;left:auto !important;bottom:auto !important;
    transform:translateY(-40px) !important;margin-bottom:-30px;
    width:180px !important;margin-left:auto;margin-right:auto;
  }
  .fj-banner-content{
    margin-left:0 !important;max-width:100% !important;
    padding:0 20px 20px !important;text-align:center;
  }
}
