/* ===== KUNDENPORTAL – DARK BLUE PREMIUM THEME ===== */

    /* HERO: Deep dark navy with blue glow accents */
    .kp-hero {
      background: #020c1b;
      min-height: 100vh;
      padding: 120px 0 80px;
      position: relative;
      overflow: hidden;
    }
    .kp-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(ellipse 55% 60% at 18% 40%, rgba(37,99,235,.20) 0%, transparent 70%),
        radial-gradient(ellipse 40% 50% at 85% 65%, rgba(99,102,241,.13) 0%, transparent 60%),
        radial-gradient(ellipse 30% 35% at 58% 15%, rgba(96,165,250,.08) 0%, transparent 50%);
    }
    /* Dot grid overlay */
    .kp-hero-grid {
      position: absolute;
      inset: 0;
      background-image: radial-gradient(circle, rgba(96,165,250,.12) 1px, transparent 1px);
      background-size: 32px 32px;
      -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 20%, transparent 100%);
      mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 20%, transparent 100%);
      pointer-events: none;
    }
    /* Decorative corner glow */
    .kp-hero::after {
      content: '';
      position: absolute;
      top: -150px; right: -150px;
      width: 500px; height: 500px;
      background: radial-gradient(circle, rgba(37,99,235,.10) 0%, transparent 65%);
      border-radius: 50%;
    }
    .kp-hero-inner {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 5rem;
      align-items: center;
      position: relative;
      z-index: 1;
    }
    .kp-badge {
      display: inline-flex; align-items: center; gap: .5rem;
      background: rgba(37,99,235,.12);
      border: 1px solid rgba(59,130,246,.28);
      color: #60a5fa;
      border-radius: 99px;
      padding: .4rem 1rem;
      font-size: .8rem; font-weight: 700; letter-spacing: .04em;
      margin-bottom: 1.5rem;
    }
    .kp-title {
      font-size: clamp(2.2rem, 3.8vw, 3.2rem);
      font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 1.25rem;
    }
    .kp-grad { background: linear-gradient(135deg, #60a5fa, #3b82f6, #818cf8); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
    .kp-sub { font-size: 1.05rem; color: rgba(255,255,255,.62); line-height: 1.7; margin-bottom: 2rem; }
    .kp-hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; }
    .kp-btn-p {
      background: linear-gradient(135deg, #2563eb, #3b82f6);
      color: #fff; border: none; border-radius: 10px;
      padding: .85rem 2rem; font-size: .95rem; font-weight: 700;
      text-decoration: none; display: inline-block;
      box-shadow: 0 0 30px rgba(37,99,235,.35);
    }
    .kp-btn-g {
      background: transparent; color: rgba(255,255,255,.72);
      border: 1px solid rgba(255,255,255,.18);
      border-radius: 10px; padding: .85rem 2rem;
      font-size: .95rem; font-weight: 600;
      text-decoration: none; display: inline-block;
    }

    /* Portal browser mockup */
    .kp-browser-wrapper {
      position: relative;
    }
    .kp-browser-glow {
      position: absolute;
      inset: -30px;
      background: radial-gradient(ellipse 70% 60% at 50% 60%, rgba(37,99,235,.18) 0%, transparent 70%);
      pointer-events: none;
      z-index: 0;
    }
    .kp-browser-float {
      position: absolute;
      top: -16px; right: -16px;
      background: #fff;
      border-radius: 12px;
      padding: .65rem 1rem;
      box-shadow: 0 8px 28px rgba(0,0,0,.15), 0 2px 6px rgba(0,0,0,.08);
      display: flex; align-items: center; gap: .5rem;
      font-size: .72rem; font-weight: 700; color: #0f172a;
      z-index: 10;
      white-space: nowrap;
    }
    .kp-browser-float-dot { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.2); flex-shrink: 0; }
    .kp-browser {
      background: #fff;
      border-radius: 18px;
      border: 1px solid rgba(255,255,255,.15);
      box-shadow: 0 32px 80px rgba(0,0,0,.35), 0 4px 16px rgba(37,99,235,.15), inset 0 1px 0 rgba(255,255,255,.9);
      overflow: hidden;
      position: relative;
      z-index: 1;
    }
    .kp-browser-bar {
      background: #f8fafc;
      border-bottom: 1px solid #e2e8f0;
      padding: .75rem 1rem;
      display: flex;
      align-items: center;
      gap: .75rem;
    }
    .kp-browser-dots { display: flex; gap: .4rem; }
    .kp-browser-dot { width: 10px; height: 10px; border-radius: 50%; }
    .kp-browser-url {
      flex: 1; background: #fff; border: 1px solid #e2e8f0;
      border-radius: 6px; padding: .3rem .75rem;
      font-size: .72rem; color: #64748b;
    }
    .kp-browser-body { padding: 1.5rem; }
    .kp-portal-header {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 1.25rem;
    }
    .kp-portal-client { font-size: .85rem; font-weight: 800; color: #0f172a; }
    .kp-portal-sub { font-size: .7rem; color: #64748b; }
    .kp-portal-badge { background: #dcfce7; color: #16a34a; border-radius: 6px; padding: .25rem .65rem; font-size: .7rem; font-weight: 700; }
    .kp-portal-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: .65rem; margin-bottom: 1.25rem; }
    .kp-portal-stat { background: #f8fafc; border-radius: 10px; padding: .75rem; text-align: center; border: 1px solid #e2e8f0; }
    .kp-portal-stat-val { font-size: 1rem; font-weight: 800; color: #0f172a; display: block; }
    .kp-portal-stat-lbl { font-size: .6rem; color: #94a3b8; }
    .kp-portal-table-head { display: grid; grid-template-columns: 1fr 60px 70px 80px; gap: .5rem; padding: .4rem .75rem; }
    .kp-portal-table-head-cell { font-size: .6rem; font-weight: 700; color: #94a3b8; text-transform: uppercase; letter-spacing: .04em; }
    .kp-portal-row {
      display: grid; grid-template-columns: 1fr 60px 70px 80px;
      gap: .5rem; padding: .6rem .75rem;
      border-radius: 8px; align-items: center;
      background: #eff6ff; border: 1px solid #bfdbfe;
      margin-bottom: .4rem;
    }
    .kp-portal-row-name { font-size: .72rem; font-weight: 700; color: #0f172a; }
    .kp-portal-row-sub { font-size: .6rem; color: #64748b; }
    .kp-portal-row-hrs { font-size: .75rem; font-weight: 700; color: #0f172a; }
    .kp-portal-row-status { font-size: .6rem; font-weight: 700; color: #1d4ed8; }
    .kp-portal-row-btns { display: flex; gap: .3rem; }
    .kp-portal-ok { background: #dcfce7; color: #16a34a; border: none; border-radius: 5px; padding: .25rem .5rem; font-size: .6rem; font-weight: 700; cursor: pointer; }
    .kp-portal-deny { background: #fee2e2; color: #dc2626; border: none; border-radius: 5px; padding: .25rem .5rem; font-size: .6rem; font-weight: 700; cursor: pointer; }

    /* Trust statistics strip */
    .kp-trust { background: #010e1e; padding: 2.5rem 0; border-top: 1px solid rgba(37,99,235,.15); border-bottom: 1px solid rgba(37,99,235,.15); }
    .kp-trust-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align: center; }
    .kp-trust-num {
      font-size: 2.2rem; font-weight: 800;
      background: linear-gradient(135deg, #60a5fa, #3b82f6);
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
      display: block; margin-bottom: .25rem;
    }
    .kp-trust-lbl { font-size: .82rem; color: rgba(255,255,255,.5); }

    /* Portal walkthrough */
    .kp-walkthrough { padding: 6rem 0; background: #fff; }
    .kp-wt-title { text-align: center; font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; color: #0f172a; margin-bottom: .5rem; }
    .kp-wt-sub { text-align: center; color: #64748b; max-width: 560px; margin: 0 auto 4rem; font-size: .95rem; line-height: 1.7; }
    .kp-wt-steps { display: flex; flex-direction: column; gap: 4rem; }
    .kp-wt-step {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 4rem;
      align-items: center;
    }
    .kp-wt-step.reverse { direction: rtl; }
    .kp-wt-step.reverse > * { direction: ltr; }
    .kp-wt-step-num {
      display: inline-flex; align-items: center; gap: .5rem;
      background: #eff6ff; color: #1d4ed8;
      border-radius: 99px; padding: .3rem .9rem;
      font-size: .78rem; font-weight: 800;
      margin-bottom: .75rem;
    }
    .kp-wt-step-content h3 { font-size: 1.3rem; font-weight: 800; color: #0f172a; margin-bottom: .75rem; }
    .kp-wt-step-content p { font-size: .9rem; color: #64748b; line-height: 1.7; margin-bottom: 1.25rem; }
    .kp-wt-features { display: flex; flex-direction: column; gap: .5rem; }
    .kp-wt-feature { display: flex; align-items: flex-start; gap: .6rem; font-size: .85rem; color: #475569; }
    .kp-wt-feature-icon { width: 22px; height: 22px; border-radius: 6px; background: #eff6ff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .05rem; }
    .kp-wt-screen {
      background: #f8fafc;
      border-radius: 20px;
      padding: 1.5rem;
      border: 1px solid #e2e8f0;
    }

    /* Self-service features */
    .kp-selfservice { padding: 6rem 0; background: #0f172a; }
    .kp-ss-title { text-align: center; color: #fff; font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; margin-bottom: .5rem; }
    .kp-ss-sub { text-align: center; color: rgba(255,255,255,.5); max-width: 560px; margin: 0 auto 3.5rem; font-size: .95rem; }
    .kp-ss-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
    .kp-ss-card {
      background: rgba(255,255,255,.05);
      border: 1px solid rgba(255,255,255,.08);
      border-radius: 16px;
      padding: 1.75rem;
    }
    .kp-ss-icon { width: 50px; height: 50px; border-radius: 14px; background: rgba(59,130,246,.15); display: flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; border: 1px solid rgba(59,130,246,.2); }
    .kp-ss-card h3 { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: .4rem; }
    .kp-ss-card p { font-size: .83rem; color: rgba(255,255,255,.5); line-height: 1.6; }
    .kp-ss-tag { display: inline-block; background: rgba(59,130,246,.15); color: #93c5fd; border-radius: 6px; padding: .2rem .6rem; font-size: .7rem; font-weight: 700; margin-top: .75rem; }

    /* Security section */
    .kp-security { padding: 6rem 0; background: #f8fafc; }
    .kp-sec-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
    .kp-sec-left h2 { font-size: clamp(1.7rem, 2.5vw, 2.2rem); font-weight: 800; color: #0f172a; margin-bottom: 1rem; }
    .kp-sec-left p { font-size: .95rem; color: #64748b; line-height: 1.7; margin-bottom: 2rem; }
    .kp-sec-points { display: flex; flex-direction: column; gap: 1rem; }
    .kp-sec-point { display: flex; gap: 1rem; }
    .kp-sec-point-icon { width: 42px; height: 42px; border-radius: 12px; background: #eff6ff; border: 1px solid #bfdbfe; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .kp-sec-point h4 { font-size: .9rem; font-weight: 700; color: #0f172a; margin-bottom: .2rem; }
    .kp-sec-point p { font-size: .82rem; color: #64748b; line-height: 1.5; }
    .kp-sec-right {
      background: #fff;
      border-radius: 24px;
      padding: 2.5rem;
      border: 1px solid #e2e8f0;
      box-shadow: 0 10px 40px rgba(0,0,0,.05);
    }
    .kp-sec-right h3 { font-size: 1rem; font-weight: 700; color: #0f172a; margin-bottom: 1.5rem; }
    .kp-access-item { display: flex; align-items: flex-start; gap: .75rem; margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid #f1f5f9; }
    .kp-access-item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
    .kp-access-icon { width: 36px; height: 36px; border-radius: 10px; background: #eff6ff; border: 1px solid #bfdbfe; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .05rem; }
    .kp-access-title { font-size: .85rem; font-weight: 700; color: #0f172a; margin-bottom: .2rem; }
    .kp-access-desc { font-size: .78rem; color: #64748b; line-height: 1.5; }
    .kp-access-badge { margin-left: auto; flex-shrink: 0; }
    .kp-badge-yes { background: #dcfce7; color: #16a34a; border-radius: 99px; padding: .2rem .6rem; font-size: .7rem; font-weight: 700; }
    .kp-badge-no { background: #fee2e2; color: #dc2626; border-radius: 99px; padding: .2rem .6rem; font-size: .7rem; font-weight: 700; }

    /* Steps */
    .kp-steps { padding: 6rem 0; background: #fff; }
    .kp-steps-title { text-align: center; color: #0f172a; font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; margin-bottom: .5rem; }
    .kp-steps-sub { text-align: center; color: #64748b; max-width: 560px; margin: 0 auto 3.5rem; font-size: .95rem; }
    .kp-steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
    .kp-step {
      text-align: center;
      background: #f8fafc;
      border-radius: 20px;
      padding: 2.5rem 2rem;
      border: 1px solid #e2e8f0;
    }
    .kp-step-circle {
      width: 64px; height: 64px; border-radius: 50%;
      background: linear-gradient(135deg, #2563eb, #3b82f6);
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 1.25rem;
    }
    .kp-step h3 { font-size: 1rem; font-weight: 700; color: #0f172a; margin-bottom: .5rem; }
    .kp-step p { font-size: .83rem; color: #64748b; line-height: 1.6; }

    /* CTA */
    .kp-cta {
      padding: 6rem 0;
      background: linear-gradient(135deg, #1e40af, #2563eb, #1e40af);
    }
    .kp-cta-inner { text-align: center; }
    .kp-cta-inner h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; color: #fff; margin-bottom: .75rem; }
    .kp-cta-inner p { color: rgba(255,255,255,.75); margin-bottom: 2rem; }
    .kp-cta-btns { display: flex; gap: 1rem; justify-content: center; }
    .kp-cta-w { background: #fff; color: #1e40af; border-radius: 10px; padding: .85rem 2rem; font-weight: 700; text-decoration: none; }
    .kp-cta-o { background: transparent; color: rgba(255,255,255,.85); border: 1px solid rgba(255,255,255,.3); border-radius: 10px; padding: .85rem 2rem; font-weight: 600; text-decoration: none; }

    @media (max-width:900px) {
      .kp-hero-inner { grid-template-columns: 1fr; gap: 3rem; }
      .kp-trust-row { grid-template-columns: 1fr 1fr; }
      .kp-wt-step { grid-template-columns: 1fr; gap: 2rem; }
      .kp-wt-step.reverse { direction: ltr; }
      .kp-ss-grid { grid-template-columns: 1fr 1fr; }
      .kp-sec-inner { grid-template-columns: 1fr; }
      .kp-steps-grid { grid-template-columns: 1fr; }
    }
    @media (max-width:600px) {
      .kp-ss-grid { grid-template-columns: 1fr; }
      .kp-trust-row { grid-template-columns: 1fr; }
    }
    @media (max-width: 768px) { footer .container > div:first-child { grid-template-columns: 1fr !important; } }
