/* ============ Tokens ============ */
:root{
  --blue-700:#0369a1;
  --blue-600:#0284c7;
  --blue-500:#0ea5e9;
  --blue-400:#38bdf8;
  --blue-100:#e0f2fe;
  --blue-50:#f0f9ff;
  --navy:#0b2945;
  --ink:#13283d;
  --slate:#506074;
  --muted:#8197ab;
  --sun:#ffd23f;
  --green:#10b981;
  --red:#ef5b54;
  --bg:#ffffff;
  --bg-soft:#f1f8fd;
  --bg-sky:#e8f5ff;
  --card:#ffffff;
  --border:#e4eef6;
  --shadow-sm:0 4px 14px rgba(11,52,90,.06);
  --shadow:0 16px 40px rgba(7,73,130,.10);
  --shadow-lg:0 30px 70px rgba(7,73,130,.16);
  --radius:18px;
  --radius-lg:26px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --container:1160px;
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --display:'Poppins',var(--font);
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --gold:#c9a45c;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}

/* ============ Shared type ============ */
.kicker{
  display:inline-block;
  font-family:var(--font);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--blue-600);
  background:var(--blue-50);
  padding:6px 14px;
  border-radius:100px;
  margin-bottom:16px;
}
.kicker--light{color:#fff;background:rgba(255,255,255,.18)}
.section-title{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(1.7rem,3.6vw,2.7rem);
  line-height:1.12;
  letter-spacing:-.02em;
  color:var(--navy);
}
.section-text{
  color:var(--slate);
  font-size:1.04rem;
  margin-top:14px;
  max-width:560px;
}
.section-head{max-width:640px;margin-bottom:44px}
.section-head .section-text{margin-inline:0}

/* ============ Buttons ============ */
.btn{
  --pad:13px 24px;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--display);
  font-weight:600;
  font-size:.96rem;
  padding:var(--pad);
  border-radius:100px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn--primary{
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));
  color:#fff;
  box-shadow:0 12px 26px rgba(2,132,199,.32);
}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(2,132,199,.42)}
.btn--ghost{
  background:#fff;color:var(--blue-700);border-color:var(--blue-100);
  box-shadow:var(--shadow-sm);
}
.btn--ghost:hover{border-color:var(--blue-400);transform:translateY(-2px)}
.btn--lg{--pad:16px 30px;font-size:1.02rem}
.btn--block{width:100%}

/* ============ Promo strip ============ */
.promo{
  background:linear-gradient(90deg,var(--blue-600),var(--blue-500));
  color:#fff;overflow:hidden;
}
.promo__track{
  display:flex;gap:26px;align-items:center;
  padding:9px 0;font-size:.82rem;font-weight:500;white-space:nowrap;
  justify-content:center;flex-wrap:wrap;
}
.promo__dot{opacity:.55}

/* ============ Header ============ */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s;
}
.header.scrolled{border-color:var(--border);box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:20px}
.brand{display:flex;align-items:center;gap:11px}
.brand__logo{height:50px;width:auto;display:block}
.brand__logo--footer{height:40px}
.brand__mark{display:grid;place-items:center;filter:drop-shadow(0 6px 10px rgba(14,165,233,.28))}
.brand__text{
  font-family:var(--display);font-weight:800;font-size:1.18rem;color:var(--navy);
  line-height:1;display:flex;flex-direction:column;
}
.brand__sub{font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-500);margin-top:3px}
.brand--light .brand__text{color:#fff}
.nav{display:flex;gap:30px}
.nav a{
  font-weight:500;font-size:.95rem;color:var(--slate);position:relative;padding:4px 0;
  transition:color .2s;
}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--blue-500);border-radius:2px;transition:width .25s var(--ease)}
.nav a:hover{color:var(--navy)}
.nav a:hover::after{width:100%}
.header__cta{display:flex;align-items:center;gap:14px}
.header__phone{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:.92rem;color:var(--blue-700)}
.header__phone:hover{color:var(--blue-500)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2.5px;background:var(--navy);border-radius:3px;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-nav{
  display:none;flex-direction:column;gap:4px;
  padding:0 24px;max-height:0;overflow:hidden;
  background:#fff;border-bottom:1px solid var(--border);
  transition:max-height .4s var(--ease),padding .4s var(--ease);
}
.mobile-nav.open{max-height:430px;padding:14px 24px 22px}
.mobile-nav a{padding:12px 6px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--border)}
.mobile-nav a:last-child{border:0;margin-top:10px}

/* ============ Hero ============ */
.hero{position:relative;background:linear-gradient(180deg,var(--bg-sky),#fff 78%);overflow:hidden}
.hero__blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;z-index:0}
.hero__blob--1{width:420px;height:420px;background:#bfe6ff;top:-120px;right:-80px}
.hero__blob--2{width:360px;height:360px;background:#d8f3e6;bottom:-120px;left:-100px;opacity:.45}
.hero__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;
  padding:64px 24px 80px;
}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.9rem;color:var(--blue-700);margin-bottom:18px}
.eyebrow__dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(16,185,129,.18)}
.hero__title{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2.3rem,5.2vw,3.7rem);line-height:1.05;letter-spacing:-.03em;color:var(--navy);
}
.hero__title .hl{
  position:relative;color:var(--blue-600);white-space:nowrap;
}
.hero__title .hl::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:.06em;height:.32em;
  background:var(--sun);opacity:.45;border-radius:6px;z-index:-1;
}
.hero__lead{color:var(--slate);font-size:1.12rem;margin:22px 0 30px;max-width:500px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero__trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 24px;margin-top:30px}
.hero__trust li{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.92rem;color:var(--navy)}

.hero__art{display:flex;justify-content:center}
.window-card{position:relative;width:min(100%,400px)}
.window-illu{width:100%;height:auto;filter:drop-shadow(0 30px 50px rgba(7,73,130,.22))}
.window-card__badge{
  position:absolute;right:-6px;bottom:18px;
  background:#fff;border-radius:16px;padding:12px 18px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;line-height:1.1;
  border:1px solid var(--border);
}
.window-card__badge strong{font-family:var(--display);font-weight:800;color:var(--blue-600);font-size:1.4rem}
.window-card__badge span{font-size:.74rem;color:var(--muted);font-weight:500}

/* hero illustration animations */
.glass-shine{animation:sweep 5s var(--ease) infinite}
@keyframes sweep{0%,62%{transform:translateX(0)}100%{transform:translateX(520px)}}
.squeegee{animation:wipe 5s var(--ease) infinite;transform-origin:center}
@keyframes wipe{0%{transform:translate(150px,150px);opacity:0}10%{opacity:1}55%{transform:translate(0,0)}70%,100%{transform:translate(-40px,-40px);opacity:0}}
.spark{transform-origin:center;animation:tw 2.6s ease-in-out infinite}
.spark--2{animation-delay:1.1s}
@keyframes tw{0%,100%{transform:scale(.5);opacity:.3}50%{transform:scale(1);opacity:1}}
.drop{animation:fall 3.4s ease-in infinite}
.drop--2{animation-delay:.7s}.drop--3{animation-delay:1.4s}
@keyframes fall{0%{transform:translateY(0);opacity:0}15%{opacity:.9}100%{transform:translateY(46px);opacity:0}}

/* ============ Badges ============ */
.badges{margin-top:-34px;position:relative;z-index:2}
.badges__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:20px;box-shadow:var(--shadow);
}
.badge{display:flex;align-items:center;gap:13px;padding:8px 10px}
.badge__icon{font-size:1.7rem;line-height:1}
.badge strong{display:block;font-family:var(--display);font-weight:700;color:var(--navy);font-size:1rem}
.badge span{font-size:.84rem;color:var(--muted)}

/* ============ Calculator ============ */
.calc{padding:84px 0}
.calc__inner{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center}
.calc__points{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:12px}
.calc__points li{display:flex;align-items:center;gap:11px;color:var(--slate);font-weight:500}
.tick{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--blue-50);color:var(--blue-600);font-weight:800;font-size:.8rem;flex:none}
.calc__panel{
  background:linear-gradient(180deg,#fff,var(--blue-50));
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px;box-shadow:var(--shadow-lg);
}
.calc__field{margin-bottom:22px}
.calc__field>label{display:block;font-weight:600;color:var(--navy);margin-bottom:11px;font-size:.96rem}
.calc__field>label strong{color:var(--blue-600)}
.seg{display:flex;gap:8px;background:#eef6fc;border-radius:14px;padding:5px}
.seg__btn{
  flex:1;border:0;background:transparent;cursor:pointer;
  font-family:var(--font);font-weight:600;font-size:.9rem;color:var(--slate);
  padding:10px 6px;border-radius:10px;transition:.2s var(--ease);
}
.seg__btn:hover{color:var(--navy)}
.seg__btn.is-active{background:#fff;color:var(--blue-600);box-shadow:var(--shadow-sm)}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:8px;
  background:linear-gradient(90deg,var(--blue-400),var(--blue-100));outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;
  border:5px solid var(--blue-500);cursor:pointer;box-shadow:var(--shadow-sm);
}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:5px solid var(--blue-500);cursor:pointer}
.calc__scale{display:flex;justify-content:space-between;font-size:.76rem;color:var(--muted);margin-top:7px}
.calc__result{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:#fff;border:1px dashed var(--blue-100);border-radius:16px;padding:18px 22px;margin-bottom:18px;
}
.calc__price{display:flex;flex-direction:column;line-height:1.1}
.calc__from{font-size:.78rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.calc__amount{font-family:var(--display);font-weight:800;font-size:2.1rem;color:var(--blue-600)}
.calc__unit{font-size:.8rem;color:var(--muted)}
.calc__before{font-size:.9rem;color:var(--muted)}
.calc__before s{color:var(--red)}
.calc__note{font-size:.8rem;color:var(--muted);text-align:center;margin-top:12px}

/* ============ Cards (shared) ============ */
.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}

/* ============ Services ============ */
.services{padding:84px 0;background:var(--bg-soft)}
.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service{padding:30px 26px}
.service:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--blue-100)}
.service__icon{font-size:2.2rem;display:block;margin-bottom:14px}
.service h3{font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.18rem;margin-bottom:8px}
.service p{color:var(--slate);font-size:.94rem}

/* ============ Steps ============ */
.steps{padding:84px 0}
.steps__grid{display:flex;align-items:stretch;gap:14px}
.step{
  flex:1;background:linear-gradient(180deg,#fff,var(--blue-50));
  border:1px solid var(--border);border-radius:var(--radius);padding:32px 26px;text-align:center;
}
.step__num{
  display:grid;place-items:center;width:48px;height:48px;margin:0 auto 16px;
  border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--blue-600));
  color:#fff;font-family:var(--display);font-weight:800;font-size:1.2rem;box-shadow:0 10px 20px rgba(2,132,199,.32);
}
.step h3{font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.16rem;margin-bottom:8px}
.step p{color:var(--slate);font-size:.94rem}
.step__arrow{display:flex;align-items:center;color:var(--blue-400);font-size:1.6rem;font-weight:700}

/* ============ Pricing ============ */
.pricing{padding:84px 0;background:var(--bg-soft)}
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.plan{padding:34px 28px;display:flex;flex-direction:column;position:relative}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan--featured{
  border:2px solid var(--blue-500);box-shadow:var(--shadow);
  background:linear-gradient(180deg,#fff,var(--blue-50));
}
.plan__badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;
  font-family:var(--display);font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 16px;border-radius:100px;box-shadow:0 8px 18px rgba(2,132,199,.34);white-space:nowrap;
}
.plan__name{font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.3rem}
.plan__freq{color:var(--muted);font-size:.86rem;margin-bottom:18px}
.plan__price{display:flex;align-items:baseline;gap:7px;margin-bottom:20px;color:var(--navy)}
.plan__price span{color:var(--muted);font-size:.86rem}
.plan__price strong{font-family:var(--display);font-weight:800;font-size:2.6rem;color:var(--blue-600);line-height:1}
.plan__list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:26px}
.plan__list li{position:relative;padding-left:26px;color:var(--slate);font-size:.94rem}
.plan__list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--green);font-weight:800}
/* funktion som paketet INTE har — grått kryss + nedtonad text (loss aversion, ej dold) */
.plan__list li.is-off{color:var(--muted)}
.plan__list li.is-off::before{content:"✕";color:#bcc6d1;font-weight:700}
.plan .btn{margin-top:auto}
.pricing__foot{text-align:center;color:var(--muted);font-size:.88rem;margin-top:26px;max-width:680px;margin-inline:auto}

/* ============ RUT band ============ */
.rut{padding:72px 0}
.rut__inner{
  display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-500));
  border-radius:var(--radius-lg);padding:46px;color:#fff;box-shadow:var(--shadow-lg);
}
.rut__text h2{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.15;margin-bottom:12px}
.rut__text p{color:rgba(255,255,255,.9);max-width:440px}
.rut__example{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:22px}
.rut__row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:.96rem}
.rut__row s{opacity:.7}
.rut__minus{font-weight:700;color:var(--sun)}
.rut__row--total{border-top:1px solid rgba(255,255,255,.25);margin-top:6px;padding-top:14px;font-size:1.05rem}
.rut__row--total strong{font-family:var(--display);font-weight:800;font-size:1.6rem}

/* ============ Why us ============ */
.why{padding:84px 0}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.why__item{padding:28px 24px}
.why__item:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--blue-100)}
.why__icon{font-size:1.9rem;display:block;margin-bottom:12px}
.why__item h3{font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.08rem;margin-bottom:7px}
.why__item p{color:var(--slate);font-size:.92rem}

/* ============ Areas ============ */
.areas{padding:30px 0 84px}
.areas__inner{
  background:var(--bg-sky);border-radius:var(--radius-lg);padding:54px 40px;text-align:center;
}
.areas__inner .section-text{margin-inline:auto}
.areas__tags{display:flex;flex-wrap:wrap;justify-content:center;gap:11px;margin-top:30px}
.areas__tags span{
  background:#fff;border:1px solid var(--border);color:var(--slate);
  padding:9px 18px;border-radius:100px;font-size:.9rem;font-weight:500;
  transition:.25s var(--ease);
}
.areas__tags span:hover{color:var(--blue-600);border-color:var(--blue-400);transform:translateY(-2px)}

/* ============ FAQ ============ */
.faq{padding:84px 0;background:var(--bg-soft)}
.faq__list{max-width:820px}
.faq__item{
  background:#fff;border:1px solid var(--border);border-radius:14px;margin-bottom:12px;
  box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq__item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 22px;font-family:var(--display);font-weight:600;color:var(--navy);font-size:1.04rem;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__plus{position:relative;width:18px;height:18px;flex:none}
.faq__plus::before,.faq__plus::after{content:"";position:absolute;background:var(--blue-500);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.faq__plus::before{left:0;right:0;top:8px;height:2px}
.faq__plus::after{top:0;bottom:0;left:8px;width:2px}
.faq__item[open] .faq__plus::after{transform:scaleY(0);opacity:0}
.faq__a{padding:0 22px 22px;color:var(--slate);font-size:.96rem}

/* ============ Book / contact ============ */
.book{padding:84px 0}
.book__inner{
  display:grid;grid-template-columns:1fr 1.05fr;gap:46px;align-items:start;
}
.book__copy{
  background:linear-gradient(150deg,var(--navy),var(--blue-700));
  color:#fff;border-radius:var(--radius-lg);padding:42px;align-self:stretch;
}
.book__copy h2{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.12;margin-bottom:14px}
.book__copy>p{color:rgba(255,255,255,.85);margin-bottom:30px}
.book__contact{list-style:none;display:flex;flex-direction:column;gap:18px}
.book__contact li{display:flex;align-items:center;gap:14px}
.book__ci{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.14);font-size:1.2rem;flex:none}
.book__contact span{display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.65)}
.book__contact strong{font-weight:600}
.book__form{padding:30px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px;display:flex;flex-direction:column}
.field label{font-weight:600;font-size:.85rem;color:var(--navy);margin-bottom:7px}
.field input,.field select,.field textarea{
  font-family:var(--font);font-size:.96rem;color:var(--ink);
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:12px;
  padding:12px 14px;outline:none;transition:border-color .2s,background .2s,box-shadow .2s;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:#9fb2c4}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--blue-400);background:#fff;box-shadow:0 0 0 4px rgba(56,189,248,.16);
}
.field--error input,.field--error select,.field--error textarea{border-color:var(--red);background:#fff5f4}
.field__error{color:var(--red);font-size:.78rem;margin-top:6px}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.book__success,.book__error{display:none;text-align:center;margin-top:14px;font-weight:600}
.book__success{color:var(--green)}
.book__success.show{display:block}
.book__error{color:var(--red)}
.book__error.show{display:block}

/* ============ Footer ============ */
.footer{background:var(--navy);color:#cdddec;padding:60px 0 26px}
.footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand p{margin-top:16px;font-size:.92rem;color:#9fb6cc;max-width:300px}
.footer__col h4{font-family:var(--display);font-weight:700;color:#fff;font-size:.96rem;margin-bottom:16px}
.footer__col a,.footer__col span{display:block;color:#9fb6cc;font-size:.92rem;padding:5px 0;transition:color .2s}
.footer__col a:hover{color:var(--blue-400)}
.footer__bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-top:22px;font-size:.84rem;color:#7e98b1}

/* ============ Floating action button (mobile) ============ */
.fab{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:55;display:none;
  justify-content:center;align-items:center;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;
  font-family:var(--display);font-weight:700;padding:16px;border-radius:16px;
  box-shadow:0 14px 30px rgba(2,132,199,.42);
}

/* ============ Scroll progress ============ */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:80;
  background:linear-gradient(90deg,var(--blue-400),var(--blue-600));
  box-shadow:0 0 10px rgba(2,132,199,.5);transition:width .12s linear;
}

/* ============ Hero campaign chip ============ */
.camp-chip{
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#fff,var(--blue-50));
  border:1px solid var(--blue-100);
  color:var(--blue-700);font-weight:600;font-size:.88rem;
  padding:7px 8px 7px 14px;border-radius:100px;margin-bottom:18px;
  box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.camp-chip:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.camp-chip__leaf{font-size:1rem;display:inline-block;animation:leafSpin 6s ease-in-out infinite}
.camp-chip__arrow{
  display:grid;place-items:center;width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;font-size:.8rem;
  transition:transform .25s var(--ease);
}
.camp-chip:hover .camp-chip__arrow{transform:translateX(3px)}
@keyframes leafSpin{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(10deg)}}

/* ============ Hero rating badge ============ */
.window-card__rating{
  position:absolute;left:-6px;top:22px;
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:9px 14px;box-shadow:var(--shadow);display:flex;flex-direction:column;line-height:1.25;
}
.window-card__stars{color:#ffc043;font-size:.86rem;letter-spacing:1px}
.window-card__rating span{font-size:.74rem;color:var(--muted)}
.window-card__rating strong{color:var(--navy);font-size:.82rem}

/* ============ Light button (on dark/colour) ============ */
.btn--light{background:#fff;color:var(--blue-700);box-shadow:0 12px 26px rgba(3,30,55,.22)}
.btn--light:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(3,30,55,.30)}

/* ============ Campaign band ============ */
.campaign{padding:20px 0 8px}
.campaign__inner{
  position:relative;overflow:hidden;
  display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between;
  background:linear-gradient(120deg,#0b2945,#0e4f7c 55%,#0284c7);
  border-radius:var(--radius-lg);padding:34px 40px;color:#fff;box-shadow:var(--shadow-lg);
}
.campaign__glow{
  position:absolute;width:340px;height:340px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,210,63,.30),transparent 70%);top:-150px;right:6%;
}
.campaign__leaf{position:absolute;font-size:1.6rem;opacity:.55;pointer-events:none;animation:floatLeaf 7s ease-in-out infinite}
.campaign__leaf--1{top:16px;right:30%}
.campaign__leaf--2{bottom:12px;right:46%;font-size:1.2rem;animation-delay:1.6s}
@keyframes floatLeaf{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-12px) rotate(10deg)}}
.campaign__text{position:relative;z-index:1;max-width:640px}
.campaign__tag{
  display:inline-block;font-family:var(--font);font-weight:700;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;color:#ffe9a6;
  background:rgba(255,210,63,.16);border:1px solid rgba(255,210,63,.4);
  padding:6px 14px;border-radius:100px;margin-bottom:14px;
}
.campaign__text h2{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.8vw,2rem);line-height:1.16}
.campaign__text h2 span{color:var(--sun)}
.campaign__text p{color:rgba(255,255,255,.86);margin-top:12px;font-size:1rem}
.campaign .btn--light{position:relative;z-index:1;flex:none}

/* ============ Social proof ============ */
.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .section-text{margin-inline:auto}
.proof{padding:84px 0;background:var(--bg-soft);overflow:hidden}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:48px}
.stat{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px 18px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat strong{
  display:block;font-family:var(--display);font-weight:800;
  font-size:clamp(1.8rem,3.4vw,2.4rem);color:var(--blue-600);line-height:1;
}
.stat span{display:block;margin-top:8px;font-size:.86rem;color:var(--slate);font-weight:500}

.marquee{
  position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.marquee__track{display:flex;gap:20px;width:max-content;animation:marquee 46s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.tcard{
  width:340px;flex:none;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:14px;
}
.tcard__stars{color:#ffc043;letter-spacing:2px;font-size:1rem}
.tcard blockquote{color:var(--ink);font-size:.98rem;line-height:1.6}
.tcard figcaption{display:flex;align-items:center;gap:12px;margin-top:auto}
.tcard__avatar{
  display:grid;place-items:center;width:42px;height:42px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;
  font-family:var(--display);font-weight:700;font-size:.9rem;
}
.tcard__who{display:flex;flex-direction:column;line-height:1.3}
.tcard__who strong{color:var(--navy);font-weight:700;font-size:.94rem}
.tcard__who small{color:var(--muted);font-size:.8rem}
.proof__disclaimer{text-align:center;color:var(--muted);font-size:.82rem;margin-top:26px}

/* ============ Postcode check ============ */
.postcheck{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.postcheck input{
  font-family:var(--font);font-size:1rem;color:var(--ink);
  background:#fff;border:1.5px solid var(--border);border-radius:100px;
  padding:13px 22px;outline:none;min-width:262px;text-align:center;
  transition:border-color .2s,box-shadow .2s;
}
.postcheck input:focus{border-color:var(--blue-400);box-shadow:0 0 0 4px rgba(56,189,248,.16)}
.postcheck__result{
  text-align:center;font-weight:600;margin-top:16px;min-height:1.2em;
  opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s;
}
.postcheck__result.show{opacity:1;transform:none}
.postcheck__result.ok{color:var(--green)}
.postcheck__result.no{color:var(--blue-700)}

/* ============ Book campaign note ============ */
.book__campaign{
  background:rgba(255,210,63,.16);border:1px solid rgba(255,210,63,.36);
  border-radius:12px;padding:12px 16px;margin-bottom:24px;font-size:.92rem;color:#ffe9a6;
}
.book__campaign strong{color:#fff}
.book__contact a{transition:color .2s}
.book__contact a:hover strong{color:#fff;text-decoration:underline}

/* ============ Desktop sticky CTA ============ */
.cta-sticky{
  position:fixed;right:22px;bottom:26px;z-index:55;
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;
  font-family:var(--display);font-weight:700;font-size:.96rem;
  padding:14px 22px;border-radius:100px;
  box-shadow:0 16px 34px rgba(2,132,199,.42);
  opacity:0;transform:translateY(20px) scale(.96);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease),box-shadow .25s;
}
.cta-sticky.show{opacity:1;transform:none;pointer-events:auto}
.cta-sticky:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(2,132,199,.5)}

/* ============ Reveal on scroll ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .glass-shine,.squeegee,.spark,.drop,.marquee__track,.camp-chip__leaf,.campaign__leaf{animation:none!important}
  .scroll-progress{transition:none}
}

/* ============ Responsive ============ */
@media (max-width:960px){
  .nav,.header__phone{display:none}
  .burger{display:flex}
  .mobile-nav{display:flex}
  .hero__inner{grid-template-columns:1fr;gap:34px;padding-top:48px}
  .hero__art{order:-1;max-width:340px;margin:0 auto}
  .calc__inner,.book__inner,.rut__inner{grid-template-columns:1fr;gap:28px}
  .badges__grid{grid-template-columns:1fr 1fr}
  .services__grid,.why__grid{grid-template-columns:1fr 1fr}
  .pricing__grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .plan--featured{order:-1}
  .steps__grid{flex-direction:column}
  .step__arrow{transform:rotate(90deg)}
  .campaign__inner{padding:28px 26px;gap:20px}
  .campaign__leaf{display:none}
  .stats{grid-template-columns:1fr 1fr;gap:14px}
  .window-card__rating{top:8px}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .container{padding-inline:18px}
  .promo__track span:nth-child(n+5){display:none}
  .badges__grid,.services__grid,.why__grid,.footer__inner{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
  .hero__actions .btn{flex:1}
  .fab{display:flex}
  .cta-sticky{display:none!important}
  .header__cta .btn--primary{display:none}  /* FAB + burgermenyn täcker CTA:n på mobil */
  .brand__logo{height:40px}
  .rut__inner,.book__copy,.areas__inner{padding:30px 22px}
  .campaign__inner{padding:26px 22px}
  .tcard{width:280px;padding:22px}
  .postcheck input{min-width:0;width:100%}
  .postcheck .btn{width:100%}
  body{padding-bottom:80px}
}

/* ============ Intro-quiz gate ============ */
html.quiz-active{overflow:hidden}
.quizgate{display:none}
html.quiz-active .quizgate{
  display:flex;position:fixed;inset:0;z-index:9000;
  align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 120% at 50% 0%,#eaf6ff,#ffffff 55%,#e8f5ff);
}
.quizgate.is-leaving{animation:quizOut .5s var(--ease) forwards}
@keyframes quizOut{to{opacity:0;visibility:hidden}}
.quizgate__card{width:100%;max-width:720px;text-align:center;animation:quizIn .6s var(--ease) both}
@keyframes quizIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.quizgate__brand{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);font-weight:800;color:var(--navy);font-size:1.05rem;margin-bottom:26px;
}
.quizgate__brand svg{filter:drop-shadow(0 6px 10px rgba(14,165,233,.28))}
.quizgate__q{
  font-family:var(--display);font-weight:800;
  font-size:clamp(1.7rem,4.4vw,2.7rem);line-height:1.12;letter-spacing:-.02em;color:var(--navy);
}
.quizgate__sub{color:var(--slate);font-size:1.05rem;margin-top:14px}
.quizgate__choices{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:36px}
.quizchoice{
  display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 24px;cursor:pointer;font-family:var(--font);
  box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;
}
.quizchoice:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue-400)}
.quizchoice__icon{font-size:2rem;line-height:1}
.quizchoice strong{font-family:var(--display);font-weight:700;color:var(--navy);font-size:1.16rem}
.quizchoice span{color:var(--slate);font-size:.92rem}
.quizgate__foot{color:var(--muted);font-size:.84rem;margin-top:26px}
@media (max-width:620px){
  .quizgate__choices{grid-template-columns:1fr}
  .quizchoice{padding:22px 20px}
  .quizgate__q{font-size:1.6rem}
}
@media (prefers-reduced-motion:reduce){
  .quizgate__card{animation:none}
  .quizgate.is-leaving{animation:none;opacity:0;visibility:hidden}
}

/* ============ Cookie-/spårningsnotis ============ */
.cookiebar{
  position:fixed;left:16px;right:16px;bottom:18px;z-index:70;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between;
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:15px 20px;box-shadow:var(--shadow-lg);max-width:720px;margin-inline:auto;
}
.cookiebar[hidden]{display:none}
.cookiebar p{font-size:.86rem;color:var(--slate);flex:1;min-width:240px;margin:0}
.cookiebar p a{color:var(--blue-600);font-weight:600;text-decoration:underline}
.cookiebar .btn{flex:none}
.footer__bar a{color:inherit;text-decoration:underline}
.footer__bar a:hover{color:var(--blue-400)}
@media (max-width:560px){
  .cookiebar{left:10px;right:10px;bottom:84px;padding:14px 16px}
  .cookiebar .btn{width:100%}
}

/* ============ PREMIUM-LYFT (typografi · palett · ytor) ============ */
/* Eleganta serif-rubriker */
.hero__title,.section-title,.rut__text h2,.book__copy h2,.campaign__text h2,
.plan__name,.quizgate__q{
  font-family:var(--serif);font-weight:600;letter-spacing:-.015em;
}
.window-card__badge strong,.stat strong,.plan__quote,.calc__summary{
  font-family:var(--serif);font-weight:600;
}

/* Djupare, mer återhållsam primärknapp (navy istället för knallblå) */
.btn--primary{
  background:linear-gradient(135deg,var(--navy),var(--blue-700));
  box-shadow:0 14px 30px rgba(11,41,69,.26);
}
.btn--primary:hover{box-shadow:0 18px 38px rgba(11,41,69,.34)}

/* Hero-accent: dämpat guld istället för gult */
.hero__title .hl{color:var(--navy)}
.hero__title .hl::after{background:var(--gold);opacity:.5}

/* Ikoner i raffinerade plattor */
.badge__icon{
  display:grid;place-items:center;width:46px;height:46px;border-radius:13px;flex:none;
  background:var(--blue-50);font-size:1.4rem;
}
.service__icon,.why__icon{
  display:grid;place-items:center;width:56px;height:56px;border-radius:16px;
  background:var(--blue-50);font-size:1.7rem;margin-bottom:18px;
}
/* Rena linje-ikoner (ersätter emojis) */
.svgi{width:26px;height:26px;display:block;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.badge .badge__icon{color:var(--blue-600)}
.service__icon,.why__icon{color:var(--blue-600)}
.service__icon .svgi,.why__icon .svgi{width:30px;height:30px}
.book__ci{color:#fff}
.subs__perks li span{color:#fff}

/* ============ Recensioner (tidig social proof) ============ */
.reviews{padding:62px 0 8px}
.reviews__rating{text-align:center;font-size:1.05rem;color:var(--navy);margin-bottom:30px}
.reviews__rating strong{font-weight:800}
.reviews__stars{color:#ffc043;letter-spacing:2px}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{padding:26px;display:flex;flex-direction:column;gap:14px}
.review__stars{color:#ffc043;letter-spacing:2px;font-size:1rem}
.review blockquote{color:var(--ink);font-size:.98rem;line-height:1.6}
.review figcaption{display:flex;align-items:center;gap:12px;margin-top:auto}
.review__avatar{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;flex:none;background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff;font-family:var(--display);font-weight:700;font-size:.9rem}
.review__who{display:flex;flex-direction:column}
.review__who small{color:var(--muted);font-size:.82rem}
.reviews__note{text-align:center;color:var(--muted);font-size:.8rem;margin-top:26px}
@media(max-width:780px){.reviews__grid{grid-template-columns:1fr}}

/* ============ Kombinerad offert: konfigurator i formuläret ============ */
.bform__rec{margin-top:11px;font-size:.85rem;color:var(--slate);line-height:1.5;background:var(--blue-50);border-radius:10px;padding:11px 14px}
.bform__rec strong{color:var(--blue-700)}
.bform__sep{border:none;border-top:1px solid var(--border);margin:24px 0}
.field__opt{font-weight:500;color:var(--muted);font-size:.85em}
/* Abonnemang-först: diskret engångs-länk, engångs-ruta, Populärast-tag */
.bform__altlink{display:inline-block;margin-top:14px;background:none;border:0;padding:0;cursor:pointer;
  font-family:var(--font);font-size:.85rem;color:var(--muted);text-decoration:underline;text-underline-offset:2px}
.bform__altlink span{color:var(--blue-600);font-weight:600}
.bform__altlink:hover{color:var(--slate)}
.bform__engang{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:var(--bg-soft);border:1px solid var(--border);border-radius:12px;padding:13px 16px;font-size:.92rem;color:var(--slate)}
.bform__engang strong{color:var(--navy)}
.bform__engang .bform__altlink{margin-top:0;white-space:nowrap}
.seg__tag{display:inline-block;margin-left:5px;font-size:.6rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
  color:var(--blue-600);background:var(--blue-50);padding:2px 6px;border-radius:6px;vertical-align:middle}

/* ============ FAQ-sida (/vanliga-fragor) ============ */
.faqp-hero{padding:54px 0 6px;text-align:center}
.faqp-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.4vw,3rem);color:var(--navy);letter-spacing:-.02em;margin-top:8px}
.faqp-hero p{color:var(--slate);max-width:540px;margin:14px auto 0}
.faqp-cats{padding:30px 0 26px}
.faqp-cats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.faqp-cat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;
  padding:28px 18px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-lg);
  text-decoration:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s}
.faqp-cat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue-100)}
.faqp-cat .faqp-cat__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:15px;background:var(--blue-50);color:var(--blue-600);margin-bottom:8px}
.faqp-cat__icon .svgi{width:28px;height:28px}
.faqp-cat strong{font-family:var(--display);font-weight:700;font-size:1.08rem;color:var(--navy)}
.faqp-cat>span{font-size:.84rem;color:var(--muted)}
.faqp-groups{padding:24px 0 76px}
.faqp-group{margin-bottom:42px;scroll-margin-top:96px}
.faqp-group:last-child{margin-bottom:0}
.faqp-group__title{display:flex;align-items:center;gap:13px;font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--navy);margin-bottom:18px}
.faqp-group__icon{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:var(--blue-50);color:var(--blue-600);flex:none}
.faqp-group__icon .svgi{width:24px;height:24px}
.faq__a a:not(.btn){color:var(--blue-600);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.faq__a a:not(.btn):hover{color:var(--blue-700)}
.faq__cta{display:block;margin-top:16px}
@media(max-width:900px){.faqp-cats__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.faqp-cats__grid{gap:12px}.faqp-cat{padding:20px 12px}}

/* ============ Lätt sidövergång ============ */
@keyframes pageIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: no-preference){
  main{animation:pageIn .45s cubic-bezier(.33,0,.2,1) both}
  html.is-leaving{opacity:0;transition:opacity .2s ease}
}

/* ============ Quiz: feedback när man svarar ============ */
.quizchoice.is-picked{border-color:var(--blue-500);box-shadow:0 18px 44px rgba(2,132,199,.28)}
.quizchoice.is-dimmed{opacity:.4}
@keyframes quizPick{0%{transform:scale(1)}45%{transform:translateY(-8px) scale(1.05)}100%{transform:translateY(-6px) scale(1.03)}}
@media (prefers-reduced-motion: no-preference){
  .quizchoice.is-picked{animation:quizPick .42s var(--ease) forwards}
  .quizchoice.is-dimmed{transform:scale(.97);transition:opacity .3s var(--ease),transform .3s var(--ease)}
}

/* ============ Hero med foto-bakgrund (bilden täcker hela heron) ============ */
.hero--photo{position:relative;overflow:hidden;display:flex;align-items:center;min-height:clamp(520px,72vh,720px);background:none}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero--photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,27,49,.85) 0%,rgba(8,27,49,.62) 44%,rgba(8,27,49,.26) 74%,rgba(8,27,49,.12) 100%)}
.hero--photo .hero__inner{position:relative;z-index:2;display:block;padding:64px 24px;width:100%}
.hero--photo .hero__copy{max-width:560px}
.hero--photo .eyebrow{color:#fff}
.hero--photo .hero__title{color:#fff}
.hero--photo .hero__title .hl{color:#fff}
.hero--photo .hero__title .hl::after{background:var(--gold);opacity:.6}
.hero--photo .hero__lead{color:rgba(255,255,255,.92);max-width:460px}
.hero__rating{position:absolute;right:26px;bottom:26px;z-index:2;display:flex;flex-direction:column;gap:1px;background:rgba(255,255,255,.96);border-radius:14px;padding:11px 17px;box-shadow:var(--shadow)}
.hero__stars{color:#ffc043;letter-spacing:2px;font-size:.95rem}
.hero__rating>span:last-child{color:var(--navy);font-size:.85rem}
.hero__rating strong{font-weight:800}
@media(max-width:560px){
  .hero--photo{min-height:clamp(440px,74vh,600px)}
  .hero--photo .hero__inner{padding:46px 18px}
  .hero__rating{right:14px;bottom:14px;padding:9px 13px}
}

/* Mer luft mellan sektioner */
.calc,.services,.steps,.pricing,.why,.faq,.book,.proof{padding-top:96px;padding-bottom:96px}

/* Priskort utan siffror */
.plan__quote{display:flex;flex-direction:column;font-size:1.7rem;color:var(--navy);margin-bottom:22px;line-height:1.1}
.plan__quote small{font-family:var(--font);font-size:.82rem;font-weight:500;color:var(--muted);margin-top:5px}

/* Kalkylator → offert-konfigurator (utan pris) */
.calc__result--quote{align-items:center}
.calc__summary{font-size:1.32rem;color:var(--navy);display:block;margin-top:3px}
.calc__rut-pill{
  background:var(--blue-50);color:var(--blue-700);font-weight:700;font-size:.8rem;
  padding:9px 15px;border-radius:100px;white-space:nowrap;
}
/* Företag får inget RUT-avdrag → dämpad neutral pill */
.calc__rut-pill--off{background:rgba(15,23,42,.06);color:var(--slate)}

/* RUT-band utan kr-belopp */
.rut__big{display:block;font-family:var(--serif);font-weight:600;font-size:3.4rem;line-height:1;color:var(--sun);margin-bottom:10px}
.rut__example p{color:rgba(255,255,255,.9);font-size:.96rem;line-height:1.6}

/* Pris-ankare: fullpris (röd, undvik) vs rabatt (grön) + vinter-perk */
.plan__quote--full{color:var(--red)}
.plan__quote--save{color:var(--green)}
.plan__quote--soft{color:#aebccb}
.plan__quote--soft small{color:#bcc8d4}

/* Hero: postnummer → offert */
.hero-post{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px;max-width:440px}
.hero-post input{
  flex:1;min-width:150px;font-family:var(--font);font-size:1rem;color:var(--ink);
  background:#fff;border:1.5px solid var(--border);border-radius:100px;padding:14px 22px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.hero-post input:focus{border-color:var(--blue-400);box-shadow:0 0 0 4px rgba(56,189,248,.16)}
.hero-post .btn{flex:none}
.hero-post__hint{margin-top:13px;font-size:.85rem;color:var(--slate);font-weight:500}
.hero-post__hint--err{color:var(--red)}
.hero-post__link{display:inline-block;margin-top:10px;color:var(--blue-600);font-weight:600;font-size:.92rem}
.hero-post__link:hover{text-decoration:underline}

/* Tilläggstjänster-chips */
.services__more{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-top:34px}
.services__more-label{font-weight:700;color:var(--navy);margin-right:4px}
.services__more .tag{
  background:#fff;border:1px solid var(--border);color:var(--slate);
  padding:9px 18px;border-radius:100px;font-size:.9rem;font-weight:500;transition:.25s var(--ease);
}
.services__more .tag:hover{color:var(--blue-600);border-color:var(--blue-400);transform:translateY(-2px)}

/* Abonnemang-band */
.subs{padding:24px 0}
.subs__inner{
  display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;
  background:linear-gradient(135deg,var(--navy),var(--blue-700));
  border-radius:var(--radius-lg);padding:48px;color:#fff;box-shadow:var(--shadow-lg);
}
.subs__text h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.14;margin:6px 0 12px;letter-spacing:-.015em}
.subs__text p{color:rgba(255,255,255,.88);max-width:460px;margin-bottom:26px}
.subs__perks{list-style:none;display:flex;flex-direction:column;gap:14px}
.subs__perks li{display:flex;align-items:center;gap:13px;font-weight:600;font-size:1rem}
.subs__perks li span{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.13);font-size:1.15rem;flex:none}
@media (max-width:860px){.subs__inner{grid-template-columns:1fr;padding:34px 26px;gap:30px}}

/* ===== Tjänstesidor (fasadtvätt, taktvätt, solpanelstvätt) ===== */
.srv-head{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--border)}
.srv-head__inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.srv-hero{background:linear-gradient(180deg,var(--bg-sky),#fff 80%);padding:70px 0 60px}
.srv-hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.srv-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,4.6vw,3.2rem);line-height:1.08;letter-spacing:-.02em;color:var(--navy);margin:14px 0 16px}
.srv-hero p{color:var(--slate);font-size:1.12rem;max-width:480px;margin-bottom:26px}
.srv-hero__cta{display:flex;gap:12px;flex-wrap:wrap}
.srv-hero__art{display:grid;place-items:center;font-size:clamp(6rem,14vw,11rem);filter:drop-shadow(0 24px 40px rgba(7,73,130,.18))}
.srv-sec{padding:60px 0}
.srv-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.srv-list{list-style:none;display:flex;flex-direction:column;gap:13px;margin-top:14px}
.srv-list li{position:relative;padding-left:30px;color:var(--slate);font-size:1rem}
.srv-list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--green);font-weight:800}
.srv-cta{background:linear-gradient(135deg,var(--navy),var(--blue-700));border-radius:var(--radius-lg);padding:48px;text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.srv-cta h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:10px}
.srv-cta p{color:rgba(255,255,255,.85);margin-bottom:24px;max-width:520px;margin-inline:auto}
.srv-foot{background:var(--navy);color:#9fb6cc;padding:28px 0;text-align:center;font-size:.9rem}
.srv-foot a{color:#cdddec;font-weight:600}
.srv-foot a:hover{color:var(--blue-400)}
@media (max-width:780px){.srv-hero__grid,.srv-grid{grid-template-columns:1fr}.srv-hero__art{display:none}}

/* Hero-foto (ersätter SVG-illustrationen) */
.hero__photo{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center;border-radius:22px;box-shadow:0 30px 50px rgba(7,73,130,.24);display:block}

/* "Så putsar vi" — fotosektion */
.process{padding:96px 0;background:var(--bg-soft)}
.process__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.process__card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.process__card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.process__card img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block}
.process__card figcaption{padding:20px 22px}
.process__card figcaption strong{display:block;font-family:var(--serif);font-weight:600;color:var(--navy);font-size:1.12rem;margin-bottom:5px}
.process__card figcaption span{color:var(--slate);font-size:.92rem}
@media (max-width:860px){.process__grid{grid-template-columns:1fr}}

/* Full-bleed foto-band (fina hus, sida till sida) */
.showcase{position:relative;width:100%;min-height:clamp(340px,46vw,560px);overflow:hidden;display:grid}
.showcase__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.showcase__overlay{
  position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:24px;padding:48px 24px;
  background:linear-gradient(180deg,rgba(11,41,69,.28),rgba(11,41,69,.55));
}
.showcase__overlay h2{
  font-family:var(--serif);font-weight:600;color:#fff;
  font-size:clamp(1.7rem,4vw,2.9rem);line-height:1.12;letter-spacing:-.02em;max-width:20ch;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
}

/* Foto i offert-/konfigurator-sektionen */
/* Offert-sektionen: husbild som full-bredd bakgrund + ljus text */
.calc{
  background-image:linear-gradient(rgba(11,41,69,.64),rgba(11,41,69,.72)), url('assets/fint-hus.jpg');
  background-size:cover;background-position:center;
}
.calc .kicker{color:#fff;background:rgba(255,255,255,.16)}
.calc .section-title{color:#fff}
.calc .section-text{color:rgba(255,255,255,.92)}
.calc .section-text strong{color:#fff}
.calc__points li{color:#fff}
.calc__points .tick{background:rgba(255,255,255,.22);color:#fff}
.plan__perk{font-weight:700;color:var(--navy)}
.plan__perk::before{content:"❄️"!important;color:inherit;font-weight:400}

/* ============ Långt foto-band: EN stående bild bakom tre sektioner ============ */
.bandwrap{
  position:relative;
  background-image:
    linear-gradient(180deg,
      rgba(11,41,69,.86) 0%,
      rgba(11,41,69,.60) 15%,
      rgba(11,41,69,.58) 85%,
      rgba(11,41,69,.88) 100%),
    url('assets/norra-tornen.jpg');
  background-size:cover;
  background-position:center;
}
/* sektionerna inuti bandet blir genomskinliga så husbilden syns igenom */
.bandwrap .steps,
.bandwrap .proof,
.bandwrap .pricing{background:transparent}
/* ljus text på den mörka husbilden (korten behåller sin vita bakgrund) */
.bandwrap .kicker{color:#fff;background:rgba(255,255,255,.18)}
.bandwrap .section-title{color:#fff}
.bandwrap .section-text{color:rgba(255,255,255,.92)}
.bandwrap .section-text strong{color:#fff}
.bandwrap .step__arrow{color:rgba(255,255,255,.72)}
.bandwrap .proof__disclaimer{color:rgba(255,255,255,.82)}
.bandwrap .pricing__foot{color:rgba(255,255,255,.86)}

/* diskret foto-kredit (CC BY-SA kräver attribution) */
.footer__credit{
  text-align:center;font-size:.74rem;color:rgba(255,255,255,.4);
  padding:0 20px 22px;margin:0;
}
.footer__credit a{color:rgba(255,255,255,.6);text-decoration:underline}
.footer__credit a:hover{color:rgba(255,255,255,.85)}

/* ============================================================================
   HERO · FULLSKÄRMS-FOTO (spröjs borttaget — bilden täcker hela heron)
   Fotot ligger kantfullt, texten ovanpå med en läsbar navy-scrim.
   Scopas till .hero--glas → originalet ligger kvar.
   ============================================================================ */
.hero.hero--glas{
  display:flex;align-items:center;position:relative;overflow:hidden;
  min-height:clamp(560px,88vh,860px);background:#06182f;
}

/* Fotot täcker hela heron */
.hero.hero--glas .hero__bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  z-index:0;animation:heroZoom 18s ease-out both;
}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1.0)}}

/* Scrim för läsbar text: mörkast till vänster, klarnar mot höger + topp-ljus */
.hero.hero--glas::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 14% -10%,rgba(140,190,235,.18),transparent 55%),
    linear-gradient(100deg,rgba(5,17,33,.9) 0%,rgba(5,17,33,.72) 34%,rgba(5,17,33,.4) 62%,rgba(5,17,33,.12) 100%);
}

/* Innehåll ovanpå fotot */
.hero.hero--glas .hero__inner{
  position:relative;z-index:3;display:block;width:100%;max-width:var(--container);
  padding:clamp(48px,7vw,104px) 24px;
}
.hero.hero--glas .hero__copy{max-width:620px}
.hero--glas .eyebrow{color:rgba(255,255,255,.88)}
.hero--glas .eyebrow__dot{background:var(--gold);box-shadow:0 0 0 4px rgba(201,164,92,.22)}
.hero--glas .hero__title{
  color:#fff;font-size:clamp(2.7rem,6vw,4.8rem);line-height:1.0;letter-spacing:-.03em;
}
.hero--glas .hero__title .hl{color:#fff;white-space:normal}
.hero--glas .hero__title .hl::after{
  background:linear-gradient(90deg,var(--gold),#e7cf9b);opacity:1;height:.16em;bottom:.04em;border-radius:2px;
}
.hero--glas .hero__lead{color:rgba(255,255,255,.92);font-size:1.16rem;max-width:460px;margin:22px 0 30px}
.hero--glas .hero__actions{display:flex;align-items:center;gap:20px;flex-wrap:wrap}

/* Knapp: ren vit yta med en guld-detalj (pilen) */
.hero--glas .hero__cta{background:#fff;color:var(--navy);box-shadow:0 12px 28px rgba(3,14,28,.34)}
.hero--glas .hero__cta:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(3,14,28,.42)}
.hero--glas .hero__cta svg{color:var(--gold)}
.hero--glas .hero__rating-inline{display:inline-flex;align-items:center;gap:7px;font-size:.9rem;color:rgba(255,255,255,.9);font-weight:600}
.hero--glas .hero__rating-inline .hero__stars{color:var(--gold);letter-spacing:1px}
.hero--glas .hero__rating-inline strong{color:#fff}

/* Ljusreflex som sveper över fotot vid laddning (subtil signatur) */
.hero--glas .hero__wipe{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.hero--glas .hero__wipe::before{
  content:"";position:absolute;top:-30%;left:0;width:38%;height:160%;
  transform:translateX(-140%) rotate(12deg);
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 35%,rgba(255,255,255,.35) 50%,rgba(201,164,92,.4) 53%,rgba(255,255,255,.1) 68%,transparent 100%);
  filter:blur(2px);
  animation:heroWipe 3s cubic-bezier(.22,.61,.18,1) .55s both;
}
@keyframes heroWipe{
  0%{transform:translateX(-140%) rotate(12deg);opacity:0}
  14%{opacity:1}
  86%{opacity:.9}
  100%{transform:translateX(360%) rotate(12deg);opacity:0}
}

/* Inträde: texten stiger fram */
.hero--glas .hero__copy>*{animation:heroRise .8s cubic-bezier(.2,.7,.2,1) both}
.hero--glas .eyebrow{animation-delay:.15s}
.hero--glas .hero__title{animation-delay:.28s}
.hero--glas .hero__lead{animation-delay:.44s}
.hero--glas .hero__actions{animation-delay:.6s}
@keyframes heroRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

@media (max-width:820px){
  .hero.hero--glas{min-height:clamp(500px,82vh,700px)}
  .hero.hero--glas .hero__inner{padding:44px 18px}
  .hero--glas .hero__title{font-size:clamp(2.3rem,9vw,3.3rem)}
  .hero--glas .hero__lead{max-width:none}
}

@media (prefers-reduced-motion:reduce){
  .hero--glas .hero__wipe::before{animation:none;opacity:0}
  .hero--glas .hero__bg{animation:none;transform:none}
  .hero--glas .hero__copy>*{animation:none}
}

/* ============================================================================
   QUIZ-GRIND · större/tydligare fråga + billiga valet nedtonat & mindre
   (kvalitets-valet står fram som det självklara)
   ============================================================================ */
.quizgate__q{font-size:clamp(2.1rem,5.8vw,3.4rem);line-height:1.08}
.quizgate__sub{font-size:1.16rem}

/* Kvalitets-valet = primärt, större, tydlig blå ram */
.quizchoice[data-quiz="kvalitet"]{
  border:2px solid var(--blue-500);
  box-shadow:0 18px 42px rgba(2,132,199,.20);
  padding:36px 28px;
}
.quizchoice[data-quiz="kvalitet"] strong{font-size:1.3rem}
.quizchoice[data-quiz="kvalitet"] span{font-size:1rem}

/* Billiga valet = mindre färg, mindre knapp, mindre lockande */
.quizchoice[data-quiz="billig"]{
  background:var(--bg-soft);
  border-color:var(--border);
  box-shadow:none;
  padding:16px 18px;
  opacity:.78;
}
.quizchoice[data-quiz="billig"] strong{color:var(--slate);font-weight:600;font-size:.98rem}
.quizchoice[data-quiz="billig"] span{color:var(--muted);font-size:.84rem}
.quizchoice[data-quiz="billig"]:hover{transform:none;box-shadow:none;border-color:var(--border)}

/* Desktop: kvalitets-valet bredare, billiga smalare + centrerat i höjd */
@media (min-width:621px){
  .quizgate__choices{grid-template-columns:.78fr 1.22fr;align-items:center}
}
/* Mobil: billiga valet smalare och centrerat, större fråga */
@media (max-width:620px){
  .quizgate__q{font-size:2.1rem}
  .quizchoice[data-quiz="billig"]{max-width:300px;width:100%;margin:0 auto}
}

/* ============================================================================
   ENKEL STARTSIDA · slim trygghets-rad + "vad vi putsar" med små länkar
   ============================================================================ */
.trust{background:var(--navy)}
.trust__row{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:12px 30px;padding:18px 24px;text-align:center;
}
.trust__item{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;color:rgba(255,255,255,.9)}
.trust__item strong{color:#fff;font-weight:700}
.trust__stars{color:var(--gold);letter-spacing:1.5px}

.offer{padding:clamp(56px,8vw,100px) 0;text-align:center}
.offer__head{max-width:640px;margin:0 auto}
.offer__list{
  list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:12px;
  margin:34px 0 24px;padding:0;
}
.offer__list li{
  background:#fff;border:1px solid var(--border);border-radius:100px;
  padding:12px 22px;font-weight:600;color:var(--navy);font-size:1rem;box-shadow:var(--shadow-sm);
}
.offer__more{color:var(--slate);font-size:.96rem;margin:0 auto;max-width:640px}
.offer__more a{color:var(--blue-700);font-weight:600;text-decoration:none;margin:0 5px;white-space:nowrap}
.offer__more a:hover{text-decoration:underline}
