:root{
  --navy:#0B2D4D; --blue:#0F6BD7; --light:#F2F6FC; --ink:#223043; --muted:#637089;
  --border:#e6ebf2; --surface:#ffffff; --bg:#F7FAFF;
  --radii:16px; --radii-lg:20px;
  --shadow:0 6px 24px rgba(13,41,70,.10); --shadow-lg:0 12px 36px rgba(13,41,70,.18);
}
*{box-sizing:border-box}
html,body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:'Source Sans 3',system-ui,Segoe UI,Roboto,Arial,sans-serif;
  /* MOBILFIX: förhindra horisontell scroll */
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Raleway',system-ui,Segoe UI,Roboto,Arial,sans-serif;letter-spacing:.2px}
.container{max-width:1100px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--border);z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:70px;width:auto;display:block}
.menu a{position:relative;margin-left:16px;text-decoration:none;color:var(--navy);font-weight:600;opacity:.9;
  transition:opacity .2s ease, transform .2s ease}
.menu a:hover{opacity:1;transform:translateY(-1px)}
.menu a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--blue);border-radius:2px;transition:width .25s ease}
.menu a:hover::after{width:100%}

/* Buttons */
.btn,.btn-light{display:inline-block;padding:12px 16px;border-radius:14px;text-decoration:none;font-weight:700;transition:all .3s ease;cursor:pointer}
.btn{border:1px solid var(--blue);color:var(--blue);background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.75)); box-shadow:var(--shadow)}
.btn:hover{background:rgba(15,107,215,.08);box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.btn-primary{background:linear-gradient(180deg, #2aa0ff, #0F6BD7);color:#fff;border:1px solid #0f6bd7;box-shadow:0 10px 24px rgba(15,107,215,.35)}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 14px 30px rgba(15,107,215,.45);transform:translateY(-1px)}
.btn-light{border:1px solid #fff;color:#fff;background:rgba(255,255,255,.06);padding:12px 18px}
.carousel .btn-light:hover,.carousel-caption .btn-light:hover{background:rgba(15,107,215,.85);color:#fff;border-color:rgba(255,255,255,.95);box-shadow:0 8px 26px rgba(15,107,215,.48);transform:translateY(-1px)}

/* Sections */
.section{padding:56px 0}
.h1{font-size:42px;margin:0 0 8px;color:var(--navy);font-weight:800}
.h2{font-size:30px;margin:0 0 12px;color:var(--navy);font-weight:800}
.p{color:var(--muted);font-size:18px;line-height:1.65}

/* Hero + Carousel */
.hero{background:var(--light)}
.carousel{position:relative;height:460px;border:1px solid var(--border);border-radius:var(--radii-lg);overflow:hidden;background:#000;box-shadow:var(--shadow)}
.carousel-track{display:flex;height:100%;transition:transform .6s ease}
.carousel-slide{min-width:100%;height:100%;position:relative}
.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block}
.carousel-caption{position:absolute;left:24px;bottom:24px;background:linear-gradient(180deg, rgba(11,45,77,.84), rgba(11,45,77,.76));color:#fff;padding:18px 20px;border-radius:16px;max-width:680px;box-shadow:0 8px 22px rgba(11,45,77,.25)}
.carousel-caption h2{font-size:30px;line-height:1.35;margin:0 0 12px}
.carousel-slide.active .carousel-caption .cap{animation:capIn .45s ease both}
@keyframes capIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
.carousel-slide.active .carousel-caption .cap:nth-child(2){animation-delay:.08s}
.carousel-nav{pointer-events:none}.carousel-btn{pointer-events:auto}
.carousel-nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px}
.carousel-btn{width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:#fff;cursor:pointer;box-shadow:var(--shadow)}
.carousel-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;gap:8px;justify-content:center}
.carousel-dot{width:10px;height:10px;border-radius:999px;background:#fff;border:1px solid var(--border);opacity:.7}
.carousel-dot.active{opacity:1;background:#0F6BD7}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.steps-grid{grid-template-columns:1fr}}
.step{border:1px solid var(--border);border-radius:16px;background:#fff;overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.step-img{position:relative;overflow:hidden;height:230px}
.step-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1);transition:transform .55s ease}
.step:hover .step-img img{transform:scale(1.08)}
.step-body{padding:16px 18px}
.step-title{margin:8px 0 6px;font-size:19px;color:var(--navy);font-weight:800}
.step-text{margin:0;color:var(--muted)}

/* Services */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.grid3{grid-template-columns:1fr}}
.card{border:1px solid var(--border);border-radius:var(--radii);background:var(--surface);padding:18px;box-shadow:var(--shadow)}
.service{display:block;color:inherit;text-decoration:none;border:1px solid var(--border);border-radius:var(--radii);background:#fff;overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease}
.service:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.service-img{height:220px;overflow:hidden}
.service-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1);transition:transform .55s ease}
.service:hover .service-img img{transform:scale(1.08)}
.service-body{padding:16px 18px}
.service-title{margin:6px 0 6px;font-size:20px;color:var(--navy);font-weight:800}
.service-text{margin:0;color:var(--muted)}
.service-cta{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-weight:700;color:var(--blue)}
.service-cta svg{width:16px;height:16px;transition:transform .2s ease}
.service:hover .service-cta svg{transform:translateX(2px)}

/* Partners */
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:18px}
@media(max-width:900px){.partner-grid{grid-template-columns:repeat(2,1fr)}}
.partner{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease}
.partner:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.partner img{max-height:54px;max-width:100%;width:auto;height:auto;display:block}

/* Testimonials wrapper */
.testimonial-wrap{background:#0f1729;color:#e7eef7;border-radius:24px;padding:28px;margin-top:36px;box-shadow:0 14px 50px rgba(11,45,77,.22);border:1px solid rgba(255,255,255,.06)}
.testimonial-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;margin-top:0;align-items:stretch}
@media(max-width:900px){.testimonial-grid{grid-template-columns:1fr;gap:18px}}
.cta-left h3{font-size:30px;margin:0 0 10px}
.cta-left .actions{display:flex;gap:12px;margin-top:12px}
.cta-left .actions .btn{background:#fff;border-color:#fff;color:var(--navy)}

/* Review carousel (one-at-a-time) */
.reviews{position:relative; overflow:hidden; border-radius:16px;}
.reviews-track{display:flex; transition:transform .6s ease; will-change:transform;}
.reviews-slide{min-width:100%; flex:0 0 100%;}
.testi{background:#111a2e;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:18px}
.testi-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.testi-logo{width:40px;height:40px;border-radius:999px;background:#0b2d4d;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.stars{display:flex;gap:4px}
.stars svg{width:16px;height:16px;fill:#0F6BD7}

/* Move nav arrows just OUTSIDE the card so they don't cover text */
.review-nav{display:none; position:absolute; top:50%; left:-10px; right:-10px; display:flex; justify-content:space-between; align-items:center; transform:translateY(-50%); pointer-events:none}
.review-btn{pointer-events:auto;width:44px;height:44px;border-radius:999px;border:1px solid var(--border);background:#fff;color:#0b2d4d;box-shadow:var(--shadow)}
.review-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.review-dots{display:flex;gap:8px;justify-content:center;margin-top:12px}
.review-dot{width:8px;height:8px;border-radius:999px;background:#3b4a66;opacity:.5}
.review-dot.active{opacity:1;background:#0F6BD7}

/* Footer */
.site-footer{background:#0b1726;color:#e7eef7;padding:32px 0;margin-top:40px;box-shadow:0 -8px 30px rgba(11,45,77,.12)}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-brand img{height:28px;width:auto;display:block}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:900px){.form-grid{grid-template-columns:1fr}}
label{display:block;font-weight:600;margin-bottom:6px}
.input{width:100%;padding:12px 12px;border:1px solid var(--border);border-radius:12px;background:#fff}

/* Backline */
.backline{display:flex;justify-content:flex-end;align-items:center;margin-bottom:10px}
.backline .back{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-weight:700;border:1px solid var(--border);padding:10px 14px;border-radius:12px;background:#fff;color:var(--navy);box-shadow:var(--shadow);transition:all .25s ease}
.backline .back:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.backline .back svg{width:16px;height:16px}

/* Receptionist widget */
.receptionist-wrap{display:flex;gap:18px;align-items:flex-start;margin-top:18px}
.receptionist{position:relative;width:220px;flex:0 0 220px;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;cursor:pointer}
.receptionist img{display:block;width:100%;height:auto}
.receptionist::after{content:'Klicka på mig för att chatta!';position:absolute;left:10px;bottom:10px;background:rgba(15,107,215,.9);color:#fff;padding:8px 10px;border-radius:10px;font-weight:700;opacity:0;transform:translateY(4px);transition:.25s ease}
.receptionist:hover::after{opacity:1;transform:none}

/* Chat modal (flytande avatar + panel) */
.chat-fab{position:fixed;right:22px;bottom:22px;width:60px;height:60px;border-radius:999px;background:#0F6BD7;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-lg);cursor:pointer;z-index:999}
.chat-fab img{width:36px;height:36px;border-radius:999px;object-fit:cover}
.chat-box{position:fixed;right:22px;bottom:90px;width:320px;max-width:92vw;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);display:none;z-index:999;overflow:hidden}
.chat-header{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0b2d4d;color:#fff}
.chat-header img{width:32px;height:32px;border-radius:999px;object-fit:cover}
.chat-body{max-height:320px;overflow:auto;padding:12px;background:#F7FAFF}
.msg{display:flex;gap:8px;margin-bottom:10px}
.msg.you{justify-content:flex-end}
.bubble{padding:10px 12px;border-radius:14px;box-shadow:var(--shadow)}
.msg.lisa .bubble{background:#fff;border:1px solid var(--border)}
.msg.you .bubble{background:#0F6BD7;color:#fff}
.chat-input{display:flex;gap:8px;padding:10px;border-top:1px solid var(--border);background:#fff}
.chat-input input{flex:1;border:1px solid var(--border);border-radius:10px;padding:10px}
.chat-close{margin-left:auto;background:transparent;border:none;color:#fff;cursor:pointer}

.receptionist img{transform:scale(1);transition:transform .6s ease}
.receptionist:hover img{transform:scale(1.06)}

/* Sustain cards zoom */
.sustain-zoom img{transform:scale(1);transition:transform .5s ease}
.sustain-zoom:hover img{transform:scale(1.06)}

.footer-link{color:#e7eef7;text-decoration:none}
.footer-link:hover{text-decoration:underline}
@media(max-width:900px){
  .site-footer .footer-inner{grid-template-columns:1fr 1fr}
}

/* Chat bubble & panel (nyare implementation) */
#chat-fab{position:fixed;right:18px;bottom:18px;width:64px;height:64px;border-radius:999px;overflow:hidden;border:2px solid var(--border);box-shadow:0 8px 22px rgba(13,41,70,.25);background:#fff;cursor:pointer;z-index:999}
#chat-fab img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
#chat-fab:hover img{transform:scale(1.06)}
#chat-panel{position:fixed;right:18px;bottom:96px;width:320px;max-width:92vw;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 28px rgba(13,41,70,.25);display:none;flex-direction:column;z-index:1000;overflow:hidden}
#chat-panel.active{display:flex}
#chat-panel .chat-header{color:var(--ink);display:flex;align-items:center;justify-content:space-between;background:var(--light);padding:8px 10px;border-bottom:1px solid var(--border)}
#chat-panel .agent{display:flex;align-items:center;gap:8px}
#chat-panel .agent img{width:32px;height:32px;border-radius:999px;object-fit:cover}
#chat-body{padding:10px;height:220px;overflow:auto}
#chat-body .msg{margin:6px 0;padding:10px 12px;border-radius:12px;max-width:85%}
#chat-body .msg.agent{background:#eef5ff;color:#1a2a40}
#chat-body .msg.user{background:#0F6BD7;color:#fff;margin-left:auto}
#chat-form{display:flex;padding:8px;border-top:1px solid var(--border)}
#chat-input{flex:1;border:1px solid var(--border);border-radius:10px;padding:10px}

#chat-panel .chat-header strong{color:var(--ink)}
#chat-panel .chat-header .small{color:var(--muted)}

#chat-thanks{position:fixed;inset:0;z-index:1000}
#chat-thanks .cth-backdrop{position:absolute;inset:0;background:rgba(10,20,30,.45);backdrop-filter:blur(2px)}
#chat-thanks .cth-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 48px rgba(15,35,60,.35);padding:16px;max-width:420px;width:92%}
#chat-thanks .cth-head{display:flex;gap:10px;align-items:center;margin-bottom:8px}
#chat-thanks .cth-head img{width:40px;height:40px;border-radius:999px;object-fit:cover}
#chat-thanks #cth-close{margin-left:auto;border:1px solid var(--border);background:#fff;border-radius:8px;width:28px;height:28px;cursor:pointer}

/* =========================================================
   MOBILFIX (ENDAST MOBIL) – chatt-avatar & kontaktformulär
   ========================================================= */
@media (max-width: 780px) {
  /* Kontaktkolumn: form överst, receptionist under – centrerad och mindre */
  .receptionist-wrap{
    display:flex;
    flex-direction:column;
    gap:14px;
    align-items:stretch;
  }
  .receptionist{
    width:160px;
    flex:0 0 auto;
    align-self:center;
  }
  .receptionist img{ border-radius:14px; }

  /* Formens 3-kolumn → 1 kolumn + tätare */
  .form .grid3{ grid-template-columns:1fr !important; gap:10px; }
  .form .card{ padding:12px; }
  .input, .form select, .form textarea{ width:100%; }

  /* Knappar och typografi lite tajtare i mobil */
  .btn, .btn-primary, .btn-light{ padding:10px 12px; border-radius:12px; }
  .h2{ font-size:26px; }
  .p{ font-size:16px; }
}

/* Flytande chatt-avatar: säkra placering/storlek i mobil och över footer */
#chat-fab, .chat-fab{
  position:fixed !important;
  right:16px !important;
  bottom:16px !important;
  z-index:999 !important;
  transform:none !important;
  max-width:68px; max-height:68px;
}
@media (max-width:480px){
  #chat-fab, .chat-fab{ right:12px !important; bottom:12px !important; max-width:60px; max-height:60px; }
}
/* Säkra att panelen alltid ligger över footern */
#chat-panel{ z-index:1000; }

/* Generellt skydd – stora media ska inte skapa sidleds-scroll */
img, video{ max-width:100%; height:auto; }
.partner-grid img, .service-img img{ display:block; }

/* =========================================================
   FOOTER: MOBILFIX – stapla kolumner snyggt och undvik radbrytar-kaos
   ========================================================= */
@media (max-width: 780px){
  .site-footer{ padding:24px 0; }
  .footer-inner{
    display:grid !important;
    grid-template-columns:1fr;
    gap:18px;
    align-items:flex-start;
  }
  .footer-inner > *{ min-width:0; width:100%; }

  .footer-brand{ justify-content:flex-start; gap:10px; }
  .footer-brand img{ height:36px; }

  /* Rubriker & länkar i footern */
  .site-footer h4,
  .site-footer .footer-title{ margin:0 0 8px; font-size:18px; }
  .site-footer ul{ list-style:none; padding:0; margin:0; }
  .site-footer li{ margin:6px 0; }
  .site-footer a,
  .site-footer p,
  .site-footer li{ font-size:16px; line-height:1.5; }

  /* Undvik sidleds-scroll även i footern */
  .site-footer, .footer-inner{ overflow-x:hidden; }
}

