/* =========================================================
   ELIT AS — Landing page
   Brand: #0074C8 (blå)  ·  #002039 (mørk marine)
   Premium · Clean · Professional · Sharp corners (0 radius)
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
    --blue:        #0074C8;
    --blue-600:    #0063ab;
    --blue-700:    #00518c;
    --navy:        #002039;
    --navy-800:    #04182b;   /* deeper for contrast layers */
    --navy-700:    #0a2c47;
    --navy-600:    #123a59;

    --ink:         #14202c;   /* body text on light */
    --muted:       #5a6b7a;   /* secondary text */
    --line:        #e3e8ee;   /* hairlines */
    --line-strong: #cfd8e2;
    --bg:          #ffffff;
    --bg-soft:     #f4f7fa;
    --bg-softer:   #eef3f8;
    --white:       #ffffff;

    --maxw: 1240px;
    --gutter: 24px;

    --shadow-sm: 0 1px 0 rgba(2,32,57,.04), 0 6px 18px rgba(2,32,57,.06);
    --shadow-md: 0 18px 44px rgba(2,32,57,.12);
    --shadow-blue: 0 14px 30px rgba(0,116,200,.28);

    --t-fast: .18s ease;
    --t: .28s cubic-bezier(.4,0,.2,1);

    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --font-heading: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; padding:0; border-radius:0 !important; } /* sharp corners everywhere */
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:118px; overflow-x:hidden; }
body{
    font-family:var(--font);
    color:var(--ink);
    background:var(--bg);
    line-height:1.65;
    font-size:17px;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
input,select,textarea{ font-family:inherit; font-size:1rem; }
::selection{ background:var(--blue); color:#fff; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* ---------- Typography helpers ---------- */
h1,h2,h3,h4{ font-family:var(--font-heading); line-height:1.12; letter-spacing:normal; font-weight:800; color:var(--navy); }
h2{ font-size:clamp(1.9rem,3.6vw,2.9rem); }
h3{ font-size:1.1rem; }
.eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    font-size:.78rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
    color:var(--blue);
}
.eyebrow::before{ content:""; width:30px; height:2px; background:var(--blue); display:inline-block; }
.eyebrow--light{ color:#5fb4ff; }
.eyebrow--light::before{ background:#5fb4ff; }

.section{ padding:80px 0; }
.section-head{ max-width:680px; margin:0 auto 56px; text-align:center; }
.section-head--light *{ color:#fff; }
.section-title{ margin:18px 0 16px; }
.section-title--left{ margin-left:0; }
.section-title--light{ color:#fff; }
.section-title-accent{ color:var(--blue); }
.kabel .section-title-accent,
.why .section-title-accent,
.testimonials .section-title-accent,
.cta-band .section-title-accent{ color:#5fb4ff; }
.section-sub{ color:var(--muted); font-size:1.08rem; }
.section-sub--light{ color:rgba(255,255,255,.72); }

/* ---------- Buttons ---------- */
.btn{
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    font-weight:700; font-size:.97rem; letter-spacing:.01em;
    padding:14px 26px; border:2px solid transparent;
    transition:background var(--t), border-color var(--t), color var(--t), box-shadow var(--t), transform .22s cubic-bezier(.2,.6,.2,1);
    white-space:nowrap; line-height:1; transform:translateY(0);
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }
.btn__ic{ width:18px; height:18px; flex-shrink:0; transition:transform .22s cubic-bezier(.2,.6,.2,1); }
.btn:hover .btn__ic{ transform:translateX(3px); }
.btn--lg .btn__ic{ width:20px; height:20px; }
.btn--sm .btn__ic{ width:16px; height:16px; }
.btn--primary{ background:var(--blue); color:#fff; border-color:var(--blue); }
.btn--primary:hover{ background:var(--blue-700); border-color:var(--blue-700); box-shadow:0 8px 24px rgba(0,116,200,.32); }
.btn--secondary{ background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.btn--secondary:hover{ background:#fff; color:var(--navy); border-color:#fff; box-shadow:0 8px 24px rgba(0,0,0,.18); }
.btn--white{ background:#fff; color:var(--navy); border-color:#fff; }
.btn--white:hover{ background:var(--bg-soft); border-color:var(--bg-soft); box-shadow:0 8px 24px rgba(0,0,0,.12); }
.btn--lg{ padding:17px 32px; font-size:1.02rem; }
.btn--sm{ padding:11px 18px; font-size:.9rem; }
.btn--block{ width:100%; }


/* =========================================================
   HEADER / NAV
   ========================================================= */
.header{
    position:fixed; top:0; left:0; right:0; z-index:1000;
    background:rgba(2,32,57,.55);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(255,255,255,.07);
    transition:box-shadow var(--t), background var(--t), backdrop-filter var(--t);
}
.header.is-stuck{
    background:var(--navy);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    box-shadow:0 10px 30px rgba(2,32,57,.25);
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; height:76px; gap:24px; }
.header__logo img{ height:30px; width:auto; }

.nav__list{ display:flex; align-items:center; gap:6px; }
.nav__item{ position:relative; }
.nav__link{
    display:inline-flex; align-items:center; gap:6px;
    color:rgba(255,255,255,.82); font-weight:600; font-size:.96rem;
    padding:12px 16px; transition:color var(--t-fast); position:relative;
}
.nav__link::after{
    content:""; position:absolute; left:16px; right:16px; bottom:6px; height:2px;
    background:var(--blue); transform:scaleX(0); transform-origin:left; transition:transform var(--t);
}
.nav__link:hover{ color:#fff; }
.nav__link:hover::after{ transform:scaleX(1); }
.nav__chevron{ width:15px; height:15px; transition:transform var(--t-fast); }
.nav__item--has-dropdown:hover .nav__chevron{ transform:rotate(180deg); }

.nav__dropdown{
    position:absolute; top:calc(100% + 10px); left:50%;
    transform:translateX(-50%) translateY(8px);
    width:420px; background:var(--navy);
    border:1px solid rgba(255,255,255,.10); border-top:3px solid var(--blue);
    box-shadow:0 20px 48px rgba(0,0,0,.45), 0 4px 16px rgba(0,0,0,.25);
    padding:0; opacity:0; visibility:hidden;
    transition:opacity var(--t), transform var(--t), visibility var(--t);
}
.nav__item--has-dropdown:hover .nav__dropdown{
    opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
}

.nav__dd-head{
    padding:10px 16px 8px;
    font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:var(--blue); border-bottom:1px solid rgba(255,255,255,.08);
}

.nav__dd-grid{
    display:grid; grid-template-columns:1fr 1fr;
    padding:6px; gap:1px;
}

.nav__dropdown-link{
    display:flex; align-items:center; gap:9px; white-space:nowrap;
    padding:10px 14px; color:rgba(255,255,255,.75); font-weight:500; font-size:.88rem;
    border-left:2px solid transparent; transition:var(--t-fast);
}
.nav__dropdown-link::before{
    content:""; display:block; width:4px; height:4px; flex-shrink:0;
    background:rgba(0,116,200,.55); transition:background var(--t-fast);
}
.nav__dropdown-link:hover{ background:rgba(0,116,200,.18); color:#fff; border-left-color:var(--blue); }
.nav__dropdown-link:hover::before{ background:var(--blue); }

.nav__dd-all{
    display:flex; align-items:center; justify-content:flex-end; gap:6px;
    padding:10px 16px; border-top:1px solid rgba(255,255,255,.08);
    font-size:.82rem; font-weight:600; color:var(--blue);
    transition:color var(--t-fast);
}
.nav__dd-all svg{ transition:transform var(--t-fast); }
.nav__dd-all:hover{ color:#fff; }
.nav__dd-all:hover svg{ transform:translateX(3px); }

.header__actions{ display:flex; align-items:center; gap:14px; }

.header__burger{ display:none; width:44px; height:44px; flex-direction:column; justify-content:center; align-items:center; gap:5px; }
.header__burger span{ width:24px; height:2px; background:#fff; transition:var(--t); }
.header__burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.header__burger.is-open span:nth-child(2){ opacity:0; }
.header__burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg video,.hero__bg img{ width:100%; height:100%; object-fit:cover; object-position:center center; }
.hero__overlay{
    position:absolute; inset:0;
    background:linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.32) 45%, rgba(0,0,0,.08) 100%);
}
.hero__inner{ position:relative; z-index:2; padding:136px 0 62px; }
.hero__content{ max-width:680px; }
.hero__badge{
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(0,116,200,.16); border:1px solid rgba(95,180,255,.32);
    color:#cfe6fb; font-size:.84rem; font-weight:600; letter-spacing:.02em;
    padding:9px 16px;
}
.hero__badge-dot{ width:8px; height:8px; background:var(--blue); box-shadow:0 0 0 4px rgba(0,116,200,.25); }
.hero__title{
    color:#fff; font-size:clamp(2.4rem,5.4vw,4.1rem); font-weight:900; letter-spacing:-.03em;
    margin:24px 0 22px;
}
.hero__title-accent{ color:#3a9be8; position:relative; white-space:nowrap; }
.hero__text{ font-size:1.18rem; color:rgba(255,255,255,.82); max-width:660px; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }

.hero__stats{ display:flex; align-items:center; gap:0; margin-top:48px; padding-top:36px; border-top:1px solid rgba(255,255,255,.14); }
.hero__stat{ display:flex; flex-direction:column; padding:0 56px 0 0; }
.hero__stat:first-child{ padding-left:0; }
.hero__stat-num{ font-size:2.4rem; font-weight:800; color:#fff; letter-spacing:-.03em; line-height:1; }
.hero__stat-label{ font-size:.82rem; font-weight:500; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.5); margin-top:9px; }
.hero__stat-sep{ width:1px; height:44px; background:rgba(255,255,255,.18); margin-right:56px; flex-shrink:0; }

/* Hero content animates in on load — never depends on scroll/JS (above the fold) */
.hero__content .reveal{ animation:heroIn .85s cubic-bezier(.2,.6,.2,1) both; }
.hero__content .reveal:nth-child(1){ animation-delay:.06s; }
.hero__content .reveal:nth-child(2){ animation-delay:.16s; }
.hero__content .reveal:nth-child(3){ animation-delay:.26s; }
.hero__content .reveal:nth-child(4){ animation-delay:.36s; }
.hero__content .reveal:nth-child(5){ animation-delay:.46s; }
@keyframes heroIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .hero__content .reveal{ animation:none; opacity:1; transform:none; } }

/* =========================================================
   VALUE STRIP
   ========================================================= */
.values{ background:var(--bg-soft); border-top:1px solid var(--line); padding:54px 0; }
.values__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.value{ position:relative; display:flex; flex-direction:column; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:15px; padding:26px 24px; box-shadow:0 1px 2px rgba(2,32,57,.05), 0 6px 18px rgba(2,32,57,.045); text-decoration:none; transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.value:hover{ transform:translateY(-5px); border-color:rgba(0,116,200,.45); box-shadow:0 18px 40px rgba(2,32,57,.14), 0 0 0 1px rgba(0,116,200,.16), 0 0 24px rgba(0,116,200,.12); }
.value__icon{ flex-shrink:0; width:56px; height:56px; border-radius:14px; background:var(--navy); color:#fff; display:grid; place-items:center; margin-bottom:20px; transition:transform .3s ease, background .3s ease; }
.value__icon svg{ width:27px; height:27px; }
.value:hover .value__icon{ transform:scale(1.08); background:var(--blue); }
.value__body{ display:flex; flex-direction:column; min-width:0; }
.value__title{ font-family:'DM Sans',sans-serif; font-weight:800; font-size:1.05rem; line-height:1.25; margin-bottom:9px; color:var(--navy); letter-spacing:-.01em; }
.value__text{ font-size:.84rem; color:var(--muted); line-height:1.6; }
.value__arrow{ position:absolute; top:30px; right:24px; width:20px; height:20px; color:var(--blue); opacity:0; transform:translateX(-6px); transition:opacity .3s ease, transform .3s ease; }
.value:hover .value__arrow{ opacity:1; transform:translateX(0); }

/* =========================================================
   PRODUCT CATEGORIES — Industrial Control Panel
   ========================================================= */
.cp-section .section-head{ margin-bottom:48px; }

@keyframes cpBlink{ 0%,100%{ opacity:1; } 50%{ opacity:.12; } }

/* ── Grid ── */
.cp__grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr 1fr;
    grid-template-rows:190px 280px 190px;
    gap:5px;
    background:#010f1a;
    border:1px solid rgba(0,116,200,.22);
    padding:5px;
    will-change:transform;
    transition:transform .12s ease-out;
}

/* Explicit panel positions */
.cp__pan[data-cidx="0"]  { grid-column:1;   grid-row:1; }
.cp__pan[data-cidx="1"]  { grid-column:2;   grid-row:1; }
.cp__pan[data-cidx="2"]  { grid-column:3;   grid-row:1; }
.cp__pan[data-cidx="3"]  { grid-column:4;   grid-row:1; }
.cp__pan[data-cidx="4"]  { grid-column:1;   grid-row:2; }
.cp__pan[data-cidx="hub"]{ grid-column:2/4; grid-row:2/4; }
.cp__pan[data-cidx="5"]  { grid-column:4;   grid-row:2; }
.cp__pan[data-cidx="6"]  { grid-column:1;   grid-row:3; }
.cp__pan[data-cidx="7"]  { grid-column:4;   grid-row:3; }

/* ── Panel base ── */
.cp__pan{
    position:relative; overflow:hidden; display:block;
    background:var(--navy);
    border:1px solid rgba(255,255,255,.07);
    text-decoration:none;
    opacity:0; transform:scale(.97);
    transition:
        opacity .5s ease,
        transform .5s cubic-bezier(.2,.6,.2,1),
        border-color .3s ease,
        box-shadow .3s ease;
    z-index:1;
}
.cp__pan.cp-on{ opacity:1; transform:scale(1); }
.cp__pan:hover{
    border-color:rgba(0,116,200,.55);
    box-shadow:inset 0 0 0 1px rgba(0,116,200,.18);
    z-index:5;
}

@keyframes cpFlash{
    0%  { filter:brightness(2.8); }
    100%{ filter:brightness(1); }
}
.cp__pan.cp-flash{ animation:cpFlash .38s ease-out forwards; }

/* ── Image ── */
.cp__pan-img{ position:absolute; inset:0; }
.cp__pan-img img{
    width:100%; height:100%; object-fit:cover;
    filter:brightness(.88) saturate(.9);
    transition:transform .7s cubic-bezier(.2,.6,.2,1), filter .5s ease;
    will-change:transform;
}
.cp__pan:hover .cp__pan-img img{
    transform:scale(1.05);
    filter:brightness(1) saturate(1.05);
}

/* ── Overlay ── */
.cp__pan-ov{
    position:absolute; inset:0; z-index:1;
    background:linear-gradient(
        to top,
        rgba(0,32,57,.82) 0%,
        rgba(0,32,57,.22) 52%,
        rgba(0,18,32,.0) 100%
    );
}

/* ── Body ── */
.cp__pan-bd{
    position:absolute; bottom:0; left:0; right:0;
    padding:11px 13px 13px; z-index:3;
    transition:transform .3s cubic-bezier(.2,.6,.2,1);
}
.cp__pan:hover .cp__pan-bd{ transform:translateY(-3px); }

.cp__mod-id{
    display:block;
    font-family:'Courier New',Courier,monospace;
    font-size:.58rem; font-weight:700;
    letter-spacing:.22em; text-transform:uppercase;
    color:rgba(0,116,200,.55); margin-bottom:4px;
    transition:color .3s ease;
}
.cp__pan:hover .cp__mod-id{ color:var(--blue); }

.cp__mod-nm{
    color:#fff; font-weight:700;
    line-height:1.18; letter-spacing:-.01em; margin:0 0 7px;
}

.cp__mod-ft{ display:flex; align-items:center; gap:7px; }

.cp__mod-dot{
    width:5px; height:5px; flex-shrink:0;
    border-radius:50%;
    background:rgba(0,116,200,.28);
    transition:background .3s ease, box-shadow .3s ease;
}
.cp__pan:hover .cp__mod-dot{
    background:var(--blue);
    box-shadow:0 0 7px rgba(0,116,200,.9);
}

.cp__mod-ex{
    font-size:.7rem; font-weight:700;
    letter-spacing:.07em; text-transform:uppercase;
    color:rgba(255,255,255,.35);
    transition:color .3s ease;
}
.cp__pan:hover .cp__mod-ex{ color:rgba(255,255,255,.82); }

.cp__mod-arr{
    width:13px; height:13px; flex-shrink:0;
    color:rgba(0,116,200,.32);
    transition:color .3s ease, transform .3s cubic-bezier(.2,.6,.2,1);
}
.cp__pan:hover .cp__mod-arr{
    color:var(--blue); transform:translateX(4px);
}

/* ── Corner brackets ── */
.cp__brk{
    position:absolute; width:12px; height:12px; z-index:4;
    opacity:.3; transition:opacity .3s ease, border-color .3s ease;
}
.cp__pan:hover .cp__brk{ opacity:1; }
.cp__brk-tl{ top:7px;    left:7px;   border-top:1.5px  solid rgba(0,116,200,.6); border-left:1.5px  solid rgba(0,116,200,.6); }
.cp__brk-tr{ top:7px;    right:7px;  border-top:1.5px  solid rgba(0,116,200,.6); border-right:1.5px solid rgba(0,116,200,.6); }
.cp__brk-bl{ bottom:7px; left:7px;   border-bottom:1.5px solid rgba(0,116,200,.6); border-left:1.5px  solid rgba(0,116,200,.6); }
.cp__brk-br{ bottom:7px; right:7px;  border-bottom:1.5px solid rgba(0,116,200,.6); border-right:1.5px solid rgba(0,116,200,.6); }
.cp__pan:hover .cp__brk-tl,
.cp__pan:hover .cp__brk-tr,
.cp__pan:hover .cp__brk-bl,
.cp__pan:hover .cp__brk-br{ border-color:var(--blue); }

/* ── Hub panel ── */
.cp__pan--hub .cp__pan-bd{ padding:18px 22px 22px; }
.cp__pan--hub .cp__mod-nm{ font-weight:800; margin-bottom:10px; }
.cp__pan--hub .cp__mod-ex{ font-size:.75rem; }
.cp__pan--hub .cp__brk{ width:18px; height:18px; }
.cp__pan--hub .cp__brk-tl{ top:13px;    left:13px;   }
.cp__pan--hub .cp__brk-tr{ top:13px;    right:13px;  }
.cp__pan--hub .cp__brk-bl{ bottom:13px; left:13px;   }
.cp__pan--hub .cp__brk-br{ bottom:13px; right:13px;  }
.cp__pan--hub:hover{
    transform:scale(1.006) !important;
    border-color:rgba(0,116,200,.65) !important;
    box-shadow:inset 0 0 0 1px rgba(0,116,200,.18), 0 0 36px rgba(0,116,200,.07) !important;
}

/* Hub badge */
.cp__hub-badge{
    display:inline-flex; align-items:center; gap:7px;
    border:1px solid rgba(0,116,200,.28);
    background:rgba(0,116,200,.1);
    padding:3px 10px;
    font-family:'Courier New',Courier,monospace;
    font-size:.58rem; font-weight:700;
    letter-spacing:.18em; text-transform:uppercase;
    color:var(--blue); margin-bottom:12px;
}
.cp__hub-dot{
    width:5px; height:5px; flex-shrink:0;
    border-radius:50%;
    background:var(--blue);
    animation:cpBlink 1.4s ease-in-out infinite;
}

/* Hub description */
.cp__hub-desc{
    font-size:.83rem; color:rgba(255,255,255,.44);
    line-height:1.68; margin-bottom:16px;
}

/* Hub always-active dot */
.cp__mod-dot--hub{
    background:var(--blue) !important;
    box-shadow:0 0 8px rgba(0,116,200,.9);
    animation:cpBlink 2.2s ease-in-out infinite;
}

/* Hub scan line */
.cp__hub-scan{
    position:absolute; left:0; right:0; height:1px; z-index:2;
    pointer-events:none;
    background:linear-gradient(
        to right,
        transparent 0%,
        rgba(0,116,200,.45) 28%,
        rgba(0,116,200,.8) 50%,
        rgba(0,116,200,.45) 72%,
        transparent 100%
    );
    animation:cpScan 3.8s linear infinite;
}
@keyframes cpScan{
    0%  { top:0;    opacity:0; }
    4%  { opacity:1; }
    96% { opacity:1; }
    100%{ top:100%; opacity:0; }
}

/* Hub glows when siblings are hovered */
.cp__pan--hub.is-connected{
    border-color:rgba(0,116,200,.42) !important;
    box-shadow:inset 0 0 0 1px rgba(0,116,200,.14), 0 0 28px rgba(0,116,200,.06) !important;
}

/* =========================================================
   FEATURE (DRIFT)
   ========================================================= */
.feature{ background:var(--bg-soft); }
.feature__inner{ display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:stretch; }
.feature__media{ position:relative; }
.feature__media img{ width:100%; height:100%; object-fit:cover; border:1px solid var(--line); display:block; min-height:320px; }
.feature__media::after{ content:""; position:absolute; right:-14px; bottom:-14px; width:60%; height:60%; border:2px solid var(--blue); z-index:-1; }
.feature__badge{
    position:absolute; top:20px; left:20px; background:var(--navy); color:#fff;
    font-size:.8rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:9px 16px;
}
.feature__content .section-title{ margin-top:16px; }
.feature__text{ color:var(--muted); margin-bottom:24px; font-size:1.06rem; }
.feature__list{ display:flex; flex-direction:column; gap:14px; margin-bottom:34px; }
.feature__list li{ display:flex; align-items:flex-start; gap:13px; font-weight:500; color:var(--ink); }
.feature__list svg{ width:22px; height:22px; color:#fff; background:var(--blue); padding:4px; flex-shrink:0; margin-top:1px; }

/* =========================================================
   HOBO UNDERWATER LOGGERS
   ========================================================= */
.loggers{ background:var(--bg); }
.loggers__head{ display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center; margin-bottom:58px; }
.loggers__lead{ color:var(--muted); font-size:1.08rem; margin:16px 0 26px; }
.loggers__points{ display:flex; flex-direction:column; gap:13px; margin-bottom:32px; }
.loggers__points li{ display:flex; align-items:flex-start; gap:13px; font-weight:500; color:var(--ink); }
.loggers__points svg{ width:22px; height:22px; color:#fff; background:var(--blue); padding:4px; flex-shrink:0; margin-top:1px; }
.loggers__figure{ position:relative; margin:0; }
.loggers__figure img{ width:100%; aspect-ratio:4/3; object-fit:cover; border:1px solid var(--line); }
.loggers__figure::after{ content:""; position:absolute; left:-14px; top:-14px; width:55%; height:55%; border:2px solid var(--blue); z-index:-1; }
.loggers__figure-badge{ position:absolute; left:20px; bottom:20px; background:var(--navy); color:#fff; font-size:.8rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:9px 16px; }

.loggers__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.logger-card{ position:relative; background:#fff; border:1px solid var(--line); border-radius:15px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 1px 2px rgba(2,32,57,.05), 0 6px 18px rgba(2,32,57,.045); transform:translateZ(0); -webkit-backface-visibility:hidden; backface-visibility:hidden; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.logger-card:hover{ transform:translate3d(0,-5px,0); border-color:rgba(0,116,200,.45); box-shadow:0 18px 42px rgba(2,32,57,.15), 0 0 0 1px rgba(0,116,200,.16), 0 0 26px rgba(0,116,200,.13); }
.logger-card__media{ height:240px; background:radial-gradient(120% 120% at 50% 0%, #fbfcfe 0%, #eaeef3 100%); border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:26px; overflow:hidden; }
.logger-card__media img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; mix-blend-mode:multiply; -webkit-backface-visibility:hidden; backface-visibility:hidden; transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.logger-card:hover .logger-card__media img{ transform:scale(1.06); }
.logger-card__body{ padding:22px 24px 24px; display:flex; flex-direction:column; flex-grow:1; }
.logger-card__tag{ align-self:flex-start; font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--blue); background:rgba(0,116,200,.09); padding:5px 11px; border-radius:7px; margin-bottom:14px; }
.logger-card__model{ font-family:'DM Sans',sans-serif; font-weight:800; font-size:1.12rem; color:var(--navy); letter-spacing:-.01em; margin-bottom:7px; transition:color var(--t); }
.logger-card:hover .logger-card__model{ color:var(--blue); }
.logger-card__desc{ font-size:.88rem; color:var(--muted); line-height:1.6; flex-grow:1; }
.logger-card__specs{ display:flex; margin-top:18px; border-top:1px solid var(--line); }
.logger-card__specs li{ flex:1; display:flex; flex-direction:column; padding:15px 0 0; font-weight:800; color:var(--navy); font-size:.98rem; }
.logger-card__specs li + li{ padding-left:18px; margin-left:18px; border-left:1px solid var(--line); }
.logger-card__specs span{ font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:5px; }
.logger-card__btn{ position:static; width:100%; margin-top:22px; padding:12px 18px; font-size:.85rem; border-width:1px; border-radius:10px; }
.logger-card__btn::after{ content:""; position:absolute; inset:0; z-index:1; }
.logger-card__btn:hover{ transform:none; }
.section-cta{ text-align:center; margin-top:52px; }
.section-cta .btn{ min-width:220px; }

@media (max-width:960px){
    .loggers__head{ grid-template-columns:1fr; gap:36px; }
    .loggers__figure::after{ display:none; }
    .loggers__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
    .loggers__grid{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
}

/* =========================================================
   KABELSERTIFISERING
   ========================================================= */
.kabel{ background:var(--navy); position:relative; overflow:hidden; }
.kabel::before{
    content:""; position:absolute; inset:0;
    background:radial-gradient(60% 80% at 85% 10%, rgba(0,116,200,.22), transparent 60%);
}
.kabel .container{ position:relative; z-index:2; }
.kabel .section-title{ color:#fff; }
.kabel__lead{ color:rgba(255,255,255,.58); }
.kabel__item-title{ color:#fff; }
.kabel__item-text{ color:rgba(255,255,255,.5); }

/* Split heading row */
.kabel__head{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:0 80px;
    align-items:end;
    margin-bottom:40px;
}
.kabel__head-l .eyebrow{ margin-bottom:14px; }
.kabel__head-l .section-title{ margin-top:0; }
.kabel__lead{
    font-size:1.04rem; color:var(--muted);
    line-height:1.75; padding-bottom:6px;
}

/* Banner */
.kabel__banner{
    background:var(--navy);
    position:relative;
    height:340px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    border:1px solid rgba(0,116,200,.18);
    border-bottom:none;
}
.kabel__banner-img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover; object-position:center;
    z-index:0;
}
.kabel__banner-ov{
    position:absolute; inset:0;
    background:rgba(0,20,40,.72);
    z-index:1;
}
.kabel__word{
    font-size:clamp(4.5rem,13vw,9.5rem);
    font-weight:900;
    letter-spacing:-.02em;
    color:rgba(255,255,255,.30);
    text-transform:uppercase;
    line-height:1;
    user-select:none;
    white-space:nowrap;
    position:absolute;
    z-index:2;
}
.kabel__banner-meta{
    position:absolute;
    bottom:18px;
    left:0; right:0;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    font-family:'Courier New',Courier,monospace;
    font-size:.62rem; font-weight:700;
    letter-spacing:.18em; text-transform:uppercase;
    color:rgba(0,116,200,.6);
    z-index:2;
}
.kabel__meta-dot{
    width:3px; height:3px;
    border-radius:50%;
    background:rgba(0,116,200,.45);
    flex-shrink:0;
}

/* 4-col grid — sits flush under banner */
.kabel__grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    border:1px solid var(--line);
}
.kabel__item{
    padding:34px 28px 38px;
    border-right:1px solid var(--line);
}
.kabel__item:last-child{ border-right:none; }
.kabel__item:hover .kabel__ic{ color:var(--blue-700); }

.kabel__ic{
    width:34px; height:34px;
    color:var(--blue);
    margin-bottom:18px;
    transition:color var(--t);
}
.kabel__ic svg{ width:100%; height:100%; }

.kabel__item-title{
    font-weight:700;
    color:#fff;
    margin:0 0 9px; line-height:1.25;
}
.kabel__item-text{
    font-size:.875rem;
    color:rgba(255,255,255,.52);
    line-height:1.7;
}

@media (max-width:960px){
    .kabel__head{ grid-template-columns:1fr; gap:16px; }
    .kabel__lead{ padding-bottom:0; }
    .kabel__grid{ grid-template-columns:repeat(2,1fr); }
    .kabel__item:nth-child(2){ border-right:none; }
    .kabel__item:nth-child(3){ border-top:1px solid var(--line); }
    .kabel__item:nth-child(4){ border-top:1px solid var(--line); }
}
@media (max-width:680px){
    .kabel__banner{ height:220px; }
    .kabel__grid{ grid-template-columns:1fr; }
    .kabel__item{ border-right:none; border-top:1px solid var(--line); }
    .kabel__item:first-child{ border-top:none; }
}

/* =========================================================
   WIREXPERT MP (DARK SPOTLIGHT)
   ========================================================= */
.wirexpert{ position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.wirexpert__bg{ position:absolute; inset:0; z-index:0; }
.wirexpert__bg img{ width:100%; height:100%; object-fit:cover; opacity:.30; object-position:center; }
.wirexpert__overlay{ position:absolute; inset:0;
    background:linear-gradient(90deg, var(--navy) 22%, rgba(0,32,57,.82) 58%, rgba(0,32,57,.62) 100%); }
.wirexpert__inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.08fr 1fr; gap:60px; align-items:center; }
.wirexpert__lead{ color:rgba(255,255,255,.82); font-size:1.1rem; margin:16px 0 26px; }
.wirexpert__features{ display:flex; flex-direction:column; gap:14px; margin-bottom:32px; }
.wirexpert__features li{ display:flex; align-items:flex-start; gap:13px; font-weight:500; color:rgba(255,255,255,.92); }
.wirexpert__features svg{ width:22px; height:22px; color:#fff; background:var(--blue); padding:4px; flex-shrink:0; margin-top:1px; }
.wirexpert__media{ position:relative; margin:0; background:var(--navy-700); border:1px solid rgba(255,255,255,.14); }
.wirexpert__media img{ width:100%; display:block; }
.wirexpert__media::after{ content:""; position:absolute; right:-14px; bottom:-14px; width:50%; height:50%; border:2px solid var(--blue); z-index:-1; }
.wirexpert__badge{ position:absolute; top:0; left:0; z-index:2; background:var(--blue); color:#fff; font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:8px 14px; }
.wirexpert__cap{ display:flex; flex-direction:column; gap:2px; padding:18px 22px; border-top:1px solid rgba(255,255,255,.12); }
.wirexpert__cap strong{ font-size:1.05rem; font-weight:800; color:#fff; }
.wirexpert__cap span{ font-size:.9rem; color:rgba(255,255,255,.6); }

.wirexpert__stats{ position:relative; z-index:2; display:grid; grid-template-columns:repeat(4,1fr); border:1px solid rgba(255,255,255,.14); margin-top:60px; background:rgba(4,24,43,.5); }
.wirexpert__stat{ text-align:center; padding:30px 18px; border-left:1px solid rgba(255,255,255,.14); }
.wirexpert__stat:first-child{ border-left:none; }
.wirexpert__stat-num{ display:block; font-size:2.5rem; font-weight:900; color:#fff; letter-spacing:-.02em; line-height:1; }
.wirexpert__stat-num span{ font-size:1.1rem; font-weight:700; color:#5fb4ff; }
.wirexpert__stat-label{ display:block; margin-top:11px; color:#5fb4ff; font-size:.8rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; }

@media (max-width:960px){
    .wirexpert__inner{ grid-template-columns:1fr; gap:40px; }
    .wirexpert__media::after{ display:none; }
    .wirexpert__stats{ grid-template-columns:repeat(2,1fr); }
    .wirexpert__stat:nth-child(3){ border-left:none; }
    .wirexpert__stat{ border-top:1px solid rgba(255,255,255,.14); }
    .wirexpert__stat:nth-child(1),.wirexpert__stat:nth-child(2){ border-top:none; }
}
@media (max-width:680px){
    .wirexpert__stats{ grid-template-columns:1fr; }
    .wirexpert__stat{ border-left:none !important; border-top:1px solid rgba(255,255,255,.14); }
    .wirexpert__stat:first-child{ border-top:none; }
}

/* =========================================================
   WHY ELIT (DARK)
   ========================================================= */
.why{ background:var(--navy); position:relative; overflow:hidden; }
.why::before{
    content:""; position:absolute; inset:0;
    background:radial-gradient(60% 80% at 85% 10%, rgba(0,116,200,.22), transparent 60%);
}
.why .container{ position:relative; z-index:2; }
/* features — connected timeline */
.why-steps{ position:relative; display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.why-steps::before{ content:""; position:absolute; top:38px; left:12.5%; right:12.5%; height:2px; background:linear-gradient(90deg, rgba(0,116,200,0), rgba(0,116,200,.45) 12%, rgba(0,116,200,.45) 88%, rgba(0,116,200,0)); z-index:0; }
.why-step{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 6px; }
.why-step__node{ width:76px; height:76px; border-radius:50%; background:var(--navy-700); border:1px solid rgba(0,116,200,.35); display:grid; place-items:center; color:#5fb4ff; margin-bottom:24px; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease; }
.why-step__node svg{ width:30px; height:30px; transition:transform .25s ease; }
.why-step:hover .why-step__node{ transform:translateY(-4px); border-color:rgba(0,116,200,.8); background:var(--navy-600); box-shadow:0 14px 30px rgba(0,0,0,.4), 0 0 26px rgba(0,116,200,.32); }
.why-step:hover .why-step__node svg{ transform:scale(1.12); }
.why-step__num{ font-family:'DM Sans',sans-serif; font-size:.74rem; font-weight:800; letter-spacing:.22em; color:var(--blue); margin-bottom:11px; }
.why-step__title{ font-family:'DM Sans',sans-serif; font-size:1.12rem; font-weight:800; color:#fff; margin-bottom:11px; letter-spacing:-.01em; line-height:1.25; }
.why-step__text{ font-size:.89rem; color:rgba(255,255,255,.62); line-height:1.6; max-width:240px; }

/* stats — full-width horizontal strip with counters */
.why-stats{ position:relative; display:grid; grid-template-columns:repeat(4,1fr); margin-top:64px; padding:48px 0; background:radial-gradient(130% 150% at 50% 0%, rgba(0,116,200,.10), transparent 68%); border-top:1px solid rgba(255,255,255,.10); }
.why-stat{ position:relative; text-align:center; padding:4px 24px; }
.why-stat::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:1px; height:56px; background:linear-gradient(180deg, transparent, rgba(255,255,255,.18), transparent); }
.why-stat:first-child::before{ display:none; }
.why-stat__num{ display:block; font-family:'DM Sans',sans-serif; font-size:3.3rem; font-weight:900; color:#fff; letter-spacing:-.03em; line-height:1; }
.why-stat__label{ display:block; margin-top:14px; color:#5fb4ff; font-size:.8rem; font-weight:600; letter-spacing:.09em; text-transform:uppercase; }

/* =========================================================
   COURSES
   ========================================================= */
.courses{ background:var(--bg); }
.courses__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.course{
    display:flex; flex-direction:column; background:#fff;
    border:1px solid var(--line-strong); border-top:3px solid var(--blue);
    padding:34px 30px 30px; position:relative; transition:var(--t);
    box-shadow:0 2px 12px rgba(2,32,57,.10), 0 1px 3px rgba(2,32,57,.06);
}
.course:hover{ box-shadow:var(--shadow-md); border-color:var(--line-strong); transform:translateY(-4px); }
.course--featured{ background:var(--navy); border-color:var(--navy); transform:translateY(-12px); }
.course--featured:hover{ transform:translateY(-16px); box-shadow:var(--shadow-md); }
.course__ribbon{
    position:absolute; top:0; right:0; background:var(--blue); color:#fff;
    font-size:.74rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:8px 14px;
}
.course__tag{
    display:inline-block; font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:var(--blue); background:var(--bg-softer); padding:6px 12px; margin-bottom:16px;
}
.course--featured .course__tag{ background:rgba(0,116,200,.2); color:#7cc0f5; }
.course__title{ margin-bottom:14px; }
.course--featured .course__title{ color:#fff; }
.course__text{ color:var(--muted); font-size:.96rem; }
.course--featured .course__text{ color:rgba(255,255,255,.7); }
.course__meta{ display:flex; flex-direction:column; gap:10px; margin:20px 0 24px; }
.course__meta li{ display:flex; align-items:center; gap:10px; font-size:.9rem; font-weight:500; color:var(--ink); }
.course--featured .course__meta li{ color:rgba(255,255,255,.82); }
.course__meta svg{ width:18px; height:18px; color:var(--blue); flex-shrink:0; }
.course--featured .course__meta svg{ color:#7cc0f5; }
.course__foot{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:auto; padding-top:22px; border-top:1px solid var(--line); }
.course--featured .course__foot{ border-top-color:rgba(255,255,255,.14); }
.course__price{ font-size:1.7rem; font-weight:800; color:var(--navy); letter-spacing:-.02em; }
.course--featured .course__price{ color:#fff; }
.course__price span{ font-size:.92rem; font-weight:600; color:var(--muted); }
.course--featured .course__price span{ color:rgba(255,255,255,.6); }
.courses__note{ text-align:center; margin-top:30px; color:var(--muted); font-size:.88rem; }

/* =========================================================
   CERTIFICATIONS
   ========================================================= */
.certs{ background:var(--bg-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.certs__text{ text-align:center; max-width:640px; margin-inline:auto; }
.certs__sub{ color:var(--muted); margin-top:16px; font-size:1.05rem; }
/* certification logos — static row, no hover */
.cert-show{ display:flex; flex-wrap:wrap; justify-content:center; align-items:stretch; gap:34px; margin-top:46px; }
.cert-item{ display:flex; }
.cert-item__logo{ width:210px; height:132px; background:#fff; border:1px solid var(--line); box-shadow:0 1px 2px rgba(2,32,57,.05), 0 14px 34px rgba(2,32,57,.07); display:flex; align-items:center; justify-content:center; padding:28px 30px; }
.cert-item__logo img{ max-width:100%; max-height:100%; object-fit:contain; }

/* credentials trust strip */
.certs__trust{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; margin-top:32px; padding-top:40px; border-top:1px solid var(--line); }
.certs__trust-item{ position:relative; display:flex; align-items:center; gap:11px; padding:8px 32px; font-weight:600; color:var(--navy); font-size:.92rem; }
.certs__trust-item:not(:last-child)::after{ content:""; position:absolute; right:0; top:50%; transform:translateY(-50%); width:1px; height:26px; background:var(--line); }
.certs__trust-item svg{ width:23px; height:23px; color:var(--blue); flex:none; }

@media (max-width:900px){
    .cert-show{ gap:22px; }
    .certs__trust{ flex-direction:column; gap:18px; }
    .certs__trust-item{ padding:0; }
    .certs__trust-item:not(:last-child)::after{ display:none; }
}

/* =========================================================
   CTA BAND
   ========================================================= */
.cta-band{ padding:80px 0; }
.cta-band__inner{
    background:var(--blue) url('cta bg.png') center/cover no-repeat; color:#fff; position:relative; overflow:hidden;
    display:flex; flex-direction:column; align-items:center; text-align:center;
    gap:32px; padding:64px 48px; z-index:2;
}
.cta-band__inner::before{ content:""; position:absolute; inset:0; background:rgba(0,0,0,.60); }
.cta-band__inner::after{ content:""; position:absolute; right:-80px; top:-80px; width:340px; height:340px; border:60px solid rgba(255,255,255,.07); }
.cta-band__text{ position:relative; z-index:1; }
.cta-band__title{ color:#fff; }
.cta-band__sub{ color:rgba(255,255,255,.85); margin-top:12px; font-size:1.08rem; max-width:560px; margin-inline:auto; }
.cta-band__actions{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; position:relative; z-index:1; }
.cta-band__actions svg{ width:18px; height:18px; }

/* =========================================================
   FAQ — B2B support experience
   ========================================================= */
.faq{ background:var(--bg-soft); }
.faq__grid{ display:grid; grid-template-columns:0.86fr 1.14fr; gap:56px; align-items:start; }

/* ---------- Left column: heading + support panel (sticky) ---------- */
.faq__aside{ position:sticky; top:128px; }
.faq__aside .eyebrow{ margin-bottom:16px; }
.faq__aside-text{ color:var(--muted); font-size:1.02rem; line-height:1.7; margin-top:14px; max-width:430px; }

.faq__support{ margin-top:30px; background:#fff; border:1px solid var(--line); padding:26px 26px 24px; box-shadow:0 1px 2px rgba(2,32,57,.05), 0 18px 44px rgba(2,32,57,.07); }
.faq__support-label{ display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:20px; }
.faq__support-list{ display:grid; gap:16px; margin-bottom:24px; }
.faq__support-list li{ display:flex; align-items:center; gap:14px; }
.faq__support-ic{ flex:none; width:44px; height:44px; background:var(--bg-softer); color:var(--blue); display:grid; place-items:center; }
.faq__support-ic svg{ width:20px; height:20px; }
.faq__support-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.faq__support-k{ font-size:.76rem; color:var(--muted); font-weight:600; }
.faq__support-v{ font-size:1rem; font-weight:700; color:var(--navy); line-height:1.3; word-break:break-word; transition:color var(--t-fast); }
a.faq__support-v:hover{ color:var(--blue); }
.faq__support-cta{ margin-bottom:20px; }
.faq__trust{ display:flex; flex-wrap:wrap; gap:9px 16px; padding-top:18px; border-top:1px solid var(--line); }
.faq__trust li{ display:inline-flex; align-items:center; gap:7px; font-size:.82rem; font-weight:600; color:var(--navy); }
.faq__trust svg{ width:15px; height:15px; color:var(--blue); flex:none; }

/* ---------- Right column: accordion ---------- */
.faq__list{ display:grid; gap:14px; }
.faq__item{ background:#fff; border:1px solid var(--line); box-shadow:0 1px 2px rgba(2,32,57,.04); transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease; }
.faq__item:hover{ border-color:rgba(0,116,200,.45); box-shadow:0 1px 2px rgba(2,32,57,.05), 0 14px 30px rgba(2,32,57,.09); transform:translateY(-2px); }
.faq__item.is-open{ border-color:rgba(0,116,200,.5); box-shadow:0 1px 2px rgba(2,32,57,.05), 0 16px 36px rgba(2,32,57,.10); }

.faq__q{ display:flex; align-items:center; justify-content:space-between; gap:18px; width:100%; text-align:left; padding:20px 22px; background:none; border:none; cursor:pointer; font-family:var(--font-heading); font-weight:700; font-size:1.06rem; color:var(--navy); line-height:1.35; transition:color var(--t-fast); }
.faq__q:hover, .faq__item.is-open .faq__q{ color:var(--blue); }
.faq__q:focus-visible{ outline:2px solid var(--blue); outline-offset:-2px; }
.faq__q-text{ flex:1; }

/* plus / minus icon */
.faq__icon{ position:relative; flex:none; width:28px; height:28px; border:1px solid var(--line-strong); transition:background .25s ease, border-color .25s ease; }
.faq__icon::before, .faq__icon::after{ content:""; position:absolute; left:50%; top:50%; width:12px; height:2px; background:var(--blue); transform:translate(-50%,-50%); transition:transform .28s cubic-bezier(.4,0,.2,1), opacity .2s ease, background .25s ease; }
.faq__icon::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq__item:hover .faq__icon{ border-color:rgba(0,116,200,.5); }
.faq__item.is-open .faq__icon{ background:var(--blue); border-color:var(--blue); }
.faq__item.is-open .faq__icon::before{ background:#fff; }
.faq__item.is-open .faq__icon::after{ transform:translate(-50%,-50%) rotate(0deg); opacity:0; }

/* animated answer (grid-rows height transition + content fade) */
.faq__a{ display:grid; grid-template-rows:1fr; transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1); }
.faq__list.js .faq__item:not(.is-open) .faq__a{ grid-template-rows:0fr; }
.faq__list.is-init .faq__a, .faq__list.is-init .faq__a-inner p{ transition:none; }
.faq__a-inner{ overflow:hidden; min-height:0; }
.faq__a-inner p{ padding:2px 22px 22px; max-width:60ch; font-size:.97rem; color:var(--muted); line-height:1.75; transition:opacity .28s ease .04s, transform .28s ease .04s; }
.faq__list.js .faq__item:not(.is-open) .faq__a-inner p{ opacity:0; transform:translateY(-6px); }

/* ---------- Bottom CTA banner ---------- */
.faq__cta{ position:relative; overflow:hidden; margin-top:46px; display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; background:linear-gradient(120deg,var(--navy) 0%,var(--navy-700) 100%); padding:34px 40px; box-shadow:var(--shadow-md); }
.faq__cta::before{ content:""; position:absolute; right:-40px; top:-70px; width:300px; height:300px; background:radial-gradient(circle,rgba(0,116,200,.30),transparent 70%); pointer-events:none; }
.faq__cta-text{ position:relative; }
.faq__cta-title{ color:#fff; font-size:1.5rem; margin-bottom:6px; }
.faq__cta-text p{ color:rgba(255,255,255,.74); font-size:1rem; max-width:540px; line-height:1.6; }
.faq__cta-actions{ position:relative; display:flex; gap:12px; flex-wrap:wrap; }
.faq__cta .btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.faq__cta .btn--ghost:hover{ background:#fff; color:var(--navy); border-color:#fff; box-shadow:0 8px 24px rgba(0,0,0,.18); }

/* ---------- Responsive ---------- */
@media (max-width:980px){
    .faq__grid{ grid-template-columns:1fr; gap:36px; }
    .faq__aside{ position:static; }
    .faq__aside-text{ max-width:none; }
    .faq__cta{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:560px){
    .faq__support{ padding:22px 20px; }
    .faq__q{ padding:17px 18px; font-size:1rem; gap:14px; }
    .faq__a-inner p{ padding:2px 18px 18px; }
    .faq__cta{ padding:28px 24px; }
    .faq__cta-actions{ width:100%; }
    .faq__cta-actions .btn{ flex:1 1 auto; }
}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{ background:var(--bg); }
.contact__inner{ display:grid; grid-template-columns:1fr 1.05fr; gap:64px; align-items:start; }
.contact__lead{ color:var(--muted); margin:16px 0 32px; font-size:1.06rem; }
.contact__details{ display:flex; flex-direction:column; gap:6px; }
.contact__details li{ display:flex; align-items:center; gap:16px; padding:16px 0; border-bottom:1px solid var(--line); }
.contact__ic{ width:46px; height:46px; background:var(--bg-soft); border:1px solid var(--line); color:var(--blue); display:grid; place-items:center; flex-shrink:0; }
.contact__ic svg{ width:21px; height:21px; }
.contact__label{ display:block; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:600; margin-bottom:2px; }
.contact__value{ font-weight:700; color:var(--navy); font-size:1.02rem; transition:color var(--t-fast); }
a.contact__value:hover{ color:var(--blue); }

.contact__form-wrap{ background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.contact__form{ padding:38px; }
.contact__form-title{ margin-bottom:24px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ margin-bottom:18px; display:flex; flex-direction:column; }
.field label{ font-size:.82rem; font-weight:600; color:var(--navy); margin-bottom:7px; letter-spacing:.01em; }
.field input,.field select,.field textarea{
    border:1px solid var(--line-strong); background:#fff; padding:13px 15px; color:var(--ink);
    transition:var(--t-fast); width:100%; resize:vertical;
}
.field input:focus,.field select:focus,.field textarea:focus{
    outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(0,116,200,.14);
}
.field input::placeholder,.field textarea::placeholder{ color:#9aa8b5; }
.contact__form-note{ text-align:center; font-size:.82rem; color:var(--muted); margin-top:14px; }
.field--consent{ margin-top:4px; margin-bottom:0; }
.field__consent-label{
    display:flex; align-items:flex-start; gap:11px;
    cursor:pointer; font-size:.88rem; color:var(--muted); line-height:1.5;
}
.field__consent-label input[type="checkbox"]{
    flex-shrink:0; width:18px; height:18px; margin-top:2px; accent-color:var(--blue); cursor:pointer;
}
.field__consent-label a{ color:var(--blue); text-decoration:underline; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--navy-800); color:rgba(255,255,255,.7); }
.footer__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:44px; padding:74px 24px 56px; }
.footer__logo{ height:30px; width:auto; margin-bottom:20px; }
.footer__tagline{ font-size:.94rem; line-height:1.7; color:rgba(255,255,255,.6); max-width:340px; margin-bottom:24px; }
.footer__social{ display:flex; gap:10px; }
.footer__social a{ width:40px; height:40px; border:1px solid rgba(255,255,255,.14); display:grid; place-items:center; color:rgba(255,255,255,.75); transition:var(--t); }
.footer__social svg{ width:17px; height:17px; }
.footer__social a:hover{ background:var(--blue); border-color:var(--blue); color:#fff; }
.footer__heading{ color:#fff; font-size:1rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:20px; font-weight:700; }
.footer__links li{ margin-bottom:12px; font-size:.94rem; line-height:1.5; }
.footer__links a,.footer__contact a{ color:rgba(255,255,255,.66); transition:color var(--t-fast); }
.footer__links a:hover,.footer__contact a:hover{ color:#fff; }
.footer__contact li{ display:flex; align-items:flex-start; gap:10px; margin-bottom:14px; font-size:.94rem; line-height:1.5; color:rgba(255,255,255,.6); }
.footer__contact-ic{ width:15px; height:15px; flex-shrink:0; color:rgba(255,255,255,.45); margin-top:3px; }
.footer__org{ padding-top:4px; font-size:.86rem; color:rgba(255,255,255,.4); }
.footer__org .footer__contact-ic{ margin-top:2px; }
.footer__bottom{ border-top:1px solid rgba(255,255,255,.08); }
.footer__bottom-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 24px; font-size:.86rem; color:rgba(255,255,255,.5); }
.footer__credit{ font-size:.78rem; color:rgba(255,255,255,.32); }
.footer__credit a{ color:rgba(255,255,255,.32); transition:color var(--t-fast); }
.footer__credit a:hover{ color:rgba(255,255,255,.65); }
.footer__legal{ display:flex; gap:24px; }
.footer__legal a{ color:rgba(255,255,255,.5); transition:color var(--t-fast); }
.footer__legal a:hover{ color:#fff; }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.6,.2,1); }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
    .reveal{ opacity:1; transform:none; transition:none; }
    html{ scroll-behavior:auto; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
    .footer__top{ grid-template-columns:1fr 1fr; gap:40px; }
    .footer__brand{ grid-column:1 / -1; }
}

@media (max-width:960px){
    .section{ padding:64px 0; }
    .nav{
        position:fixed; inset:0 0 0 auto; top:0; width:min(360px,86vw); height:100dvh;
        background:var(--navy); border-left:1px solid rgba(255,255,255,.08);
        padding:96px 26px 40px; transform:translateX(100%); transition:transform var(--t); overflow-y:auto;
        box-shadow:-20px 0 50px rgba(0,0,0,.3);
    }
    .nav.is-open{ transform:translateX(0); }
    .nav__list{ flex-direction:column; align-items:stretch; gap:2px; }
    .nav__link{ padding:14px 8px; font-size:1.05rem; border-bottom:1px solid rgba(255,255,255,.07); }
    .nav__link::after{ display:none; }
    .nav__chevron{ margin-left:auto; }
    .nav__dropdown{
        position:static; opacity:1; visibility:visible; transform:none; box-shadow:none;
        background:transparent; border:none; border-top:none !important;
        width:100%; padding:0; max-height:0; overflow:hidden; transition:max-height var(--t);
    }
    .nav__item--has-dropdown.is-open .nav__dropdown{ max-height:600px; }
    .nav__item--has-dropdown:hover .nav__dropdown{ opacity:1; }
    .nav__dd-head{ display:none; }
    .nav__dd-grid{ display:flex; flex-direction:column; gap:0; padding:0; }
    .nav__dropdown-link{ color:rgba(255,255,255,.72); padding:9px 12px; }
    .nav__dropdown-link::before{ display:none; }
    .nav__dropdown-link:hover{ background:rgba(255,255,255,.06); color:#fff; border-left-color:var(--blue); }
    .nav__dd-all{ justify-content:flex-start; padding:10px 12px; border-top:none; color:rgba(255,255,255,.5); font-size:.8rem; }
    .header__cta, .header__login{ display:none; }
    .header__burger{ display:flex; }
    .nav__item--mobile-only{ display:block; }
    .nav-backdrop{ position:fixed; inset:0; background:rgba(0,16,30,.55); opacity:0; visibility:hidden; transition:var(--t); z-index:999; }
    .nav-backdrop.is-open{ opacity:1; visibility:visible; }

    .values__grid{ grid-template-columns:repeat(2,1fr); }
    .value{ padding:24px 22px; }
    .feature__inner{ grid-template-columns:1fr; gap:40px; }
    .feature__media::after{ display:none; }
    .why-steps{ grid-template-columns:repeat(2,1fr); gap:44px 24px; }
    .why-steps::before{ display:none; }
    .why-stats{ grid-template-columns:repeat(2,1fr); row-gap:40px; }
    .why-stat:nth-child(3)::before{ display:none; }
    .courses__grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
    .course--featured{ transform:none; }
    .course--featured:hover{ transform:translateY(-4px); }
    .certs__inner{ grid-template-columns:1fr; gap:36px; }
    .cta-band__inner{ padding:48px 28px; }
    .contact__inner{ grid-template-columns:1fr; gap:44px; }
    /* Control Panel — tablet: 2 cols, hub full width row 3 */
    .cp__grid{
        grid-template-columns:1fr 1fr;
        grid-template-rows:180px 180px 300px 180px 180px;
    }
    .cp__pan[data-cidx="0"]  { grid-column:1;   grid-row:1; }
    .cp__pan[data-cidx="1"]  { grid-column:2;   grid-row:1; }
    .cp__pan[data-cidx="2"]  { grid-column:1;   grid-row:2; }
    .cp__pan[data-cidx="3"]  { grid-column:2;   grid-row:2; }
    .cp__pan[data-cidx="4"]  { grid-column:1;   grid-row:4; }
    .cp__pan[data-cidx="hub"]{ grid-column:1/3; grid-row:3; }
    .cp__pan[data-cidx="5"]  { grid-column:2;   grid-row:4; }
    .cp__pan[data-cidx="6"]  { grid-column:1;   grid-row:5; }
    .cp__pan[data-cidx="7"]  { grid-column:2;   grid-row:5; }
    .cp__hub-desc{ font-size:.8rem; margin-bottom:12px; }
}

@media (max-width:680px){
    .section{ padding:48px 0; }
    .hero__inner{ padding:72px 0 80px; }
    .hero__stats{ flex-wrap:wrap; gap:20px; }
    .hero__stat-sep{ display:none; }
    .hero__stat{ flex:0 0 calc(50% - 10px); }
    .hero__actions .btn{ flex:1 1 auto; }
    .values__grid{ grid-template-columns:1fr; }
    .value{ padding:24px 22px; }
    /* Control Panel — mobile: smaller rows */
    .cp__grid{ grid-template-rows:150px 150px 240px 150px 150px; }
    .cp__hub-desc{ display:none; }
    .cp__pan--hub .cp__pan-bd{ padding:14px 16px 18px; }
    .why-steps{ grid-template-columns:1fr; gap:38px; }
    .why-stats{ grid-template-columns:1fr; row-gap:34px; padding:40px 0; }
    .why-stat::before{ display:none; }
    .field-row{ grid-template-columns:1fr; gap:0; }
    .contact__form{ padding:26px 22px; }
    .footer__top{ grid-template-columns:1fr; gap:32px; padding:54px 24px 40px; }
    .footer__bottom-inner{ flex-direction:column; align-items:flex-start; gap:12px; }
    .footer__legal{ flex-wrap:wrap; gap:14px 20px; }
    .section-head{ margin-bottom:40px; }
    .btn{ padding:13px 22px; }
}

/* =========================================================
   TESTIMONIALS CAROUSEL
   ========================================================= */
.testimonials{ background:var(--navy); position:relative; }
.testimonials::before{
    content:""; position:absolute; inset:0; pointer-events:none;
    background:radial-gradient(60% 80% at 15% 90%, rgba(0,116,200,.18), transparent 60%);
}
.testimonials .container{ position:relative; z-index:1; }

/* Dark theme — matches .why section treatment */
.testimonials .eyebrow{ color:#5fb4ff; }
.testimonials .eyebrow::before{ background:#5fb4ff; }
.testimonials .section-title{ color:#fff; }
.testimonials .section-sub{ color:rgba(255,255,255,.68); }

/* ---- Reviews marquee ---- */
.rv-wrap{ overflow:hidden; margin-top:44px; padding-bottom:60px; }
.rv-row{ display:flex; gap:20px; width:max-content; padding:4px 0; }
.rv-row--fwd{ animation:rv-fwd 45s linear infinite; }
.rv-row--rev{ animation:rv-rev 45s linear infinite; margin-top:20px; }
@keyframes rv-fwd{ 0%{ transform:translateX(0); } 100%{ transform:translateX(-50%); } }
@keyframes rv-rev{ 0%{ transform:translateX(-50%); } 100%{ transform:translateX(0); } }
.rv-wrap:hover .rv-row{ animation-play-state:paused; }

.rv-card{
    width:320px; flex-shrink:0;
    background:#0d3b5e;
    border:1px solid rgba(255,255,255,.12);
    border-top:3px solid var(--blue);
    padding:24px 26px;
    display:flex; flex-direction:column; gap:14px;
    transition:transform .22s ease, box-shadow .22s ease;
}
.rv-card:hover{ transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.35); }
.rv-header{ display:flex; align-items:center; gap:12px; }
.rv-logo{
    width:44px; height:44px; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    font-size:13px; font-weight:800; letter-spacing:.02em; color:#fff;
}
.rv-company{ font-size:.9rem; font-weight:700; color:#fff; }
.rv-industry{ font-size:.71rem; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.07em; font-weight:600; margin-top:3px; }
.rv-stars{ font-size:14px; color:#d4913a; letter-spacing:2px; }
.rv-quote{ font-size:.84rem; line-height:1.65; color:rgba(255,255,255,.82); }
.rv-person{ font-size:.76rem; color:rgba(255,255,255,.45); border-top:1px solid rgba(255,255,255,.1); padding-top:12px; margin-top:auto; }

@media (max-width:380px){
    body{ font-size:16px; }
}

/* =========================================================
   CATEGORY PAGES
   ========================================================= */
.cat-hero{ position:relative; background:var(--navy); color:#fff; overflow:hidden; min-height:620px; display:flex; align-items:flex-end; }
.cat-hero__bg{ position:absolute; inset:0; z-index:0; }
.cat-hero__bg img{ width:100%; height:100%; object-fit:cover; }
.cat-hero__overlay{ position:absolute; inset:0; background:linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.32) 45%, rgba(0,0,0,.08) 100%); z-index:1; }
.cat-hero__inner{ position:relative; z-index:2; padding:136px 0 72px; width:100%; }
.cat-breadcrumb{ display:flex; align-items:center; gap:8px; font-size:.78rem; font-weight:600; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:.07em; margin-bottom:22px; text-shadow:0 1px 6px rgba(0,0,0,.6); }
.cat-breadcrumb a{ color:rgba(255,255,255,.7); text-decoration:none; transition:color var(--t); }
.cat-breadcrumb a:hover{ color:#fff; }
.cat-breadcrumb__sep{ opacity:.45; }
.cat-hero__eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:#5fb8ff; margin-bottom:14px; text-shadow:0 1px 8px rgba(0,0,0,.7); }
.cat-hero__eyebrow::before{ content:""; display:block; width:6px; height:6px; background:#5fb8ff; border-radius:50%; }
.cat-hero__title{ font-family:'DM Sans',sans-serif; font-size:clamp(2.2rem,5vw,3.6rem); font-weight:800; line-height:1.1; letter-spacing:-.03em; margin-bottom:20px; color:#fff; text-shadow:0 2px 18px rgba(0,0,0,.8); }
.cat-hero__title-accent{ color:#5fb8ff; }
.cat-hero__text{ font-size:1.08rem; color:rgba(255,255,255,.92); max-width:560px; margin-bottom:32px; line-height:1.65; text-shadow:0 1px 10px rgba(0,0,0,.7); }
.cat-hero__actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* Feature grid */
.cat-features{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.cat-feature{ background:#fff; border:1px solid var(--line); padding:32px 26px; transition:box-shadow var(--t),transform var(--t); }
.cat-feature:hover{ box-shadow:0 8px 32px rgba(2,32,57,.1); transform:translateY(-3px); }
.cat-feature__icon{ width:48px; height:48px; background:rgba(0,116,200,.08); display:flex; align-items:center; justify-content:center; margin-bottom:20px; color:var(--blue); }
.cat-feature__icon svg{ width:24px; height:24px; }
.cat-feature__title{ font-weight:700; font-size:.98rem; color:var(--navy); margin-bottom:8px; }
.cat-feature__text{ font-size:.86rem; color:var(--muted); line-height:1.65; }

/* Subcategory chip list (full assortment) */
.cat-subcats{ margin-top:48px; }
.cat-subcats__head{ font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); margin-bottom:18px; }
.cat-subcats__list{ display:flex; flex-wrap:wrap; gap:12px; }
.cat-subcats__chip{ display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line); padding:11px 18px; font-size:.9rem; font-weight:600; color:var(--navy); text-decoration:none; transition:border-color var(--t),color var(--t),box-shadow var(--t),transform var(--t); }
.cat-subcats__chip::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--blue); flex:none; }
.cat-subcats__chip:hover{ border-color:var(--blue); color:var(--blue); box-shadow:0 6px 20px rgba(2,32,57,.08); transform:translateY(-2px); }

/* =========================================================
   CATEGORY EXPLORER (interactive — måleinstrumenter)
   ========================================================= */
/* primary category navigation */
.cat-explorer__nav{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cat-explorer__tab{ position:relative; overflow:hidden; display:flex; flex-direction:column; align-items:flex-start; text-align:left; width:100%; padding:28px 26px 30px; background:#fff; border:1px solid var(--line); cursor:pointer; transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease, background .25s ease; }
.cat-explorer__tab::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:3px; background:linear-gradient(90deg,var(--blue),#3a9be8); transform:scaleX(0); transform-origin:left; transition:transform .3s cubic-bezier(.4,0,.2,1); }
.cat-explorer__tab:hover{ border-color:rgba(0,116,200,.42); box-shadow:0 16px 34px rgba(2,32,57,.1), 0 0 24px rgba(0,116,200,.06); transform:translateY(-4px); }
.cat-explorer__tab.is-active{ border-color:rgba(0,116,200,.5); background:linear-gradient(165deg,#ffffff 0%,#eef6fd 100%); box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 20px 40px rgba(0,116,200,.13), 0 4px 12px rgba(2,32,57,.05); }
.cat-explorer__tab.is-active::after{ transform:scaleX(1); }
.cat-explorer__tab-ic{ width:50px; height:50px; display:flex; align-items:center; justify-content:center; background:rgba(0,116,200,.08); border:1px solid rgba(0,116,200,.12); color:var(--blue); margin-bottom:20px; transition:background .25s ease, color .25s ease, transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.cat-explorer__tab-ic svg{ width:24px; height:24px; }
.cat-explorer__tab:hover .cat-explorer__tab-ic{ transform:translateY(-2px) scale(1.04); border-color:rgba(0,116,200,.3); }
.cat-explorer__tab.is-active .cat-explorer__tab-ic{ background:linear-gradient(160deg,var(--blue),var(--blue-700)); border-color:transparent; color:#fff; box-shadow:0 10px 22px rgba(0,116,200,.36); transform:scale(1.04); }
.cat-explorer__tab-name{ font-family:var(--font-heading); font-weight:800; font-size:1.08rem; color:var(--navy); letter-spacing:-.015em; margin-bottom:9px; }
.cat-explorer__tab-desc{ font-size:.85rem; color:var(--muted); line-height:1.6; margin-bottom:20px; }
.cat-explorer__tab-count{ margin-top:auto; display:inline-flex; align-items:center; gap:8px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--blue); }
.cat-explorer__tab-count::before{ content:""; width:16px; height:2px; background:currentColor; flex:none; }

/* body: chips + preview */
.cat-explorer__body{ display:grid; grid-template-columns:1fr 340px; gap:40px; margin-top:42px; align-items:start; }

/* chip panels (only active shown, fade+up on switch) */
.cat-explorer__panel{ display:none; }
.cat-explorer__panel.is-active{ display:block; animation:catFadeUp .36s cubic-bezier(.2,.7,.2,1) both; }
.cat-explorer__panel-label{ font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); margin-bottom:22px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.cat-explorer__chips{ display:flex; flex-wrap:wrap; gap:14px; }
.cat-explorer__chip{ position:relative; display:inline-flex; align-items:center; gap:11px; background:#fff; border:1px solid var(--line); padding:13px 22px; font-size:.9rem; font-weight:600; color:var(--navy); text-decoration:none; box-shadow:0 1px 2px rgba(2,32,57,.04); transition:border-color .22s ease, color .22s ease, box-shadow .22s ease, transform .22s ease; }
.cat-explorer__chip::before{ content:""; width:6px; height:6px; background:var(--blue); flex:none; transition:transform .22s ease; }
.cat-explorer__chip:hover{ border-color:var(--blue); color:var(--blue); box-shadow:0 12px 26px rgba(0,116,200,.15); transform:translateY(-3px); }
.cat-explorer__chip:hover::before{ transform:scale(1.5); }

/* product preview (updates per category) */
.cat-explorer__pcard{ display:none; }
.cat-explorer__pcard.is-active{ display:block; box-shadow:0 1px 2px rgba(2,32,57,.05), 0 24px 50px rgba(2,32,57,.1); animation:catFadeUp .36s cubic-bezier(.2,.7,.2,1) both; }
.cat-explorer__pmedia{ position:relative; display:flex; align-items:center; justify-content:center; height:224px; padding:30px; background:linear-gradient(160deg,#fbfdff 0%,#e6eef6 100%); border:1px solid var(--line); border-bottom:none; }
.cat-explorer__pmedia::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 44%, rgba(0,116,200,.12), transparent 62%); pointer-events:none; }
.cat-explorer__pmedia img{ position:relative; z-index:1; max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; transition:transform .35s ease; }
.cat-explorer__pcard:hover .cat-explorer__pmedia img{ transform:scale(1.04); }
.cat-explorer__pinfo{ background:#fff; border:1px solid var(--line); padding:24px 24px 26px; }
.cat-explorer__peyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); margin-bottom:11px; }
.cat-explorer__peyebrow::before{ content:""; width:14px; height:2px; background:currentColor; flex:none; }
.cat-explorer__pcount{ display:block; font-family:var(--font-heading); font-weight:800; font-size:1.32rem; color:var(--navy); letter-spacing:-.02em; line-height:1.25; margin-bottom:22px; }

@keyframes catFadeUp{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:translateY(0); } }

@media (max-width:900px){
    .cat-explorer__nav{ grid-template-columns:repeat(2,1fr); }
    .cat-explorer__body{ grid-template-columns:1fr; }
    .cat-explorer__preview{ max-width:380px; }
}
@media (max-width:560px){
    .cat-explorer__nav{ grid-template-columns:1fr; }
}

/* =========================================================
   SHOP LAYOUT — category sidebar + product grid
   ========================================================= */
.shop-layout{ display:grid; grid-template-columns:288px 1fr; gap:38px; align-items:start; margin-top:8px; }
.shop-main{ min-width:0; }
/* sticky until the products grid ends; capped to viewport so all rows stay inside the table */
.shop-sidebar{ position:sticky; top:124px; align-self:start; }
.shop-cats{ display:flex; flex-direction:column; max-height:calc(100vh - 150px); overflow-y:auto; background:#fff; border:1px solid var(--line); box-shadow:0 1px 2px rgba(2,32,57,.04), 0 10px 26px rgba(2,32,57,.05); }
.shop-cats__head{ position:sticky; top:0; z-index:2; margin:0; padding:14px 16px; background:var(--navy); color:#fff; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; }
.shop-cat{ border-bottom:1px solid var(--line); }
.shop-cat:last-child{ border-bottom:none; }
.shop-cat__head{ position:relative; display:flex; align-items:stretch; }
.shop-cat__link{ display:flex; align-items:center; gap:12px; flex:1 1 auto; min-width:0; padding:14px 10px 14px 16px; color:var(--navy); font-weight:700; font-size:.8rem; text-transform:uppercase; letter-spacing:.03em; line-height:1.25; text-decoration:none; transition:color var(--t-fast); }
.shop-cat__link:hover{ color:var(--blue); }
.shop-cat__ic{ flex:none; width:22px; height:22px; color:var(--blue); display:grid; place-items:center; }
.shop-cat__ic svg{ width:20px; height:20px; }
.shop-cat__name{ min-width:0; }
.shop-cat__toggle{ flex:none; width:44px; display:grid; place-items:center; color:var(--muted); background:none; border:none; border-left:1px solid var(--line); cursor:pointer; transition:color var(--t-fast), background var(--t-fast); }
.shop-cat__toggle:hover{ color:var(--blue); background:var(--bg-soft); }
.shop-cat__chev{ width:15px; height:15px; transition:transform .28s ease; }
.shop-cat.is-open .shop-cat__chev{ transform:rotate(180deg); }
/* current category */
.shop-cat.is-active{ box-shadow:inset 3px 0 0 var(--blue); }
.shop-cat.is-active > .shop-cat__head{ background:var(--bg-soft); }
.shop-cat.is-active .shop-cat__link{ color:var(--blue); }
/* animated dropdown */
.shop-cat__panel{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1); background:var(--bg-soft); }
.shop-cat.is-open .shop-cat__panel{ grid-template-rows:1fr; }
.shop-cats.is-init .shop-cat__panel{ transition:none; }
.shop-cat__panel-inner{ overflow:hidden; min-height:0; }
.shop-cat__sublink{ display:block; padding:8px 16px 8px 50px; font-size:.82rem; font-weight:500; color:var(--muted); text-decoration:none; border-top:1px solid rgba(2,32,57,.05); transition:color var(--t-fast), background var(--t-fast); }
.shop-cat__sublink:hover{ color:var(--blue); background:#fff; }
.shop-cat__panel-inner > .shop-cat__sublink:first-child{ border-top:none; padding-top:12px; }
.shop-cat__panel-inner > .shop-cat__sublink:last-child{ padding-bottom:14px; }
/* product grid inside shop layout: 2-up, 3-up on wide screens */
.shop-main .cat-products{ grid-template-columns:repeat(2,1fr); }
@media (min-width:1080px){ .shop-main .cat-products{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:900px){
    .shop-layout{ grid-template-columns:1fr; gap:26px; }
    .shop-sidebar{ position:static; max-width:440px; }
    .shop-cats{ max-height:none; overflow:visible; }
}

/* Product cards */
.cat-products{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.cat-product{ position:relative; display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:15px; overflow:hidden; box-shadow:0 1px 2px rgba(2,32,57,.05), 0 6px 18px rgba(2,32,57,.045); transition:box-shadow .3s ease, transform .3s ease, border-color .3s ease; }
.cat-product:hover{ transform:translateY(-5px); border-color:rgba(0,116,200,.45); box-shadow:0 18px 42px rgba(2,32,57,.15), 0 0 0 1px rgba(0,116,200,.16), 0 0 26px rgba(0,116,200,.13); }
/* image — larger, soft technical gradient */
.cat-product__img{ position:relative; height:248px; overflow:hidden; background:radial-gradient(120% 120% at 50% 0%, #fbfcfe 0%, #eaeef3 100%); border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:28px; }
.cat-product__img img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; mix-blend-mode:multiply; transition:transform .5s cubic-bezier(.2,.7,.2,1); }
.cat-product:hover .cat-product__img img{ transform:scale(1.06); }
.cat-product__img a{ display:flex; width:100%; height:100%; align-items:center; justify-content:center; }
.cat-product__body{ padding:20px 22px 22px; display:flex; flex-direction:column; flex:1; }
/* metadata chips */
.cat-product__chips{ display:flex; flex-wrap:wrap; align-items:center; gap:7px; margin-bottom:13px; }
.cat-product__tag{ align-self:flex-start; font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--blue); background:rgba(0,116,200,.09); padding:4px 10px; border-radius:7px; margin-bottom:13px; }
.cat-product__chips .cat-product__tag{ margin-bottom:0; }
.chip{ display:inline-flex; align-items:center; gap:6px; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:4px 10px; border-radius:7px; white-space:nowrap; }
.chip--stock{ color:var(--navy); background:rgba(0,116,200,.09); }
.chip--stock i{ width:6px; height:6px; border-radius:50%; background:var(--blue); flex:none; }
.chip--info{ color:var(--muted); background:var(--bg-soft); }
/* product name (primary) + brand (secondary, italic) */
.cat-product__name{ font-family:'DM Sans',sans-serif; font-weight:800; font-size:1.12rem; color:var(--navy); margin-bottom:3px; line-height:1.28; letter-spacing:-.01em; transition:color var(--t); }
.cat-product__name a{ color:inherit; text-decoration:none; }
.cat-product:hover .cat-product__name{ color:var(--blue); }
.cat-product__model{ font-style:italic; font-size:.84rem; font-weight:600; color:var(--muted); margin-bottom:12px; }
/* description clamped to 3 lines for equal height & fast comparison */
.cat-product__desc{ font-size:.86rem; color:var(--muted); line-height:1.6; margin-bottom:18px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.cat-product__price{ margin-bottom:16px; }
.cat-product__price-now{ font-weight:800; font-size:1.12rem; color:var(--navy); }
.cat-product__price-was{ font-size:.86rem; color:var(--muted); text-decoration:line-through; margin-left:8px; }
.cat-product__price-unit{ display:block; font-size:.72rem; color:var(--muted); margin-top:2px; }
/* CTA — smaller but prominent; stretches to make the whole card clickable */
.cat-product__cta{ margin-top:auto; display:flex; align-items:center; justify-content:center; gap:9px; background:var(--blue); color:#fff; font-size:.85rem; font-weight:700; padding:12px 18px; border-radius:10px; text-decoration:none; transition:background var(--t); }
.cat-product__cta::after{ content:""; position:absolute; inset:0; z-index:1; }
.cat-product:hover .cat-product__cta{ background:#005a9c; }
.cat-product__cta svg{ width:16px; height:16px; transition:transform var(--t); }
.cat-product:hover .cat-product__cta svg{ transform:translateX(4px); }
/* Load more */
.cat-products__more{ display:flex; justify-content:center; margin-top:44px; }
/* badge (New / Best Seller) */
.cat-product__badge{ position:absolute; top:14px; left:14px; z-index:3; pointer-events:none; background:var(--blue); color:#fff; font-size:.64rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; padding:5px 11px; border-radius:8px; box-shadow:0 6px 16px rgba(0,116,200,.32); }
.cat-product--sale{ position:relative; }

/* Responsive */
@media (max-width:960px){
    .cat-features{ grid-template-columns:repeat(2,1fr); }
    .cat-products{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
    .cat-features{ grid-template-columns:1fr; }
    .cat-products{ grid-template-columns:1fr; }
    .cat-hero{ min-height:520px; }
    .cat-hero__inner{ padding:100px 0 56px; }
}

/* =========================================================
   PRODUCT DETAIL PAGE (PDP)
   ========================================================= */
.pdp-bar{ background:var(--navy); padding:104px 0 30px; }
.pdp-bar .cat-breadcrumb{ margin-bottom:0; }
.pdp{ padding:52px 0 64px; }
.pdp__grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:flex-start; }

/* Gallery */
.pdp-gallery__main{ background:#fff; border:1px solid var(--line); aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; padding:44px; }
.pdp-gallery__main img{ max-width:100%; max-height:100%; object-fit:contain; }
.pdp-gallery__thumbs{ display:flex; gap:12px; margin-top:14px; flex-wrap:wrap; }
.pdp-gallery__thumb{ width:84px; height:84px; border:1px solid var(--line); background:#fff; display:flex; align-items:center; justify-content:center; padding:9px; cursor:pointer; transition:border-color var(--t); }
.pdp-gallery__thumb.is-active{ border-color:var(--blue); }
.pdp-gallery__thumb img{ max-width:100%; max-height:100%; object-fit:contain; }

/* Info column */
.pdp-info__eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); margin-bottom:14px; }
.pdp-info__eyebrow::before{ content:""; width:6px; height:6px; background:var(--blue); border-radius:50%; }
.pdp-info__title{ font-family:'DM Sans',sans-serif; font-size:clamp(1.8rem,3.4vw,2.5rem); font-weight:800; color:var(--navy); line-height:1.14; letter-spacing:-.02em; margin-bottom:8px; }
.pdp-info__model{ font-style:italic; font-weight:600; color:var(--blue); font-size:1.05rem; margin-bottom:20px; }
.pdp-info__lead{ color:var(--muted); line-height:1.7; margin-bottom:24px; font-size:1.02rem; }
.pdp-meta{ display:flex; flex-wrap:wrap; gap:14px 32px; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:26px; }
.pdp-meta__label{ color:var(--muted); display:block; font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:3px; }
.pdp-meta__value{ font-weight:700; color:var(--navy); font-size:.92rem; }
.pdp-info__highlights{ list-style:none; margin:0 0 30px; padding:0; display:grid; gap:12px; }
.pdp-info__highlights li{ position:relative; padding-left:30px; color:var(--navy); font-size:.94rem; line-height:1.5; }
.pdp-info__highlights li svg{ position:absolute; left:0; top:1px; width:19px; height:19px; color:var(--blue); }
.pdp-info__actions{ display:flex; flex-wrap:wrap; gap:14px; }
.pdp-info__note{ margin-top:16px; font-size:.84rem; color:var(--muted); }

/* Lower detail sections */
.pdp-detail-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:flex-start; }
.pdp-block__title{ font-family:'DM Sans',sans-serif; font-size:1.25rem; font-weight:800; color:var(--navy); margin-bottom:22px; letter-spacing:-.01em; }
.pdp-specs{ width:100%; border-collapse:collapse; }
.pdp-specs tr{ border-bottom:1px solid var(--line); }
.pdp-specs tr:first-child{ border-top:1px solid var(--line); }
.pdp-specs th{ text-align:left; padding:13px 16px 13px 0; font-weight:500; color:var(--muted); font-size:.9rem; width:55%; vertical-align:top; }
.pdp-specs td{ padding:13px 0; font-weight:700; color:var(--navy); font-size:.9rem; text-align:right; }
.pdp-included{ list-style:none; margin:0; padding:0; display:grid; gap:13px; }
.pdp-included li{ position:relative; padding-left:30px; color:var(--navy); font-size:.94rem; line-height:1.5; }
.pdp-included li svg{ position:absolute; left:0; top:1px; width:19px; height:19px; color:var(--blue); }
.pdp-docs{ display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:12px; }
.pdp-doc{ display:flex; align-items:center; gap:12px; padding:15px 18px; background:#fff; border:1px solid var(--line); color:var(--navy); font-weight:600; font-size:.88rem; text-decoration:none; transition:border-color var(--t),box-shadow var(--t),transform var(--t); }
.pdp-doc:hover{ border-color:var(--blue); box-shadow:0 6px 20px rgba(2,32,57,.08); transform:translateY(-2px); }
.pdp-doc svg{ width:20px; height:20px; color:var(--blue); flex:none; }

/* Tabs */
.pdp-tabs{ border:1px solid var(--line); background:#fff; }
.pdp-tabs__nav{ display:flex; flex-wrap:wrap; border-bottom:1px solid var(--line); }
.pdp-tab{ appearance:none; border:0; background:transparent; padding:17px 24px; font-family:inherit; font-size:.92rem; font-weight:700; color:var(--muted); cursor:pointer; transition:color var(--t),background var(--t); }
.pdp-tab:hover{ color:var(--navy); }
.pdp-tab.is-active{ background:var(--navy); color:#fff; }
.pdp-tabs__panel{ display:none; padding:40px 36px; }
.pdp-tabs__panel.is-active{ display:block; }
.pdp-tabs__panel .pdp-block__title{ font-size:1.1rem; margin-bottom:18px; }
.pdp-tabs__lead{ color:var(--muted); line-height:1.7; font-size:1rem; max-width:760px; margin-bottom:28px; }
.pdp-empty{ display:flex; flex-direction:column; align-items:center; text-align:center; padding:36px 20px; color:var(--muted); }
.pdp-empty svg{ width:40px; height:40px; color:#c7d0d9; margin-bottom:14px; }
.pdp-empty strong{ color:var(--navy); font-size:1.02rem; margin-bottom:4px; }
.pdp-docgroups{ display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:34px; }
.pdp-docgroup__title{ font-weight:800; color:var(--navy); font-size:.92rem; margin-bottom:14px; }
.pdp-docgroup__list{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.pdp-docgroup__list a{ display:inline-flex; align-items:flex-start; gap:8px; color:var(--blue); text-decoration:none; font-size:.86rem; font-weight:600; line-height:1.45; transition:color var(--t); }
.pdp-docgroup__list a:hover{ color:var(--navy); text-decoration:underline; }
.pdp-docgroup__list svg{ width:15px; height:15px; flex:none; margin-top:2px; }
.pdp-acc{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:2px 32px; }
.pdp-acc li{ position:relative; padding:12px 0 12px 26px; border-bottom:1px solid var(--line); color:var(--navy); font-size:.92rem; }
.pdp-acc li::before{ content:""; position:absolute; left:0; top:18px; width:6px; height:6px; background:var(--blue); border-radius:50%; }
.pdp-article{ display:flex; align-items:center; gap:16px; padding:20px 24px; border:1px solid var(--line); text-decoration:none; max-width:520px; transition:border-color var(--t),box-shadow var(--t),transform var(--t); }
.pdp-article:hover{ border-color:var(--blue); box-shadow:0 6px 20px rgba(2,32,57,.08); transform:translateY(-2px); }
.pdp-article__ic{ width:46px; height:46px; background:rgba(0,116,200,.08); display:flex; align-items:center; justify-content:center; color:var(--blue); flex:none; }
.pdp-article__ic svg{ width:22px; height:22px; }
.pdp-article__title{ font-weight:700; color:var(--navy); font-size:.98rem; margin-bottom:2px; }
.pdp-article__meta{ font-size:.82rem; color:var(--muted); }
/* video */
.pdp-video{ position:relative; width:100%; aspect-ratio:16/9; background:#000; max-width:860px; }
.pdp-video iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.pdp-video__actions{ margin-top:18px; display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.pdp-mute{ display:inline-flex; align-items:center; gap:9px; padding:12px 22px; background:var(--blue); color:#fff; border:0; font-family:inherit; font-weight:700; font-size:.9rem; cursor:pointer; transition:background var(--t); }
.pdp-mute:hover{ background:#005a9c; }
.pdp-mute svg{ width:18px; height:18px; flex:none; }
.pdp-mute .pdp-mute__off{ display:none; }
.pdp-mute.is-muted .pdp-mute__on{ display:none; }
.pdp-mute.is-muted .pdp-mute__off{ display:inline-block; }
.pdp-video__note{ font-size:.84rem; color:var(--muted); }

@media (max-width:900px){
    .pdp-bar{ padding:92px 0 24px; }
    .pdp{ padding:40px 0 48px; }
    .pdp__grid{ grid-template-columns:1fr; gap:32px; }
    .pdp-detail-grid{ grid-template-columns:1fr; gap:44px; }
    .pdp-tab{ padding:13px 16px; font-size:.85rem; }
    .pdp-tabs__panel{ padding:28px 20px; }
}

/* =========================================================
   HOMEPAGE — B2B E-COMMERCE ENHANCEMENTS
   ========================================================= */
/* Header "Logg inn" */
.header__login{ display:inline-flex; align-items:center; gap:8px; padding:9px 15px; color:#fff; font-weight:600; font-size:.88rem; text-decoration:none; border:1px solid rgba(255,255,255,.4); transition:background var(--t),color var(--t),border-color var(--t),box-shadow var(--t); white-space:nowrap; }
.header__login:hover{ background:#fff; color:var(--navy); border-color:#fff; box-shadow:0 8px 24px rgba(0,0,0,.18); }
.header__login svg{ width:17px; height:17px; flex:none; }

/* Hero B2B trust row */
.hero__trust{ display:flex; flex-wrap:wrap; gap:10px 26px; margin-top:28px; padding:0; }
.hero__trust li{ display:flex; align-items:center; gap:9px; color:rgba(255,255,255,.85); font-size:.88rem; font-weight:500; list-style:none; }
.hero__trust svg{ width:18px; height:18px; color:#3a9be8; flex:none; }

/* Featured products 4-up (reuses .cat-products / .cat-product) */
.cat-products.is-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:1000px){ .cat-products.is-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .cat-products.is-4{ grid-template-columns:1fr; } }

/* B2B "Slik handler du" steps */
.steps__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.step{ position:relative; background:#fff; border:1px solid var(--line); padding:36px 32px; transition:box-shadow var(--t),transform var(--t); }
.step:hover{ box-shadow:0 8px 32px rgba(2,32,57,.08); transform:translateY(-3px); }
.step:not(:last-child)::after{ content:""; position:absolute; top:50%; left:calc(100% + 12px); width:11px; height:11px; border-top:2.5px solid var(--blue); border-right:2.5px solid var(--blue); transform:translate(-50%,-50%) rotate(45deg); z-index:2; }
.step__num{ display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; background:var(--blue); color:#fff; font-family:'DM Sans',sans-serif; font-weight:800; font-size:1.2rem; margin-bottom:22px; }
.step__title{ font-weight:700; font-size:1.08rem; color:var(--navy); margin-bottom:10px; }
.step__text{ font-size:.92rem; color:var(--muted); line-height:1.65; }
@media (max-width:880px){ .steps__grid{ grid-template-columns:1fr; } .step:not(:last-child)::after{ top:calc(100% + 12px); left:50%; transform:translate(-50%,-50%) rotate(135deg); } }
/* secondary button readable on the light "Bli kunde" section */
#bli-kunde .btn--secondary,#paamelding .btn--secondary{ color:var(--navy); border-color:var(--navy); }
#bli-kunde .btn--secondary:hover,#paamelding .btn--secondary:hover{ background:var(--navy); color:#fff; border-color:var(--navy); box-shadow:0 8px 24px rgba(2,32,57,.18); }

/* mobile-only nav item (Logg inn / bli kunde) */
.nav__item--mobile-only{ display:none; }

/* =========================================================
   PRODUCT CATEGORIES — B2B uniform grid (replaces masonry)
   ========================================================= */
.catgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.catcard{ position:relative; display:flex; flex-direction:column; background:var(--navy); border:1px solid rgba(255,255,255,.10); border-radius:14px; overflow:hidden; text-decoration:none; box-shadow:0 2px 8px rgba(0,0,0,.25), 0 10px 28px rgba(0,0,0,.22); transform:translateZ(0); -webkit-backface-visibility:hidden; backface-visibility:hidden; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.catcard:hover{ transform:translate3d(0,-5px,0); border-color:rgba(0,116,200,.55); box-shadow:0 22px 48px rgba(0,0,0,.38), 0 0 30px rgba(0,116,200,.22); }
.catcard__media{ position:relative; height:172px; overflow:hidden; }
.catcard__media img{ width:100%; height:100%; object-fit:cover; -webkit-backface-visibility:hidden; backface-visibility:hidden; transition:transform .3s cubic-bezier(.2,.7,.2,1); }
.catcard:hover .catcard__media img{ transform:scale(1.06); }
.catcard__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(2,32,57,.05) 0%, rgba(2,32,57,.12) 55%, rgba(2,32,57,.65) 85%, var(--navy) 100%); }
/* clean minimal category number */
.catcard__id{ position:absolute; top:12px; left:12px; z-index:2; min-width:26px; text-align:center; font-family:'DM Sans',sans-serif; font-size:.72rem; font-weight:800; letter-spacing:.02em; color:#fff; background:rgba(1,15,26,.5); border:1px solid rgba(255,255,255,.2); padding:4px 8px; border-radius:7px; backdrop-filter:blur(5px); }
/* featured badge */
.catcard__flag{ position:absolute; top:12px; right:12px; z-index:2; display:inline-flex; align-items:center; gap:6px; font-size:.6rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:var(--blue); padding:5px 10px; border-radius:7px; box-shadow:0 4px 14px rgba(0,116,200,.45); }
.catcard__flag svg{ width:11px; height:11px; flex:none; }
.catcard__body{ position:relative; z-index:2; flex:1; display:flex; flex-direction:column; padding:20px 20px 18px; }
.catcard__title{ font-family:'DM Sans',sans-serif; font-size:1.26rem; font-weight:800; color:#fff; letter-spacing:-.015em; margin-bottom:8px; transition:transform .25s ease; }
.catcard:hover .catcard__title{ transform:translateY(-2px); }
.catcard__meta{ font-size:.8rem; font-weight:600; color:rgba(255,255,255,.68); line-height:1.5; margin-bottom:20px; }
.catcard__cta{ margin-top:auto; display:inline-flex; align-items:center; gap:9px; font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#3a9be8; transition:color .25s ease; }
.catcard__cta i{ width:6px; height:6px; background:var(--blue); flex:none; }
.catcard__cta svg{ width:15px; height:15px; transition:transform .25s ease; }
.catcard:hover .catcard__cta{ color:#fff; }
.catcard:hover .catcard__cta svg{ transform:translateX(5px); }
@media (max-width:980px){ .catgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .catgrid{ grid-template-columns:1fr; gap:14px; } }

/* =========================================================
   PRODUCT DETAIL PAGE — premium B2B redesign (4–8px radius)
   ========================================================= */
.pdp-hero{ padding:36px 0 8px; }
.pdp-hero__grid{ display:grid; grid-template-columns:minmax(0,40fr) minmax(0,60fr); gap:48px; align-items:start; }

/* ---- gallery ---- */
.pdp-gal{ display:grid; grid-template-columns:84px 1fr; grid-template-rows:auto auto; gap:14px 16px; position:sticky; top:92px; align-self:start; }
.pdp-gal__thumbs{ grid-column:1; grid-row:1; display:flex; flex-direction:column; gap:10px; }
.pdp-gal__thumb{ width:84px; height:84px; border:1px solid var(--line); border-radius:6px !important; background:#fff; padding:8px; cursor:pointer; display:grid; place-items:center; overflow:hidden; transition:border-color .2s ease, box-shadow .2s ease; }
.pdp-gal__thumb img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.pdp-gal__thumb:hover{ border-color:var(--line-strong); }
.pdp-gal__thumb.is-active{ border-color:var(--blue); box-shadow:inset 0 0 0 1px var(--blue); }
.pdp-gal__stage{ grid-column:2; grid-row:1; position:relative; border:1px solid var(--line); border-radius:8px !important; background:linear-gradient(160deg,#fff 0%,#eef3f8 100%); aspect-ratio:1/1; display:grid; place-items:center; padding:40px; overflow:hidden; }
.pdp-gal__stage img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; transition:transform .35s ease; cursor:zoom-in; }
.pdp-gal__stage.is-zoom img{ transform:scale(1.9); cursor:zoom-out; }
.pdp-gal__badge{ position:absolute; top:14px; left:14px; z-index:2; font-size:.64rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:#fff; background:var(--navy); padding:5px 10px; border-radius:4px !important; }
.pdp-gal__hint{ position:absolute; bottom:14px; right:14px; z-index:2; display:inline-flex; align-items:center; gap:6px; font-size:.7rem; font-weight:600; color:var(--muted); background:rgba(255,255,255,.92); border:1px solid var(--line); padding:6px 10px; border-radius:4px !important; pointer-events:none; }
.pdp-gal__hint svg{ width:13px; height:13px; }
.pdp-gal__tools{ grid-column:1 / -1; grid-row:2; display:flex; gap:10px; flex-wrap:wrap; }
.pdp-gal__tool{ display:inline-flex; align-items:center; gap:8px; font-size:.82rem; font-weight:600; color:var(--navy); background:#fff; border:1px solid var(--line); border-radius:6px !important; padding:10px 15px; cursor:pointer; text-decoration:none; transition:border-color .2s ease, color .2s ease, background .2s ease; }
.pdp-gal__tool svg{ width:16px; height:16px; color:var(--blue); }
.pdp-gal__tool:hover{ border-color:var(--blue); color:var(--blue); background:var(--bg-soft); }

/* fullscreen lightbox */
.pdp-lightbox{ position:fixed; inset:0; z-index:200; display:none; place-items:center; background:rgba(2,16,28,.92); padding:40px; }
.pdp-lightbox.is-open{ display:grid; }
.pdp-lightbox img{ max-width:92vw; max-height:88vh; object-fit:contain; }
.pdp-lightbox__close{ position:absolute; top:22px; right:26px; width:46px; height:46px; display:grid; place-items:center; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.3); border-radius:6px !important; color:#fff; cursor:pointer; }
.pdp-lightbox__close svg{ width:22px; height:22px; }

/* ---- buy panel (sticky) ---- */
.pdp-buy{ position:sticky; top:92px; }
.pdp-buy__brand{ display:inline-flex; align-items:center; gap:8px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); margin-bottom:14px; }
.pdp-buy__brand::before{ content:""; width:16px; height:2px; background:currentColor; }
.pdp-buy__title{ font-family:var(--font-heading); font-size:clamp(1.7rem,2.4vw,2.15rem); font-weight:800; color:var(--navy); letter-spacing:-.02em; line-height:1.14; margin-bottom:8px; }
.pdp-buy__sub{ font-size:1.02rem; font-style:italic; color:var(--blue); font-weight:600; margin-bottom:16px; }
.pdp-buy__lead{ font-size:.95rem; color:var(--muted); line-height:1.65; margin-bottom:22px; }

.pdp-idgrid{ display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--line); border-radius:6px !important; overflow:hidden; margin-bottom:20px; }
.pdp-idgrid__cell{ padding:12px 14px; border-right:1px solid var(--line); }
.pdp-idgrid__cell:last-child{ border-right:none; }
.pdp-idgrid__k{ display:block; font-size:.64rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin-bottom:4px; }
.pdp-idgrid__v{ font-size:.9rem; font-weight:700; color:var(--navy); font-variant-numeric:tabular-nums; }

.pdp-price{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:16px 18px; background:var(--bg-soft); border:1px solid var(--line); border-radius:6px !important; margin-bottom:16px; }
.pdp-price__lock{ display:flex; align-items:center; gap:13px; }
.pdp-price__lock > svg{ width:24px; height:24px; color:var(--blue); flex:none; }
.pdp-price__label{ display:block; font-family:var(--font-heading); font-weight:800; font-size:1.05rem; color:var(--navy); }
.pdp-price__hint{ display:block; font-size:.76rem; color:var(--muted); margin-top:2px; }
.pdp-price__login{ font-size:.82rem; font-weight:700; color:var(--blue); white-space:nowrap; text-decoration:none; }
.pdp-price__login:hover{ text-decoration:underline; }

.pdp-avail{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-bottom:22px; }
.pdp-avail__item{ display:flex; align-items:center; gap:9px; font-size:.85rem; font-weight:600; color:var(--navy); }
.pdp-avail__dot{ width:9px; height:9px; border-radius:50% !important; background:var(--blue); flex:none; box-shadow:0 0 0 3px rgba(0,116,200,.16); }
.pdp-avail__item svg{ width:16px; height:16px; color:var(--blue); flex:none; }

.pdp-buy__order{ display:flex; gap:12px; margin-bottom:12px; }
.pdp-qty{ display:inline-flex; align-items:stretch; border:1px solid var(--line-strong); border-radius:6px !important; overflow:hidden; flex:none; }
.pdp-qty__btn{ width:42px; background:var(--bg-soft); border:none; color:var(--navy); font-size:1.2rem; line-height:1; cursor:pointer; transition:background .2s ease, color .2s ease; }
.pdp-qty__btn:hover{ background:var(--bg-softer); color:var(--blue); }
.pdp-qty__input{ width:52px; border:none; border-left:1px solid var(--line); border-right:1px solid var(--line); text-align:center; font-weight:700; color:var(--navy); font-size:1rem; -moz-appearance:textfield; }
.pdp-qty__input::-webkit-outer-spin-button,.pdp-qty__input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.pdp-buy__order .btn{ flex:1; }
.pdp-buy__cta2{ width:100%; margin-bottom:18px; }
.pdp-buy__cta2.btn--secondary{ background:#fff; color:var(--navy); border-color:var(--navy); }
.pdp-buy__cta2.btn--secondary:hover{ background:var(--navy); color:#fff; border-color:var(--navy); box-shadow:0 8px 24px rgba(2,32,57,.18); }

.pdp-buy__sub-actions{ display:flex; gap:8px; padding-top:18px; border-top:1px solid var(--line); margin-bottom:20px; }
.pdp-iconbtn{ flex:1; display:inline-flex; flex-direction:column; align-items:center; gap:7px; padding:12px 6px; background:#fff; border:1px solid var(--line); border-radius:6px !important; font-size:.72rem; font-weight:600; color:var(--navy); cursor:pointer; text-decoration:none; text-align:center; transition:border-color .2s ease, color .2s ease, background .2s ease; }
.pdp-iconbtn svg{ width:18px; height:18px; color:var(--blue); }
.pdp-iconbtn:hover{ border-color:var(--blue); color:var(--blue); background:var(--bg-soft); }

.pdp-buy__trust{ display:grid; grid-template-columns:1fr 1fr; gap:11px 16px; }
.pdp-buy__trust li{ display:flex; align-items:center; gap:9px; font-size:.8rem; color:var(--navy); font-weight:500; }
.pdp-buy__trust svg{ width:16px; height:16px; color:var(--blue); flex:none; }

/* ---- feature cards ---- */
.pdp-feats{ padding:30px 0 6px; }
.pdp-feats__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.pdp-feat{ display:flex; gap:14px; align-items:flex-start; padding:20px; background:#fff; border:1px solid var(--line); border-radius:6px !important; }
.pdp-feat__ic{ flex:none; width:42px; height:42px; display:grid; place-items:center; background:var(--bg-soft); border:1px solid var(--line); border-radius:6px !important; color:var(--blue); }
.pdp-feat__ic svg{ width:20px; height:20px; }
.pdp-feat__txt strong{ display:block; font-size:.92rem; color:var(--navy); margin-bottom:4px; font-weight:700; }
.pdp-feat__txt span{ font-size:.82rem; color:var(--muted); line-height:1.55; }

/* ---- trust indicators row ---- */
.pdp-trust{ display:grid; grid-template-columns:repeat(6,1fr); border:1px solid var(--line); border-radius:6px !important; overflow:hidden; background:#fff; margin-top:18px; }
.pdp-trust__item{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:9px; padding:20px 12px; border-right:1px solid var(--line); }
.pdp-trust__item:last-child{ border-right:none; }
.pdp-trust__item svg{ width:24px; height:24px; color:var(--blue); }
.pdp-trust__item span{ font-size:.74rem; font-weight:600; color:var(--navy); line-height:1.35; }

/* ---- sticky tab nav + panels ---- */
.pdp-tabwrap{ background:#fff; border-top:1px solid var(--line); }
.pdp-tabnav{ position:sticky; top:70px; z-index:30; display:flex; gap:2px; background:#fff; border-bottom:1px solid var(--line); overflow-x:auto; scrollbar-width:none; }
.pdp-tabnav::-webkit-scrollbar{ display:none; }
.pdp-tab2{ flex:none; padding:17px 20px; background:none; border:none; border-bottom:2px solid transparent; font-size:.9rem; font-weight:700; color:var(--muted); cursor:pointer; white-space:nowrap; transition:color .2s ease, border-color .2s ease; }
.pdp-tab2:hover{ color:var(--navy); }
.pdp-tab2.is-active{ color:var(--blue); border-bottom-color:var(--blue); }
.pdp-panels{ padding:40px 0 8px; }
.pdp-panel{ display:none; }
.pdp-panel.is-active{ display:block; animation:catFadeUp .3s ease both; }
.pdp-panel__head{ font-family:var(--font-heading); font-size:1.35rem; font-weight:800; color:var(--navy); margin-bottom:22px; letter-spacing:-.01em; }
.pdp-panel__head + .pdp-panel__head{ margin-top:36px; }
.pdp-twocol{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }

/* document cards */
.pdp-docs2{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.pdp-doccard{ display:flex; align-items:center; gap:15px; padding:15px 16px; background:#fff; border:1px solid var(--line); border-radius:6px !important; text-decoration:none; transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.pdp-doccard:hover{ border-color:var(--blue); box-shadow:0 8px 20px rgba(2,32,57,.07); transform:translateY(-2px); }
.pdp-doccard__ic{ flex:none; width:42px; height:50px; display:grid; place-items:end center; padding-bottom:7px; background:var(--bg-soft); border:1px solid var(--line); border-radius:4px !important; color:#fff; font-size:.54rem; font-weight:800; letter-spacing:.04em; position:relative; }
.pdp-doccard__ic::before{ content:""; position:absolute; top:0; left:0; right:0; height:18px; background:repeating-linear-gradient(180deg,transparent,transparent 4px,rgba(2,32,57,.06) 4px,rgba(2,32,57,.06) 5px); }
.pdp-doccard__ic span{ background:var(--blue); padding:2px 5px; border-radius:2px !important; }
.pdp-doccard__body{ min-width:0; flex:1; }
.pdp-doccard__name{ display:block; font-size:.86rem; font-weight:600; color:var(--navy); word-break:break-word; line-height:1.4; }
.pdp-doccard__meta{ display:block; font-size:.74rem; color:var(--muted); margin-top:3px; }
.pdp-doccard__dl{ flex:none; color:var(--blue); }
.pdp-doccard__dl svg{ width:18px; height:18px; }
.pdp-docgroup2{ margin-bottom:26px; }
.pdp-docgroup2:last-child{ margin-bottom:0; }
.pdp-docgroup2__title{ font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-bottom:12px; }

/* accessory cards */
.pdp-acc2{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px 24px; }
.pdp-acc2 li{ display:flex; align-items:flex-start; gap:11px; padding:11px 0; border-bottom:1px solid var(--line); font-size:.88rem; color:var(--navy); font-weight:500; }
.pdp-acc2 li svg{ width:16px; height:16px; color:var(--blue); flex:none; margin-top:2px; }

/* calibration */
.pdp-cal{ display:grid; grid-template-columns:1.2fr 1fr; gap:32px; align-items:start; }
.pdp-cal__card{ padding:24px; background:var(--bg-soft); border:1px solid var(--line); border-radius:6px !important; }
.pdp-cal__card svg{ width:30px; height:30px; color:var(--blue); margin-bottom:14px; }
.pdp-cal__card h4{ font-size:1rem; color:var(--navy); margin-bottom:8px; }
.pdp-cal__card p{ font-size:.88rem; color:var(--muted); line-height:1.6; }

/* faq (reuse simple) */
.pdp-faq__item{ border-bottom:1px solid var(--line); padding:18px 0; }
.pdp-faq__item:first-child{ padding-top:0; }
.pdp-faq__q{ font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; }
.pdp-faq__a{ font-size:.9rem; color:var(--muted); line-height:1.7; max-width:70ch; }

/* ---- related sections ---- */
.pdp-sec{ padding:44px 0; border-top:1px solid var(--line); }
.pdp-sec--soft{ background:var(--bg-soft); }
.pdp-secthead{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:24px; }
.pdp-secthead h2{ font-family:var(--font-heading); font-size:1.5rem; font-weight:800; color:var(--navy); letter-spacing:-.015em; }
.pdp-secthead p{ font-size:.9rem; color:var(--muted); margin-top:4px; }
.pdp-secthead a{ font-size:.84rem; font-weight:700; color:var(--blue); white-space:nowrap; text-decoration:none; }
.pdp-prodrow{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.pdp-prod{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:6px !important; overflow:hidden; text-decoration:none; transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.pdp-prod:hover{ border-color:var(--blue); box-shadow:0 12px 26px rgba(2,32,57,.09); transform:translateY(-3px); }
.pdp-prod__img{ aspect-ratio:4/3; display:grid; place-items:center; padding:22px; background:linear-gradient(160deg,#fff 0%,#eef3f8 100%); border-bottom:1px solid var(--line); }
.pdp-prod__img img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.pdp-prod__body{ padding:15px 16px 16px; display:flex; flex-direction:column; flex:1; }
.pdp-prod__tag{ font-size:.64rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--blue); margin-bottom:7px; }
.pdp-prod__name{ font-size:.9rem; font-weight:700; color:var(--navy); line-height:1.35; margin-bottom:5px; }
.pdp-prod__model{ font-size:.78rem; color:var(--muted); font-style:italic; margin-bottom:13px; }
.pdp-prod__cta{ margin-top:auto; font-size:.8rem; font-weight:700; color:var(--blue); display:inline-flex; align-items:center; gap:7px; }
.pdp-prod__cta svg{ width:14px; height:14px; transition:transform .2s ease; }
.pdp-prod:hover .pdp-prod__cta svg{ transform:translateX(4px); }

/* frequently bought together */
.pdp-fbt{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; padding:26px; background:#fff; border:1px solid var(--line); border-radius:6px !important; }
.pdp-fbt__item{ width:128px; text-align:center; }
.pdp-fbt__item img{ height:96px; max-width:100%; object-fit:contain; mix-blend-mode:multiply; margin:0 auto 10px; display:block; }
.pdp-fbt__item span{ font-size:.78rem; font-weight:600; color:var(--navy); line-height:1.35; display:block; }
.pdp-fbt__plus{ font-size:1.6rem; color:var(--line-strong); font-weight:300; padding:0 4px; }
.pdp-fbt__sum{ margin-left:auto; padding-left:26px; border-left:1px solid var(--line); align-self:stretch; display:flex; flex-direction:column; justify-content:center; gap:12px; min-width:200px; }
.pdp-fbt__sum-label{ font-size:.8rem; color:var(--muted); }
.pdp-fbt__sum-label strong{ display:block; font-family:var(--font-heading); font-size:1.05rem; color:var(--navy); margin-top:2px; }

/* ---- PDP responsive ---- */
@media (max-width:980px){
    .pdp-hero__grid{ grid-template-columns:1fr; gap:32px; }
    .pdp-buy{ position:static; }
    .pdp-gal{ position:static; }
    .pdp-feats__grid{ grid-template-columns:repeat(2,1fr); }
    .pdp-trust{ grid-template-columns:repeat(3,1fr); }
    .pdp-trust__item:nth-child(3){ border-right:none; }
    .pdp-prodrow{ grid-template-columns:repeat(2,1fr); }
    .pdp-twocol,.pdp-cal{ grid-template-columns:1fr; gap:28px; }
    .pdp-docs2,.pdp-acc2{ grid-template-columns:1fr; }
    .pdp-fbt__sum{ margin-left:0; padding-left:0; border-left:none; border-top:1px solid var(--line); padding-top:18px; width:100%; }
}
@media (max-width:560px){
    .pdp-gal{ grid-template-columns:1fr; }
    .pdp-gal__thumbs{ grid-column:1; grid-row:2; flex-direction:row; flex-wrap:wrap; }
    .pdp-gal__stage{ grid-column:1; grid-row:1; }
    .pdp-gal__tools{ grid-row:3; }
    .pdp-feats__grid{ grid-template-columns:1fr; }
    .pdp-trust{ grid-template-columns:repeat(2,1fr); }
    .pdp-trust__item{ border-right:1px solid var(--line); }
    .pdp-trust__item:nth-child(2n){ border-right:none; }
    .pdp-prodrow{ grid-template-columns:1fr 1fr; gap:12px; }
    .pdp-buy__sub-actions{ flex-wrap:wrap; }
    .pdp-idgrid{ grid-template-columns:1fr; }
    .pdp-idgrid__cell{ border-right:none; border-bottom:1px solid var(--line); }
    .pdp-idgrid__cell:last-child{ border-bottom:none; }
}

/* =========================================================
   BEST SELLERS CAROUSEL (category pages)
   ========================================================= */
.bestsellers{ background:var(--bg-soft); border-top:1px solid var(--line); }
.bs-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:30px; }
.bs-head .section-title{ margin:0 0 8px; }
.bs-head .section-sub{ margin:0; }
.bs-nav{ display:flex; gap:10px; flex:none; }
.bs-arrow{ width:46px; height:46px; display:grid; place-items:center; background:#fff; border:1px solid var(--line); color:var(--navy); cursor:pointer; transition:border-color .2s ease, color .2s ease, box-shadow .2s ease, transform .15s ease; }
.bs-arrow svg{ width:20px; height:20px; }
.bs-arrow:hover{ border-color:var(--blue); color:var(--blue); box-shadow:0 8px 20px rgba(0,116,200,.14); }
.bs-arrow:active{ transform:translateY(1px); }

.bs-carousel{ position:relative; }
.bs-track{ display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding:6px 2px 10px; margin:0 -2px; scrollbar-width:none; -ms-overflow-style:none; cursor:grab; }
.bs-track::-webkit-scrollbar{ display:none; }
.bs-track.is-grabbing{ cursor:grabbing; scroll-behavior:auto; scroll-snap-type:none; }
.bs-card{ flex:0 0 270px; scroll-snap-align:start; opacity:0; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.bestsellers.is-visible .bs-card{ animation:bsFade .55s ease both; }
.bestsellers.is-visible .bs-card:nth-child(1){ animation-delay:.04s; }
.bestsellers.is-visible .bs-card:nth-child(2){ animation-delay:.10s; }
.bestsellers.is-visible .bs-card:nth-child(3){ animation-delay:.16s; }
.bestsellers.is-visible .bs-card:nth-child(4){ animation-delay:.22s; }
.bestsellers.is-visible .bs-card:nth-child(5){ animation-delay:.28s; }
.bestsellers.is-visible .bs-card:nth-child(6){ animation-delay:.34s; }
.bestsellers.is-visible .bs-card:nth-child(7){ animation-delay:.40s; }
.bestsellers.is-visible .bs-card:nth-child(8){ animation-delay:.46s; }
@keyframes bsFade{ from{ opacity:0; } to{ opacity:1; } }
/* enhanced hover micro-interactions */
.bs-card:hover{ transform:translateY(-5px); border-color:rgba(0,116,200,.5); box-shadow:0 16px 34px rgba(2,32,57,.12), 0 0 22px rgba(0,116,200,.1); }
.bs-card .cat-product__img{ overflow:hidden; }
.bs-card .cat-product__img img{ transition:transform .35s ease; }
.bs-card:hover .cat-product__img img{ transform:scale(1.05); }
.bs-card .cat-product__cta svg{ transition:transform .22s ease; }
.bs-card:hover .cat-product__cta svg{ transform:translateX(4px); }
/* best seller badge */
.bs-badge{ position:absolute; top:12px; left:12px; z-index:3; display:inline-flex; align-items:center; gap:6px; font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:#fff; background:var(--blue); padding:5px 10px; box-shadow:0 6px 16px rgba(0,116,200,.32); pointer-events:none; }
.bs-badge svg{ width:12px; height:12px; }
/* progress indicator */
.bs-progress{ position:relative; height:3px; background:var(--line); margin-top:26px; overflow:hidden; }
.bs-progress__bar{ position:absolute; top:0; left:0; height:100%; width:30%; background:var(--blue); transition:left .12s linear, width .12s linear; }

@media (prefers-reduced-motion:reduce){
    .bs-track{ scroll-behavior:auto; }
    .bestsellers.is-visible .bs-card{ animation:none; opacity:1; }
}
@media (max-width:980px){ .bs-card{ flex:0 0 248px; } }
@media (max-width:560px){
    .bs-head{ flex-direction:column; align-items:flex-start; }
    .bs-card{ flex:0 0 80%; }
}

/* =========================================================
   BLOG / ARTICLES  (blog.html · article.html)
   ========================================================= */
.blog-filter{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 auto 48px; max-width:940px; }
.blog-filter__chip{ font-family:var(--font); font-size:.85rem; font-weight:600; color:var(--navy); background:#fff; border:1px solid var(--line-strong); padding:9px 18px; transition:color var(--t-fast), border-color var(--t-fast), background var(--t-fast); }
.blog-filter__chip:hover{ border-color:var(--blue); color:var(--blue); }
.blog-filter__chip.is-active{ background:var(--navy); border-color:var(--navy); color:#fff; }

.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card{ display:flex; flex-direction:column; height:100%; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.blog-card:hover{ transform:translateY(-5px); border-color:rgba(0,116,200,.42); box-shadow:0 18px 42px rgba(2,32,57,.14), 0 0 24px rgba(0,116,200,.1); }
.blog-card__media{ position:relative; height:198px; overflow:hidden; background:var(--navy); }
.blog-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.2,.7,.2,1); }
.blog-card:hover .blog-card__media img{ transform:scale(1.06); }
.blog-card__cat{ position:absolute; top:14px; left:14px; z-index:2; font-size:.65rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:#fff; background:var(--blue); padding:5px 11px; }
.blog-card__body{ display:flex; flex-direction:column; flex:1; padding:24px 24px 26px; }
.blog-card__date{ font-size:.76rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); margin-bottom:11px; }
.blog-card__title{ font-family:var(--font-heading); font-size:1.16rem; line-height:1.32; color:var(--navy); margin-bottom:12px; }
.blog-card__excerpt{ font-size:.95rem; color:var(--muted); line-height:1.62; margin-bottom:20px; flex:1; }
.blog-card__more{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:.9rem; color:var(--blue); margin-top:auto; }
.blog-card__more svg{ width:16px; height:16px; transition:transform .22s ease; }
.blog-card:hover .blog-card__more svg{ transform:translateX(4px); }
.blog-card.is-hidden{ display:none; }
.blog-empty{ grid-column:1/-1; text-align:center; color:var(--muted); padding:48px 0; }

/* ---- Single article ---- */
.article-meta{ display:inline-flex; flex-wrap:wrap; align-items:center; gap:14px; margin-top:20px; }
.article-meta__cat{ font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:#fff; background:var(--blue); padding:6px 13px; }
.article-meta__date{ font-size:.92rem; font-weight:600; color:rgba(255,255,255,.85); }
.article-body{ max-width:820px; margin:0 auto; }
.article-body > * + *{ margin-top:22px; }
.article-body__lead{ font-size:1.24rem; line-height:1.7; color:var(--navy); font-weight:500; }
.article-body p{ color:var(--ink); font-size:1.07rem; line-height:1.78; }
.article-body h2{ font-family:var(--font-heading); font-size:1.5rem; color:var(--navy); margin-top:46px; }
.article-body h3{ font-family:var(--font-heading); font-size:1.18rem; color:var(--navy); margin-top:34px; }
.article-body strong{ color:var(--navy); font-weight:700; }
.article-body ul{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.article-body ul li{ position:relative; padding-left:28px; color:var(--ink); line-height:1.7; }
.article-body ul li::before{ content:""; position:absolute; left:0; top:10px; width:9px; height:9px; background:var(--blue); }
.article-back{ display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:.92rem; color:var(--blue); margin-bottom:30px; }
.article-back svg{ width:17px; height:17px; }
.article-share{ margin-top:46px; padding-top:26px; border-top:1px solid var(--line); display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.article-share__label{ font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); }
.article-share a{ width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--line-strong); color:var(--navy); transition:color var(--t-fast), border-color var(--t-fast); }
.article-share a:hover{ color:var(--blue); border-color:var(--blue); }
.article-share a svg{ width:18px; height:18px; }

/* =========================================================
   LEGAL PAGES (personvern · salgs-og-leveringsbetingelser)
   ========================================================= */
.legal__inner{ display:grid; grid-template-columns:262px 1fr; gap:56px; align-items:start; max-width:1100px; margin:0 auto; }
.legal__toc{ position:sticky; top:122px; }
.legal__toc-title{ font-size:.74rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.legal__toc ol{ list-style:none; display:flex; flex-direction:column; }
.legal__toc a{ display:block; font-size:.91rem; color:var(--muted); padding:9px 0; border-bottom:1px solid var(--line); transition:color var(--t-fast); }
.legal__toc a:hover{ color:var(--blue); }
.legal__body{ max-width:780px; }
.legal__updated{ display:inline-block; font-size:.82rem; font-weight:600; color:var(--muted); background:var(--bg-soft); border:1px solid var(--line); padding:8px 15px; margin-bottom:28px; }
.legal__lead{ font-size:1.12rem; line-height:1.75; color:var(--navy); }
.legal__section{ padding-top:34px; margin-top:34px; border-top:1px solid var(--line); }
.legal__section:first-of-type{ border-top:none; margin-top:24px; }
.legal__section h2{ font-family:var(--font-heading); font-size:1.32rem; color:var(--navy); margin-bottom:14px; display:flex; gap:12px; align-items:baseline; }
.legal__num{ color:var(--blue); font-weight:800; }
.legal__section p{ color:var(--ink); line-height:1.76; margin-bottom:14px; }
.legal__section p:last-child{ margin-bottom:0; }
.legal__section ul{ list-style:none; display:flex; flex-direction:column; gap:10px; margin:4px 0 16px; }
.legal__section ul li{ position:relative; padding-left:26px; line-height:1.66; color:var(--ink); }
.legal__section ul li::before{ content:""; position:absolute; left:0; top:9px; width:7px; height:7px; background:var(--blue); }
.legal__section strong{ color:var(--navy); }
.legal__contact{ margin-top:40px; background:var(--bg-soft); border:1px solid var(--line); padding:26px 28px; }
.legal__contact h3{ font-family:var(--font-heading); font-size:1.08rem; color:var(--navy); margin-bottom:12px; }
.legal__contact p{ color:var(--muted); line-height:1.7; margin:0; }
.legal__contact a{ color:var(--blue); font-weight:600; }

/* ---- Blog / legal responsive ---- */
@media (max-width:980px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:900px){
    .legal__inner{ grid-template-columns:1fr; gap:32px; }
    .legal__toc{ position:static; }
}
@media (max-width:680px){
    .blog-grid{ grid-template-columns:1fr; }
    .article-body p{ font-size:1.04rem; }
    .article-body__lead{ font-size:1.14rem; }
}

/* ---- Footer certification strip ---- */
.footer__certs{ border-top:1px solid rgba(255,255,255,.10); padding:28px 0 4px; }
.footer__certs-inner{ display:flex; flex-direction:column; align-items:center; gap:18px; text-align:center; }
.footer__certs-label{ flex:none; font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.48); }
.footer__certs-row{ display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }
.footer__cert{ display:inline-flex; align-items:center; justify-content:center; background:#fff; padding:12px 19px; height:72px; box-shadow:0 6px 18px rgba(0,0,0,.18); }
.footer__cert img{ max-height:46px; width:auto; }
@media (max-width:640px){
    .footer__certs-inner{ gap:16px; }
    .footer__cert{ height:62px; padding:10px 14px; }
    .footer__cert img{ max-height:38px; }
}

/* =========================================================
   CART & CHECKOUT  (handlekurv.html Â· kasse.html)
   ========================================================= */
/* header cart icon + badge */
.header__cart{ position:relative; display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; color:#fff; transition:color .2s ease; }
.header__cart svg{ width:23px; height:23px; }
.header__cart:hover{ color:#5fb4ff; }
.header__cart-count{ position:absolute; top:0; right:-2px; min-width:18px; height:18px; padding:0 4px; background:var(--blue); color:#fff; border-radius:50% !important; font-size:.66rem; font-weight:800; display:grid; place-items:center; line-height:1; box-shadow:0 2px 6px rgba(0,0,0,.3); }
.header__cart-count[hidden]{ display:none; }
.header__cart.is-bump{ animation:cartBump .4s ease; }
@keyframes cartBump{ 0%,100%{ transform:none; } 30%{ transform:scale(1.18); } }

/* dark page head + step indicator (keeps the white-text fixed header legible) */
.co-head{ background:var(--navy); color:#fff; padding:104px 0 0; }
.co-head__inner{ padding-bottom:24px; }
.co-head .cat-breadcrumb{ margin-bottom:14px; }
.co-head__title{ color:#fff; font-family:var(--font-heading); font-size:clamp(1.8rem,3.4vw,2.5rem); line-height:1.1; margin:0; }
.co-head__sub{ color:rgba(255,255,255,.66); margin-top:10px; font-size:1.02rem; }
.co-steps{ display:flex; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,.12); }
.co-step{ display:flex; align-items:center; gap:12px; padding:16px 0; margin-right:38px; color:rgba(255,255,255,.45); font-weight:600; font-size:.96rem; }
.co-step__num{ width:28px; height:28px; border-radius:50% !important; border:1.5px solid rgba(255,255,255,.3); display:grid; place-items:center; font-size:.84rem; flex:none; }
.co-step__num svg{ width:15px; height:15px; }
.co-step.is-active{ color:#fff; }
.co-step.is-active .co-step__num{ background:var(--blue); border-color:var(--blue); color:#fff; }
.co-step.is-done{ color:rgba(255,255,255,.82); }
.co-step.is-done .co-step__num{ background:var(--blue); border-color:var(--blue); color:#fff; }

/* cart grid */
.cart{ display:grid; grid-template-columns:1fr 360px; gap:34px; align-items:start; }
.cart__labels{ display:grid; grid-template-columns:1fr 130px 130px 40px; grid-template-areas:"prod qty price remove"; gap:16px; padding:0 0 14px; border-bottom:2px solid var(--line); font-size:.72rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.cart__labels .lq{ grid-area:qty; text-align:center; }
.cart__labels .lp{ grid-area:price; text-align:center; }
.cart-item{ display:grid; grid-template-columns:1fr 130px 130px 40px; grid-template-areas:"prod qty price remove"; gap:16px; align-items:center; padding:20px 0; border-bottom:1px solid var(--line); }
.cart-item__prod{ grid-area:prod; display:flex; gap:16px; align-items:center; min-width:0; }
.cart-item__img{ width:80px; height:80px; flex:none; background:#fff; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:8px; }
.cart-item__img img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.cart-item__name{ font-family:var(--font-heading); font-size:1.02rem; color:var(--navy); line-height:1.3; }
.cart-item__name a:hover{ color:var(--blue); }
.cart-item__model{ font-style:italic; color:var(--muted); font-size:.9rem; margin-top:2px; }
.cart-item__sku{ font-size:.78rem; color:var(--muted); margin-top:4px; }
.cart-item__qty{ grid-area:qty; justify-self:center; }
.cart-item__price{ grid-area:price; justify-self:center; text-align:center; }
.cart-item__line{ font-weight:800; color:var(--navy); }
.cart-item__unit{ display:block; font-size:.78rem; color:var(--muted); font-weight:500; margin-top:3px; }
.cart-item__remove{ grid-area:remove; justify-self:center; width:34px; height:34px; display:grid; place-items:center; color:var(--muted); border:1px solid var(--line); background:#fff; transition:color .2s, border-color .2s; }
.cart-item__remove:hover{ color:#c0392b; border-color:#c0392b; }
.cart-item__remove svg{ width:17px; height:17px; }
.cart__continue{ display:inline-flex; align-items:center; gap:9px; margin-top:26px; font-weight:700; color:var(--blue); }
.cart__continue svg{ width:18px; height:18px; }

/* empty state */
.cart-empty{ text-align:center; padding:46px 20px 60px; max-width:520px; margin:0 auto; }
.cart-empty__ic{ width:84px; height:84px; margin:0 auto 22px; display:grid; place-items:center; background:var(--bg-soft); color:var(--blue); }
.cart-empty__ic svg{ width:40px; height:40px; }
.cart-empty h2{ font-family:var(--font-heading); color:var(--navy); margin-bottom:10px; }
.cart-empty p{ color:var(--muted); margin-bottom:26px; }

/* order summary (shared cart + checkout) */
.co-summary{ background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); padding:26px 24px; position:sticky; top:96px; }
.co-summary__title{ font-family:var(--font-heading); font-size:1.18rem; color:var(--navy); margin-bottom:18px; padding-bottom:16px; border-bottom:1px solid var(--line); }
.co-summary__items{ display:grid; gap:14px; margin-bottom:18px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.co-li{ display:grid; grid-template-columns:48px 1fr auto; gap:12px; align-items:center; }
.co-li__img{ width:48px; height:48px; flex:none; background:#fff; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:5px; }
.co-li__img img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.co-li__name{ font-size:.88rem; color:var(--navy); font-weight:600; line-height:1.3; }
.co-li__qty{ font-size:.78rem; color:var(--muted); margin-top:2px; }
.co-li__price{ font-weight:700; color:var(--navy); font-size:.9rem; white-space:nowrap; }
.co-summary__row{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; margin-bottom:12px; font-size:.98rem; color:var(--ink); }
.co-summary__row .v{ font-weight:600; color:var(--navy); }
.co-summary__row--free .v{ color:var(--blue); }
.co-summary__total{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; margin-top:16px; padding-top:16px; border-top:2px solid var(--line); }
.co-summary__total .lbl{ font-family:var(--font-heading); font-size:1.08rem; color:var(--navy); font-weight:800; }
.co-summary__total .val{ font-family:var(--font-heading); font-size:1.5rem; color:var(--navy); font-weight:800; white-space:nowrap; }
.co-summary__vatnote{ font-size:.8rem; color:var(--muted); text-align:right; margin-top:4px; }
.co-summary__cta{ margin-top:22px; }
.co-summary__alt{ display:block; text-align:center; margin-top:14px; font-weight:600; color:var(--blue); font-size:.95rem; }
.co-summary__trust{ margin-top:22px; padding-top:20px; border-top:1px solid var(--line); display:grid; gap:12px; }
.co-summary__trust li{ display:flex; align-items:center; gap:11px; font-size:.88rem; color:var(--muted); }
.co-summary__trust svg{ width:19px; height:19px; color:var(--blue); flex:none; }

/* checkout form */
.checkout{ display:grid; grid-template-columns:1fr 360px; gap:34px; align-items:start; }
.checkout__aside{ position:sticky; top:96px; }
.checkout .co-summary{ position:static; }
.co-postsummary{ margin-top:18px; }
.co-postsummary .btn{ margin-top:14px; }
.co-card{ background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); padding:26px 26px 8px; margin-bottom:22px; }
.co-card__title{ display:flex; align-items:center; gap:13px; font-family:var(--font-heading); font-size:1.12rem; color:var(--navy); margin-bottom:20px; }
.co-card__num{ width:28px; height:28px; background:var(--navy); color:#fff; display:grid; place-items:center; font-size:.9rem; font-weight:800; flex:none; }
.co-pay{ display:flex; flex-direction:column; gap:12px; margin-bottom:18px; }
.co-pay__opt{ display:flex; gap:14px; align-items:flex-start; padding:16px 18px; border:1px solid var(--line-strong); cursor:pointer; transition:border-color .2s, background .2s; }
.co-pay__opt:hover{ border-color:var(--blue); }
.co-pay__opt input{ margin-top:3px; accent-color:var(--blue); flex:none; }
.co-pay__opt.is-sel{ border-color:var(--blue); background:#f3f9ff; }
.co-pay__opt h4{ font-size:.98rem; color:var(--navy); margin-bottom:3px; }
.co-pay__opt p{ font-size:.86rem; color:var(--muted); margin:0; }
.co-check{ display:flex; gap:12px; align-items:flex-start; margin:4px 0 18px; font-size:.92rem; color:var(--ink); line-height:1.5; }
.co-check input{ margin-top:3px; accent-color:var(--blue); flex:none; }
.co-check a{ color:var(--blue); font-weight:600; }

/* confirmation */
.co-confirm{ max-width:680px; margin:0 auto; text-align:center; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); padding:54px 40px; }
.co-confirm__ic{ width:88px; height:88px; margin:0 auto 24px; display:grid; place-items:center; background:#eafaf1; color:#1e9e5a; border-radius:50% !important; }
.co-confirm__ic svg{ width:46px; height:46px; }
.co-confirm h1{ font-family:var(--font-heading); color:var(--navy); margin-bottom:12px; }
.co-confirm p{ color:var(--muted); margin-bottom:8px; }
.co-confirm__order{ display:inline-block; margin:18px 0 26px; padding:12px 22px; background:var(--bg-soft); border:1px solid var(--line); font-weight:700; color:var(--navy); letter-spacing:.04em; }
.co-confirm__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:8px; }

@media (max-width:980px){
    .cart, .checkout{ grid-template-columns:1fr; }
    .co-summary{ position:static; }
}
@media (max-width:640px){
    .cart__labels{ display:none; }
    .cart-item{ grid-template-columns:1fr auto; grid-template-areas:"prod remove" "qty price"; row-gap:14px; }
    .cart-item__remove{ align-self:start; }
    .cart-item__qty{ justify-self:start; }
    .cart-item__price{ justify-self:end; text-align:right; }
}

/* =========================================================
   BÃ†REKRAFT  (baerekraft.html)
   ========================================================= */
.bk-certs{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.bk-cert{ display:flex; flex-direction:column; align-items:center; text-align:center; background:#fff; border:1px solid var(--line); padding:28px 22px; box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.bk-cert:hover{ transform:translateY(-4px); border-color:rgba(0,116,200,.4); box-shadow:0 16px 36px rgba(2,32,57,.12), 0 0 22px rgba(0,116,200,.1); }
.bk-cert__logo{ height:78px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.bk-cert__logo img{ max-height:70px; max-width:100%; object-fit:contain; }
.bk-cert__name{ font-family:var(--font-heading); font-size:1.04rem; color:var(--navy); margin-bottom:9px; }
.bk-cert__desc{ font-size:.9rem; color:var(--muted); line-height:1.6; }

.bk-docs{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.bk-doc{ display:flex; gap:16px; align-items:flex-start; background:#fff; border:1px solid var(--line); padding:24px; box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.bk-doc:hover{ transform:translateY(-4px); border-color:rgba(0,116,200,.4); box-shadow:0 16px 36px rgba(2,32,57,.12); }
.bk-doc__ic{ width:50px; height:50px; flex:none; background:var(--bg-soft); color:var(--blue); display:grid; place-items:center; }
.bk-doc__ic svg{ width:25px; height:25px; }
.bk-doc__body{ min-width:0; }
.bk-doc__title{ font-family:var(--font-heading); font-size:1.04rem; color:var(--navy); line-height:1.3; margin-bottom:5px; }
.bk-doc__meta{ font-size:.78rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.bk-doc__link{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:.9rem; color:var(--blue); }
.bk-doc__link svg{ width:16px; height:16px; transition:transform .22s ease; }
.bk-doc:hover .bk-doc__link svg{ transform:translateY(2px); }

@media (max-width:980px){ .bk-certs{ grid-template-columns:repeat(2,1fr); } .bk-docs{ grid-template-columns:1fr; } }
@media (max-width:520px){ .bk-certs{ grid-template-columns:1fr; } }


/* ===== B2B: logg inn for pris ===== */
.price-login{display:inline-flex;align-items:center;gap:.35em;font-weight:700;color:var(--brand,#022039);text-decoration:underline;text-underline-offset:2px}
.price-login:hover{color:var(--accent,#e30613)}


/* ===== Tilgjengelighet (WCAG) ===== */
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:8px;left:8px;z-index:100000;background:var(--navy,#022039);color:#fff;padding:12px 20px;border-radius:8px;font-weight:700;text-decoration:none;transform:translateY(calc(-100% - 16px));transition:transform .15s ease}
.skip-link:focus{transform:translateY(0);outline:3px solid var(--accent,#e30613);outline-offset:2px}
#main:focus{outline:none}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid #2b7fff;outline-offset:2px;border-radius:3px}
