/* =========================================================
   GL26 v2.0 — GPS Logik · Light Technical
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --gl-bone:#ffffff;
  --gl-white:#f1f0ec;
  --gl-soft:#efece2;
  --gl-ink:#0b0f14;
  --gl-ink-2:#3b4654;
  --gl-ink-3:#697484;
  --gl-rule:#e4e0d3;
  --gl-rule-2:#d9d4c3;
  --gl-blue:#3d6fb0;
  --gl-navy:#1f3968;
  --gl-signal:#ff4d14;
  --gl-mint:#0ec484;
  --gl-ember:#ff8a00;

  --gl-font:'Archivo',system-ui,sans-serif;
  --gl-mono:'JetBrains Mono',ui-monospace,monospace;

  --gl-fs-display:clamp(2.4rem,5vw,4.25rem);
  --gl-fs-h2:clamp(1.8rem,3.2vw,2.85rem);
  --gl-fs-h3:clamp(1.15rem,1.6vw,1.45rem);
  --gl-wrap:1320px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body.gl-2026{
  margin:0;
  background:var(--gl-bone);
  color:var(--gl-ink);
  font-family:var(--gl-font);
  font-size:16px;
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','cv11';
}
body.gl-2026 a{color:inherit}
body.gl-2026 img{max-width:100%;display:block}

.gl-wrap{max-width:var(--gl-wrap);margin:0 auto;padding:0 1.75rem}
.gl-mono{font-family:var(--gl-mono);letter-spacing:0.02em}
.gl-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--gl-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gl-ink-2);padding:.4rem .8rem;border:1px solid var(--gl-rule);border-radius:999px;background:var(--gl-white)}
.gl-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gl-signal);box-shadow:0 0 0 4px rgba(255,77,20,.12)}

/* ---------- HEADER ---------- */
.gl-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--gl-rule)}
.gl-header__inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.75rem;max-width:var(--gl-wrap);margin:0 auto;gap:2rem}
.gl-logo{display:inline-flex;align-items:center;text-decoration:none}
.gl-logo img{height:42px;width:auto;display:block}
.gl-nav{display:flex;align-items:center;gap:2rem}
.gl-nav__list{display:flex;align-items:center;gap:1.9rem;list-style:none;margin:0;padding:0}
.gl-nav__list > li > a{color:var(--gl-ink);text-decoration:none;font-weight:500;font-size:.92rem;letter-spacing:-.01em;transition:color .2s}
.gl-nav__list > li > a:hover{color:var(--gl-blue)}
.gl-cta{display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 1.55rem;background:var(--gl-ink);color:#ffffff !important;border-radius:999px;text-decoration:none;font-weight:600;font-size:.9rem;letter-spacing:-.005em;transition:transform .25s,background .25s,border-color .25s;border:1px solid var(--gl-ink)}
.gl-cta:hover{transform:translateY(-2px);background:var(--gl-blue);border-color:var(--gl-blue)}
.gl-cta--ghost{background:transparent;color:var(--gl-ink) !important;border-color:var(--gl-rule-2,#d9d4c3)}
.gl-cta--ghost:hover{background:var(--gl-ink);color:#ffffff !important;border-color:var(--gl-ink)}

/* Mega menu */
.gl-nav__list .has-mega{position:relative}
.gl-nav__list .has-mega > .gl-mega{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:18px;padding:2rem;min-width:720px;display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:1.75rem;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:0 30px 60px -25px rgba(11,15,20,.25)}
.gl-nav__list .has-mega:hover > .gl-mega,.gl-nav__list .has-mega:focus-within > .gl-mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.gl-mega__intro h3{font-size:1.5rem;font-weight:800;margin:.5rem 0 .5rem;letter-spacing:-.02em}
.gl-mega__intro p{font-size:.85rem;color:var(--gl-ink-2);margin:0}
.gl-mega__col h4{font-family:var(--gl-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gl-ink-3);margin:0 0 .75rem;font-weight:500}
.gl-mega__col ul{list-style:none;margin:0;padding:0}
.gl-mega__col li{margin-bottom:.4rem}
.gl-mega__col a{display:flex;justify-content:space-between;color:var(--gl-ink);text-decoration:none;font-size:.88rem;font-weight:500;padding:.25rem 0;transition:color .2s}
.gl-mega__col a:hover{color:var(--gl-blue)}
.gl-mega__col a span{opacity:.4}

/* ---------- HERO WITH VIDEO ---------- */
.gl-hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;overflow:hidden;background:#0b0f14;isolation:isolate}
.gl-hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.gl-hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,15,20,.2) 0%,rgba(11,15,20,.15) 40%,rgba(11,15,20,.7) 85%,rgba(11,15,20,.92) 100%)}
.gl-hero__grain{position:absolute;inset:0;z-index:2;opacity:.08;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.4) 1px,transparent 1px);background-size:3px 3px;mix-blend-mode:screen}
.gl-hero__inner{position:relative;z-index:3;width:100%;padding:8rem 0 4.5rem;color:#fff}
.gl-hero__tag{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--gl-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);padding:.45rem .85rem;border:1px solid rgba(255,255,255,.3);border-radius:999px;backdrop-filter:blur(10px);background:rgba(255,255,255,.08)}
.gl-hero__tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gl-signal);box-shadow:0 0 12px var(--gl-signal);animation:glPulse 2s ease-in-out infinite}
@keyframes glPulse{0%,100%{opacity:1}50%{opacity:.35}}
.gl-hero h1{font-size:var(--gl-fs-display);font-weight:800;line-height:1.02;letter-spacing:-.035em;margin:1.25rem 0 1.25rem;color:#fff;max-width:900px}
.gl-hero h1 em{font-style:normal;color:var(--gl-signal)}
.gl-hero__lede{font-size:1.08rem;max-width:560px;color:rgba(255,255,255,.82);margin:0 0 2rem;line-height:1.55}
.gl-hero__actions{display:flex;gap:.9rem;flex-wrap:wrap}
.gl-hero__actions .gl-cta{background:#fff;color:var(--gl-ink) !important;border-color:#fff}
.gl-hero__actions .gl-cta:hover{background:var(--gl-signal);color:#fff !important;border-color:var(--gl-signal)}
.gl-hero__actions .gl-cta--ghost{background:rgba(255,255,255,.08);color:#fff !important;border:1px solid rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.gl-hero__actions .gl-cta--ghost:hover{background:#fff;color:var(--gl-ink) !important}

/* Hero bottom coordinates */
.gl-hero__coord{position:absolute;bottom:1.5rem;right:1.75rem;z-index:4;font-family:var(--gl-mono);font-size:.7rem;color:rgba(255,255,255,.55);letter-spacing:.05em;text-align:right}
.gl-hero__coord b{display:block;color:var(--gl-signal);font-weight:500}

/* ---------- STATS STRIP ---------- */
.gl-stats{background:var(--gl-white);border-bottom:1px solid var(--gl-rule);position:relative;z-index:5}
.gl-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--gl-wrap);margin:0 auto}
.gl-stat{padding:2rem 2rem;border-right:1px solid var(--gl-rule);display:flex;flex-direction:column;gap:.2rem}
.gl-stat:last-child{border-right:0}
.gl-stat__num{font-size:2.75rem;font-weight:800;letter-spacing:-.035em;line-height:1;color:var(--gl-ink)}
.gl-stat__num span{color:var(--gl-signal)}
.gl-stat__label{font-family:var(--gl-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gl-ink-3);margin-top:.35rem}
@media(max-width:900px){.gl-stats__grid{grid-template-columns:repeat(2,1fr)}.gl-stat:nth-child(2){border-right:0}.gl-stat:nth-child(-n+2){border-bottom:1px solid var(--gl-rule)}}
@media(max-width:520px){.gl-stats__grid{grid-template-columns:1fr}.gl-stat{border-right:0;border-bottom:1px solid var(--gl-rule)}.gl-stat:last-child{border-bottom:0}}

/* ---------- FEATURE GRID ---------- */
.gl-features{padding:6rem 0 6.5rem;background:var(--gl-bone)}
.gl-features__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.gl-features__head > div:first-child{max-width:640px}
.gl-features__head h2{font-size:var(--gl-fs-h2);font-weight:800;letter-spacing:-.035em;line-height:1.05;margin:.75rem 0 0;color:var(--gl-ink)}
.gl-features__head h2 em{font-style:italic;color:var(--gl-blue)}
.gl-features__head p{font-family:var(--gl-mono);font-size:.8rem;color:var(--gl-ink-3);max-width:260px;text-align:right;margin:0}
.gl-features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gl-rule);border:1px solid var(--gl-rule);border-radius:18px;overflow:hidden}
.gl-feature{position:relative;background:var(--gl-white);padding:2.25rem 1.85rem 2.5rem;display:flex;flex-direction:column;gap:.6rem;transition:background .3s}
.gl-feature:hover{background:var(--gl-soft)}
.gl-feature__icon{width:42px;height:42px;color:var(--gl-blue);margin-bottom:.8rem;display:flex;align-items:center;justify-content:center}
.gl-feature__icon svg{width:100%;height:100%}
.gl-feature__num{position:absolute;top:1.25rem;right:1.5rem;font-family:var(--gl-mono);font-size:.68rem;color:var(--gl-ink-3);letter-spacing:.06em}
.gl-feature h3{font-size:1.02rem;font-weight:700;margin:0;line-height:1.25;letter-spacing:-.01em;color:var(--gl-ink)}
.gl-feature p{font-size:.86rem;line-height:1.55;color:var(--gl-ink-2);margin:.35rem 0 0}
@media(max-width:1080px){.gl-features__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gl-features__grid{grid-template-columns:1fr}}

/* ---------- BRAND CARDS ---------- */
.gl-brands{padding:6rem 0;background:var(--gl-white);border-top:1px solid var(--gl-rule)}
.gl-brands__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.gl-brand-card{position:relative;padding:2.75rem 2.5rem 2.5rem;border:1px solid var(--gl-rule);border-radius:20px;background:var(--gl-bone);display:flex;flex-direction:column;gap:1.25rem;transition:transform .3s,box-shadow .3s;overflow:hidden}
.gl-brand-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -25px rgba(11,15,20,.18)}
.gl-brand-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--gl-blue)}
.gl-brand-card[data-brand='dm']::before{background:var(--gl-mint)}
.gl-brand-card[data-brand='ru']::before{background:var(--gl-signal)}
.gl-brand-card header{display:flex;flex-direction:column;gap:.65rem}
.gl-brand-card h2{font-size:clamp(2rem,3.5vw,2.85rem);font-weight:800;line-height:1;margin:0;letter-spacing:-.035em}
.gl-brand-card h2 em{font-style:italic;color:var(--gl-blue);font-weight:800}
.gl-brand-card p{font-size:.95rem;color:var(--gl-ink-2);line-height:1.55;margin:0;flex:1}
.gl-brand-card__foot{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;border-top:1px solid var(--gl-rule);font-family:var(--gl-mono);font-size:.78rem;color:var(--gl-ink-3);letter-spacing:.04em}
.gl-brand-card__foot a{color:var(--gl-ink);text-decoration:none;font-weight:600;font-family:var(--gl-font);font-size:.92rem;letter-spacing:-.005em;transition:color .2s}
.gl-brand-card__foot a:hover{color:var(--gl-blue)}
@media(max-width:860px){.gl-brands__grid{grid-template-columns:1fr}}

/* ---------- SECTION HEADS + CATALOG ---------- */
.gl-section{padding:6rem 0;background:var(--gl-bone)}
.gl-section--white{background:var(--gl-white)}
.gl-catalog__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.gl-catalog__head > div:first-child{max-width:700px}
.gl-catalog__head h2{font-size:var(--gl-fs-h2);font-weight:800;letter-spacing:-.035em;line-height:1.05;margin:.75rem 0 0;color:var(--gl-ink)}
.gl-catalog__head h2 em{font-style:italic;color:var(--gl-blue);font-weight:800}
.gl-catalog__head .gl-mono{font-size:.78rem;color:var(--gl-ink-3);text-align:right;line-height:1.7}

.gl-catalog__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.4rem}
.gl-card{position:relative;display:flex;flex-direction:column;background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--gl-ink);transition:transform .3s,box-shadow .3s,border-color .3s}
.gl-card:hover{transform:translateY(-5px);box-shadow:0 24px 50px -20px rgba(11,15,20,.2);border-color:var(--gl-rule-2)}
.gl-card__media{position:relative;aspect-ratio:4/3;background:linear-gradient(135deg,#f1f0ec 0%,#e7e5df 100%);display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}
.gl-card__media::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(61,111,176,.08),transparent 70%)}
.gl-card__img{position:relative;max-width:75%;max-height:75%;object-fit:contain;filter:drop-shadow(0 16px 28px rgba(11,15,20,.22));transition:transform .45s}
.gl-card:hover .gl-card__img{transform:scale(1.05)}
.gl-card__body{padding:1.25rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.gl-card__meta{font-family:var(--gl-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gl-ink-3);margin-bottom:.35rem}
.gl-card__title{font-size:1.2rem;font-weight:700;line-height:1.15;margin:0 0 .45rem;letter-spacing:-.02em;color:var(--gl-ink)}
.gl-card__spec{font-family:var(--gl-mono);font-size:.7rem;color:var(--gl-blue);margin-bottom:.65rem;letter-spacing:.02em}
.gl-card__desc{font-size:.85rem;color:var(--gl-ink-2);line-height:1.5;margin:0;flex:1}
.gl-card__arrow{align-self:flex-end;margin-top:1rem;font-size:1.15rem;color:var(--gl-ink-3);transition:transform .3s,color .3s}
.gl-card:hover .gl-card__arrow{transform:translateX(4px);color:var(--gl-blue)}
.gl-pill{position:absolute;top:.85rem;right:.85rem;padding:.38rem .8rem .38rem 1.7rem;background:rgba(255,255,255,.92);border:1px solid var(--gl-rule);border-radius:999px;font-family:var(--gl-mono);font-size:.62rem;letter-spacing:.05em;text-transform:uppercase;font-weight:500;color:var(--gl-ink-2);backdrop-filter:blur(10px);z-index:2}
.gl-pill::before{content:'';position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:#aaa}
.gl-pill--wired::before{background:var(--gl-ember)}
.gl-pill--battery::before{background:var(--gl-mint)}
.gl-pill--obd::before{background:var(--gl-blue)}
.gl-pill--ble::before{background:#8b5cf6}
.gl-card--digital-matter{--accent:var(--gl-mint)}
.gl-card--ruptela{--accent:var(--gl-signal)}
.gl-card--digital-matter::after,.gl-card--ruptela::after{content:'';position:absolute;top:0;left:0;width:48px;height:3px;background:var(--accent);z-index:3}

/* ---------- SOLUTIONS ---------- */
.gl-solutions{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gl-rule);border:1px solid var(--gl-rule);border-radius:18px;overflow:hidden}
.gl-sol{position:relative;padding:2.5rem 2rem 2.75rem;background:var(--gl-white);text-decoration:none;color:var(--gl-ink);transition:background .3s;display:flex;flex-direction:column;gap:.5rem}
.gl-sol:hover{background:var(--gl-bone)}
.gl-sol .gl-mono{font-size:.7rem;color:var(--gl-ink-3);letter-spacing:.08em;text-transform:uppercase}
.gl-sol h3{font-size:1.4rem;font-weight:700;margin:.4rem 0 .4rem;letter-spacing:-.02em;color:var(--gl-ink)}
.gl-sol p{font-size:.88rem;color:var(--gl-ink-2);margin:0;line-height:1.55}
.gl-sol__arrow{position:absolute;bottom:1.75rem;right:1.75rem;font-size:1.25rem;color:var(--gl-blue);transition:transform .3s}
.gl-sol:hover .gl-sol__arrow{transform:translateX(6px)}
@media(max-width:960px){.gl-solutions{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.gl-solutions{grid-template-columns:1fr}}

/* ---------- CTA BAND ---------- */
.gl-cta-band{padding:5.5rem 0;background:var(--gl-ink);color:#fff;position:relative;overflow:hidden}
.gl-cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(61,111,176,.25),transparent 60%);pointer-events:none}
.gl-cta-band__inner{position:relative;display:flex;justify-content:space-between;align-items:center;gap:3rem;flex-wrap:wrap}
.gl-cta-band .gl-eyebrow{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.2)}
.gl-cta-band h2{font-size:var(--gl-fs-h2);font-weight:800;line-height:1.1;letter-spacing:-.035em;margin:.75rem 0 0;color:#fff;max-width:640px}
.gl-cta-band h2 em{color:var(--gl-signal);font-style:normal}
.gl-cta-band__actions{display:flex;gap:1rem;flex-wrap:wrap}
.gl-cta-band .gl-cta{background:var(--gl-signal);color:#fff !important;border-color:var(--gl-signal)}
.gl-cta-band .gl-cta:hover{background:#fff;color:var(--gl-ink) !important;border-color:#fff}
.gl-cta-band .gl-cta--ghost{background:transparent;color:#fff !important;border-color:rgba(255,255,255,.4)}
.gl-cta-band .gl-cta--ghost:hover{background:#fff;color:var(--gl-ink) !important;border-color:#fff}

/* ---------- FOOTER ---------- */
.gl-footer{padding:5rem 0 2rem;background:var(--gl-white);border-top:1px solid var(--gl-rule);color:var(--gl-ink)}
.gl-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.gl-footer__brand{max-width:380px}
.gl-footer__brand img{height:48px;width:auto;margin-bottom:1.1rem}
.gl-footer__tag{color:var(--gl-ink-2);font-size:.92rem;line-height:1.55;margin:0 0 1rem}
.gl-footer__coord{font-size:.72rem;color:var(--gl-ink-3);letter-spacing:.04em}
.gl-footer__col h5{font-family:var(--gl-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gl-ink-3);margin:0 0 1rem;font-weight:500}
.gl-footer__col ul{list-style:none;padding:0;margin:0}
.gl-footer__col li{margin-bottom:.55rem}
.gl-footer__col a{color:var(--gl-ink);text-decoration:none;font-size:.9rem;transition:color .2s}
.gl-footer__col a:hover{color:var(--gl-blue)}
.gl-footer__base{display:flex;justify-content:space-between;padding-top:2rem;border-top:1px solid var(--gl-rule);font-family:var(--gl-mono);font-size:.72rem;color:var(--gl-ink-3);letter-spacing:.04em;flex-wrap:wrap;gap:1rem}
@media(max-width:900px){.gl-footer__grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.gl-footer__grid{grid-template-columns:1fr}}

/* ---------- MOBILE ---------- */
@media(max-width:900px){
  .gl-header__inner{padding:.85rem 1.25rem;gap:1rem}
  .gl-logo img{height:36px}
  .gl-nav{gap:1rem}
  .gl-nav__list{display:none}
  .gl-hero{min-height:78vh}
  .gl-hero__inner{padding:5rem 0 3.5rem}
  .gl-hero__coord{display:none}
  .gl-features,.gl-brands,.gl-section,.gl-cta-band{padding:4rem 0}
  .gl-features__head,.gl-catalog__head{flex-direction:column;align-items:flex-start}
  .gl-features__head p{text-align:left;max-width:none}
  .gl-cta-band__inner{flex-direction:column;align-items:flex-start;gap:1.5rem}
  .gl-brand-card{padding:2rem 1.75rem}
}

/* ---------- SINGLE / ARCHIVE HEAD ---------- */
.gl-archive-hero{padding:8rem 0 4rem;background:var(--gl-bone);border-bottom:1px solid var(--gl-rule)}
.gl-archive-hero h1{font-size:var(--gl-fs-display);font-weight:800;letter-spacing:-.035em;line-height:1.02;margin:1rem 0 0;color:var(--gl-ink)}
.gl-archive-hero h1 em{font-style:italic;color:var(--gl-blue)}
.gl-single{padding:6rem 0;background:var(--gl-bone)}
.gl-single__wrap{max-width:820px;margin:0 auto}
.gl-single h1{font-size:var(--gl-fs-h2);font-weight:800;letter-spacing:-.03em;margin:1rem 0 1.5rem}
.gl-single .gl-single__content{font-size:1rem;line-height:1.7;color:var(--gl-ink-2)}
.gl-single .gl-single__content p{margin:0 0 1.25rem}

/* =========================================================
   GL26 v2.0.1 — Legacy class shims + contact/team/map
   (All classes referenced by taxonomy/archive/contact
    templates that were missing after the light rewrite.)
   ========================================================= */

/* Display + heading helpers */
.gl-display{font-family:var(--gl-font);font-weight:800;letter-spacing:-.035em;line-height:1.05;color:var(--gl-ink);margin:0}
.gl-display em{font-style:italic;color:var(--gl-blue)}
.gl-h1{font-size:var(--gl-fs-display)}
.gl-h2{font-size:var(--gl-fs-h2)}
.gl-h3{font-size:var(--gl-fs-h3)}
.gl-section--bone{background:var(--gl-bone)}

/* Ensure h1 inside catalog head uses proper size */
.gl-catalog__head h1{font-size:var(--gl-fs-display);font-weight:800;letter-spacing:-.035em;line-height:1.02;margin:.75rem 0 0;color:var(--gl-ink)}
.gl-catalog__head h1 em{font-style:italic;color:var(--gl-blue)}

/* ---------- CONTACT HERO ---------- */
.gl-contact-hero{padding:7rem 0 5rem;background:var(--gl-bone);border-bottom:1px solid var(--gl-rule)}
.gl-contact-hero__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:start}
.gl-contact-hero__grid > div:first-child .gl-display{font-size:var(--gl-fs-display);margin-top:1rem}
.gl-contact-hero__phones{display:flex;flex-direction:column;gap:1rem;background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:18px;padding:1.75rem}
.gl-phone{display:flex;flex-direction:column;gap:.3rem;padding:1rem 1.25rem;border:1px solid var(--gl-rule);border-radius:12px;text-decoration:none;color:var(--gl-ink);transition:background .25s,border-color .25s,transform .25s;background:var(--gl-bone)}
.gl-phone:hover{background:var(--gl-white);border-color:var(--gl-blue);transform:translateY(-2px)}
.gl-phone .gl-mono{font-size:.68rem;color:var(--gl-ink-3);letter-spacing:.08em;text-transform:uppercase}
.gl-phone__num{font-family:var(--gl-font);font-size:1.15rem;font-weight:700;letter-spacing:-.015em;color:var(--gl-ink)}
.gl-phone--alt .gl-mono{color:var(--gl-signal)}
@media(max-width:860px){.gl-contact-hero__grid{grid-template-columns:1fr}}

/* ---------- CONTACT INFO CARDS ---------- */
.gl-contact-grid{background:var(--gl-bone)}
.gl-contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:-3rem;position:relative;z-index:2}
.gl-info-card{background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:18px;padding:2rem 1.85rem 2.25rem;display:flex;flex-direction:column;gap:.6rem;transition:transform .3s,box-shadow .3s}
.gl-info-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -20px rgba(11,15,20,.18)}
.gl-info-card .gl-mono{font-size:.68rem;color:var(--gl-ink-3);letter-spacing:.08em;text-transform:uppercase}
.gl-info-card .gl-display{font-size:1.6rem;font-weight:800;margin:.25rem 0 .5rem;letter-spacing:-.025em;line-height:1.1}
.gl-info-card address{font-style:normal;font-size:.9rem;color:var(--gl-ink-2);line-height:1.6}
.gl-info-card p{font-size:.9rem;color:var(--gl-ink-2);line-height:1.55;margin:.25rem 0}
.gl-info-card__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:auto;padding-top:1rem;color:var(--gl-blue);text-decoration:none;font-weight:600;font-size:.88rem}
.gl-info-card__link:hover{color:var(--gl-signal)}
.gl-info-card--signal{background:var(--gl-ink);color:#fff;border-color:var(--gl-ink)}
.gl-info-card--signal .gl-display{color:#fff}
.gl-info-card--signal p{color:rgba(255,255,255,.75)}
.gl-info-card--signal .gl-mono{color:rgba(255,255,255,.55)}
.gl-info-card--signal .gl-cta{background:var(--gl-signal);border-color:var(--gl-signal);color:#fff !important;align-self:flex-start;margin-top:.5rem}
.gl-info-card--signal .gl-cta:hover{background:#fff;color:var(--gl-ink) !important;border-color:#fff}
@media(max-width:900px){.gl-contact-cards{grid-template-columns:1fr;margin-top:0}}

/* ---------- MAP ---------- */
.gl-map-section{background:var(--gl-bone);padding-top:4rem!important}
.gl-map{position:relative;border:1px solid var(--gl-rule);border-radius:18px;overflow:hidden;background:var(--gl-white)}
.gl-map iframe{display:block;filter:grayscale(.4) contrast(1.05)!important}
.gl-map__pin{position:absolute;top:1.25rem;left:1.25rem;background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:999px;padding:.5rem .9rem;font-size:.72rem;color:var(--gl-ink);box-shadow:0 10px 25px -12px rgba(11,15,20,.25)}
.gl-map__pin .gl-mono{color:var(--gl-signal);font-weight:600}

/* ---------- TEAM ---------- */
.gl-team{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.gl-team__card{position:relative;background:var(--gl-white);border:1px solid var(--gl-rule);border-radius:18px;padding:2rem 1.75rem 2rem;display:flex;flex-direction:column;gap:.5rem;transition:transform .3s,box-shadow .3s}
.gl-team__card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -20px rgba(11,15,20,.18)}
.gl-team__idx{position:absolute;top:1.25rem;right:1.4rem;font-size:.68rem;color:var(--gl-ink-3);letter-spacing:.08em}
.gl-team__photo{width:96px;height:96px;border-radius:50%;overflow:hidden;background:var(--gl-bone);border:1px solid var(--gl-rule);margin-bottom:.75rem}
.gl-team__photo img{width:100%;height:100%;object-fit:cover}
.gl-team__name{font-size:1.35rem;font-weight:800;letter-spacing:-.025em;line-height:1.1;margin:.25rem 0 .15rem}
.gl-team__role{font-size:.72rem;color:var(--gl-blue);letter-spacing:.04em;text-transform:uppercase;margin-bottom:.65rem}
.gl-team__bio{font-size:.88rem;color:var(--gl-ink-2);line-height:1.55;margin:0}
@media(max-width:900px){.gl-team{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.gl-team{grid-template-columns:1fr}}

/* ---------- Guard: prevent logo img from ever blowing up ---------- */
.gl-logo img{max-height:42px!important;width:auto!important;display:block}
.gl-footer__brand img{max-height:48px!important;width:auto!important;display:block}



/* =========================================================
   GL26 v2.0.2 — Mega menu HARD FIX
   WP nav menu exports `.menu-item-has-children` (not our
   custom `.has-mega` which the walker wasn't applying).
   Hide the mega panel by default and only show on hover.
   ========================================================= */

/* Default-hide the inline .gl-mega div inside every nav list item */
.gl-nav__list .gl-mega{
  position:absolute;
  top:calc(100% + 12px);
  left:50%;
  transform:translateX(-50%) translateY(10px);
  background:var(--gl-white);
  border:1px solid var(--gl-rule);
  border-radius:18px;
  padding:2rem;
  min-width:720px;
  max-width:min(90vw,900px);
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr 1fr;
  gap:1.75rem;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .25s,transform .25s,visibility .25s;
  box-shadow:0 30px 60px -25px rgba(11,15,20,.25);
  z-index:200;
}

/* The li must be the anchor for the absolute panel */
.gl-nav__list > li{position:relative}
.gl-nav__list > li.menu-item-has-children{position:relative}

/* Show on hover / focus of the parent li */
.gl-nav__list > li.menu-item-has-children:hover > .gl-mega,
.gl-nav__list > li.menu-item-has-children:focus-within > .gl-mega,
.gl-nav__list > li.has-mega:hover > .gl-mega,
.gl-nav__list > li.has-mega:focus-within > .gl-mega{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}

/* Restore header flex behaviour (was inadvertently nuked by earlier guards) */
.gl-header{position:sticky;top:0;z-index:100}
.gl-header__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.gl-nav{display:flex;align-items:center;gap:2rem}
.gl-nav__list{display:flex;align-items:center;gap:1.9rem;list-style:none;margin:0;padding:0}
.gl-nav__list > li > a{color:var(--gl-ink);text-decoration:none;font-weight:500;font-size:.92rem;letter-spacing:-.01em;transition:color .2s;white-space:nowrap}
.gl-nav__list > li > a:hover{color:var(--gl-blue)}

/* Hard lock the logo size */
.gl-logo img{max-height:42px;height:42px;width:auto;display:block}

/* =========================================================
   GL26 v2.0.3 — Mega menu hover bridge + delay
   Prevents dropdown from closing when mouse crosses
   the gap between nav item and mega panel.
   ========================================================= */

/* Invisible bridge: extend li’s hover area down into the gap */
.gl-nav__list > li.menu-item-has-children::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:20px;
  pointer-events:auto;
}

/* Panel sits right at the bottom of the li — no gap */
.gl-nav__list .gl-mega{
  top:100% !important;
  margin-top:10px;
  padding-top:1.75rem;
  padding-bottom:1.75rem;
}

/* Tiny hide delay so the cursor has time to reach the panel */
.gl-nav__list .gl-mega{
  transition:opacity .25s,transform .25s,visibility .25s;
  transition-delay:.15s;
}
.gl-nav__list > li.menu-item-has-children:hover > .gl-mega,
.gl-nav__list > li.menu-item-has-children:focus-within > .gl-mega{
  transition-delay:0s;
}

/* =========================================================
   GL-PAGE ROUTING  —  shared chrome for all legacy pages
   ========================================================= */
.gl-page{background:var(--gl-bone);color:var(--gl-ink);}
.gl-page .gl-wrap--narrow{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:clamp(2rem,4vw,4rem);align-items:start;}
@media (max-width:900px){ .gl-page .gl-wrap--narrow{grid-template-columns:1fr;} }

.gl-page__hero{
    padding:clamp(4.5rem,9vw,8rem) 0 clamp(2rem,4vw,3rem);
    background:
        radial-gradient(60% 80% at 10% 0%, rgba(61,111,176,.08), transparent 60%),
        linear-gradient(180deg, var(--gl-white) 0%, var(--gl-bone) 100%);
    border-bottom:1px solid var(--gl-rule);
    position:relative;
}
.gl-page__hero::before{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(to right, rgba(11,15,20,.035) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(11,15,20,.035) 1px, transparent 1px);
    background-size:64px 64px;
    mask-image:radial-gradient(ellipse at top, #000 40%, transparent 80%);
    pointer-events:none;
}
.gl-page__hero .gl-wrap{position:relative;}
.gl-page__title{
    font-family:var(--gl-font);
    font-size:var(--gl-fs-display);
    line-height:1.02;
    letter-spacing:-.025em;
    font-weight:600;
    margin:.4rem 0 0;
    max-width:18ch;
}
.gl-page__lede{
    font-size:clamp(1.05rem,1.3vw,1.25rem);
    line-height:1.55;
    color:var(--gl-ink-2);
    max-width:52ch;
    margin:1.25rem 0 0;
}
.gl-crumbs{
    display:flex;gap:.5rem;align-items:center;
    font-family:var(--gl-mono);font-size:.72rem;
    text-transform:uppercase;letter-spacing:.12em;
    color:var(--gl-ink-3);margin-bottom:1rem;
}
.gl-crumbs a{color:var(--gl-ink-3);text-decoration:none;border-bottom:1px solid transparent;}
.gl-crumbs a:hover{color:var(--gl-blue);border-color:currentColor;}
.gl-crumbs__current{color:var(--gl-ink);}

.gl-page__body{
    padding:clamp(3rem,6vw,5rem) 0 clamp(4rem,8vw,7rem);
}

/* ---- CONTENT PROSE STYLES ---- */
.gl-page__content{
    font-family:var(--gl-font);
    font-size:1.0625rem;
    line-height:1.68;
    color:var(--gl-ink-2);
    max-width:68ch;
}
.gl-page__content > *:first-child{margin-top:0;}
.gl-page__content > *:last-child{margin-bottom:0;}
.gl-page__content p{margin:0 0 1.15em;}
.gl-page__content h1,.gl-page__content h2,.gl-page__content h3,.gl-page__content h4{
    font-family:var(--gl-font);
    color:var(--gl-ink);
    font-weight:600;
    letter-spacing:-.015em;
    line-height:1.15;
    margin:2em 0 .65em;
}
.gl-page__content h2{font-size:clamp(1.5rem,2.4vw,2.05rem);}
.gl-page__content h3{font-size:clamp(1.2rem,1.8vw,1.55rem);}
.gl-page__content h4{font-size:1.1rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gl-ink-3);font-weight:500;}
.gl-page__content a{
    color:var(--gl-blue);
    text-decoration:none;
    border-bottom:1px solid rgba(61,111,176,.3);
    transition:border-color .2s;
}
.gl-page__content a:hover{border-bottom-color:var(--gl-blue);}
.gl-page__content ul,.gl-page__content ol{margin:0 0 1.25em;padding-left:1.25em;}
.gl-page__content li{margin-bottom:.4em;}
.gl-page__content ul li::marker{color:var(--gl-blue);}
.gl-page__content blockquote{
    margin:1.8em 0;
    padding:1.25em 1.5em;
    border-left:3px solid var(--gl-blue);
    background:var(--gl-white);
    color:var(--gl-ink);
    font-size:1.1rem;
    line-height:1.55;
    font-style:normal;
}
.gl-page__content blockquote p:last-child{margin-bottom:0;}
.gl-page__content img{
    max-width:100%;height:auto;
    border-radius:6px;
    border:1px solid var(--gl-rule);
    margin:1.5em 0;
}
.gl-page__content table{
    width:100%;border-collapse:collapse;margin:1.5em 0;font-size:.95rem;
}
.gl-page__content th,.gl-page__content td{
    padding:.75em 1em;text-align:left;
    border-bottom:1px solid var(--gl-rule);
}
.gl-page__content th{
    font-family:var(--gl-mono);font-size:.72rem;
    text-transform:uppercase;letter-spacing:.08em;
    color:var(--gl-ink-3);font-weight:500;
}
.gl-page__content hr{
    border:0;border-top:1px solid var(--gl-rule);
    margin:2.5em 0;
}
.gl-page__content code{
    font-family:var(--gl-mono);font-size:.9em;
    background:var(--gl-white);padding:.15em .4em;border-radius:3px;
}

/* ---- PLACEHOLDER (page has no real content yet) ---- */
.gl-page__placeholder{
    padding:2.5rem;
    background:var(--gl-white);
    border:1px dashed var(--gl-rule);
    border-radius:8px;
}
.gl-page__placeholder p{font-size:1.1rem;color:var(--gl-ink-2);margin:0 0 1.5rem;}
.gl-page__placeholder-actions{display:flex;gap:.75rem;flex-wrap:wrap;}

.gl-btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.85rem 1.4rem;
    font-family:var(--gl-font);
    font-size:.95rem;font-weight:500;
    letter-spacing:-.005em;
    border-radius:4px;
    text-decoration:none;
    transition:background .2s,border-color .2s,color .2s,transform .15s;
    border:1px solid transparent;
}
.gl-btn--primary{background:var(--gl-ink);color:var(--gl-bone);}
.gl-btn--primary:hover{background:var(--gl-blue);transform:translateY(-1px);}
.gl-btn--ghost{background:transparent;color:var(--gl-ink);border-color:var(--gl-rule);}
.gl-btn--ghost:hover{border-color:var(--gl-ink);color:var(--gl-ink);}

/* ---- ASIDE ---- */
.gl-page__aside{
    position:sticky;top:calc(var(--gl-header-h,72px) + 2rem);
    display:flex;flex-direction:column;gap:1rem;
}
@media (max-width:900px){ .gl-page__aside{position:static;} }
.gl-aside-card{
    padding:1.5rem;
    background:var(--gl-white);
    border:1px solid var(--gl-rule);
    border-radius:6px;
}
.gl-aside-card h3{
    font-family:var(--gl-font);
    font-size:1.15rem;
    letter-spacing:-.01em;
    color:var(--gl-ink);
    margin:.35rem 0 .75rem;
    font-weight:600;
}
.gl-aside-card p{
    font-size:.92rem;line-height:1.55;color:var(--gl-ink-2);
    margin:0 0 .6rem;
}
.gl-aside-card p:last-child{margin-bottom:0;}
.gl-aside-card--muted{background:transparent;border-style:dashed;}
.gl-link{color:var(--gl-blue);text-decoration:none;border-bottom:1px solid rgba(61,111,176,.3);}
.gl-link:hover{border-color:var(--gl-blue);}

/* =========================================================
   GL-PRODUCT SINGLE  —  hardware detail page
   ========================================================= */
.gl-product{
    padding:clamp(4.5rem,9vw,8rem) 0 clamp(4rem,7vw,6rem);
    background:
        radial-gradient(60% 80% at 90% 0%, rgba(61,111,176,.06), transparent 60%),
        linear-gradient(180deg, var(--gl-white) 0%, var(--gl-bone) 320px);
    color:var(--gl-ink);
    position:relative;
}
.gl-product::before{
    content:'';position:absolute;inset:0;
    background-image:
        linear-gradient(to right, rgba(11,15,20,.035) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(11,15,20,.035) 1px, transparent 1px);
    background-size:64px 64px;
    mask-image:radial-gradient(ellipse at top, #000 30%, transparent 75%);
    pointer-events:none;
}
.gl-product .gl-wrap{position:relative;}
.gl-product .gl-crumbs{margin-bottom:1.25rem;}

.gl-product__grid{
    display:grid;
    grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
    gap:clamp(2rem,5vw,5rem);
    align-items:start;
    margin-top:1rem;
}
@media (max-width:880px){ .gl-product__grid{grid-template-columns:1fr;} }

.gl-product__head .gl-eyebrow{display:inline-flex;}
.gl-product__head h1,
.gl-product__head .gl-display{
    font-family:var(--gl-font);
    font-size:var(--gl-fs-display);
    line-height:1.02;
    letter-spacing:-.025em;
    font-weight:700;
    color:var(--gl-ink);
    margin:.6rem 0 1.1rem;
    max-width:14ch;
}
.gl-product__excerpt{
    font-size:clamp(1.05rem,1.3vw,1.2rem);
    line-height:1.55;
    color:var(--gl-ink-2);
    max-width:46ch;
    margin-bottom:1.75rem;
}
.gl-product__excerpt p{margin:0;}
.gl-product__actions{display:flex;gap:.75rem;flex-wrap:wrap;}

.gl-product__visual{
    background:var(--gl-white);
    border:1px solid var(--gl-rule);
    border-radius:8px;
    padding:clamp(1.5rem,3vw,2.5rem);
    aspect-ratio:1/1;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.gl-product__visual img{
    max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
}
.gl-product__placeholder{
    width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;
    color:var(--gl-ink-3);
}
.gl-product__placeholder svg{max-width:80%;}

.gl-product__body{
    margin-top:clamp(3rem,5vw,4.5rem);
    padding-top:clamp(2.5rem,4vw,3.5rem);
    border-top:1px solid var(--gl-rule);
    display:grid;
    grid-template-columns:minmax(0,1fr);
    max-width:68ch;
}

/* Treat the_content() output inside single-produkter as prose */
.gl-product__body{
    font-family:var(--gl-font);
    font-size:1.0625rem;
    line-height:1.68;
    color:var(--gl-ink-2);
}
.gl-product__body > *:first-child{margin-top:0;}
.gl-product__body > *:last-child{margin-bottom:0;}
.gl-product__body p{margin:0 0 1.15em;}
.gl-product__body h2{
    font-family:var(--gl-font);
    font-size:clamp(1.5rem,2.4vw,2.05rem);
    color:var(--gl-ink);
    font-weight:600;
    letter-spacing:-.015em;
    line-height:1.15;
    margin:2.2em 0 .65em;
}
.gl-product__body h3{
    font-family:var(--gl-font);
    font-size:clamp(1.2rem,1.8vw,1.5rem);
    color:var(--gl-ink);font-weight:600;
    margin:1.8em 0 .55em;
}
.gl-product__body ul,.gl-product__body ol{
    margin:0 0 1.25em;padding-left:1.25em;
}
.gl-product__body li{margin-bottom:.4em;}
.gl-product__body ul li::marker{color:var(--gl-blue);}
.gl-product__body strong{color:var(--gl-ink);}
.gl-product__body a{color:var(--gl-blue);text-decoration:none;border-bottom:1px solid rgba(61,111,176,.3);}
.gl-product__body a:hover{border-color:var(--gl-blue);}
.gl-product__body hr,
.gl-product__body .wp-block-separator{
    border:0;border-top:1px solid var(--gl-rule);
    margin:2.5em 0;
}

/* Gutenberg button override — was rendering ink-on-ink (invisible) */
.gl-product__body .wp-block-buttons,
.gl-page__content .wp-block-buttons{
    display:flex;gap:.75rem;flex-wrap:wrap;margin:1.75em 0;
}
.gl-product__body .wp-block-button__link,
.gl-page__content .wp-block-button__link{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.95rem 1.6rem;
    background:var(--gl-ink) !important;
    color:#ffffff !important;
    font-family:var(--gl-font);
    font-size:.95rem;font-weight:500;
    letter-spacing:-.005em;
    border-radius:4px;
    text-decoration:none;
    border:1px solid var(--gl-ink);
    transition:background .2s,border-color .2s,transform .15s;
}
.gl-product__body .wp-block-button__link:hover,
.gl-page__content .wp-block-button__link:hover{
    background:var(--gl-blue) !important;
    border-color:var(--gl-blue);
    transform:translateY(-1px);
}
.gl-product__body .wp-block-button.is-style-outline .wp-block-button__link,
.gl-page__content .wp-block-button.is-style-outline .wp-block-button__link{
    background:transparent !important;
    color:var(--gl-ink) !important;
    border-color:var(--gl-rule);
}

/* Make has-contrast-color resolve to readable ink instead of an undefined token */
.gl-product__body .has-contrast-color,
.gl-page__content .has-contrast-color{ color:var(--gl-ink-2) !important; }
.gl-product__body strong.has-contrast-color,
.gl-page__content strong.has-contrast-color{ color:var(--gl-ink) !important; }

/* =========================================================
   GL-PRODUCT-TABS  —  Digital Matter-style tabbed detail
   ========================================================= */
.gl-product__title{
    font-family:var(--gl-font);
    font-size:var(--gl-fs-display);
    line-height:1.02;
    letter-spacing:-.025em;
    font-weight:700;
    color:var(--gl-ink);
    margin:.6rem 0 1.1rem;
    max-width:14ch;
}
.gl-product__lede{
    font-size:clamp(1.05rem,1.3vw,1.2rem);
    line-height:1.55;
    color:var(--gl-ink-2);
    max-width:52ch;
    margin-bottom:1.75rem;
}
.gl-product__visual img{
    max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
    mix-blend-mode:multiply;
}

.gl-product-tabs{
    padding:clamp(3rem,6vw,5.5rem) 0 clamp(3rem,5vw,4.5rem);
    background:var(--gl-white);
    border-top:1px solid var(--gl-rule);
    border-bottom:1px solid var(--gl-rule);
}
.gl-tabs{
    display:flex;flex-wrap:wrap;gap:.25rem;
    border-bottom:1px solid var(--gl-rule);
    margin-bottom:2.5rem;
}
.gl-tabs__btn{
    background:transparent;border:0;cursor:pointer;
    padding:1rem 1.75rem;
    font-family:var(--gl-font);font-size:.95rem;font-weight:500;
    color:var(--gl-ink-3);
    letter-spacing:-.005em;
    border-bottom:2px solid transparent;
    margin-bottom:-1px;
    transition:color .2s,border-color .2s;
}
.gl-tabs__btn:hover{color:var(--gl-ink);}
.gl-tabs__btn.is-active{color:var(--gl-ink);border-bottom-color:var(--gl-ink);}
.gl-tabs__panel{display:none;}
.gl-tabs__panel.is-active{display:block;animation:gl-fade .25s ease-out;}
@keyframes gl-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.gl-tabs__heading{
    font-family:var(--gl-font);
    font-size:clamp(1.4rem,2vw,1.85rem);
    letter-spacing:-.015em;
    color:var(--gl-ink);
    font-weight:600;
    margin:0 0 1.75rem;
}

/* --- Feature grid (Overview tab) --- */
.gl-feature-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:1.25rem;
}
.gl-feature-card{
    background:var(--gl-bone);
    border:1px solid var(--gl-rule);
    border-radius:6px;
    padding:1.5rem 1.35rem 1.6rem;
    display:flex;flex-direction:column;gap:.6rem;
    transition:border-color .2s,transform .2s;
}
.gl-feature-card:hover{border-color:var(--gl-ink-3);transform:translateY(-2px);}
.gl-feature-card__icon{
    width:48px;height:48px;object-fit:contain;
    margin-bottom:.35rem;
}
.gl-feature-card__title{
    font-family:var(--gl-font);
    font-size:1rem;font-weight:600;
    color:var(--gl-ink);
    margin:0;line-height:1.25;
}
.gl-feature-card__desc{
    font-size:.9rem;
    line-height:1.55;
    color:var(--gl-ink-2);
    margin:0;
}

/* --- Tech spec accordion (Tekniska data tab) --- */
.gl-tech{display:flex;flex-direction:column;gap:2rem;}
.gl-tech__section{
    background:var(--gl-bone);
    border:1px solid var(--gl-rule);
    border-radius:6px;
    overflow:hidden;
}
.gl-tech__section-title{
    margin:0;
    padding:1rem 1.5rem;
    background:var(--gl-white);
    border-bottom:1px solid var(--gl-rule);
    font-family:var(--gl-mono);
    font-size:.72rem;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:var(--gl-ink-3);
    font-weight:500;
}
.gl-tech__list{margin:0;padding:0;}
.gl-tech__row{
    display:grid;
    grid-template-columns:minmax(180px,.4fr) minmax(0,1fr);
    gap:1.5rem;
    padding:.9rem 1.5rem;
    border-bottom:1px solid var(--gl-rule);
    align-items:baseline;
}
.gl-tech__row:last-child{border-bottom:0;}
.gl-tech__row dt{
    font-family:var(--gl-font);
    font-size:.88rem;
    font-weight:500;
    color:var(--gl-ink);
    margin:0;
}
.gl-tech__row dd{
    font-family:var(--gl-font);
    font-size:.9rem;
    line-height:1.55;
    color:var(--gl-ink-2);
    margin:0;
}
@media (max-width:640px){
    .gl-tech__row{grid-template-columns:1fr;gap:.25rem;}
}

/* --- Variants (Produktvarianter tab) --- */
.gl-variants{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:1rem;
}
.gl-variant{
    background:var(--gl-bone);
    border:1px solid var(--gl-rule);
    border-radius:6px;
    padding:1.5rem 1.35rem;
    display:flex;flex-direction:column;gap:.5rem;
}
.gl-variant__name{
    font-family:var(--gl-font);
    font-size:1.05rem;
    font-weight:600;
    color:var(--gl-ink);
    margin:0;
}
.gl-variant__conn{margin:0;}
.gl-variant__conn .gl-mono{
    display:inline-block;
    font-size:.7rem;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:var(--gl-blue);
    border:1px solid rgba(61,111,176,.3);
    border-radius:999px;
    padding:.25rem .65rem;
    background:rgba(61,111,176,.05);
}
.gl-variant__summary{
    font-size:.88rem;
    line-height:1.55;
    color:var(--gl-ink-2);
    margin:0;
}

/* --- Related products --- */
.gl-product-related{
    padding:clamp(3rem,5vw,4.5rem) 0;
    background:var(--gl-bone);
}
.gl-related-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
    gap:1.25rem;
}
.gl-related-card{
    display:flex;flex-direction:column;gap:.75rem;
    padding:1.5rem 1.35rem;
    background:var(--gl-white);
    border:1px solid var(--gl-rule);
    border-radius:6px;
    text-decoration:none;
    color:var(--gl-ink);
    transition:border-color .2s,transform .2s;
}
.gl-related-card:hover{border-color:var(--gl-ink);transform:translateY(-2px);}
.gl-related-card__visual{
    aspect-ratio:1/1;
    background:var(--gl-bone);
    border-radius:4px;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.gl-related-card__visual img{
    max-width:80%;max-height:80%;
    width:auto;height:auto;
    object-fit:contain;
    mix-blend-mode:multiply;
}
.gl-related-card__title{
    font-family:var(--gl-font);
    font-size:1rem;
    font-weight:600;
    margin:0;
    color:var(--gl-ink);
}
.gl-related-card__cat{
    font-family:var(--gl-mono);
    font-size:.7rem;
    text-transform:uppercase;
    letter-spacing:.1em;
    color:var(--gl-ink-3);
    margin:0;
}

/* --- Editorial section after tabs --- */
.gl-product-editorial{
    padding:clamp(3rem,5vw,4.5rem) 0;
    background:var(--gl-bone);
}


/* ============================================================
   FAQ section (GEO-optimised, used in product tabs)
   ============================================================ */
.gl-faq{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--gl-rule)}
.gl-faq__item{border-bottom:1px solid var(--gl-rule);padding:1.25rem 0;transition:background .15s ease}
.gl-faq__item[open]{padding-bottom:1.5rem}
.gl-faq__q{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;font-family:var(--gl-sans);font-weight:600;font-size:clamp(1rem,1.6vw,1.125rem);color:var(--gl-ink);line-height:1.4;padding-right:2rem;position:relative}
.gl-faq__q::-webkit-details-marker{display:none}
.gl-faq__q::marker{content:""}
.gl-faq__q::after{content:"+";position:absolute;right:0;top:0;font-size:1.5rem;font-weight:300;line-height:1;color:var(--gl-ink);transition:transform .2s ease;flex-shrink:0}
.gl-faq__item[open] .gl-faq__q::after{content:"\u2212";transform:rotate(0deg)}
.gl-faq__a{padding-top:.75rem;color:var(--gl-ink);opacity:.85;font-size:.975rem;line-height:1.65;max-width:72ch}
.gl-faq__a p{margin:0 0 .75rem}
.gl-faq__a p:last-child{margin-bottom:0}
@media (max-width:640px){
  .gl-faq__q{font-size:1rem;gap:1rem;padding-right:1.5rem}
  .gl-faq__a{font-size:.9375rem}
}
