/* === DOWTS AB — minimal, responsive theme (cleaned 2026-02-16) === */

/* ---- Design tokens ---- */
:root{
  --bg:#ffffff;--text:#0A1F2A;--muted:#5C7381;--accent:#0A3A55;--accent-2:#8EC9DA;--card:#F5F8FA;--radius:14px;
}
@media (prefers-color-scheme: dark){
  :root{--bg:#0A0F12;--text:#E6EDF3;--muted:#9AB0BD;--accent:#8EC9DA;--accent-2:#1F6B8B;--card:#0F171B;}
}

/* ---- Resets & base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Ubuntu,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}
.container{width:min(1100px,92vw);margin-inline:auto}
.muted{color:var(--muted)}

/* ---- Header (brand → lang-switch → nav) ---- */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0}
.site-header>.brand{margin-right:auto}
.brand{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;flex:0 0 auto}
.brand-text{font-size:clamp(1.05rem,2vw,1.2rem)}
.brand-mark{color:var(--accent)}
/* Stable logo sizing */
.site-header .brand-logo{display:inline-block;height:20px;width:auto!important;max-width:180px;object-fit:contain;vertical-align:middle}
/* Kill any global image rules inside header */
.site-header img{width:auto!important;height:auto;max-height:none}
/* ----------------------------------------------------
   MOBILE HEADER STACK (≤640px)
   Restores original responsive behavior
---------------------------------------------------- */
@media (max-width: 640px) {

  /* Stack: brand → lang-switch → nav */
  .site-header {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 0;
  }

  /* Language switch goes to second row */
  .site-header > .lang-switch {order: 2; }

  /* Navigation goes to third row and scrolls horizontally */
  .main-nav {
    order: 3;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    max-width: 100%;
    padding: 2px 6px;
    scrollbar-width: none;
  }
  .main-nav::-webkit-scrollbar {display: none; }

  /* Mobile logo sizing */
  .site-header .brand-logo {height: 18px; max-width: 150px; }
}


/* ---- Main nav ---- */
.main-nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.main-nav a{color:var(--text);text-decoration:none;font-size:.95rem;opacity:.9}
.main-nav a:hover{color:var(--accent)}
.main-nav .btn{padding:8px 14px;line-height:1.1}

/* ---- Buttons ---- */
.btn{display:inline-block;padding:10px 16px;border-radius:999px;border:1px solid var(--accent);color:var(--accent);text-decoration:none;font-weight:600}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.ghost{background:transparent}

/* ---- Language switch (chip-style) ---- */
.lang-switch{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:600;white-space:nowrap}
.site-header .lang-switch{margin:0 14px}
.site-header .lang-switch a{display:inline-block;color:var(--muted);text-decoration:none;font-size:.95rem;line-height:1;padding:6px 10px;border-radius:999px;border:1px solid transparent;background:transparent;transition:color .15s ease,background-color .15s ease,border-color .15s ease}
.site-header .lang-switch a:hover{color:var(--accent);background:rgba(10,58,85,.08);border-color:rgba(10,58,85,.18)}
.site-header .lang-switch a.active,
.site-header .lang-switch a[aria-current="page"]{color:var(--text);background:rgba(10,58,85,.12);border-color:rgba(10,58,85,.28)}
.site-header .lang-switch a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;background:rgba(10,58,85,.12);border-color:var(--accent)}
.lang-switch .sep{opacity:.5;user-select:none}

/* ---- Sections & components ---- */
.hero{padding:clamp(48px,12vw,120px) 0;text-align:center}
.hero h1{font-size:clamp(2rem,6vw,3.2rem);margin:0 0 8px;letter-spacing:.2px}
.hero .lead{font-size:clamp(1.05rem,2.4vw,1.3rem);margin:0 0 4px}
.hero .tagline{color:var(--muted);margin:6px 0 22px}
.hero .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.section{padding:clamp(40px,7vw,80px) 0}
.section-header{margin-bottom:28px;text-align:center}
.section-header h2{font-size:clamp(1.5rem,4vw,2rem);margin:0 0 6px}

.features.four,.cards.four,.cards.three{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.grid.two{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;align-items:start}
.card{background:var(--card);border:1px solid color-mix(in srgb, var(--accent) 15%, transparent);border-radius:var(--radius);padding:18px;position:relative}
.card h3{margin:8px 0 6px;font-size:1.05rem}
.card p{margin:0;color:var(--muted)}
.card.add-on{border-style:dashed}

/* Prevent badge overlapping card content */
.card.add-on {
  padding-top: 42px;   /* previously 18px — this leaves room for badge */
  position: relative;  /* ensure badge is positioned relative to this card */
}

.badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;border-radius:999px;padding:4px 10px;font-size:.7rem;font-weight:700}

.check{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:8px}
.check li{position:relative;padding-left:22px}
.check li::before{content:"";position:absolute;left:0;top:8px;width:10px;height:10px;border-radius:3px;background:var(--accent)}

.process{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:0;padding:0}
.process li{background:var(--card);border:1px solid color-mix(in srgb, var(--accent) 15%, transparent);border-radius:var(--radius);padding:18px;position:relative}
.step{position:absolute;top:12px;right:14px;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:.9rem;font-weight:700}

.bullets{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.bullets li{padding-left:20px;position:relative}
.bullets li::before{content:"\2192";position:absolute;left:0;color:var(--accent)}

.diagram svg{width:100%;height:auto;display:block}
.narrow{max-width:70ch}
.footnote{margin-top:12px}

.specs{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.spec{background:var(--card);border:1px solid color-mix(in srgb, var(--accent) 15%, transparent);border-radius:var(--radius);padding:18px}
.spec h3{margin-top:0}

.contact a{color:var(--accent)}
.site-footer{padding:28px 0 40px;text-align:center;color:var(--muted);letter-spacing:.2px}
.site-footer small{opacity:.85}

/* ---- Accessibility & motion ---- */
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* ---- Responsive tweaks ---- */
@media (max-width:720px){.main-nav{gap:12px}.main-nav a{font-size:.95rem}}

/* ≤640px: stack header, make nav scrollable and tighten spacing */
@media (max-width:640px){
  .site-header{flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:10px 0}
  .site-header>.lang-switch{order:2}
  .main-nav{order:3;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:14px;max-width:100%;padding:2px 6px;scrollbar-width:none}
  /*.main-nav::-webkit-scrollbar{display:none}*/
  .site-header .brand-logo{height:18px;max-width:150px}
}

/* Firefox: thin scrollbar */
@media (max-width:640px){
  .main-nav{ scrollbar-width: thin; scrollbar-color: color-mix(in srgb, var(--accent) 40%, transparent) transparent; }
}

/* WebKit (Chrome/Edge/Safari): minimal thumb */
@media (max-width:640px){
  .main-nav::-webkit-scrollbar { height: 6px; }
  .main-nav::-webkit-scrollbar-track { background: transparent; }
  .main-nav::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--accent) 40%, transparent);
    border-radius: 999px;
  }
}


@media (max-width: 640px){
  .main-nav {
    scroll-snap-type: x proximity;
  }
  .main-nav a {
    scroll-snap-align: start; /* each item aligns to left edge */
  }
}


@media (max-width: 640px) and (hover: hover) and (pointer: fine) {
  .main-nav { cursor: grab; }
  .main-nav:active { cursor: grabbing; }
}


@media (max-width:640px){
  .badge {
    top: 8px;
    left: 8px;
    padding: 3px 8px;
    font-size: 0.65rem;
  }
  .card.add-on {
    padding-top: 34px;
  }
}



/* 641–900px: small spacing tweaks */
@media (min-width:641px) and (max-width:900px){
  .site-header{gap:12px}
  .main-nav{flex-wrap:wrap;justify-content:center}
}

/* --- Scroll hint: fade edges for horizontally scrollable nav --- */
@media (max-width: 640px) {
  .main-nav {
    /* Positioning for pseudo-elements */
    position: relative;
    /* keep your existing overflow-x:auto, gap, padding etc. (already in your CSS) */
  }

  /* Right fade */
  .main-nav::after,
  .main-nav::before {
    content: "";
    position: absolute;
    top: 0; bottom: 0;
    width: 24px;                /* width of the fade */
    pointer-events: none;       /* don’t block taps */
  }
  .main-nav::after {
    right: 0;
    background: linear-gradient(to left, var(--bg) 45%, rgba(255,255,255,0));
  }
  /* Left fade (only if content has been scrolled) */
  .main-nav::before {
    left: 0;
    background: linear-gradient(to right, var(--bg) 45%, rgba(255,255,255,0));
    opacity: 0;                 /* hidden at start */
    transition: opacity .2s ease;
  }

  /* When user has scrolled, reveal the left fade.
     We'll add the .is-scrolled class via a tiny JS snippet */
  .main-nav.is-scrolled::before { opacity: 1; }
}

/* Dark mode tune (uses your tokens) */
@media (prefers-color-scheme: dark) {
  .main-nav::after {
    background: linear-gradient(to left, var(--bg) 45%, rgba(0,0,0,0));
  }
  .main-nav::before {
    background: linear-gradient(to right, var(--bg) 45%, rgba(0,0,0,0));
  }
}

.card .price {
  margin-top: 10px;        /* adds breathing room */
  font-weight: 600;        /* makes it visually stronger */
  color: #0d2840;          /* slightly darker than body text */
  font-size: 1.05rem;      /* subtle emphasis */
  display: block;
}


