/* ==========================================================================
   qify 2026 — Consolidated Stylesheet
   colors_and_type.css + site.css + dark-mode + teal-amplify + mobile-first
   ========================================================================== */

/* Webfonts — only weights actually used */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,500;0,9..144,600;1,9..144,500&display=swap');

/* ==========================================================================
   LIGHT-MODE TOKENS (default)
   ========================================================================== */
:root {
  /* Brand palette */
  --qify-talent-blue:       #1C5090;
  --qify-sky-blue:          #33A8DF;
  --qify-teal:              #5CC5D1;
  --qify-cyan:              #53C8EB;
  --qify-white:             #FFFFFF;

  /* Talent Blue scale */
  --qify-talent-blue-900:   #0F3A6D;
  --qify-talent-blue-800:   #143F7C;
  --qify-talent-blue-700:   #1C5090;
  --qify-talent-blue-600:   #2863A8;
  --qify-talent-blue-500:   #3A7CC2;
  --qify-talent-blue-400:   #6CA0D4;
  --qify-talent-blue-300:   #9DBEE1;
  --qify-talent-blue-200:   #CEDDEF;
  --qify-talent-blue-100:   #E5EDF5;
  --qify-talent-blue-50:    #F4F8FC;

  /* Sky Blue scale */
  --qify-sky-700:           #1E8BC0;
  --qify-sky-600:           #2898CE;
  --qify-sky-500:           #33A8DF;
  --qify-sky-400:           #66BFE7;
  --qify-sky-300:           #99D4EF;
  --qify-sky-200:           #CCE9F7;
  --qify-sky-100:           #E6F4FB;

  /* Neutrals */
  --qify-ink:               #0C1F36;
  --qify-ink-soft:          #3C4A5E;
  --qify-muted:             #6B7A90;
  --qify-muted-soft:        #97A3B6;
  --qify-hairline:          #E5EDF5;
  --qify-surface-alt:       #F4F8FC;

  /* Semantic status */
  --qify-success:           #2FB56F;
  --qify-warning:           #E5A23D;
  --qify-error:             #D0464B;

  /* Semantic tokens */
  --fg-1:                   var(--qify-ink);
  --fg-2:                   var(--qify-ink-soft);
  --fg-3:                   var(--qify-muted);
  --fg-brand:               var(--qify-talent-blue);
  --fg-accent:              var(--qify-sky-blue);
  --fg-on-brand:            var(--qify-white);
  --bg-canvas:              var(--qify-white);
  --bg-alt:                 var(--qify-surface-alt);
  --bg-brand:               var(--qify-talent-blue);
  --bg-accent:              var(--qify-sky-blue);
  --border-default:         var(--qify-hairline);
  --border-strong:          var(--qify-talent-blue-200);
  --border-focus:           var(--qify-sky-blue);
  --link:                   var(--qify-sky-blue);
  --link-hover:             var(--qify-talent-blue);

  /* Gradients */
  --gradient-primary:       linear-gradient(135deg, #1C5090 0%, #33A8DF 100%);
  --gradient-soft:          linear-gradient(135deg, #5CC5D1 0%, #33A8DF 100%);
  --gradient-mark:          linear-gradient(140deg, #5CC5D1 0%, #33A8DF 45%, #1C5090 100%);
  --gradient-surface-wash:  linear-gradient(180deg, #F4F8FC 0%, #FFFFFF 100%);

  /* Typography */
  --font-display:           'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-body:              'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono:              ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;
  --font-editorial:         'Fraunces', Georgia, serif;

  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;

  --fs-h1:       clamp(42px, 5.2vw, 72px);
  --fs-h2:       clamp(30px, 3.4vw, 48px);
  --fs-h3:       clamp(20px, 2.2vw, 28px);
  --fs-h4:       1.25rem;
  --fs-body-lg:  1.125rem;
  --fs-body:     1rem;
  --fs-body-sm:  0.9375rem;
  --fs-caption:  0.8125rem;
  --fs-micro:    0.6875rem;

  --lh-tight:   1.1;
  --lh-snug:    1.25;
  --lh-normal:  1.5;
  --lh-loose:   1.65;

  --ls-tight:  -0.02em;
  --ls-normal: 0;
  --ls-wide:    0.08em;
  --ls-eyebrow: 0.12em;

  /* Spacing (4px base) */
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;
  --space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;
  --space-16:64px;--space-20:80px;--space-24:96px;--space-32:128px;

  /* Radii */
  --radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:22px;--radius-xl:32px;--radius-pill:999px;

  /* Shadows (cool-tinted) */
  --shadow-xs: 0 1px 2px rgba(28,80,144,.06);
  --shadow-sm: 0 2px 6px rgba(28,80,144,.08);
  --shadow-md: 0 4px 14px rgba(28,80,144,.10);
  --shadow-lg: 0 14px 40px rgba(28,80,144,.18);
  --shadow-xl: 0 24px 60px rgba(28,80,144,.22);
  --shadow-cta: 0 10px 24px rgba(51,168,223,.35);
  --shadow-pop: 0 20px 60px rgba(28,80,144,.14);
  --shadow-lift: 0 8px 28px rgba(28,80,144,.10);

  /* Motion */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast:    150ms;
  --dur-med:     250ms;
  --dur-slow:    400ms;

  /* Layout */
  --max: 1240px;
  --page-gutter: 32px;

  /* Widget bridge tokens */
  --qify-talent-blue-widget: var(--qify-talent-blue);
  --qify-sky-blue-widget:    var(--qify-sky-blue);
  --qify-teal-widget:        var(--qify-teal);
}

/* ==========================================================================
   DARK-MODE TOKENS — @media (prefers-color-scheme: dark)
   ========================================================================== */
@media (prefers-color-scheme: dark) {
  :root {
    --fg-1:             #E6ECF4;
    --fg-2:             #B4C2D4;
    --fg-3:             #7A8AA3;
    --fg-brand:         #E6ECF4;
    --fg-accent:        var(--qify-teal);
    --fg-on-brand:      #FFFFFF;

    --bg-canvas:        #0A1628;
    --bg-alt:           #0F1E2E;
    --bg-brand:         #0F1E2E;
    --bg-accent:        var(--qify-sky-blue);

    --border-default:   rgba(92,197,209,.14);
    --border-strong:    rgba(92,197,209,.25);
    --border-focus:     var(--qify-teal);

    --link:             var(--qify-sky-400);
    --link-hover:       var(--qify-teal);

    --qify-hairline:    rgba(255,255,255,.08);
    --qify-surface-alt: #0F1E2E;
    --qify-ink:         #E6ECF4;
    --qify-ink-soft:    #B4C2D4;
    --qify-muted:       #7A8AA3;
    --qify-muted-soft:  #5A6A80;

    --shadow-sm: 0 2px 6px rgba(0,0,0,.3);
    --shadow-md: 0 4px 14px rgba(0,0,0,.4);
    --shadow-lg: 0 14px 40px rgba(0,0,0,.5);
    --shadow-cta: 0 10px 24px rgba(51,168,223,.4);
    --shadow-lift: 0 8px 28px rgba(0,0,0,.35);
    --shadow-pop: 0 20px 60px rgba(0,0,0,.4);
  }
}

/* ==========================================================================
   BASE RESET & ELEMENTS
   ========================================================================== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:var(--lh-normal);
  color:var(--fg-1);
  background:var(--bg-canvas);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--fg-brand);
  letter-spacing:var(--ls-tight);
  margin:0;
}
h1{font-size:var(--fs-h1);line-height:var(--lh-tight);font-weight:var(--fw-bold)}
h2{font-size:var(--fs-h2);line-height:var(--lh-snug);font-weight:var(--fw-bold)}
h3{font-size:22px;line-height:1.3;font-weight:var(--fw-semibold)}
h4{font-size:var(--fs-h4);line-height:var(--lh-snug);font-weight:var(--fw-semibold)}
p{line-height:var(--lh-loose);color:var(--fg-2);text-wrap:pretty}

a{color:var(--link);text-decoration:none;transition:color var(--dur-fast) var(--ease-out)}
a:hover{color:var(--link-hover);text-decoration:underline;text-underline-offset:3px}

.eyebrow{
  font:var(--fw-semibold) 11px/1 var(--font-display);
  letter-spacing:.16em;text-transform:uppercase;color:var(--fg-accent);
}
.editorial{font-family:var(--font-editorial);font-style:italic;font-weight:500;color:var(--qify-sky-blue)}
.num-tabular{font-variant-numeric:tabular-nums}

code,.code{
  font-family:var(--font-mono);font-size:.9em;
  background:var(--qify-talent-blue-50);color:var(--qify-talent-blue);
  padding:2px 6px;border-radius:var(--radius-xs);
}

/* Focus ring */
:where(a,button,input,select,textarea,[tabindex]):focus-visible{
  outline:2px solid var(--border-focus);outline-offset:2px;border-radius:var(--radius-xs);
}

/* ==========================================================================
   LAYOUT
   ========================================================================== */
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 var(--page-gutter)}}

/* ==========================================================================
   NAV
   ========================================================================== */
.qnav{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--border-default);
}
.qnav-inner{
  max-width:var(--max);margin:0 auto;padding:0 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.qnav .logo{padding:14px 0;display:flex;align-items:center}
.qnav .logo img{height:28px}
.qnav ul{list-style:none;display:none;margin:0;padding:0;align-items:stretch}
.qnav li a{
  display:flex;align-items:center;padding:0 14px;
  color:var(--qify-talent-blue-900);font-weight:var(--fw-semibold);font-size:14px;
  text-decoration:none;white-space:nowrap;position:relative;
}
.qnav li a:hover{background:var(--bg-alt);text-decoration:none}
.qnav li a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-1px;
  height:3px;background:var(--qify-talent-blue);border-radius:3px 3px 0 0;
}
/* Teal underline on hover (spec) */
.qnav li a::before{
  content:"";position:absolute;left:14px;right:14px;bottom:-1px;
  height:2px;background:var(--qify-teal);border-radius:2px;
  transform:scaleX(0);transform-origin:left;transition:transform var(--dur-med) var(--ease-out);
}
.qnav li a:hover::before{transform:scaleX(1)}

.qnav-right{display:flex;align-items:center;gap:8px;padding:10px 0}

@media(min-width:768px){
  .qnav-inner{padding:0 var(--page-gutter)}
  .qnav .logo img{height:32px}
  .qnav ul{display:flex}
  .qnav li a{padding:0 18px}
}

@media (prefers-color-scheme: dark) {
  .qnav{
    background:rgba(10,22,40,.85);
    border-bottom:1px solid rgba(92,197,209,.1);
  }
  .qnav li a{color:var(--fg-1)}
  .qnav li a:hover{background:rgba(255,255,255,.05)}
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:var(--fw-semibold);font-size:14px;text-decoration:none;
  border:0;cursor:pointer;font-family:inherit;
  transition:all .2s var(--ease-out);
}
.btn:hover{text-decoration:none}
.btn-pri{
  background:var(--gradient-primary);color:#fff;
  padding:12px 22px;border-radius:var(--radius-pill);
  box-shadow:var(--shadow-cta);
}
.btn-pri:hover{transform:translateY(-1px);filter:brightness(1.05);color:#fff}
.btn-pri:active{transform:translateY(0);box-shadow:0 4px 12px rgba(51,168,223,.25)}
/* Gradient shimmer on hover */
.btn-pri{background-size:200% 100%;background-position:0 0}
.btn-pri:hover{background-position:100% 0}

.btn-sec{
  background:var(--bg-canvas);color:var(--qify-talent-blue);
  border:1.5px solid var(--border-strong);padding:10px 20px;border-radius:var(--radius-pill);
}
.btn-sec:hover{border-color:var(--qify-talent-blue);color:var(--qify-talent-blue)}
.btn-ghost{color:var(--qify-talent-blue-900);padding:10px 14px;border-radius:var(--radius-pill)}
.btn-ghost:hover{background:var(--bg-alt);color:var(--fg-brand)}
.btn-lg{font-size:15px;padding:16px 28px}

@media (prefers-color-scheme: dark) {
  .btn-pri{
    box-shadow:0 0 0 1px rgba(92,197,209,.3), 0 12px 30px rgba(51,168,223,.4);
  }
  .btn-sec{background:transparent;color:var(--fg-1);border-color:var(--border-default)}
  .btn-sec:hover{border-color:var(--qify-teal);color:var(--fg-1)}
  .btn-ghost{color:var(--fg-1)}
  .btn-ghost:hover{background:rgba(255,255,255,.05)}
  .cta-band .btn-pri{background:#fff;color:var(--qify-talent-blue)}
}

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.section{padding:64px 0}
.section.alt{background:var(--bg-alt)}
.section.dark{background:var(--qify-talent-blue-900);color:#fff}
.section.dark h2,.section.dark h3,.section.dark h4{color:#fff}
.section.dark p{color:var(--qify-sky-200)}
.section.dark .eyebrow{color:var(--qify-cyan)}
.section-head{max-width:760px;margin:0 auto 40px;text-align:center}
.section-head .eyebrow{display:block;margin-bottom:12px}
.section-head p{font-size:18px;margin-top:14px}

@media(min-width:768px){.section{padding:96px 0}.section-head{margin-bottom:56px}}

/* Section-alt wash with teal tint (spec) */
.section.alt{
  background:linear-gradient(180deg, var(--bg-alt), rgba(92,197,209,.08), var(--bg-canvas));
}
@media (prefers-color-scheme: dark) {
  .section.alt{background:var(--bg-alt)}
  .section.dark{background:#0A1628}
}

/* ==========================================================================
   CARDS
   ========================================================================== */
.card{
  background:var(--bg-canvas);
  border:1px solid var(--border-default);
  border-radius:var(--radius-lg);padding:24px;
  transition:all var(--dur-med) var(--ease-out);
}
.card:hover{
  transform:translateY(-3px);box-shadow:var(--shadow-lift);
  border-color:var(--qify-teal); /* teal on hover (spec) */
}
@media (prefers-color-scheme: dark) {
  .card{background:#172A3F;border-color:rgba(92,197,209,.14)}
  .card:hover{border-color:var(--qify-teal);box-shadow:var(--shadow-lift)}
}
@media(min-width:768px){.card{padding:28px}}

/* ==========================================================================
   GRIDS — mobile-first stacking
   ========================================================================== */
.grid-2,.grid-3,.grid-4{display:grid;gap:16px}
@media(min-width:768px){
  .grid-2{grid-template-columns:1fr 1fr;gap:24px}
  .grid-3{grid-template-columns:repeat(3,1fr);gap:20px}
  .grid-4{grid-template-columns:repeat(2,1fr);gap:20px}
}
@media(min-width:1080px){
  .grid-4{grid-template-columns:repeat(4,1fr)}
}

/* ==========================================================================
   CTA BAND
   ========================================================================== */
.cta-band{
  background:var(--qify-talent-blue-900);color:#fff;
  padding:64px 0;text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(51,168,223,.22),transparent 60%);
}
.cta-band h2{color:#fff;margin-bottom:14px;position:relative;z-index:1}
.cta-band p{color:var(--qify-sky-200);max-width:620px;margin:0 auto 28px;font-size:17px;position:relative;z-index:1}
.cta-band .btn-pri{position:relative;z-index:1}
@media(min-width:768px){.cta-band{padding:80px 0}}

/* ==========================================================================
   PILLS & BADGES
   ========================================================================== */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:var(--radius-pill);
  background:var(--bg-alt);color:var(--qify-talent-blue);
  font-size:12px;font-weight:var(--fw-semibold);border:1px solid var(--border-default);
}
.pill.live{background:rgba(47,181,111,.1);color:#1E8A52;border-color:rgba(47,181,111,.2)}
.pill.live .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--qify-teal); /* teal live dot (spec) */
  box-shadow:0 0 8px var(--qify-teal);
  animation:qify-pulse 2.2s ease-in-out infinite;
}
@keyframes qify-pulse{0%,100%{opacity:1}50%{opacity:.45}}

@media (prefers-color-scheme: dark) {
  .pill{background:rgba(92,197,209,.1);color:var(--qify-teal);border-color:rgba(92,197,209,.2)}
}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq{
  background:var(--bg-canvas);border:1px solid var(--border-default);
  border-radius:var(--radius-md);padding:20px 24px;
}
.faq+.faq{margin-top:10px}
.faq summary{
  cursor:pointer;font-weight:var(--fw-semibold);color:var(--fg-brand);
  list-style:none;display:flex;justify-content:space-between;gap:12px;font-size:16px;
}
.faq summary::after{content:"+";color:var(--qify-sky-blue);font-size:22px;font-weight:300}
.faq[open] summary::after{content:"\2212"}
.faq p{margin:14px 0 0;font-size:14px}
.faq-list{max-width:820px;margin:0 auto}

@media (prefers-color-scheme: dark) {
  .faq{background:#172A3F;border-color:rgba(92,197,209,.14)}
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.qfoot{
  background:linear-gradient(165deg,#0F3A6D 0%,#1C5090 55%,#143F7C 100%);
  color:#fff;padding:48px 0 20px;position:relative;overflow:hidden;
}
/* Sky glow blob */
.qfoot::before{
  content:"";position:absolute;right:-160px;top:-140px;width:380px;height:380px;
  border-radius:50%;background:radial-gradient(circle,rgba(51,168,223,.3),transparent 70%);
}
/* Teal glow blob (spec) */
.qfoot::after{
  content:"";position:absolute;left:-100px;bottom:-180px;width:340px;height:340px;
  border-radius:50%;background:radial-gradient(circle,rgba(92,197,209,.22),transparent 70%);
}
.qfoot-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr;gap:32px;
}
.qfoot .brand img{height:36px;filter:brightness(0) invert(1)}
.qfoot .brand p{color:var(--qify-sky-200);font-size:13px;max-width:280px;margin:14px 0 16px;line-height:1.6}
.qfoot .badge{
  display:inline-flex;gap:8px;align-items:center;
  background:rgba(51,168,223,.18);border:1px solid rgba(102,191,231,.35);
  color:var(--qify-sky-200);padding:6px 12px;border-radius:var(--radius-pill);
  font-size:11px;font-weight:var(--fw-semibold);letter-spacing:.04em;
}
.qfoot .badge .dot{
  width:6px;height:6px;background:var(--qify-teal);border-radius:50%;
  box-shadow:0 0 8px var(--qify-teal);
}
.qfoot .cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.qfoot h4{
  color:var(--qify-teal); /* teal section headers (spec) */
  font:var(--fw-semibold) 11px/1.4 var(--font-display);
  letter-spacing:.14em;text-transform:uppercase;margin:0 0 14px;
  padding-bottom:10px;border-bottom:1px solid rgba(92,197,209,.25);
}
.qfoot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.qfoot li a{color:#fff;text-decoration:none;font-size:13px}
.qfoot li a:hover{color:var(--qify-cyan)}
.qfoot-copy{
  position:relative;z-index:1;border-top:1px solid rgba(92,197,209,.18);
  margin-top:32px;padding-top:18px;display:flex;flex-wrap:wrap;
  justify-content:space-between;color:var(--qify-talent-blue-300);font-size:11px;gap:12px;
}
.qfoot-copy .socials{display:flex;gap:8px}
.qfoot-copy .socials a{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);border-radius:50%;
  color:var(--qify-teal);font-size:11px;font-weight:var(--fw-bold);text-decoration:none;
}
.qfoot-copy .socials a:hover{background:var(--qify-sky-blue);color:#fff}

@media(min-width:768px){
  .qfoot{padding:64px 0 24px}
  .qfoot-inner{grid-template-columns:1.2fr 2.4fr;gap:56px}
  .qfoot .cols{grid-template-columns:repeat(4,1fr);gap:28px}
}

@media (prefers-color-scheme: dark) {
  /* Blobs kräftiger in dark mode (+10% opacity) */
  .qfoot::before{background:radial-gradient(circle,rgba(51,168,223,.4),transparent 70%)}
  .qfoot::after{background:radial-gradient(circle,rgba(92,197,209,.32),transparent 70%)}
}

/* ==========================================================================
   LOGO TICKER / MARQUEE
   ========================================================================== */
.logo-ticker{
  padding:36px 0;border-top:1px solid var(--border-default);
  border-bottom:1px solid var(--border-default);
  background:var(--bg-canvas);position:relative;overflow:hidden;
}
.logo-ticker .eyebrow{
  display:block;text-align:center;font-size:12px;color:var(--fg-3);
  letter-spacing:.14em;text-transform:uppercase;font-weight:var(--fw-semibold);margin-bottom:20px;
}
.logo-ticker .viewport{
  position:relative;overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.logo-ticker .track{
  display:flex;gap:48px;width:max-content;animation:qify-marquee 60s linear infinite;
}
.logo-ticker:hover .track{animation-play-state:paused}
.logo-ticker .mark{
  flex:none;color:var(--fg-3);height:40px;display:flex;align-items:center;
  justify-content:center;white-space:nowrap;font-family:var(--font-display);
  transition:color .2s;
}
.logo-ticker .mark:hover{color:var(--fg-brand)}
/* brand-specific treatments */
.m-aok{font-weight:800;font-size:26px;letter-spacing:.02em}
.m-brenntag{font-weight:700;font-size:22px;letter-spacing:-.01em;text-transform:lowercase}
.m-clyde{font-family:Georgia,serif;font-weight:400;font-size:20px;letter-spacing:.02em}
.m-fressnapf{font-weight:800;font-size:22px;letter-spacing:-.01em}
.m-ndr{font-weight:900;font-size:26px;letter-spacing:.04em}
.m-diffu{font-family:Georgia,serif;font-style:italic;font-weight:500;font-size:20px}
.m-terhell{font-weight:600;font-size:20px;letter-spacing:.12em;text-transform:uppercase}
.m-sg{font-family:Georgia,serif;font-weight:400;font-size:18px;letter-spacing:.22em;text-transform:uppercase}
.m-sasol{font-weight:800;font-size:24px;letter-spacing:.06em;text-transform:lowercase}
.m-toyota{font-weight:700;font-size:22px;letter-spacing:.32em;text-transform:uppercase}
.m-zeppelin{font-family:Georgia,serif;font-weight:400;font-size:22px;letter-spacing:.04em}
.m-ude{font-weight:600;font-size:14px;letter-spacing:.02em;line-height:1.15;text-align:left;max-width:200px;white-space:normal}
.m-landgard{font-weight:700;font-size:22px;letter-spacing:-.01em}
@keyframes qify-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.logo-ticker .track{animation:none;flex-wrap:wrap;justify-content:center;width:100%}}

@media(min-width:768px){.logo-ticker{padding:44px 0}.logo-ticker .track{gap:64px}}

/* ==========================================================================
   HERO STATS — gradient text fill with teal (spec)
   ========================================================================== */
.hero-stat-num{
  font-family:var(--font-display);font-size:32px;font-weight:var(--fw-bold);
  letter-spacing:-.01em;
  background:linear-gradient(135deg, var(--qify-teal), var(--qify-sky-blue));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ==========================================================================
   CHECK ICONS in lists — teal (spec)
   ========================================================================== */
.check-list li::before{
  content:"\2713";color:var(--qify-teal);font-weight:700;margin-right:8px;
}

/* ==========================================================================
   STICKY MOBILE CTA
   ========================================================================== */
.sticky-mobile-cta{
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  background:rgba(15,58,109,.95);backdrop-filter:blur(10px);
  padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:12px;
  border-top:1px solid rgba(92,197,209,.2);
  transform:translateY(100%);
}
.sticky-mobile-cta.visible{transform:translateY(0)}
.sticky-mobile-cta .btn-pri{
  width:100%;max-width:360px;justify-content:center;
  padding:14px 24px;font-size:15px;
}
@media(min-width:768px){.sticky-mobile-cta{display:none!important}}

/* ==========================================================================
   CHAT WIDGET SECTION
   ========================================================================== */
.chat-section{padding:48px 0}
.chat-section .chat-host{max-width:720px;margin:0 auto}
.chat-section .chat-host #qify-chat{min-height:480px}
.chat-section .chat-note{
  font-size:12px;color:var(--fg-3);text-align:center;margin-top:12px;
}
.chat-section .chat-note a{color:var(--link)}

@media (prefers-color-scheme: dark) {
  .chat-section{background:var(--bg-alt)}
}

/* ==========================================================================
   LIVE-MATCHING WOW SECTION
   ========================================================================== */
.live-matching{
  position:relative;overflow:hidden;padding:80px 0;
  background:var(--qify-talent-blue-900);color:#fff;text-align:center;
}
.live-matching canvas,.live-matching .network-bg{
  position:absolute;inset:0;width:100%;height:100%;
}
.live-matching .overlay{position:relative;z-index:2}
.live-matching .live-counter{
  font-size:clamp(28px,4vw,48px);font-weight:var(--fw-bold);
  font-family:var(--font-display);margin-bottom:8px;
  font-variant-numeric:tabular-nums;
}
.live-matching .live-dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  background:var(--qify-teal);box-shadow:0 0 12px var(--qify-teal);
  animation:qify-pulse 2.2s ease-in-out infinite;
  vertical-align:middle;margin-right:10px;
}
.live-matching .sub{color:var(--qify-sky-200);font-size:17px;margin-bottom:28px}

/* ==========================================================================
   KOMPASS / MODULE MATRIX (from sap-dienstleistungen)
   ========================================================================== */
.kompass-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;border-bottom:1px solid var(--border-default);padding-bottom:0}
.kompass-tab{
  background:transparent;border:0;padding:10px 14px;
  font:var(--fw-semibold) 13px/1 var(--font-display);color:var(--fg-3);
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;
  letter-spacing:.02em;transition:color var(--dur-fast),border-color var(--dur-fast);font-family:inherit;
}
.kompass-tab:hover{color:var(--fg-brand)}
.kompass-tab[aria-selected="true"]{color:var(--fg-brand);border-bottom-color:var(--qify-sky-blue)}
.kompass-panel{display:none}
.kompass-panel.on{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.mod-group{border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-canvas);margin-bottom:12px;overflow:hidden}
.mod-group summary{list-style:none;cursor:pointer;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;user-select:none}
.mod-group summary::-webkit-details-marker{display:none}
.mod-group summary:hover{background:var(--bg-alt)}
.mod-group[open] summary{background:var(--bg-alt);border-bottom:1px solid var(--border-default)}
.mod-group .code{font:var(--fw-bold) 13px/1 var(--font-display);letter-spacing:.06em;color:var(--qify-sky-blue);background:var(--qify-sky-100);padding:6px 10px;border-radius:6px;flex:none}
.mod-group .title{font:var(--fw-semibold) 16px/1.3 var(--font-display);color:var(--fg-brand);flex:1}
.mod-group .de{font-size:13px;color:var(--fg-3);font-weight:var(--fw-medium)}
.mod-group .chev{color:var(--fg-3);font-size:18px;transition:transform .2s}
.mod-group[open] .chev{transform:rotate(180deg)}
.mod-body{padding:8px 20px 20px}
.mod-sub{display:grid;grid-template-columns:1fr;gap:4px;padding:12px 0;list-style:none;margin:0}
.mod-sub li{padding:6px 0;border-bottom:1px dashed var(--border-default);display:flex;gap:10px;align-items:baseline;font-size:13px}
.mod-sub li:last-child{border-bottom:0}
.mod-sub code{font:var(--fw-bold) 11px/1 var(--font-display);letter-spacing:.04em;color:var(--qify-talent-blue);background:var(--bg-alt);padding:3px 7px;border-radius:4px;flex:none}
.mod-sub span{color:var(--fg-2)}
.mod-sub b{color:var(--fg-brand);font-weight:var(--fw-semibold)}
.kompass-intro{max-width:820px;margin-bottom:32px;font-size:16px;color:var(--fg-2)}
.kompass-expand{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-strong);border-radius:var(--radius-pill);padding:8px 16px;font:var(--fw-medium) 13px/1 var(--font-display);color:var(--fg-brand);cursor:pointer;margin-left:auto;font-family:inherit}
.kompass-expand:hover{background:var(--bg-alt)}
.kompass-actions{display:flex;justify-content:flex-end;gap:10px;margin:-12px 0 18px}
.strengths{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-default)}
.strengths>div{text-align:center}
.strengths .num{font:var(--fw-bold) 32px/1 var(--font-display);color:var(--fg-brand);letter-spacing:-.02em}
.strengths .lbl{font-size:13px;color:var(--fg-3);margin-top:8px}
@media(min-width:768px){
  .kompass-tab{padding:12px 18px;font-size:14px}
  .mod-group summary{padding:20px 24px}
  .mod-body{padding:8px 24px 24px}
  .mod-sub{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:6px 28px}
  .strengths{grid-template-columns:repeat(4,1fr);margin-top:40px;padding-top:32px}
  .strengths .num{font-size:40px}
}

@media (prefers-color-scheme: dark) {
  .mod-group{background:#172A3F;border-color:rgba(92,197,209,.14)}
  .mod-group .code{background:rgba(51,168,223,.15);color:var(--qify-sky-blue)}
  .mod-sub code{background:rgba(92,197,209,.1);color:var(--qify-teal)}
  .kompass-tab[aria-selected="true"]{color:var(--fg-1);border-bottom-color:var(--qify-teal)}
}

/* ==========================================================================
   LEGAL PAGES (impressum, datenschutz, ki-hinweis)
   ========================================================================== */
.legal-body{max-width:820px;margin:0 auto;padding:42px 20px 80px}
.legal-body h1{font-size:clamp(28px,4vw,40px);margin:0 0 18px}
.legal-body h2{margin-top:32px;margin-bottom:8px;font-size:1.12rem;letter-spacing:-.005em}
.legal-body p,.legal-body li{color:var(--fg-2);line-height:1.7}
.legal-body ul,.legal-body ol{padding-left:22px}
.legal-body li{margin:6px 0}
.legal-body table{width:100%;border-collapse:collapse;margin:14px 0;border:1px solid var(--border-default);border-radius:var(--radius-sm);overflow:hidden}
.legal-body th,.legal-body td{padding:8px 12px;border-bottom:1px solid var(--border-default);text-align:left}
.legal-body strong{color:var(--fg-1)}
.legal-body .toc{border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:14px 16px;background:var(--bg-alt);margin:18px 0 28px;font-size:.95rem}
.legal-body .toc a{color:var(--link);text-decoration:none}
.legal-body .toc a:hover{text-decoration:underline}
.breadcrumbs{color:var(--fg-3);font-size:.88rem;margin-bottom:18px}
.breadcrumbs a{color:var(--link);text-decoration:none}
.stand{color:var(--fg-3);font-size:.85rem;margin-top:30px;padding-top:12px;border-top:1px dashed var(--border-default)}
.info-card{border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-alt);padding:16px 18px;margin:14px 0}
.info-card h3{margin:0 0 6px;font-size:1rem}
.info-card p{margin:0;font-size:.95rem}
.info-card dl{display:grid;grid-template-columns:max-content 1fr;gap:4px 18px;margin:10px 0 0}
.info-card dt{color:var(--fg-3)}
.info-card dd{margin:0}

@media(min-width:768px){.legal-body{padding:42px var(--page-gutter) 80px}}
@media (prefers-color-scheme: dark) {
  .info-card{background:#172A3F;border-color:rgba(92,197,209,.14)}
}

/* ==========================================================================
   PROCESS TIMELINE (from prozess.html)
   ========================================================================== */
.process-timeline{position:relative}
.process-line{
  position:absolute;left:42px;top:10px;bottom:10px;width:2px;
  background:linear-gradient(180deg,var(--qify-teal),var(--qify-sky-blue),var(--qify-talent-blue));
  border-radius:2px;
}
.process-step{display:grid;grid-template-columns:86px 1fr;gap:20px;align-items:start}
.process-num{
  width:64px;height:64px;border-radius:50%;background:var(--bg-canvas);
  border:2px solid var(--qify-sky-blue);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-editorial);font-size:24px;font-weight:var(--fw-semibold);
  color:var(--fg-brand);position:relative;z-index:1;
}
@media(min-width:768px){
  .process-step{grid-template-columns:86px 1fr;gap:28px}
  .process-num{width:86px;height:86px;font-size:30px}
}

/* ==========================================================================
   SCROLL REVEAL (data-reveal attribute)
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
[data-reveal].revealed{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}

/* ==========================================================================
   CURSOR SPOTLIGHT (dark sections)
   ========================================================================== */
.cursor-spotlight{
  position:absolute;pointer-events:none;width:400px;height:400px;
  border-radius:50%;opacity:0;
  background:radial-gradient(circle,rgba(92,197,209,.15),transparent 70%);
  mix-blend-mode:screen;transition:opacity .3s;z-index:1;
}
@media(pointer:coarse){.cursor-spotlight{display:none}}

/* ==========================================================================
   FOOTER GLOW BREATHING
   ========================================================================== */
@keyframes glow-breathe{
  0%,100%{opacity:.2;transform:scale(1)}
  50%{opacity:.35;transform:scale(1.08)}
}
.qfoot::before,.qfoot::after{
  animation:glow-breathe 30s ease-in-out infinite;
}
.qfoot::after{animation-delay:-15s}

/* ==========================================================================
   CARD TILT (pointer: fine only)
   ========================================================================== */
@media(pointer:fine){
  .card[data-tilt]{transition:transform var(--dur-med) var(--ease-out);transform-style:preserve-3d}
}
@media(pointer:coarse){.card[data-tilt]{transform:none!important}}

/* ==========================================================================
   UTILITY — sr-only
   ========================================================================== */
.sr-only{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ==========================================================================
   MOBILE OVERRIDES (375px critical)
   Force inline grids to stack on narrow viewports
   ========================================================================== */
@media(max-width:767px){
  /* Force all inline 2-col/3-col grids to single column */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1.1fr"],
  [style*="grid-template-columns: 1fr 1.1fr"],
  [style*="grid-template-columns:1.15fr 1fr"],
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr 1fr"],
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns: repeat(4"]{
    grid-template-columns:1fr!important;
  }

  /* Founder card on ueber-uns */
  [style*="grid-template-columns:160px 1fr"]{
    grid-template-columns:1fr!important;
    text-align:center;
  }

  /* Stats row */
  [style*="display:flex"][style*="gap:40px"]{
    gap:24px!important;
  }

  /* Hero H1 sizing floor */
  h1{font-size:clamp(32px,8vw,56px)!important}

  /* Touch targets */
  .btn{min-height:44px}
  .qnav li a{min-height:44px}
  .faq summary{min-height:44px;padding:14px 16px}
  input,select,textarea{min-height:44px}

  /* Process timeline compact */
  .process-step{grid-template-columns:60px 1fr;gap:14px}
  .process-num{width:60px;height:60px;font-size:22px}
  .process-line{left:30px}

  /* Sticky CTA safe zone — no overlap with footer */
  .sticky-mobile-cta{padding-bottom:max(12px,env(safe-area-inset-bottom))}
  body{padding-bottom:72px} /* space for sticky CTA */

  /* Nav: hide desktop links, keep CTA */
  .qnav ul{display:none!important}
  .qnav .btn-ghost{display:none}
  .qnav .logo img{height:26px}
  .qnav-inner{padding:0 16px}

  /* Chat widget section */
  .chat-section .chat-host #qify-chat{min-height:420px}

  /* Legal pages */
  .info-card dl{grid-template-columns:1fr}
}
