:root{
    --dark:#14294a;
    --cyan:#33d0ff;
    --sand:#F7F5F1;
    --coral:#f2b37a;
    --ink:#0b1220;
    --radius:16px;
    --grad-a:#1d4d7a;
    --grad-b:#0c2038;
  }
  *{box-sizing:border-box}
  body{
    margin:0; background:var(--sand); color:var(--ink);
    font-family:'Space Grotesk',Inter,system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,sans-serif;
  }
  .serif{font-family:"Libre Baskerville",serif}
  .container{max-width:1120px;margin:0 auto;padding:0 24px}
  .py-6{padding-block:5rem}
  .display-2{font-size:clamp(32px,6vw,56px);font-weight:700;margin:0}
  .lead{color:#2b3446;max-width:70ch}

  /* För att undvika att innehåll hamnar "under" fixed element vid ankarlänkar */
  #tjanster,
  #cases,
  #kontakt{
    scroll-margin-top: 96px;
  }

  /* NAV (transparent, sticky – fallback) */
  .navbar{
    position:sticky;top:0;z-index:1000;
    background:rgba(255,255,255,0.05);
    backdrop-filter:blur(12px) saturate(1.4);
    padding:.8rem 0;
    transition:background .3s ease, backdrop-filter .3s ease;
    border-bottom:1px solid rgba(255,255,255,0.08)
  }
  .navbar:hover{
    background:rgba(255,255,255,0.08);
    backdrop-filter:blur(14px) saturate(1.6)
  }
  /* Begränsa nav-länkarna till navbaren så de inte påverkar Bootstrap-tabs */
  .navbar .nav-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:48px;
    height:48px;
    border-radius:14px;
    transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
    color:rgba(255,255,255,0.9);
    padding:0;
  }
  .navbar .nav-link svg{width:26px;height:26px;opacity:.9}
  .navbar .nav-link:hover{
    background:rgba(0,194,255,.12);
    box-shadow:0 8px 22px rgba(0,194,255,.18);
    transform:translateY(-1px)
  }
  .navbar-brand span{font-weight:700;letter-spacing:.4px;color:#fff}
  .navbar::after{
    content:"";
    position:absolute;left:0;right:0;bottom:0;height:1px;
    background:linear-gradient(90deg,rgba(255,255,255,.25),transparent)
  }

  h1{font-weight:700}

  /* Fixed logo + höger-dock (ersätter navbar visuellt) */
  .navbar{display:none !important}
  .logo-fixed{
    position:fixed;top:16px;left:16px;z-index:1100;
    display:inline-flex;align-items:center;gap:8px;
    color:#fff;text-decoration:none
  }
  .logo-fixed img{height:70px}

  .dock{
    position:fixed;top:50%;right:16px;transform:translateY(-50%);
    z-index:1100;display:flex;flex-direction:column;gap:10px
  }
  .dock-btn{
    width:48px;height:48px;border-radius:14px;
    display:inline-flex;align-items:center;justify-content:center;
    color:#fff;text-decoration:none;background:transparent;
    transition:transform .2s ease, box-shadow .2s ease, background .2s ease
  }
  .dock-btn svg{width:26px;height:26px}
  .dock-btn:hover{
    background:rgba(0,194,255,.12);
    box-shadow:0 8px 22px rgba(0,194,255,.18);
    transform:translateY(-1px)
  }
  @media (max-width: 768px){
    .dock{top:auto;bottom:16px;right:16px;transform:none;flex-direction:row;background:transparent}
  }

  /* HERO */
  .hero{
    position: relative;
    padding: 140px 0 90px;
    overflow: hidden;
    color:var(--sand);
    isolation: isolate;
  }
  .hero > .container{position: relative;z-index: 1;}
  .hero::before{
    content: "";
    position: absolute; inset: 0; z-index: -1;
    background:
      linear-gradient(rgba(10, 40, 80, 0.9), rgba(10, 40, 80, 0.9)),
      url("happy-excited-min.jpg") center / cover no-repeat;
    opacity: 0.97;
  }
  .hero::after{
    content: "";
    position: absolute; inset: -20%; z-index: -1;
    background:
      radial-gradient(60% 60% at 75% 25%, rgba(0,194,255,.18), transparent 55%),
      radial-gradient(50% 50% at 15% 85%, rgba(10, 40, 80, 0.88), transparent 55%);
    filter: blur(30px); pointer-events: none;
  }
  .eyebrow{
    display:inline-block;font-weight:700;letter-spacing:.14em;
    text-transform:uppercase;color:rgba(255,255,255,.7);
    font-size:.82rem;border-left:3px solid var(--cyan);
    padding-left:10px;margin-bottom:18px
  }
  .hero h1{
    position:relative;line-height:1.02;
    margin:0 0 18px;letter-spacing:.5px;
    font-size:clamp(3.1rem, 7vw, 5.6rem); /* större, kaxigare, men responsiv */
  }
  .hero-kicker{
    font-size: clamp(1.02rem, 1.5vw, 1.25rem);
    max-width:720px;color:rgba(242,239,234,.9);
    margin:0 0 30px
  }
  .cta{
    display:inline-block;background:var(--coral);color:#fff;
    padding:14px 26px;border-radius:12px;font-weight:700;
    text-decoration:none;transform: translateZ(0);
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
    box-shadow:0 8px 24px rgba(255,107,74,.25)
  }
  .cta:hover{
    transform: translateY(-2px);
    background:#ff8464;
    box-shadow:0 12px 30px rgba(255,107,74,.35)
  }
  .btn-gradient{background:linear-gradient(135deg,#ff9f6a,#ff7a5a);color:#fff;border:none}
  .btn-gradient:hover{filter:saturate(1.05) brightness(1.05)}
  .divider{
    width:110px;height:4px;
    background:linear-gradient(90deg,var(--cyan),transparent);
    border-radius:4px;margin:34px 0 0
  }

  /* Bild-kort */
  .cards{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:22px;margin:60px 0 20px
  }
  @media (max-width:960px){ .cards{ grid-template-columns:1fr; } }
  .image-card{
    position:relative;border-radius:18px;min-height:280px;
    overflow:hidden;isolation:isolate;background:#0a1523;
    transform: translateZ(0);
    transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease;
    box-shadow:0 14px 34px rgba(0,0,0,.35)
  }
  .image-card::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(7,22,38,.1) 0%, rgba(7,22,38,.55) 55%, rgba(7,22,38,.85) 100%),
               var(--card-image, url('bild1.jpg')) center/cover no-repeat;
    z-index:-2;transition: transform .6s ease
  }
  .image-card::after{
    content:"";position:absolute;inset:0;
    background: linear-gradient( to top right, rgba(0,194,255,.35), transparent 60% );
    mix-blend-mode: screen;opacity:.6;
    transition: opacity .35s.ease;z-index:-1
  }
  .image-card:hover{
    transform: translateY(-8px) scale(1.02);
    box-shadow:0 22px 48px rgba(0,0,0,.45)
  }
  .image-card:hover::before{ transform: scale(1.05) }
  .image-card:hover::after{ opacity:.85 }
  .card-content{
    position:absolute;left:18px;right:18px;bottom:18px;
    color:var(--sand);
  }
  .card-tag{
    display:inline-block;font-weight:700;letter-spacing:.14em;
    text-transform:uppercase;font-size:.72rem;
    padding:6px 10px;border-radius:999px;
    background:rgba(0,194,255,.18);
    border:1px solid rgba(0,194,255,.45);
    backdrop-filter: blur(4px);margin-bottom:10px
  }
  .card-title{
    font-size:1.6rem;line-height:1.15;
    margin:0 0 6px;text-shadow:0 2px 14px rgba(0,0,0,.45)
  }
  .card-sub{margin:0;color:rgba(255,255,255,.9);font-size:.98rem}

  /* Slideinnehåll – inga skuggor, flyter mot bakgrunden */
  .card{background:transparent;border:none;border-radius:var(--radius);padding:8px}
  .card h3{margin:14px 0 8px}
  .card p{margin:0}

  /* Illustrationer */
  .illu{
    width:100%; aspect-ratio:16/9; border-radius:var(--radius);
    background:rgba(0,0,0,.035);
    display:flex; align-items:center; justify-content:center;
  }
  .illu svg{width:82%; height:auto}
  .stroke{ stroke: var(--dark); stroke-width:2; fill: none; stroke-linecap:round; stroke-linejoin:round; }
  .accent-cyan{ stroke: var(--cyan) }
  .accent-coral{ stroke: var(--coral) }

  /* Snap-carousel (egen, glitch-fri) */
  .snap-wrap{position:relative; padding-right:4%;}
  .snap-track{
    display:flex; gap:24px; overflow-x:auto; overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory; scroll-padding-inline:12%;
    -webkit-overflow-scrolling:touch; padding:6px 0 12px;
  }
  .snap-track::-webkit-scrollbar{height:10px}
  .snap-track::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:999px}
  .slide{ flex:0 0 86%; scroll-snap-align:center; }
  .slide.is-active .illu{ background:rgba(0,0,0,.06) }

  /* Indikatorer (fyra bollar) */
  .indicators{ display:flex; justify-content:center; gap:.7rem; margin-top:16px }
  .dot{
    width:16px; height:16px; border-radius:50%;
    border:2px solid rgba(0,0,0,.15); background:var(--sand); cursor:pointer;
    transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    display:inline-block;
  }
  .dot:hover{ transform:scale(1.08) }
  .dot.synlighet{ border-color: rgba(242,179,122,.6) }
  .dot.crm      { border-color: rgba(51,208,255,.35) }
  .dot.insikt   { border-color: rgba(242,179,122,.6) }
  .dot.analys   { border-color: rgba(242,179,122,.35) }
  .dot.active{ box-shadow:0 0 0 4px rgba(0,0,0,.06); transform:scale(1.15); border-color:#000 }

  /* Pilar – utanför, alltid synliga */
  .arrow{
    position:absolute; top:50%; transform:translateY(-50%);
    width:72px; height:72px; border-radius:50%;
    background:#fff; color:var(--dark); border:2px solid rgba(0,0,0,.08); cursor:pointer;
    display:grid; place-items:center; transition:transform .2s ease;
    z-index:5;
  }
  .arrow:hover{ transform:translateY(-50%) scale(1.08) }
  .prev{ left:-88px } .next{ right:-88px }

  .icon-pill{
    width:50px;height:50px;border-radius:12px;
    display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg, rgba(0,194,255,.12), rgba(0,194,255,.02));
    border:1px solid rgba(0,194,255,.35);margin-bottom:12px
  }
  .icon-pill svg{width:30px;height:30px}

  .synlighet-card .content,
  .crm-card .content,
  .insikter-card .content,
  .analys-card .content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
  }

  .synlighet-card img,
  .crm-card img,
  .insikter-card img,
  .analys-card img {
    max-width: 500px;
    height: auto;
  }

  /* Bootstrap nav-tabs anpassning */
  .nav-tabs{
    border-bottom:1px solid rgba(0,0,0,.06);
    margin-top:1.5rem;
    margin-bottom:1.5rem;
    gap:.25rem;
  }
  .nav-tabs .nav-item{
    margin-bottom:-1px;
  }
  .nav-tabs .nav-link{
    display:inline-block;
    width:auto;
    height:auto;
    border:none;
    border-bottom:2px solid transparent;
    color:#4b5565;
    font-weight:500;
    background:transparent;
    padding:0.75rem 1.25rem;
    border-radius:999px 999px 0 0;
    line-height:1.3;
  }
  .nav-tabs .nav-link:hover{
    border-color:transparent;
    color:var(--dark);
    background:rgba(20,41,74,0.04);
  }
  .nav-tabs .nav-link.active{
    color:var(--dark);
    border-bottom-color:var(--dark);
    background:rgba(20,41,74,0.06);
  }

  /* FOOTER / KONTAKT */
  .footer-cta{
    position:relative;
    background:
      radial-gradient(80% 120% at 0% 0%, rgba(0,194,255,.25), transparent 55%),
      linear-gradient(135deg, #1d4d7a, #0c2038);
    color:var(--sand);
    padding:4.5rem 0 3rem;
    overflow:hidden;
    isolation:isolate;
  }
  .footer-cta::before{
    content:"";
    position:absolute; inset:-20%;
    background:
      radial-gradient(45% 45% at 85% 15%, rgba(255,255,255,.12), transparent 60%),
      radial-gradient(60% 60% at 10% 90%, rgba(0,0,0,.45), transparent 55%);
    opacity:.7;
    filter:blur(26px);
    z-index:-1;
  }
  .footer-cta .container{position:relative;z-index:1;}

  .footer-pill{
    display:inline-flex;
    align-items:center;
    gap:.5rem;
    padding:6px 12px;
    border-radius:999px;
    font-size:.78rem;
    letter-spacing:.16em;
    text-transform:uppercase;
    border:1px solid rgba(255,255,255,.35);
    background:rgba(9,19,35,.65);
    color:rgba(255,255,255,.8);
    margin-bottom:1rem;
  }
  .footer-pill-dot{
    width:9px;height:9px;border-radius:50%;
    background:var(--cyan);
    box-shadow:0 0 0 4px rgba(51,208,255,.35);
  }

  .footer-heading{
    font-family:"Libre Baskerville",serif;
    font-size:clamp(26px,3vw,32px);
    margin:0 0 10px;
  }
  .footer-sub{
    max-width:34rem;
    margin:0 0 22px;
    color:rgba(242,239,234,.9);
  }
  .footer-meta{
    font-size:.9rem;
    color:rgba(255,255,255,.65);
  }

  .footer-form-card{
    background:rgba(6,18,34,.92);
    border-radius:18px;
    padding:1.75rem 1.75rem 1.5rem;
    box-shadow:0 18px 40px rgba(0,0,0,.55);
    border:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(10px);
  }

  .footer-cta label{
    font-size:.85rem;
    font-weight:500;
    color:rgba(255,255,255,.9);
  }
  .footer-cta .form-control,
  .footer-cta .form-select{
    background:rgba(9,20,38,.95);
    border-radius:10px;
    border:1px solid rgba(255,255,255,.16);
    color:#f9fafb;
    font-size:.95rem;
  }
  .footer-cta .form-control::placeholder{
    color:rgba(148,163,184,.9);
  }
  .footer-cta .form-control:focus,
  .footer-cta .form-select:focus{
    border-color:var(--cyan);
    box-shadow:0 0 0 1px rgba(51,208,255,.6);
    background:rgba(9,20,38,1);
  }

  .footer-cta .btn-submit{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.4rem;
    padding:0.7rem 1.4rem;
    border-radius:999px;
    border:none;
    font-weight:600;
    font-size:.95rem;
    background:linear-gradient(135deg,#ff9f6a,#ff7a5a);
    color:#fff;
    box-shadow:0 10px 26px rgba(255,122,90,.35);
    transition:transform .18s ease, box-shadow .18s ease, filter .18s.ease;
  }
  .footer-cta .btn-submit:hover{
    transform:translateY(-1px);
    filter:brightness(1.05) saturate(1.05);
    box-shadow:0 16px 34px rgba(255,122,90,.45);
  }

  .footer-cta small{
    font-size:.78rem;
    color:rgba(148,163,184,.95);
  }

  .footer-bottom{
    border-top:1px solid rgba(255,255,255,.12);
    margin-top:2.5rem;
    padding-top:1.3rem;
    font-size:.85rem;
    color:rgba(226,232,240,.8);
  }

  /* Responsiv footer */
  @media (max-width: 992px){
    .footer-cta{
      padding:3.5rem 0 2.5rem;
    }
    .footer-form-card{
      margin-top:2rem;
    }
  }

  /* Responsiva justeringar */
  @media (max-width:1200px){
    .slide{ flex-basis:90% }
    .prev{ left:-64px } .next{ right:-64px }
  }
  @media (max-width:992px){
    .slide{ flex-basis:92% }
    .prev,.next{ width:56px;height:56px; }
    .prev{ left:-48px } .next{ right:-48px }
    .synlighet-card .content,
    .crm-card .content,
    .insikter-card .content,
    .analys-card .content {
      flex-direction:column;
    }
  }
  @media (max-width:640px){
    .slide{ flex-basis:96% }
    .prev{ left:-32px } .next{ right:-32px }
    .dot{ width:14px; height:14px }
  }
  @media (max-width:420px){
    .slide{ flex-basis:98% }
    .prev{ left:-20px } .next{ right:-20px }
  }

  /* Tillgänglighet: mindre rörelse om användaren föredrar det */
  @media (prefers-reduced-motion: reduce){
    .snap-track{ scroll-behavior:auto }
  }