/* Ketpy Authenticator — design system aligned with ketpy.com (ember + ink + paper).
   Tokens replicated from https://ketpy.com/assets/css/style.css */

:root {
    /* ember (primary) */
    --ember:        #FF5A36;
    --ember-deep:   #D63C18;
    --ember-light:  #FF7A57;
    --ember-soft:   #FBE5DC;
    --ember-rgb:    255, 90, 54;

    /* ink (text + dark surfaces) */
    --ink:          #181614;
    --ink-soft:     #3C3833;
    --ink-light:    #7C766E;
    --ink-rgb:      24, 22, 20;

    /* paper (backgrounds) */
    --bone:         #F2EFE6;
    --cream:        #FAF6EE;
    --paper:        #FFFCF4;

    /* lines */
    --rule:         rgba(24,22,20,0.10);
    --rule-strong:  rgba(24,22,20,0.20);

    /* sage (tags only) */
    --sage:         #587866;

    /* semantic aliases */
    --primary:      var(--ember);
    --primary-dark: var(--ember-deep);
    --bg:           var(--bone);
    --card-bg:      var(--cream);
    --text:         var(--ink);
    --muted:        var(--ink-light);
    --line:         var(--rule);
    --soft:         var(--cream);

    /* shadows */
    --shadow-sm:    0 1px 2px rgba(24,22,20,0.04);
    --shadow:       0 6px 18px rgba(24,22,20,0.08);
    --shadow-lg:    0 18px 40px rgba(24,22,20,0.12);
    --shadow-ember: 0 6px 18px rgba(var(--ember-rgb), 0.28);
    --glow:         0 8px 28px rgba(24,22,20,0.10);

    /* radii */
    --r-sm: 6px;
    --r:    12px;
    --r-lg: 16px;
    --r-xl: 20px;
    --r-pill: 999px;

    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);

    --font-body:    'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-display: 'Bricolage Grotesque', 'Hanken Grotesk', system-ui, sans-serif;
    --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    font-family: var(--font-body); color: var(--text); background: var(--bone);
    -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, .ka-page-title, .ka-hero-title, .ka-h2 {
    font-family: var(--font-display); letter-spacing: -0.01em;
}
a { color: inherit; text-decoration: none; }
code, pre, .ka-mono { font-family: var(--font-mono); }

/* =================================================================
   PUBLIC TOP BAR + HERO
   ================================================================= */
.ka-top {
    background: rgba(250,246,238,.85);
    border-bottom: 1px solid var(--rule);
    position: sticky; top: 0; z-index: 30;
    backdrop-filter: saturate(160%) blur(10px);
}
.ka-top--minimal { background: transparent; border-bottom: 0; backdrop-filter: none; }
.ka-top-inner {
    max-width: 1120px; margin: 0 auto; padding: 14px 20px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.ka-brand { display: flex; align-items: center; gap: 10px; font-weight: 700; font-family: var(--font-display); }
.ka-brand-mark {
    width: 34px; height: 34px; border-radius: 9px;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); font-weight: 800; display: grid; place-items: center;
    box-shadow: var(--shadow-ember);
}
.ka-brand-text { font-size: 17px; }
.ka-brand-soft { color: var(--muted); font-weight: 500; }

.ka-top-nav { display: flex; align-items: center; gap: 8px; }
.ka-link { color: var(--ink-soft); font-weight: 500; padding: 8px 10px; border-radius: 8px; }
.ka-link:hover { color: var(--ink); background: var(--ember-soft); }
.ka-cta {
    background: var(--ink); color: var(--paper); padding: 8px 14px; border-radius: var(--r);
    font-weight: 600; transition: transform .15s var(--ease-out-expo), box-shadow .15s var(--ease-out-expo);
}
.ka-cta:hover { transform: translateY(-1px); box-shadow: var(--shadow-lg); }

/* hero */
.ka-hero {
    background:
        radial-gradient(900px 400px at 80% -10%, rgba(var(--ember-rgb),.18), transparent 60%),
        radial-gradient(700px 320px at -10% 110%, rgba(88,120,102,.12), transparent 60%),
        linear-gradient(180deg, var(--paper), var(--bone) 90%);
    padding: 64px 20px 56px;
}
.ka-hero-inner { max-width: 1120px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center; }
@media (min-width: 900px) {
    .ka-hero-inner { grid-template-columns: 1.05fr .95fr; gap: 56px; }
    .ka-hero { padding: 96px 24px 88px; }
}
.ka-eyebrow {
    display: inline-block; padding: 6px 12px; background: var(--ember-soft);
    color: var(--ember-deep); font-weight: 700; font-size: 12px; border-radius: var(--r-pill);
    letter-spacing: .08em; text-transform: uppercase;
}
.ka-eyebrow--admin { background: rgba(24,22,20,.08); color: var(--ink); }
.ka-hero-title { font-size: clamp(30px, 5vw, 50px); line-height: 1.05; font-weight: 800; margin: 14px 0; letter-spacing: -0.02em; }
.ka-text-grad {
    background: linear-gradient(90deg, var(--ember), var(--ember-deep));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ka-hero-sub { color: var(--ink-soft); font-size: 17.5px; max-width: 42ch; line-height: 1.55; }
.ka-hero-cta { display: flex; gap: 10px; margin-top: 22px; flex-wrap: wrap; }
.ka-hero-foot { color: var(--muted); font-size: 13px; margin-top: 18px; }

/* hero card mock */
.ka-hero-card { position: relative; }
.ka-card-shadow {
    position: absolute; inset: 24px -10px -16px 10px;
    background: linear-gradient(135deg, rgba(var(--ember-rgb),.30), rgba(88,120,102,.18));
    filter: blur(40px); border-radius: 28px; z-index: 0;
}
.ka-card {
    position: relative; background: var(--paper); border-radius: var(--r-xl);
    box-shadow: var(--shadow-lg);
    padding: 22px; border: 1px solid var(--rule);
}
.ka-card-head { display: flex; align-items: center; gap: 12px; }
.ka-card-logo {
    width: 44px; height: 44px; border-radius: var(--r); display: grid; place-items: center;
    background: linear-gradient(135deg, var(--ember-deep), var(--ember));
    color: var(--paper); font-weight: 800; font-size: 18px; font-family: var(--font-display);
}
.ka-card-org { font-weight: 700; font-family: var(--font-display); }
.ka-card-sub { color: var(--muted); font-size: 13px; }
.ka-badge { margin-left: auto; padding: 6px 10px; border-radius: var(--r-pill); font-size: 12px; font-weight: 700; }
.ka-badge-ok { background: rgba(88,120,102,.14); color: var(--sage); }
.ka-card-rows { margin-top: 18px; display: grid; gap: 10px; }
.ka-card-rows > div { display: grid; grid-template-columns: 110px 1fr; gap: 12px; padding: 8px 0; border-bottom: 1px dashed var(--rule); }
.ka-card-rows > div:last-child { border-bottom: 0; }
.ka-card-rows dt { color: var(--muted); font-size: 13px; }
.ka-card-rows dd { margin: 0; font-weight: 600; }

/* features grid */
.ka-grid-section { padding: 56px 20px; }
.ka-section-inner { max-width: 1120px; margin: 0 auto; }
.ka-h2 { font-size: 28px; font-weight: 800; text-align: center; margin: 0 0 28px; letter-spacing: -0.01em; }
.ka-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px)  { .ka-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .ka-grid { grid-template-columns: repeat(4, 1fr); } }
.ka-feature { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 22px; transition: transform .25s var(--ease-out-expo), box-shadow .25s var(--ease-out-expo); }
.ka-feature:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.ka-feat-icon {
    width: 38px; height: 38px; border-radius: var(--r); display: grid; place-items: center;
    background: var(--ember-soft); color: var(--ember-deep); font-weight: 800; margin-bottom: 12px; font-family: var(--font-display);
}
.ka-feature h3 { font-size: 17px; font-weight: 700; margin: 0 0 6px; font-family: var(--font-display); }
.ka-feature p  { color: var(--ink-soft); font-size: 14.5px; margin: 0; line-height: 1.55; }

/* coming soon page */
.ka-coming { padding: 80px 20px; }
.ka-coming-inner { max-width: 600px; margin: 0 auto; text-align: center; }
.ka-coming h1 { font-size: 36px; font-weight: 800; margin: 14px 0 10px; }
.ka-coming p { color: var(--muted); }

/* =================================================================
   BUTTONS
   ================================================================= */
.ka-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 18px; border-radius: var(--r); font-weight: 700; font-size: 15px;
    transition: transform .15s var(--ease-out-expo), box-shadow .15s var(--ease-out-expo), background .15s var(--ease-out-expo);
    min-height: 44px; border: 0; cursor: pointer; font-family: var(--font-body);
}
.ka-btn:disabled { opacity: .55; cursor: not-allowed; }
.ka-btn-primary { background: var(--ember); color: var(--paper); box-shadow: var(--shadow-ember); }
.ka-btn-primary:hover:not(:disabled) { background: var(--ember-deep); transform: translateY(-1px); }
.ka-btn-admin { background: var(--ink); color: var(--paper); box-shadow: 0 10px 24px -14px rgba(24,22,20,.7); }
.ka-btn-admin:hover:not(:disabled) { background: #000; transform: translateY(-1px); }
.ka-btn-ghost { background: var(--paper); color: var(--ink); border: 1px solid var(--rule); }
.ka-btn-ghost:hover:not(:disabled) { background: var(--ember-soft); border-color: rgba(var(--ember-rgb),.3); }
.ka-btn-block { width: 100%; }

/* =================================================================
   AUTH CARD
   ================================================================= */
.ka-auth-card {
    width: 100%; max-width: 440px; background: var(--paper);
    border: 1px solid var(--rule); border-radius: var(--r-xl);
    padding: 30px 28px; box-shadow: var(--shadow-lg);
}
.ka-auth-head { margin-bottom: 20px; }
.ka-auth-head h1 { font-size: 24px; font-weight: 800; margin: 10px 0 6px; }
.ka-auth-head p  { color: var(--muted); font-size: 14.5px; margin: 0; }
.ka-auth-alt    { color: var(--muted); font-size: 13px; text-align: center; margin: 18px 0 0; }

/* forms */
.ka-form { display: grid; gap: 14px; }
.ka-field { display: grid; gap: 6px; }
.ka-label { font-size: 13px; font-weight: 700; color: var(--ink-soft); letter-spacing: .01em; }
.ka-field input, .ka-input, textarea.ka-input {
    padding: 12px 14px; border: 1px solid var(--rule); border-radius: var(--r);
    font-size: 15px; min-height: 44px; outline: none; font-family: inherit;
    transition: border-color .15s var(--ease-out-expo), box-shadow .15s var(--ease-out-expo);
    background: var(--paper); color: var(--ink); width: 100%;
}
.ka-field input:focus, .ka-input:focus, textarea.ka-input:focus {
    border-color: var(--ember); box-shadow: 0 0 0 4px rgba(var(--ember-rgb),.16);
}
.ka-hint { font-size: 12px; color: var(--muted); }

/* password show/hide eye */
.ka-pw-field { position: relative; }
.ka-pw-field > input[type="password"],
.ka-pw-field > input[type="text"] { padding-right: 44px; }
.ka-pw-eye {
    position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
    width: 34px; height: 34px; border: 0; background: transparent;
    cursor: pointer; border-radius: 8px; padding: 0;
    color: var(--ink-light); font-size: 18px; line-height: 1;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s var(--ease-out-expo), color .15s var(--ease-out-expo);
}
.ka-pw-eye:hover  { background: var(--ember-soft); color: var(--ember-deep); }
.ka-pw-eye:focus-visible { outline: 2px solid var(--ember); outline-offset: 2px; }
.ka-pw-eye[aria-pressed="true"] { color: var(--ember-deep); }

/* flash */
.ka-flash-stack {
    position: fixed; top: 70px; left: 50%; transform: translateX(-50%);
    display: grid; gap: 8px; z-index: 50; width: min(560px, calc(100% - 24px));
}
.ka-flash {
    padding: 12px 14px; border-radius: var(--r); font-weight: 500; font-size: 14px;
    box-shadow: var(--shadow); border: 1px solid;
    background: var(--paper);
    animation: ka-pop .25s var(--ease-out-expo);
}
.ka-flash-success { color: var(--sage); border-color: rgba(88,120,102,.4); background: rgba(88,120,102,.08); }
.ka-flash-error   { color: var(--ember-deep); border-color: rgba(var(--ember-rgb),.4); background: var(--ember-soft); }
.ka-flash-info    { color: var(--ink-soft); border-color: var(--rule-strong); background: var(--cream); }
@keyframes ka-pop { from { opacity: 0; transform: translate(-50%, -8px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* footer */
.ka-footer { border-top: 1px solid var(--rule); background: var(--paper); padding: 22px 20px; }
.ka-footer-inner { max-width: 1120px; margin: 0 auto; text-align: center; }
.ka-footer-text { color: var(--muted); font-size: 13px; letter-spacing: .01em; }

@media (max-width: 640px) {
    .ka-top-inner { padding: 12px 16px; }
    .ka-hero-cta .ka-btn { flex: 1 1 0; }
}

/* =================================================================
   LANDING PAGE (lp-*)
   Long-form marketing layout modeled on book.ketpy.com.
   ================================================================= */

.lp-hero {
    position: relative;
    background: linear-gradient(180deg, var(--paper) 0%, var(--bone) 100%);
    overflow: hidden;
}
.lp-hero-bg {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(900px 380px at 78% -10%, rgba(var(--ember-rgb),.22), transparent 60%),
        radial-gradient(700px 340px at -8% 105%, rgba(88,120,102,.14), transparent 60%),
        radial-gradient(500px 250px at 50% 90%, rgba(var(--ember-rgb),.10), transparent 65%);
}
.lp-hero-inner {
    position: relative; z-index: 1;
    max-width: 1180px; margin: 0 auto; padding: 64px 20px 72px;
    display: grid; gap: 36px; grid-template-columns: 1fr;
}
@media (min-width: 960px) {
    .lp-hero-inner { grid-template-columns: 1.05fr .95fr; gap: 56px; padding: 110px 24px 100px; }
}
.lp-hero-title { font-family: var(--font-display); font-size: clamp(36px, 6vw, 62px); line-height: 1.02; font-weight: 800; letter-spacing: -0.025em; margin: 14px 0 18px; }
.lp-hero-sub   { color: var(--ink-soft); font-size: 17.5px; max-width: 46ch; line-height: 1.6; }
.lp-hero-sub strong { color: var(--ink); }
.lp-hero-trust {
    display: flex; flex-wrap: wrap; gap: 6px 8px; align-items: center;
    margin-top: 22px; color: var(--muted); font-size: 13px;
}
.lp-hero-trust i { color: var(--rule-strong); font-style: normal; }

/* hero stack */
.lp-hero-stack { position: relative; min-height: 380px; }
.lp-stack-blur { position: absolute; inset: 30px -20px -20px 10px; background: linear-gradient(135deg, rgba(var(--ember-rgb),.35), rgba(88,120,102,.16)); filter: blur(44px); border-radius: 30px; z-index: 0; }
.lp-stack-card {
    position: absolute; z-index: 1; background: var(--paper);
    border: 1px solid var(--rule); border-radius: var(--r-xl);
    box-shadow: var(--shadow-lg); padding: 22px;
}
.lp-stack-card--front { top: 0; left: 0; right: 50px; }
.lp-stack-card--back  { bottom: -10px; right: 0; left: 60px; transform: rotate(2deg); padding: 18px; }
@media (max-width: 640px) {
    .lp-stack-card--front { right: 0; }
    .lp-stack-card--back  { display: none; }
}
.lp-mini-head { display: flex; align-items: center; gap: 12px; }
.lp-mini-logo { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: linear-gradient(135deg, var(--ember-deep), var(--ember)); color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 18px; }
.lp-mini-org { font-weight: 700; font-family: var(--font-display); }
.lp-mini-sub { color: var(--muted); font-size: 13px; }
.lp-mini-rows { margin: 18px 0 0; display: grid; gap: 8px; }
.lp-mini-rows > div { display: grid; grid-template-columns: 90px 1fr; gap: 12px; padding: 8px 0; border-bottom: 1px dashed var(--rule); }
.lp-mini-rows > div:last-child { border-bottom: 0; }
.lp-mini-rows dt { color: var(--muted); font-size: 13px; }
.lp-mini-rows dd { margin: 0; font-weight: 600; }

/* fake QR box */
.lp-qr-box { background: var(--ink); border-radius: var(--r); padding: 12px; display: inline-block; }
.lp-qr-grid {
    width: 140px; height: 140px; background:
      linear-gradient(45deg, var(--paper) 25%, transparent 25%, transparent 75%, var(--paper) 75%, var(--paper)),
      linear-gradient(45deg, var(--paper) 25%, transparent 25%, transparent 75%, var(--paper) 75%, var(--paper)),
      var(--ink);
    background-position: 0 0, 7px 7px;
    background-size: 14px 14px;
    border-radius: 4px;
}
.lp-qr-meta { margin-top: 10px; display: flex; flex-direction: column; gap: 2px; }
.lp-qr-meta strong { font-family: var(--font-display); font-size: 15px; }
.lp-qr-meta span { color: var(--muted); font-size: 12.5px; }

/* trust strip */
.lp-strip { background: var(--paper); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.lp-strip-inner {
    max-width: 1180px; margin: 0 auto; padding: 24px 20px;
    display: flex; align-items: center; justify-content: space-around; gap: 14px; flex-wrap: wrap;
}
.lp-strip-item { display: flex; flex-direction: column; align-items: center; min-width: 110px; }
.lp-strip-item strong { font-family: var(--font-display); font-size: 28px; font-weight: 800; color: var(--ink); line-height: 1; }
.lp-strip-item span { font-size: 12px; color: var(--muted); margin-top: 4px; }
.lp-strip-sep { width: 1px; height: 30px; background: var(--rule); }
@media (max-width: 640px) { .lp-strip-sep { display: none; } }

/* section base */
.lp-section { padding: 80px 20px; background: var(--bone); }
.lp-section--alt { background: var(--cream); }
.lp-section-inner { max-width: 1180px; margin: 0 auto; }
.lp-section-head { text-align: center; margin-bottom: 44px; }
.lp-section-head h2 { font-family: var(--font-display); font-size: clamp(28px, 4.5vw, 40px); font-weight: 800; letter-spacing: -0.02em; margin: 12px 0 12px; max-width: 22ch; margin-left: auto; margin-right: auto; line-height: 1.1; }
.lp-section-head p { color: var(--ink-soft); font-size: 16px; max-width: 60ch; margin: 0 auto; line-height: 1.6; }
.lp-section-foot { text-align: center; color: var(--muted); font-size: 13px; margin-top: 22px; }

/* modules grid */
.lp-modules-grid { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media (min-width: 600px)  { .lp-modules-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .lp-modules-grid { grid-template-columns: repeat(4, 1fr); } }
.lp-mod-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 22px; transition: transform .25s var(--ease-out-expo), box-shadow .25s var(--ease-out-expo); }
.lp-mod-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.lp-mod-tag { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 14px; margin-bottom: 12px; }
.lp-mod-card h3 { font-family: var(--font-display); font-size: 18px; font-weight: 700; margin: 0 0 6px; }
.lp-mod-card p  { color: var(--ink-soft); font-size: 14px; line-height: 1.55; margin: 0; }

/* 3-step */
.lp-steps { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media (min-width: 900px) { .lp-steps { grid-template-columns: repeat(3, 1fr); } }
.lp-step { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 24px; position: relative; }
.lp-step-no { position: absolute; top: -16px; left: 24px; width: 36px; height: 36px; border-radius: 50%; background: var(--ember); color: var(--paper); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 16px; box-shadow: var(--shadow-ember); }
.lp-step h3 { font-family: var(--font-display); font-size: 20px; font-weight: 800; margin: 8px 0 10px; }
.lp-step p { color: var(--ink-soft); font-size: 14.5px; line-height: 1.6; margin: 0 0 14px; }
.lp-step ul { padding: 0; margin: 0; list-style: none; display: grid; gap: 6px; }
.lp-step ul li { color: var(--ink-soft); font-size: 13.5px; padding-left: 22px; position: relative; }
.lp-step ul li::before { content: '→'; position: absolute; left: 0; color: var(--ember); font-weight: 800; }

/* split rows */
.lp-split { display: grid; gap: 32px; grid-template-columns: 1fr; align-items: center; }
@media (min-width: 900px) { .lp-split { grid-template-columns: 1fr 1fr; gap: 64px; } }
.lp-split--reverse .lp-split-visual { order: -1; }
@media (min-width: 900px) { .lp-split--reverse .lp-split-visual { order: 1; } .lp-split--reverse .lp-split-copy { order: 2; } }
.lp-split-copy h2 { font-family: var(--font-display); font-size: clamp(26px, 3.8vw, 36px); font-weight: 800; letter-spacing: -0.01em; margin: 12px 0 14px; line-height: 1.1; }
.lp-split-copy p { color: var(--ink-soft); font-size: 15.5px; line-height: 1.6; margin: 0 0 18px; }
.lp-bullets { padding: 0; margin: 0 0 22px; list-style: none; display: grid; gap: 8px; }
.lp-bullets li { color: var(--ink-soft); font-size: 14.5px; padding-left: 24px; position: relative; line-height: 1.55; }
.lp-bullets li::before { content: '✓'; position: absolute; left: 0; color: var(--sage); font-weight: 800; }
.lp-bullets li strong { color: var(--ink); }
.lp-code { background: var(--cream); padding: 2px 8px; border-radius: 6px; font-family: var(--font-mono); font-size: 13px; color: var(--ember-deep); }

/* phone mockup */
.lp-phone {
    background: var(--ink); border-radius: 32px; padding: 14px; max-width: 320px; margin: 0 auto;
    box-shadow: var(--shadow-lg);
}
.lp-phone-screen { background: var(--paper); border-radius: 24px; padding: 24px 22px; }
.lp-phone-head { display: flex; align-items: center; gap: 8px; }
.lp-phone-logo { width: 28px; height: 28px; border-radius: 6px; background: var(--ember); color: var(--paper); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 14px; }
.lp-phone-brand { font-family: var(--font-display); font-weight: 700; font-size: 14px; }
.lp-phone-h { font-family: var(--font-display); font-size: 18px; margin: 18px 0 14px; font-weight: 800; }
.lp-phone-scan { background: var(--ink); color: var(--paper); padding: 12px; border-radius: 10px; text-align: center; font-weight: 600; font-size: 14px; }
.lp-phone-or { text-align: center; color: var(--muted); font-size: 12px; margin: 8px 0; }
.lp-phone-input { background: var(--cream); border: 1px solid var(--rule); border-radius: 10px; padding: 12px; color: var(--muted); font-size: 13px; }
.lp-phone-cta { width: 100%; margin-top: 12px; padding: 12px; border-radius: 10px; border: 0; background: var(--ember); color: var(--paper); font-weight: 700; font-size: 14px; cursor: default; }

/* template gallery */
.lp-tpl-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; max-width: 460px; margin: 0 auto; }
@media (min-width: 600px) { .lp-tpl-grid { grid-template-columns: repeat(5, 1fr); } }
.lp-tpl-card { background: var(--paper); border: 1px solid var(--rule); border-radius: 10px; padding: 8px; transition: transform .2s var(--ease-out-expo); }
.lp-tpl-card:hover { transform: translateY(-2px); }
.lp-tpl-thumb { aspect-ratio: 1; display: grid; place-items: center; border-radius: 8px; }
.lp-tpl-no { color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 22px; }
.lp-tpl-name { font-size: 11px; color: var(--ink-soft); text-align: center; margin-top: 6px; font-weight: 600; }

/* embed code */
.lp-embed-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 900px) { .lp-embed-grid { grid-template-columns: 1.5fr 1fr; } }
.lp-embed-code { background: var(--ink); border-radius: var(--r-lg); padding: 18px; overflow: auto; }
.lp-embed-code pre { margin: 0; }
.lp-embed-code code { color: #FCD3C4; font-family: var(--font-mono); font-size: 12.5px; line-height: 1.6; white-space: pre; }
.lp-embed-notes { display: grid; gap: 14px; align-content: start; }
.lp-embed-notes h3 { font-family: var(--font-display); font-size: 16px; font-weight: 700; margin: 0; }
.lp-embed-notes p { color: var(--ink-soft); font-size: 14px; line-height: 1.55; margin: 4px 0 0; }
.lp-embed-notes code { background: var(--cream); padding: 1px 6px; border-radius: 5px; font-family: var(--font-mono); font-size: 12.5px; color: var(--ember-deep); }

/* security grid */
.lp-sec-grid { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media (min-width: 600px)  { .lp-sec-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .lp-sec-grid { grid-template-columns: repeat(3, 1fr); } }
.lp-sec-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r); padding: 18px; }
.lp-sec-check { width: 28px; height: 28px; border-radius: 50%; background: rgba(88,120,102,.16); color: var(--sage); display: grid; place-items: center; font-weight: 800; margin-bottom: 10px; }
.lp-sec-card h4 { font-family: var(--font-display); font-size: 15px; font-weight: 700; margin: 0 0 6px; }
.lp-sec-card p { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; margin: 0; }

/* use cases */
.lp-use-grid { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media (min-width: 600px)  { .lp-use-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .lp-use-grid { grid-template-columns: repeat(4, 1fr); } }
.lp-use-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r); padding: 18px; }
.lp-use-card h4 { font-family: var(--font-display); font-size: 14.5px; font-weight: 700; margin: 0 0 8px; }
.lp-use-card p { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; margin: 0; }

/* pricing */
.lp-price-grid { display: grid; gap: 18px; grid-template-columns: 1fr; align-items: stretch; }
@media (min-width: 900px) { .lp-price-grid { grid-template-columns: repeat(3, 1fr); } }
.lp-price-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 26px 22px; display: flex; flex-direction: column; gap: 10px; position: relative; }
.lp-price-card--featured { border-color: var(--ember); box-shadow: 0 22px 50px -28px rgba(var(--ember-rgb),.55); transform: translateY(-4px); }
.lp-price-pop { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--ember); color: var(--paper); padding: 4px 12px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.lp-price-name { font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--muted); letter-spacing: .12em; text-transform: uppercase; }
.lp-price-amt  { font-family: var(--font-display); font-size: 32px; font-weight: 800; }
.lp-price-sub  { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; }
.lp-price-card ul { margin: 14px 0; padding: 0; list-style: none; display: grid; gap: 6px; }
.lp-price-card ul li { color: var(--ink-soft); font-size: 13.5px; padding-left: 22px; position: relative; }
.lp-price-card ul li::before { content: '✓'; position: absolute; left: 0; color: var(--sage); font-weight: 800; }
.lp-price-card .ka-btn { margin-top: auto; }

/* FAQ */
.lp-faq-inner { max-width: 880px; }
.lp-faq { display: grid; gap: 10px; }
.lp-faq-item { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r); padding: 0; transition: border-color .15s ease; }
.lp-faq-item[open] { border-color: rgba(var(--ember-rgb),.4); }
.lp-faq-item summary { padding: 18px 22px; cursor: pointer; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink); list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.lp-faq-item summary::-webkit-details-marker { display: none; }
.lp-faq-item summary::after { content: '+'; color: var(--ember); font-weight: 800; font-size: 22px; line-height: 1; transition: transform .2s ease; }
.lp-faq-item[open] summary::after { transform: rotate(45deg); }
.lp-faq-a { padding: 0 22px 18px; color: var(--ink-soft); font-size: 14.5px; line-height: 1.65; }
.lp-faq-a code { background: var(--cream); padding: 1px 6px; border-radius: 5px; font-family: var(--font-mono); font-size: 12.5px; color: var(--ember-deep); }

/* final CTA — light black overlay (was ember) */
.lp-cta {
    position: relative; overflow: hidden;
    background: linear-gradient(135deg, #2A2622 0%, #181614 100%);
    color: var(--paper); padding: 100px 20px;
}
.lp-cta-bg {
    position: absolute; inset: 0; z-index: 0;
    background: url('https://images.unsplash.com/photo-1521791136064-7986c2920216?w=1600&q=70&auto=format') center/cover no-repeat;
    opacity: .22; mix-blend-mode: luminosity;
}
.lp-cta-inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; text-align: center; }
.lp-cta-inner h2 { font-family: var(--font-display); font-size: clamp(28px, 4vw, 42px); font-weight: 800; letter-spacing: -0.02em; margin: 0 0 14px; line-height: 1.1; }
.lp-cta-inner p { color: rgba(255,252,244,.86); font-size: 17px; line-height: 1.6; margin: 0 0 26px; }

/* =================================================================
   KETPY PUBLIC SITE (kp-*)
   Shared chrome + components for the multi-page public site.
   ================================================================= */
.kp-body { background: var(--bone); }
.kp-main { min-height: 60vh; }

/* sticky nav */
.kp-nav {
    position: sticky; top: 0; z-index: 40;
    background: rgba(250,246,238,.88);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--rule);
}
.kp-nav-inner { max-width: 1200px; margin: 0 auto; padding: 12px 20px; display: flex; align-items: center; gap: 18px; }
.kp-brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.kp-brand-mark {
    width: 32px; height: 32px; border-radius: 9px;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); font-weight: 800; display: grid; place-items: center; font-size: 15px;
    box-shadow: var(--shadow-ember);
}
.kp-brand-text { color: var(--ink); }
.kp-brand-soft { color: var(--muted); font-weight: 500; }
.kp-nav-links { display: none; align-items: center; gap: 4px; margin-left: 20px; flex: 1; }
@media (min-width: 900px) { .kp-nav-links { display: flex; } }
.kp-nav-link {
    padding: 8px 12px; border-radius: 8px; color: var(--ink-soft); font-weight: 500; font-size: 14.5px;
    transition: background .15s var(--ease-out-expo), color .15s;
}
.kp-nav-link:hover, .kp-nav-link.is-active { background: var(--ember-soft); color: var(--ember-deep); }
.kp-nav-cta { display: none; }
@media (min-width: 900px) { .kp-nav-cta { display: block; } .kp-nav-links { flex: 1; } }
.kp-mob-burger { display: inline-flex; width: 40px; height: 40px; border: 0; background: transparent; flex-direction: column; align-items: center; justify-content: center; gap: 4px; margin-left: auto; cursor: pointer; border-radius: 8px; }
@media (min-width: 900px) { .kp-mob-burger { display: none; } }
.kp-mob-burger span { display: block; width: 20px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .2s var(--ease-out-expo); }
.kp-mob-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.kp-mob-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.kp-mob-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.kp-mob-menu {
    display: none; padding: 14px 20px 22px;
    background: var(--paper); border-bottom: 1px solid var(--rule);
}
.kp-mob-menu.is-open { display: flex; flex-direction: column; gap: 4px; }
.kp-mob-link { padding: 12px 12px; border-radius: 8px; color: var(--ink); font-weight: 600; font-size: 16px; }
.kp-mob-link:hover { background: var(--ember-soft); }
.kp-mob-cta { margin-top: 8px; }

/* shared buttons */
.kp-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 10px 18px; border-radius: 10px; font-weight: 700; font-size: 14.5px;
    transition: transform .15s var(--ease-out-expo), box-shadow .15s, background .15s; border: 0; cursor: pointer;
    font-family: var(--font-body); min-height: 42px;
    text-decoration: none;
}
.kp-btn-primary { background: var(--ember); color: var(--paper); box-shadow: var(--shadow-ember); }
.kp-btn-primary:hover { background: var(--ember-deep); transform: translateY(-1px); }
.kp-btn-ghost { background: var(--paper); color: var(--ink); border: 1px solid var(--rule); }
.kp-btn-ghost:hover { background: var(--ember-soft); border-color: rgba(var(--ember-rgb),.3); }
.kp-btn-dark { background: var(--ink); color: var(--paper); }
.kp-btn-dark:hover { background: #000; transform: translateY(-1px); }

/* page hero (sub-pages) */
.kp-hero {
    position: relative; overflow: hidden;
    background: linear-gradient(135deg, var(--cream) 0%, var(--bone) 80%);
    padding: 84px 20px 64px;
}
.kp-hero--dark { background: linear-gradient(135deg, var(--ink) 0%, #2A1B17 100%); color: var(--paper); }
.kp-hero--ember { background: linear-gradient(135deg, var(--ember) 0%, var(--ember-deep) 100%); color: var(--paper); }
.kp-hero-bg {
    position: absolute; inset: 0; z-index: 0;
    background-size: cover; background-position: center;
}
.kp-hero--dark .kp-hero-bg, .kp-hero--ember .kp-hero-bg { opacity: .28; mix-blend-mode: overlay; }
.kp-hero--light .kp-hero-bg { opacity: .55; }
.kp-hero-inner { position: relative; z-index: 1; max-width: 1100px; margin: 0 auto; text-align: center; }
.kp-eyebrow { display: inline-block; padding: 6px 14px; background: rgba(var(--ember-rgb),.14); color: var(--ember-deep); font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; border-radius: 999px; }
.kp-hero--dark .kp-eyebrow, .kp-hero--ember .kp-eyebrow { background: rgba(255,252,244,.18); color: var(--paper); }
.kp-hero h1 { font-family: var(--font-display); font-size: clamp(34px, 5vw, 56px); font-weight: 800; letter-spacing: -0.025em; margin: 14px auto 14px; line-height: 1.05; max-width: 22ch; }
.kp-hero p { color: var(--ink-soft); font-size: 17px; line-height: 1.6; margin: 0 auto; max-width: 60ch; }
.kp-hero--dark p, .kp-hero--ember p { color: rgba(255,252,244,.86); }

/* generic section */
.kp-sec { padding: 72px 20px; }
.kp-sec--alt { background: var(--cream); }
.kp-sec--dark { background: var(--ink); color: var(--paper); }
.kp-sec-inner { max-width: 1100px; margin: 0 auto; }
.kp-sec-head { text-align: center; margin-bottom: 44px; }
.kp-sec-head h2 { font-family: var(--font-display); font-size: clamp(26px, 3.6vw, 38px); font-weight: 800; letter-spacing: -0.02em; margin: 12px auto 12px; max-width: 22ch; line-height: 1.1; }
.kp-sec-head p { color: var(--ink-soft); font-size: 16px; max-width: 60ch; margin: 0 auto; line-height: 1.6; }
.kp-sec--dark .kp-sec-head h2 { color: var(--paper); }
.kp-sec--dark .kp-sec-head p { color: rgba(255,252,244,.78); }

/* generic card grid */
.kp-grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media (min-width: 600px)  { .kp-grid.cols-2 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px)  { .kp-grid.cols-3 { grid-template-columns: repeat(3,1fr); } .kp-grid.cols-4 { grid-template-columns: repeat(4,1fr); } }
.kp-card { background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 24px; transition: transform .25s var(--ease-out-expo), box-shadow .25s; }
.kp-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kp-card-icon {
    width: 48px; height: 48px; border-radius: 12px;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); display: grid; place-items: center; font-family: var(--font-display);
    font-weight: 800; font-size: 18px; margin-bottom: 14px;
    box-shadow: var(--shadow-ember);
}
.kp-card h3 { font-family: var(--font-display); font-size: 17px; font-weight: 700; margin: 0 0 6px; }
.kp-card p { color: var(--ink-soft); font-size: 14.5px; line-height: 1.55; margin: 0; }

/* footer — 4-widget advanced */
.kp-foot { background: linear-gradient(180deg, var(--ink) 0%, #0E0C0B 100%); color: rgba(255,252,244,.7); padding: 64px 20px 28px; border-top: 1px solid rgba(255,252,244,.06); }
.kp-foot-inner { max-width: 1200px; margin: 0 auto; }
.kp-foot-grid {
    display: grid; gap: 36px;
    grid-template-columns: 1fr;
}
@media (min-width: 700px)  { .kp-foot-grid { grid-template-columns: 1.6fr 1fr 1fr 1.2fr; } }
.kp-foot-col h4 { font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--paper); margin: 0 0 14px; letter-spacing: .12em; text-transform: uppercase; }
.kp-foot-col a { display: block; color: rgba(255,252,244,.6); font-size: 14px; padding: 5px 0; transition: color .15s, transform .15s; text-decoration: none; }
.kp-foot-col a:hover { color: var(--paper); transform: translateX(2px); }
.kp-foot-brand .kp-brand { margin-bottom: 14px; }
.kp-foot-brand p { font-size: 13.5px; line-height: 1.65; color: rgba(255,252,244,.6); margin: 0 0 10px; max-width: 38ch; }
.kp-foot-mini { color: rgba(255,252,244,.4) !important; font-size: 12.5px !important; margin-top: 14px !important; padding-top: 14px; border-top: 1px solid rgba(255,252,244,.08); max-width: 38ch; }
.kp-foot-brand .kp-brand-text { color: var(--paper); }
.kp-foot-brand .kp-brand-soft { color: rgba(255,252,244,.55); }

.kp-foot-login-btn {
    display: inline-flex !important; align-items: center; gap: 6px;
    padding: 9px 16px !important; border-radius: 10px;
    background: var(--ember); color: var(--paper) !important;
    font-weight: 700; font-size: 13.5px;
    transition: background .15s, transform .15s, box-shadow .15s;
    box-shadow: 0 8px 18px -10px rgba(var(--ember-rgb),.6);
}
.kp-foot-login-btn:hover { background: var(--ember-deep); transform: translateY(-1px) !important; }

.kp-foot-socials { display: flex; gap: 8px; flex-wrap: wrap; padding: 0; }
.kp-foot-socials a {
    width: 38px; height: 38px; padding: 0 !important;
    display: inline-grid !important; place-items: center;
    border-radius: 10px;
    background: rgba(255,252,244,.06);
    color: rgba(255,252,244,.78) !important;
    border: 1px solid rgba(255,252,244,.06);
    transition: background .15s, color .15s, transform .15s;
}
.kp-foot-socials a:hover {
    background: var(--ember); color: var(--paper) !important;
    transform: translateY(-2px) !important;
    border-color: var(--ember);
}
.kp-foot-ketpy {
    display: inline-block !important;
    margin-top: 18px !important;
    color: var(--ember-light) !important;
    font-size: 13px; padding: 0 !important;
}
.kp-foot-ketpy:hover { color: var(--paper) !important; transform: none !important; }

.kp-foot-bottom {
    margin-top: 48px; padding-top: 22px; border-top: 1px solid rgba(255,252,244,.1);
    display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
    color: rgba(255,252,244,.45); font-size: 12.5px;
}
.kp-foot-tag { color: rgba(255,252,244,.45); }

/* CTA banner shared across sub-pages — light black overlay */
.kp-cta {
    position: relative; overflow: hidden;
    background: linear-gradient(135deg, #2A2622 0%, #181614 100%);
    color: var(--paper); padding: 80px 20px;
}
.kp-cta-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; opacity: .22; mix-blend-mode: luminosity; }
.kp-cta-inner { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; text-align: center; }
.kp-cta-inner h2 { font-family: var(--font-display); font-size: clamp(26px, 3.6vw, 38px); font-weight: 800; margin: 0 0 12px; line-height: 1.1; }
.kp-cta-inner p { color: rgba(255,252,244,.86); font-size: 16.5px; margin: 0 0 22px; line-height: 1.6; }

/* prose for legal pages */
.kp-prose { max-width: 720px; margin: 0 auto; color: var(--ink-soft); font-size: 15.5px; line-height: 1.8; }
.kp-prose h2 { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--ink); margin: 36px 0 12px; }
.kp-prose h3 { font-family: var(--font-display); font-size: 17px; font-weight: 700; color: var(--ink); margin: 22px 0 8px; }
.kp-prose p { margin: 0 0 14px; }
.kp-prose ul, .kp-prose ol { padding-left: 22px; margin: 0 0 14px; }
.kp-prose li { margin: 4px 0; }
.kp-prose strong { color: var(--ink); }
.kp-prose a { color: var(--ember-deep); text-decoration: underline; }

/* solutions strip */
.kp-pill-grid { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.kp-pill {
    padding: 8px 14px; background: var(--paper); border: 1px solid var(--rule); border-radius: 999px;
    font-size: 13.5px; color: var(--ink-soft); font-weight: 600;
    transition: background .15s, color .15s;
}
.kp-pill:hover { background: var(--ember-soft); color: var(--ember-deep); }

/* contact form */
.kp-form-card { max-width: 540px; margin: 0 auto; background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 30px 28px; box-shadow: var(--shadow); }
.kp-form-card h3 { font-family: var(--font-display); font-size: 20px; font-weight: 700; margin: 0 0 6px; }
.kp-form-card p.sub { color: var(--muted); font-size: 14px; margin: 0 0 18px; }

/* =================================================================
   PUBLIC VERIFY PORTAL v2 (pvx2-*) — full-bleed Unsplash hero + grid tiles
   ================================================================= */
.pvx2 { --tenant: #FF5A36; }

.pvx2-hero {
    position: relative; overflow: hidden;
    min-height: 64vh; padding: 64px 20px 80px;
    color: #FFFCF4;
    display: flex; align-items: center; justify-content: center;
    text-align: center;
}
.pvx2-hero-bg {
    position: absolute; inset: 0; z-index: 0;
    background-size: cover; background-position: center;
    transform: scale(1.04);
}
/* Image-dominant overlay: deep dark gradient + small tenant-color glow in corner (not whole) */
.pvx2-hero-veil {
    position: absolute; inset: 0; z-index: 1;
    background:
        linear-gradient(180deg, rgba(8,7,6,.55) 0%, rgba(8,7,6,.85) 100%),
        radial-gradient(700px 360px at 80% 18%, color-mix(in srgb, var(--tenant) 32%, transparent 68%), transparent 60%),
        radial-gradient(600px 320px at 18% 90%, rgba(255,255,255,.05), transparent 70%);
}
.pvx2-hero-rings { position: absolute; inset: 0; z-index: 2; pointer-events: none; display: flex; align-items: center; justify-content: center; }
.pvx2-hero-rings span {
    position: absolute; border-radius: 50%; border: 1px solid rgba(255,255,255,.18);
    animation: pvx2-pulse 6s ease-in-out infinite;
}
.pvx2-hero-rings span:nth-child(1) { width: 260px; height: 260px; opacity: .55; animation-delay: 0s; }
.pvx2-hero-rings span:nth-child(2) { width: 400px; height: 400px; opacity: .35; animation-delay: 1.2s; }
.pvx2-hero-rings span:nth-child(3) { width: 560px; height: 560px; opacity: .20; animation-delay: 2.4s; }
.pvx2-hero-rings span:nth-child(4) { width: 740px; height: 740px; opacity: .10; animation-delay: 3.6s; }
@keyframes pvx2-pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.04); } }

.pvx2-hero-inner { position: relative; z-index: 3; max-width: 560px; }
.pvx2-shield {
    width: 60px; height: 60px; border-radius: 50%;
    margin: 0 auto 16px;
    background: rgba(255,255,255,.14);
    backdrop-filter: blur(8px);
    display: grid; place-items: center;
    box-shadow: 0 8px 32px -8px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.2) inset;
}
.pvx2-logo {
    height: 88px; max-width: 220px; object-fit: contain;
    background: rgba(255,255,255,.96); padding: 8px; border-radius: 16px;
    box-shadow: 0 16px 40px -16px rgba(0,0,0,.5);
}
.pvx2-logo--fallback {
    display: inline-grid; place-items: center;
    width: 88px; height: 88px; border-radius: 22px;
    background: rgba(255,255,255,.22);
    color: #FFFCF4; font-family: var(--font-display); font-weight: 800; font-size: 38px;
    backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.3);
    box-shadow: 0 16px 40px -16px rgba(0,0,0,.5);
}
.pvx2-brand {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(32px, 6vw, 48px);
    margin: 22px 0 6px; letter-spacing: -0.02em; line-height: 1.05;
    text-shadow: 0 4px 24px rgba(0,0,0,.45);
}
.pvx2-sub { color: rgba(255,252,244,.86); font-size: 13.5px; letter-spacing: .24em; text-transform: uppercase; font-weight: 700; }
.pvx2-tagline {
    margin-top: 22px; color: rgba(255,252,244,.66); font-size: 13.5px;
    display: inline-block; padding: 8px 18px; border-radius: 999px;
    background: rgba(0,0,0,.25); backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.12);
}
.pvx2-tagline strong { color: #FFFCF4; font-weight: 700; }

.pvx2-body {
    position: relative; z-index: 4;
    max-width: 920px;          /* ≈ 60% of typical 1440px screen — feels balanced */
    margin: -44px auto 0;
    padding: 40px 22px 56px;
    background: var(--bone);
    border-radius: 32px 32px 0 0;
    box-shadow: 0 -20px 50px -30px rgba(0,0,0,.25);
}
@media (min-width: 768px) { .pvx2-body { padding: 54px 48px 68px; } }

.pvx2-para { text-align: center; color: var(--ink-soft); font-size: 15px; line-height: 1.65; margin: 4px auto 26px; max-width: 56ch; }
.pvx2-prompt {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--ink-soft); font-size: 12.5px; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    margin: 0 auto 16px; width: 100%; justify-content: center;
}
.pvx2-prompt-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--tenant);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--tenant) 18%, transparent 82%);
    animation: pvx2-blink 2s ease-in-out infinite;
}
@keyframes pvx2-blink { 0%,100% { transform: scale(1); } 50% { transform: scale(.7); } }

.pvx2-grid {
    display: grid; gap: 16px;
    grid-template-columns: 1fr 1fr;       /* 2-col mobile */
}
@media (min-width: 700px)  { .pvx2-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; } }
@media (min-width: 1100px) { .pvx2-grid { grid-template-columns: repeat(3, 1fr); gap: 22px; } }

.pvx2-tile {
    position: relative;
    background: var(--paper);
    border: 1px solid var(--rule);
    border-radius: 22px;
    padding: 30px 20px 26px;
    text-decoration: none; color: var(--ink);
    text-align: center;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
    overflow: hidden;
    min-height: 200px;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
}
@media (min-width: 700px) { .pvx2-tile { padding: 36px 22px 28px; min-height: 230px; } }
.pvx2-tile::before {
    content: ''; position: absolute; top: -50px; right: -50px;
    width: 140px; height: 140px; border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--tenant) 16%, transparent 84%) 0%, transparent 70%);
    pointer-events: none;
}
.pvx2-tile:hover, .pvx2-tile:focus-visible {
    transform: translateY(-5px);
    box-shadow: 0 22px 50px -22px rgba(24,22,20,.25);
    border-color: rgba(0,0,0,.08);
}
.pvx2-tile-icon {
    width: 76px; height: 76px; border-radius: 22px;
    display: inline-grid; place-items: center;
    margin: 0 auto 18px;
    box-shadow:
        0 16px 34px -14px rgba(0,0,0,.4),
        0 2px 0 rgba(255,255,255,.5) inset,
        0 -2px 0 rgba(0,0,0,.2) inset;
}
.pvx2-tile-icon svg { width: 34px; height: 34px; }
.pvx2-tile-name {
    font-family: var(--font-display); font-weight: 800;
    font-size: 17px; color: var(--ink);
    line-height: 1.25; margin-bottom: 10px;
}
.pvx2-tile-cta {
    font-size: 13px; color: var(--tenant); font-weight: 700;
    letter-spacing: .04em;
}

.pvx2-contact {
    margin-top: 30px;
    background: var(--paper); border: 1px solid var(--rule); border-radius: 16px;
    padding: 18px 20px;
    display: flex; flex-direction: column; gap: 12px;
    box-shadow: 0 2px 6px -2px rgba(24,22,20,.04);
}
.pvx2-contact-h { display: flex; flex-direction: column; gap: 2px; }
.pvx2-contact-h strong { font-family: var(--font-display); font-size: 15px; color: var(--ink); }
.pvx2-contact-h span { color: var(--muted); font-size: 12.5px; }
.pvx2-contact-items { display: flex; flex-direction: column; gap: 8px; }
@media (min-width: 600px) { .pvx2-contact-items { flex-direction: row; flex-wrap: wrap; gap: 8px 18px; } }
.pvx2-contact-items a, .pvx2-contact-items div { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-soft); font-size: 14px; text-decoration: none; }
.pvx2-contact-items a:hover { color: var(--tenant); }
.pvx2-contact-ic { font-size: 14px; opacity: .85; }

/* =================================================================
   HOME HERO v2 (lp2-*) — split layout with floating mock cards
   ================================================================= */
.lp2-hero {
    position: relative; overflow: hidden;
    background: linear-gradient(180deg, var(--paper) 0%, var(--bone) 100%);
    padding: 60px 20px 80px;
}
@media (min-width: 900px) { .lp2-hero { padding: 100px 24px 120px; } }

.lp2-hero-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.lp2-hero-bg img {
    position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
    opacity: .14; mix-blend-mode: multiply;
}
.lp2-hero-veil {
    position: absolute; inset: 0;
    background:
        linear-gradient(180deg, rgba(250,246,238,.65) 0%, rgba(242,239,230,.9) 100%),
        radial-gradient(900px 400px at 80% 30%, rgba(var(--ember-rgb),.18), transparent 60%);
}
.lp2-hero-glow {
    position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; opacity: .55;
}
.lp2-hero-glow--a { top: -10%; right: -10%; width: 480px; height: 480px; background: rgba(var(--ember-rgb),.35); }
.lp2-hero-glow--b { bottom: -20%; left: -10%; width: 420px; height: 420px; background: rgba(88,120,102,.30); }

.lp2-hero-inner {
    position: relative; z-index: 1;
    max-width: 1200px; margin: 0 auto;
    display: grid; gap: 40px; grid-template-columns: 1fr; align-items: center;
}
@media (min-width: 900px) {
    .lp2-hero-inner { grid-template-columns: 1.05fr .95fr; gap: 64px; }
}

/* Left: copy */
.lp2-badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 7px 14px; border-radius: 999px;
    background: var(--paper); border: 1px solid var(--rule);
    color: var(--ink-soft); font-size: 12.5px; font-weight: 600;
    letter-spacing: .04em;
    box-shadow: 0 2px 6px -2px rgba(24,22,20,.06);
}
.lp2-badge-dot {
    width: 8px; height: 8px; border-radius: 50%; background: var(--ember);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--ember) 24%, transparent 76%);
    animation: lp2-blink 2s ease-in-out infinite;
}
@keyframes lp2-blink { 0%, 100% { transform: scale(1); } 50% { transform: scale(.7); } }

.lp2-h {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(40px, 7.5vw, 76px);
    line-height: .98; letter-spacing: -0.035em;
    margin: 22px 0 18px; color: var(--ink);
}
.lp2-strike {
    position: relative; display: inline-block; color: var(--ink-light);
}
.lp2-strike::after {
    content: ''; position: absolute; left: -4px; right: -4px;
    top: 55%; height: 6px;
    background: var(--ember); transform: rotate(-3deg);
    border-radius: 4px;
    box-shadow: 0 0 0 1px rgba(214,60,24,.3);
}
.lp2-grad {
    background: linear-gradient(135deg, var(--ember) 0%, var(--ember-deep) 100%);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
    display: inline-block;
}

.lp2-sub {
    color: var(--ink-soft); font-size: 18px; line-height: 1.6;
    max-width: 46ch; margin: 0;
}
.lp2-sub strong { color: var(--ink); font-weight: 700; }

.lp2-cta {
    display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap;
}
.lp2-cta-primary {
    padding: 14px 24px; font-size: 16px;
    box-shadow: 0 14px 28px -14px rgba(var(--ember-rgb),.6);
}
.lp2-cta-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 36px -16px rgba(var(--ember-rgb),.7); }
.lp2-cta-ghost {
    padding: 14px 24px; font-size: 16px;
    background: var(--paper); color: var(--ink); border: 1px solid var(--rule);
}
.lp2-cta-ghost:hover { background: var(--ember-soft); border-color: rgba(var(--ember-rgb),.3); }

.lp2-trust {
    margin-top: 30px;
    display: grid; gap: 8px; grid-template-columns: 1fr;
}
@media (min-width: 480px) { .lp2-trust { grid-template-columns: 1fr 1fr; } }
.lp2-trust-item {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--ink-soft); font-size: 13.5px;
}
.lp2-tick {
    width: 18px; height: 18px; border-radius: 50%;
    background: color-mix(in srgb, var(--sage) 18%, transparent 82%);
    color: var(--sage); display: inline-grid; place-items: center;
    font-size: 11px; font-weight: 800;
}

/* Right: floating mock stack */
.lp2-hero-mock { position: relative; min-height: 360px; }
@media (min-width: 900px) { .lp2-hero-mock { min-height: 480px; } }

.lp2-rings { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.lp2-rings span {
    position: absolute; border-radius: 50%; border: 1px solid rgba(var(--ember-rgb),.18);
    animation: lp2-pulse 6s ease-in-out infinite;
}
.lp2-rings span:nth-child(1) { width: 280px; height: 280px; opacity: .6; animation-delay: 0s; }
.lp2-rings span:nth-child(2) { width: 420px; height: 420px; opacity: .35; animation-delay: 1.5s; }
.lp2-rings span:nth-child(3) { width: 560px; height: 560px; opacity: .15; animation-delay: 3s; }
@keyframes lp2-pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.04); } }

.lp2-card {
    position: absolute;
    background: var(--paper);
    border: 1px solid var(--rule);
    border-radius: 22px;
    box-shadow:
        0 30px 60px -28px rgba(24,22,20,.35),
        0 4px 0 rgba(255,255,255,.6) inset,
        0 -2px 0 rgba(0,0,0,.04) inset;
    backdrop-filter: blur(20px);
}
.lp2-card--main {
    top: 5%; left: 0; right: 14%;
    padding: 22px 22px 20px;
    animation: lp2-float 6s ease-in-out infinite;
}
.lp2-card--qr {
    bottom: 5%; right: 0; left: 42%;
    padding: 16px 18px;
    transform: rotate(3deg);
    animation: lp2-float 7s ease-in-out infinite reverse;
}
@keyframes lp2-float {
    0%, 100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
    50%      { transform: translateY(-6px) rotate(var(--rot, 0deg)); }
}
.lp2-card--qr { --rot: 3deg; }
@media (max-width: 640px) {
    .lp2-card--main { right: 8%; }
    .lp2-card--qr   { display: none; }
    .lp2-hero-mock  { min-height: 320px; }
}

.lp2-card-head { display: flex; align-items: center; gap: 12px; }
.lp2-card-logo {
    width: 42px; height: 42px; border-radius: 12px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--ember-deep), var(--ember));
    color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 17px;
    box-shadow: 0 8px 16px -8px rgba(var(--ember-rgb),.5);
}
.lp2-card-titles { display: flex; flex-direction: column; }
.lp2-card-titles strong { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--ink); }
.lp2-card-titles span { font-size: 11.5px; color: var(--muted); letter-spacing: .04em; }
.lp2-card-badge {
    margin-left: auto;
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 10px; border-radius: 999px;
    background: rgba(88,120,102,.16); color: #2F5247;
    font-size: 12px; font-weight: 700;
}
.lp2-card-person { display: flex; align-items: center; gap: 12px; margin: 16px 0 12px; }
.lp2-card-avatar {
    width: 48px; height: 48px; border-radius: 12px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); font-weight: 800; font-size: 22px; font-family: var(--font-display);
}
.lp2-card-meta strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 15px; }
.lp2-card-meta span { font-size: 12.5px; color: var(--muted); }
.lp2-card-rows { display: grid; gap: 6px; margin: 6px 0 0; padding: 12px 0 0; border-top: 1px solid var(--rule); }
.lp2-card-rows > div { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.lp2-card-rows dt { color: var(--muted); margin: 0; }
.lp2-card-rows dd { color: var(--ink); margin: 0; font-weight: 600; }

/* QR card */
.lp2-card--qr .lp2-qr-img {
    width: 90px; height: 90px;
    background:
        radial-gradient(circle, var(--ink) 0 18%, transparent 18%) 8% 8% / 14% 14%,
        radial-gradient(circle, var(--ink) 0 18%, transparent 18%) 0 0 / 14% 14%,
        var(--paper);
    border: 2px solid var(--ink);
    border-radius: 6px;
    margin-bottom: 8px;
    box-shadow: 0 4px 12px -4px rgba(0,0,0,.12);
}
.lp2-card--qr .lp2-qr-meta strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 13px; }
.lp2-card--qr .lp2-qr-meta span { font-size: 11px; color: var(--muted); }

/* Floating chips */
.lp2-chip {
    position: absolute; z-index: 3;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 14px; border-radius: 999px;
    background: var(--paper);
    color: var(--ink); font-size: 12.5px; font-weight: 700;
    box-shadow: 0 14px 28px -12px rgba(24,22,20,.25);
    border: 1px solid var(--rule);
    animation: lp2-float 5s ease-in-out infinite;
}
.lp2-chip svg { color: var(--ember); }
.lp2-chip--shield { top: -4%; right: -2%; animation-delay: .4s; }
.lp2-chip--bolt   { bottom: 0; left: -4%; animation-delay: 1.6s; }
@media (max-width: 640px) { .lp2-chip--bolt { display: none; } .lp2-chip--shield { top: 0; right: 0; } }

/* =================================================================
   MANAGER DASHBOARD (mdash-*) — modernized KPI + module tiles
   ================================================================= */
.mdash-kpi {
    display: grid; gap: 16px;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 32px;
}
@media (min-width: 700px)  { .mdash-kpi { grid-template-columns: repeat(4, 1fr); } }

.mdash-kpi-card {
    --accent: #FF5A36;
    position: relative; overflow: hidden;
    background: linear-gradient(180deg, var(--paper) 0%, color-mix(in srgb, var(--paper) 92%, var(--accent) 8%) 100%);
    border: 1px solid var(--rule);
    border-radius: 18px;
    padding: 22px 20px 20px;
    box-shadow:
        0 2px 0 rgba(255,255,255,.6) inset,
        0 1px 3px rgba(24,22,20,.04),
        0 12px 24px -16px rgba(24,22,20,.08);
    transition: transform .25s var(--ease-out-expo), box-shadow .25s;
}
.mdash-kpi-card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 2px 0 rgba(255,255,255,.6) inset,
        0 18px 40px -18px color-mix(in srgb, var(--accent) 35%, transparent 65%);
}
.mdash-kpi-card::before {
    content: ''; position: absolute; top: -50px; right: -50px;
    width: 130px; height: 130px; border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 18%, transparent 82%) 0%, transparent 65%);
    pointer-events: none;
}
.mdash-kpi-icon {
    width: 42px; height: 42px; border-radius: 12px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, #000 30%));
    color: #FFFCF4;
    margin-bottom: 14px;
    box-shadow:
        0 8px 18px -10px color-mix(in srgb, var(--accent) 50%, transparent 50%),
        0 1px 0 rgba(255,255,255,.4) inset;
}
.mdash-kpi-label {
    color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .12em;
    font-weight: 700; margin-bottom: 4px;
}
.mdash-kpi-value {
    font-family: var(--font-display); font-weight: 800; font-size: 34px;
    line-height: 1; color: var(--ink); letter-spacing: -0.02em;
    background: linear-gradient(135deg, var(--ink) 0%, color-mix(in srgb, var(--ink) 60%, var(--accent) 40%) 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
}
.mdash-kpi-value--text {
    font-size: 17px; line-height: 1.25;
    -webkit-text-fill-color: var(--ink); background: none;
}
.mdash-kpi-sub { font-size: 12.5px; color: var(--muted); margin-top: 6px; }

/* Module section */
.mdash-modules { margin-bottom: 32px; }
.mdash-section-h { margin-bottom: 18px; }
.mdash-section-h h2 { font-family: var(--font-display); font-weight: 800; font-size: 22px; margin: 0; letter-spacing: -0.01em; }
.mdash-section-h p { color: var(--muted); font-size: 13.5px; margin: 4px 0 0; }

.mdash-mod-grid {
    display: grid; gap: 16px;
    grid-template-columns: 1fr;
}
@media (min-width: 600px) { .mdash-mod-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px){ .mdash-mod-grid { grid-template-columns: repeat(3, 1fr); } }

.mdash-mod-card {
    --from: #FF5A36; --to: #D63C18;
    position: relative; overflow: hidden;
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: 20px; padding: 22px;
    box-shadow:
        0 2px 0 rgba(255,255,255,.6) inset,
        0 4px 10px -4px rgba(24,22,20,.06),
        0 18px 30px -22px rgba(24,22,20,.10);
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
}
.mdash-mod-card:hover {
    transform: translateY(-5px);
    border-color: rgba(0,0,0,.08);
    box-shadow:
        0 2px 0 rgba(255,255,255,.6) inset,
        0 30px 50px -28px color-mix(in srgb, var(--from) 50%, transparent 50%);
}
.mdash-mod-glow {
    position: absolute; top: -80px; right: -60px;
    width: 200px; height: 200px; border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--from) 16%, transparent 84%) 0%, transparent 65%);
    pointer-events: none; z-index: 0;
}
.mdash-mod-icon {
    position: relative; z-index: 1;
    width: 56px; height: 56px; border-radius: 16px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--from), var(--to));
    color: #FFFCF4;
    font-family: var(--font-display); font-weight: 800; font-size: 22px;
    margin-bottom: 14px;
    box-shadow:
        0 12px 24px -12px color-mix(in srgb, var(--from) 55%, transparent 45%),
        0 2px 0 rgba(255,255,255,.5) inset,
        0 -2px 0 rgba(0,0,0,.2) inset;
}
.mdash-mod-name {
    position: relative; z-index: 1;
    font-family: var(--font-display); font-weight: 800; font-size: 17px;
    color: var(--ink); margin: 0 0 12px; letter-spacing: -0.005em;
}
.mdash-mod-stat {
    position: relative; z-index: 1;
    display: flex; align-items: baseline; gap: 6px; margin-bottom: 12px;
}
.mdash-mod-num {
    font-family: var(--font-display); font-weight: 800; font-size: 32px;
    color: var(--ink); line-height: 1; letter-spacing: -0.02em;
    background: linear-gradient(135deg, var(--ink) 0%, var(--from) 130%);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.mdash-mod-lbl { color: var(--muted); font-size: 13.5px; }
.mdash-mod-tags {
    position: relative; z-index: 1;
    display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px;
}
.mdash-tag {
    display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
}
.mdash-tag-on {
    background: color-mix(in srgb, var(--from) 12%, var(--paper) 88%);
    color: var(--from);
}
.mdash-mod-actions {
    position: relative; z-index: 1;
    display: flex; gap: 6px; flex-wrap: wrap;
}

/* ===== Auth split layout (login / change-password) ===== */
.kp-auth-body { background: var(--bone); margin: 0; }
.kp-auth-shell { display: grid; grid-template-columns: 1fr; min-height: 100vh; }
@media (min-width: 900px) { .kp-auth-shell { grid-template-columns: 1.05fr .95fr; } }

.kp-auth-art { display: none; position: relative; overflow: hidden; color: #FFFCF4; min-height: 100vh; }
@media (min-width: 900px) { .kp-auth-art { display: block; } }
.kp-auth-art-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; transform: scale(1.04); }
.kp-auth-art-veil {
    --accent: #FF5A36;
    position: absolute; inset: 0; z-index: 1;
    background:
        linear-gradient(135deg, rgba(24,22,20,.55) 0%, rgba(24,22,20,.82) 100%),
        radial-gradient(800px 400px at 70% 30%, color-mix(in srgb, var(--accent) 30%, transparent 70%), transparent 70%);
}
.kp-auth-back {
    position: absolute; top: 24px; left: 24px; z-index: 3;
    padding: 8px 14px; border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: var(--paper); font-size: 13px; font-weight: 600;
    text-decoration: none; transition: background .15s;
    display: inline-flex; align-items: center; gap: 6px;
    backdrop-filter: blur(8px);
}
.kp-auth-back:hover { background: rgba(255,255,255,.24); }
.kp-auth-art-inner { position: relative; z-index: 2; height: 100%; padding: 60px 56px; display: flex; flex-direction: column; justify-content: flex-end; }
.kp-auth-art-brand { font-size: 18px; margin-bottom: 22px; }
.kp-auth-art-brand .kp-brand-text { color: var(--paper); }
.kp-auth-art-brand .kp-brand-soft { color: rgba(255,252,244,.7); }
.kp-auth-art-h { font-family: var(--font-display); font-weight: 800; font-size: clamp(28px, 3.5vw, 42px); line-height: 1.1; letter-spacing: -0.02em; margin: 0 0 14px; max-width: 18ch; }
.kp-auth-art-sub { color: rgba(255,252,244,.78); font-size: 16px; line-height: 1.55; max-width: 38ch; margin: 0 0 26px; }
.kp-auth-art-trust { display: flex; gap: 8px; flex-wrap: wrap; }
.kp-auth-art-trust span { padding: 7px 14px; border-radius: 999px; background: rgba(255,255,255,.10); color: var(--paper); font-size: 12px; font-weight: 600; border: 1px solid rgba(255,255,255,.14); }

.kp-auth-form {
    background: var(--paper);
    display: flex; flex-direction: column;
    min-height: 100vh; padding: 28px 22px;
    position: relative;
}
@media (min-width: 900px) { .kp-auth-form { padding: 56px 64px; justify-content: center; } }

.kp-auth-mob-brand {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink);
    margin-bottom: 22px; text-decoration: none;
}
@media (min-width: 900px) { .kp-auth-mob-brand { display: none; } }

.kp-auth-content { flex: 1; display: flex; flex-direction: column; justify-content: center; max-width: 440px; width: 100%; margin: 0 auto; }
.kp-auth-foot { margin-top: 28px; padding-top: 18px; border-top: 1px solid var(--rule); text-align: center; font-size: 12px; color: var(--muted); }

.kp-auth-content .ka-auth-card { width: 100%; max-width: none; background: transparent; border: 0; padding: 0; box-shadow: none; }
.kp-auth-content .ka-auth-head h1 { font-size: 30px; }

/* ----- Blog cards + post prose ----- */
.bp-card {
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg);
    overflow: hidden;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
}
.bp-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px -18px rgba(24,22,20,.2); border-color: rgba(0,0,0,.08); }
.bp-card-link { display: block; color: inherit; text-decoration: none; }
.bp-card-img {
    width: 100%; aspect-ratio: 1.6/1;
    background-size: cover; background-position: center;
}
.bp-card-img--fallback {
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper);
    display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 800; font-size: 60px;
}
.bp-card-body { padding: 20px; }
.bp-card-meta { font-size: 12px; color: var(--muted); letter-spacing: .04em; text-transform: uppercase; font-weight: 600; }
.bp-card-title { font-family: var(--font-display); font-weight: 800; font-size: 18px; margin: 8px 0 8px; line-height: 1.25; color: var(--ink); }
.bp-card-excerpt { font-size: 14px; line-height: 1.55; color: var(--ink-soft); margin: 0 0 12px; }
.bp-card-cta { color: var(--ember-deep); font-size: 13px; font-weight: 700; }
.bp-card:hover .bp-card-cta { color: var(--ember); }

.bp-prose .bp-lede { font-size: 18.5px; line-height: 1.6; color: var(--ink); font-weight: 500; padding-left: 18px; border-left: 3px solid var(--ember); margin: 0 0 26px; }
.bp-prose pre { background: var(--ink); color: var(--paper); padding: 16px 18px; border-radius: var(--r); overflow: auto; font-family: var(--font-mono); font-size: 13px; line-height: 1.6; }
.bp-prose pre code { color: #FCD3C4; }
.bp-prose code { background: var(--cream); padding: 2px 6px; border-radius: 4px; font-family: var(--font-mono); font-size: 13px; color: var(--ember-deep); }
.bp-prose pre code { background: transparent; padding: 0; color: #FCD3C4; }
.bp-share { margin-top: 36px; padding-top: 22px; border-top: 1px solid var(--rule); display: flex; justify-content: center; }

/* ----- Cookie consent banner ----- */
.kp-cookie {
    position: fixed; left: 16px; right: 16px; bottom: 16px;
    z-index: 100;
    background: var(--ink); color: rgba(255,252,244,.86);
    border-radius: 18px;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06) inset;
    padding: 18px 22px;
    transform: translateY(150%); opacity: 0;
    transition: transform .35s var(--ease-out-expo), opacity .35s;
    max-width: 920px; margin-left: auto; margin-right: auto;
}
.kp-cookie.is-visible { transform: translateY(0); opacity: 1; }
.kp-cookie-inner {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px 18px;
    align-items: start;
}
@media (min-width: 768px) {
    .kp-cookie-inner { grid-template-columns: auto 1fr auto; align-items: center; }
}
.kp-cookie-icon {
    width: 44px; height: 44px; border-radius: 12px;
    background: rgba(255,252,244,.08);
    color: var(--ember-light);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.kp-cookie-body { min-width: 0; }
.kp-cookie-body h3 { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--paper); margin: 0 0 4px; }
.kp-cookie-body p { font-size: 13px; line-height: 1.55; color: rgba(255,252,244,.72); margin: 0; }
.kp-cookie-body a { color: var(--ember-light); text-decoration: underline; }
.kp-cookie-actions {
    grid-column: 1 / -1;
    display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end;
}
@media (min-width: 768px) { .kp-cookie-actions { grid-column: auto; } }
.kp-cookie-btn {
    padding: 10px 18px; border-radius: 10px; border: 0; cursor: pointer;
    font-weight: 700; font-size: 13.5px; font-family: var(--font-body);
    transition: background .15s, transform .15s;
}
.kp-cookie-btn--ghost {
    background: rgba(255,252,244,.06); color: var(--paper);
    border: 1px solid rgba(255,252,244,.08);
}
.kp-cookie-btn--ghost:hover { background: rgba(255,252,244,.12); }
.kp-cookie-btn--accept {
    background: var(--ember); color: var(--paper);
    box-shadow: 0 8px 16px -8px rgba(var(--ember-rgb),.6);
}
.kp-cookie-btn--accept:hover { background: var(--ember-deep); transform: translateY(-1px); }

/* Home: Embed + Pricing 50/50 split */
.lp-ep { display: grid; gap: 40px; grid-template-columns: 1fr; align-items: stretch; }
@media (min-width: 900px) { .lp-ep { grid-template-columns: 1fr 1fr; gap: 56px; } }
.lp-ep-col { display: flex; flex-direction: column; }
.lp-ep-h { font-family: var(--font-display); font-size: clamp(24px, 3.2vw, 32px); font-weight: 800; letter-spacing: -0.01em; margin: 14px 0 12px; line-height: 1.1; }
.lp-ep-sub { color: var(--ink-soft); font-size: 15.5px; line-height: 1.55; margin: 0 0 18px; }
.lp-ep-code {
    background: #0E0C0B; color: #FCD3C4; border-radius: var(--r-lg);
    padding: 20px; overflow: auto; flex: 1;
    box-shadow: 0 16px 40px -20px rgba(24,22,20,.4);
}
.lp-ep-code pre { margin: 0; }
.lp-ep-code code { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.6; color: #FCD3C4; }
.lp-ep-note { color: var(--muted); font-size: 12.5px; margin: 12px 0 0; }
.lp-ep-price {
    background: linear-gradient(180deg, var(--paper), var(--cream));
    border: 1px solid rgba(var(--ember-rgb),.3);
    border-radius: var(--r-xl); padding: 28px 26px;
    box-shadow: 0 30px 60px -30px rgba(var(--ember-rgb),.5);
    text-align: center; flex: 1;
}
.lp-ep-price .kp-price-h { font-family: var(--font-display); font-size: 22px; font-weight: 800; margin: 14px 0 6px; }
.lp-ep-price .kp-price-amt { font-family: var(--font-display); font-size: 40px; font-weight: 800; color: var(--ember-deep); margin: 4px 0; }
.lp-ep-price .kp-price-sub { color: var(--ink-soft); font-size: 13.5px; margin: 0 0 14px; }
.lp-ep-price .kp-price-features { list-style: none; padding: 0; margin: 12px 0 18px; display: grid; gap: 6px; text-align: left; }
.lp-ep-price .kp-price-features li { padding-left: 22px; position: relative; color: var(--ink-soft); font-size: 13.5px; }
.lp-ep-price .kp-price-features li::before { content: '✓'; position: absolute; left: 0; color: var(--ember); font-weight: 800; }

/* =================================================================
   VERIFY FORM v2 (pvxf-*) — /v/{slug}/{module}
   ================================================================= */
.pvxf { --tenant: #FF5A36; }

.pvxf-hero {
    position: relative; overflow: hidden;
    background: linear-gradient(135deg, color-mix(in srgb, var(--tenant) 90%, #181614 10%) 0%, color-mix(in srgb, var(--tenant) 40%, #181614 60%) 100%);
    color: #FFFCF4; padding: 40px 20px 70px;
}
.pvxf-hero-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.pvxf-hero-glow {
    position: absolute; top: -100px; right: -80px;
    width: 360px; height: 360px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.22) 0%, transparent 65%);
    filter: blur(20px);
}
.pvxf-hero-inner { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; text-align: center; }
.pvxf-back {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 12px; border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: var(--paper); font-size: 12.5px; font-weight: 600;
    text-decoration: none; transition: background .15s;
    margin-bottom: 18px;
}
.pvxf-back:hover { background: rgba(255,255,255,.22); }
.pvxf-tenant {
    display: inline-flex; align-items: center; gap: 12px;
    background: rgba(0,0,0,.18); padding: 8px 16px 8px 8px; border-radius: 999px;
    margin-bottom: 18px;
    border: 1px solid rgba(255,255,255,.12);
}
.pvxf-tenant-logo {
    width: 38px; height: 38px; border-radius: 10px; object-fit: contain;
    background: rgba(255,255,255,.96); padding: 4px;
}
.pvxf-tenant-logo--fallback {
    background: rgba(255,255,255,.22); color: var(--paper);
    display: inline-grid; place-items: center;
    font-family: var(--font-display); font-weight: 800; font-size: 16px; padding: 0;
}
.pvxf-tenant-titles { display: flex; flex-direction: column; align-items: flex-start; }
.pvxf-tenant-titles strong { font-family: var(--font-display); font-weight: 700; font-size: 14px; }
.pvxf-tenant-titles span { font-size: 11px; opacity: .75; letter-spacing: .08em; }
.pvxf-h {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(26px, 4vw, 36px);
    margin: 8px 0 8px; letter-spacing: -0.015em; line-height: 1.1;
    text-shadow: 0 2px 12px rgba(0,0,0,.25);
}
.pvxf-h-eyebrow {
    display: block;
    font-size: 12.5px; letter-spacing: .24em; text-transform: uppercase;
    color: rgba(255,255,255,.78); font-weight: 700;
    margin-bottom: 4px;
}
.pvxf-sub { color: rgba(255,255,255,.82); font-size: 14.5px; max-width: 48ch; margin: 0 auto; }

.pvxf-card-wrap {
    max-width: 520px; margin: -40px auto 50px; padding: 0 18px;
    position: relative; z-index: 2;
}
.pvxf-card {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: 22px; padding: 26px 24px;
    box-shadow: 0 30px 60px -28px rgba(24,22,20,.3), 0 2px 0 rgba(255,255,255,.6) inset;
}

.pvxf-scan-area {
    margin-bottom: 14px; background: #000; border-radius: 14px; overflow: hidden;
    aspect-ratio: 1; position: relative;
}
.pvxf-scan-area video { width: 100%; height: 100%; object-fit: cover; }

.pvxf-scan-btn {
    width: 100%; padding: 14px; border: 0; cursor: pointer;
    background: var(--ink); color: var(--paper); border-radius: 12px;
    font-weight: 700; font-size: 14.5px;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    transition: background .15s, transform .15s;
}
.pvxf-scan-btn:hover { background: #000; transform: translateY(-1px); }
.pvxf-scan-btn.is-active { background: var(--ember-deep); }

.pvxf-divider {
    display: flex; align-items: center; gap: 12px;
    margin: 16px 0; color: var(--muted); font-size: 11.5px;
    text-transform: uppercase; letter-spacing: .14em; font-weight: 700;
}
.pvxf-divider::before, .pvxf-divider::after {
    content: ''; flex: 1; height: 1px; background: var(--rule);
}

.pvxf-form { display: grid; gap: 12px; }
.pvxf-field { display: grid; gap: 6px; }
.pvxf-label { font-size: 12.5px; font-weight: 700; color: var(--ink-soft); letter-spacing: .04em; }
.pvxf-input {
    padding: 14px 16px; border: 1.5px solid var(--rule); border-radius: 12px;
    font-size: 15px; background: var(--cream); color: var(--ink);
    transition: border-color .15s, box-shadow .15s, background .15s;
    width: 100%; outline: none; font-family: inherit;
}
.pvxf-input:focus {
    border-color: var(--tenant); background: var(--paper);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--tenant) 16%, transparent 84%);
}
.pvxf-submit {
    margin-top: 6px; padding: 14px 20px; border: 0; cursor: pointer;
    background: var(--tenant); color: var(--paper);
    border-radius: 12px; font-weight: 800; font-size: 15px;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    transition: background .15s, transform .15s, box-shadow .15s;
    box-shadow: 0 10px 22px -10px color-mix(in srgb, var(--tenant) 60%, transparent 40%);
}
.pvxf-submit:hover:not(:disabled) {
    background: color-mix(in srgb, var(--tenant) 80%, #000 20%);
    transform: translateY(-1px);
}
.pvxf-submit:disabled { opacity: .6; cursor: not-allowed; }

.pvxf-error {
    margin: 16px 0 0; padding: 12px 14px;
    background: color-mix(in srgb, var(--tenant) 14%, var(--paper) 86%);
    color: color-mix(in srgb, var(--tenant) 80%, #000 20%);
    border: 1px solid color-mix(in srgb, var(--tenant) 30%, transparent 70%);
    border-radius: 12px; font-size: 13.5px; text-align: center;
}

.pvxf-help {
    margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--rule);
    display: flex; align-items: flex-start; gap: 8px;
    color: var(--muted); font-size: 12.5px; line-height: 1.5;
}
.pvxf-help svg { flex-shrink: 0; margin-top: 2px; }

/* legacy pvx- (still used by embed layout / fallback) */
.pvx { --tenant: #FF5A36; max-width: 520px; margin: 0 auto; padding: 18px 16px 30px; }

.pvx-hero {
    position: relative;
    background: linear-gradient(135deg, var(--tenant) 0%, color-mix(in srgb, var(--tenant) 60%, #181614 40%) 100%);
    color: #FFFCF4;
    border-radius: 24px;
    padding: 36px 24px 30px;
    text-align: center;
    overflow: hidden;
    box-shadow:
        0 24px 60px -22px rgba(0,0,0,.4),
        0 0 0 1px rgba(255,255,255,.06) inset;
}
.pvx-hero-rings { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.pvx-hero-rings span {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    border-radius: 50%; border: 1px solid rgba(255,255,255,.18);
}
.pvx-hero-rings span:nth-child(1) { width: 230px; height: 230px; opacity: .45; }
.pvx-hero-rings span:nth-child(2) { width: 330px; height: 330px; opacity: .25; }
.pvx-hero-rings span:nth-child(3) { width: 440px; height: 440px; opacity: .12; }
.pvx-hero-card { position: relative; z-index: 1; }
.pvx-logo {
    height: 76px; max-width: 200px; object-fit: contain;
    background: rgba(255,255,255,.94); padding: 6px;
    border-radius: 14px;
}
.pvx-logo--fallback {
    display: inline-grid; place-items: center;
    width: 76px; height: 76px; border-radius: 18px;
    background: rgba(255,255,255,.22);
    color: #FFFCF4; font-family: var(--font-display); font-weight: 800; font-size: 32px;
    backdrop-filter: blur(4px);
}
.pvx-h {
    font-family: var(--font-display); font-weight: 800; font-size: 26px;
    margin: 18px 0 4px; letter-spacing: -0.01em; line-height: 1.1;
}
.pvx-sub { color: rgba(255,252,244,.78); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }
.pvx-shield {
    position: absolute; top: 18px; right: 18px;
    width: 48px; height: 48px;
    border-radius: 50%; background: rgba(255,255,255,.12);
    display: grid; place-items: center;
    box-shadow: 0 4px 18px -6px rgba(0,0,0,.4);
}

.pvx-para {
    text-align: center; color: var(--ink-soft); font-size: 14.5px; line-height: 1.6;
    margin: 22px 6px 18px;
}

.pvx-modules { display: grid; gap: 10px; }
.pvx-mod {
    display: flex; align-items: center; gap: 14px;
    background: var(--paper); border: 1px solid var(--rule); border-radius: 16px;
    padding: 14px; text-decoration: none; color: var(--ink);
    transition: transform .2s var(--ease-out-expo), box-shadow .2s, border-color .2s;
}
.pvx-mod:hover, .pvx-mod:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px -16px rgba(0,0,0,.18);
    border-color: rgba(0,0,0,.08);
}
.pvx-mod-icon {
    width: 52px; height: 52px; border-radius: 14px;
    display: grid; place-items: center;
    box-shadow:
        0 8px 20px -10px rgba(0,0,0,.25),
        0 1px 0 rgba(255,255,255,.4) inset,
        0 -1px 0 rgba(0,0,0,.25) inset;
    flex-shrink: 0;
}
.pvx-mod-body { display: flex; flex-direction: column; }
.pvx-mod-body strong { font-family: var(--font-display); font-weight: 700; font-size: 15.5px; color: var(--ink); }
.pvx-mod-body span { color: var(--muted); font-size: 12.5px; margin-top: 1px; }

.pvx-contact {
    margin-top: 26px; padding: 16px 18px;
    background: var(--cream); border: 1px solid var(--rule); border-radius: 14px;
    display: flex; flex-direction: column; gap: 6px;
    font-size: 13px; color: var(--ink-soft);
}
.pvx-contact strong { color: var(--ink); font-family: var(--font-display); margin-bottom: 2px; }

/* single-price card */
.kp-price-single {
    max-width: 460px; margin: 0 auto;
    background: linear-gradient(180deg, var(--paper), var(--cream));
    border: 1px solid rgba(var(--ember-rgb),.3); border-radius: var(--r-xl);
    padding: 36px 30px 30px; text-align: center;
    box-shadow: 0 30px 60px -30px rgba(var(--ember-rgb),.5);
    position: relative;
}
.kp-price-eyebrow { display: inline-block; padding: 5px 14px; background: var(--ember); color: var(--paper); font-size: 11.5px; letter-spacing: .14em; text-transform: uppercase; font-weight: 800; border-radius: 999px; }
.kp-price-h { font-family: var(--font-display); font-size: 28px; font-weight: 800; margin: 18px 0 8px; }
.kp-price-amt { font-family: var(--font-display); font-size: 44px; font-weight: 800; color: var(--ember-deep); margin: 6px 0 4px; }
.kp-price-sub { color: var(--ink-soft); font-size: 14.5px; margin: 0 0 18px; }
.kp-price-features { list-style: none; padding: 0; margin: 0 0 22px; display: grid; gap: 7px; text-align: left; }
.kp-price-features li { padding-left: 24px; position: relative; color: var(--ink-soft); font-size: 14.5px; }
.kp-price-features li::before { content: '✓'; position: absolute; left: 0; color: var(--ember); font-weight: 800; }

/* =================================================================
   ADMIN / MANAGER SHELL
   ================================================================= */
.ka-shell { display: grid; grid-template-columns: 1fr; min-height: 100vh; background: var(--bone); }
@media (min-width: 1024px) { .ka-shell { grid-template-columns: 256px 1fr; } }

.ka-side {
    background: linear-gradient(180deg, var(--ink) 0%, #0E0C0B 100%);
    color: rgba(255,252,244,.78); padding: 22px 16px;
    display: none; flex-direction: column; gap: 18px;
    position: sticky; top: 0; height: 100vh;
    overflow-y: auto;
    border-right: 1px solid rgba(255,252,244,.06);
}
.ka-side::-webkit-scrollbar { width: 6px; }
.ka-side::-webkit-scrollbar-thumb { background: rgba(255,252,244,.12); border-radius: 3px; }
@media (min-width: 1024px) { .ka-side { display: flex; } }
.ka-side-brand {
    display: flex; align-items: center; gap: 10px;
    padding: 6px 6px 16px; border-bottom: 1px solid rgba(255,252,244,.10);
    font-family: var(--font-display);
}
.ka-side-brand-text { font-weight: 700; font-size: 17px; color: var(--paper); }
.ka-side-brand-text em { color: var(--ember-light); font-style: normal; font-weight: 500; }

.ka-side-nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.ka-side-link {
    display: flex; align-items: center; gap: 12px; padding: 11px 12px;
    border-radius: var(--r); color: rgba(255,252,244,.74); font-weight: 500; font-size: 14.5px;
    transition: background .15s var(--ease-out-expo), color .15s var(--ease-out-expo);
}
.ka-side-link:hover { background: rgba(255,252,244,.06); color: var(--paper); }
.ka-side-link.is-active {
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); box-shadow: var(--shadow-ember);
}
.ka-side-ic { width: 22px; text-align: center; opacity: .9; }

.ka-side-foot { border-top: 1px solid rgba(255,252,244,.10); padding-top: 14px; }
.ka-side-user { display: flex; align-items: center; gap: 10px; padding: 6px; }
.ka-side-avatar {
    width: 36px; height: 36px; border-radius: var(--r); background: linear-gradient(135deg, var(--ember-light), var(--ember));
    display: grid; place-items: center; font-weight: 800; color: var(--paper); font-family: var(--font-display);
}
.ka-side-user-name { font-weight: 600; color: var(--paper); font-size: 14px; }
.ka-side-user-role { font-size: 12px; color: rgba(255,252,244,.55); }
.ka-side-logout {
    display: block; text-align: center; margin-top: 12px;
    padding: 10px; border-radius: var(--r); background: rgba(255,252,244,.08);
    color: var(--paper); font-weight: 600; font-size: 14px;
}
.ka-side-logout:hover { background: rgba(var(--ember-rgb),.22); color: var(--paper); }

/* ----- mobile topbar + drawer ----- */
.ka-mobtop {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 14px calc(12px + env(safe-area-inset-top)); padding-top: 12px;
    background: var(--ink); color: var(--paper); position: sticky; top: 0; z-index: 30;
    border-bottom: 1px solid rgba(255,252,244,.08);
}
@media (min-width: 1024px) { .ka-mobtop { display: none; } }
.ka-mob-burger {
    width: 38px; height: 38px; border: 0; background: transparent;
    display: inline-flex; flex-direction: column; justify-content: center; align-items: center; gap: 4px;
    cursor: pointer; border-radius: 8px; padding: 0;
}
.ka-mob-burger span { display: block; width: 18px; height: 2px; background: var(--paper); border-radius: 2px; transition: transform .2s var(--ease-out-expo); }
.ka-mob-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.ka-mob-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.ka-mob-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.ka-mob-brand { display: flex; align-items: center; gap: 10px; flex: 1; font-weight: 700; font-family: var(--font-display); font-size: 15px; }
.ka-mob-brand .ka-brand-mark { width: 30px; height: 30px; border-radius: 8px; font-size: 14px; }
.ka-mob-logout {
    width: 38px; height: 38px; border-radius: 8px; background: rgba(255,252,244,.08);
    color: var(--paper); display: inline-flex; align-items: center; justify-content: center; font-size: 18px;
}

.ka-drawer { position: fixed; inset: 0; z-index: 60; pointer-events: none; }
.ka-drawer.is-open { pointer-events: auto; }
.ka-drawer-back { position: absolute; inset: 0; background: rgba(24,22,20,.55); opacity: 0; transition: opacity .2s var(--ease-out-expo); }
.ka-drawer.is-open .ka-drawer-back { opacity: 1; }
.ka-drawer-body {
    position: absolute; top: 0; bottom: 0; left: 0;
    width: min(86vw, 320px);
    background: linear-gradient(180deg, var(--ink) 0%, #0E0C0B 100%);
    color: rgba(255,252,244,.78); padding: 18px 16px;
    display: flex; flex-direction: column; gap: 16px;
    transform: translateX(-100%); transition: transform .25s var(--ease-out-expo);
    overflow-y: auto;
    box-shadow: 6px 0 30px -10px rgba(0,0,0,.5);
}
.ka-drawer.is-open .ka-drawer-body { transform: translateX(0); }
.ka-drawer-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px solid rgba(255,252,244,.08); }
.ka-drawer-x { background: transparent; border: 0; color: var(--paper); font-size: 26px; line-height: 1; cursor: pointer; padding: 4px 8px; border-radius: 8px; }
.ka-drawer-x:hover { background: rgba(255,252,244,.08); }
.ka-drawer .ka-side-nav { flex: 1; overflow-y: auto; }

/* common section heading inside both sidebar + drawer */
.ka-side-section { margin-top: 12px; padding: 0 12px; font-size: 11px; letter-spacing: .08em; color: rgba(255,252,244,.45); font-weight: 700; text-transform: uppercase; }
.ka-side-brand-text em { display: block; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--ember-light); font-style: normal; font-weight: 500; }

/* main column */
.ka-main {
    min-width: 0;
    display: flex; flex-direction: column;
    padding-bottom: 80px;
    background: var(--bone);
    min-height: 100vh;
}
@media (min-width: 1024px) { .ka-main { padding-bottom: 0; } }
.ka-main-inner { padding: 22px 18px; max-width: 1180px; width: 100%; margin: 0 auto; flex: 1 0 auto; }
@media (min-width: 768px) { .ka-main-inner { padding: 36px 32px; } }
.ka-main .ka-footer { flex-shrink: 0; }

/* impersonation banner */
.ka-imp-banner {
    background: linear-gradient(90deg, var(--ember-soft), #FCD3C4);
    color: var(--ember-deep); padding: 10px 18px;
    display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
    border-bottom: 1px solid rgba(var(--ember-rgb),.25);
    font-size: 14px;
}
.ka-imp-banner strong { color: var(--ink); }
.ka-imp-form { margin: 0; }
.ka-imp-exit {
    background: var(--ember-deep); color: var(--paper); padding: 6px 12px; border-radius: 8px;
    font-weight: 700; font-size: 13px; border: 0; cursor: pointer;
}
.ka-imp-exit:hover { background: var(--ink); }

/* page header */
.ka-page-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.ka-page-title { font-size: 26px; font-weight: 800; margin: 0; letter-spacing: -0.01em; }
.ka-page-sub   { color: var(--muted); font-size: 14.5px; margin: 2px 0 0; }
.ka-page-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* KPI grid (modernized) */
.ka-kpi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 6px; }
@media (min-width: 640px)  { .ka-kpi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .ka-kpi-grid { grid-template-columns: repeat(4, 1fr); } }
.ka-kpi {
    background: linear-gradient(135deg, var(--paper) 0%, color-mix(in srgb, var(--paper) 92%, var(--ember-soft) 8%) 100%);
    border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 20px 18px;
    display: flex; flex-direction: column; gap: 6px;
    box-shadow: 0 2px 6px -2px rgba(24,22,20,.04), 0 1px 0 rgba(255,255,255,.6) inset;
    position: relative; overflow: hidden;
    transition: transform .2s var(--ease-out-expo), box-shadow .2s;
}
.ka-kpi:hover { transform: translateY(-2px); box-shadow: 0 12px 30px -16px rgba(24,22,20,.18); }
.ka-kpi::before {
    content: ''; position: absolute; top: -30px; right: -30px;
    width: 90px; height: 90px; border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--ember-rgb),.10) 0%, transparent 70%);
    pointer-events: none;
}
.ka-kpi-label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 700; }
.ka-kpi-value { font-size: 32px; font-weight: 800; line-height: 1; font-family: var(--font-display); color: var(--ink); margin-top: 2px; letter-spacing: -0.02em; }
.ka-kpi-sub   { font-size: 12.5px; color: var(--muted); margin-top: 2px; }

/* panels (modernized) */
.ka-panel {
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg);
    padding: 22px; box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 2px 6px -2px rgba(24,22,20,.04);
}
.ka-panel + .ka-panel { margin-top: 16px; }
.ka-panel-h {
    display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap;
    margin: -22px -22px 18px; padding: 16px 22px;
    border-bottom: 1px solid var(--rule);
    background: linear-gradient(180deg, color-mix(in srgb, var(--paper) 60%, var(--cream) 40%) 0%, var(--paper) 100%);
    border-radius: var(--r-lg) var(--r-lg) 0 0;
}
.ka-panel-h h2 { font-size: 17px; font-weight: 800; margin: 0; font-family: var(--font-display); letter-spacing: -0.005em; }

/* table */
.ka-table-wrap { overflow-x: auto; }
.ka-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.ka-table thead th {
    text-align: left; font-size: 11.5px; text-transform: uppercase; letter-spacing: .08em;
    color: var(--muted); padding: 10px 12px; border-bottom: 1px solid var(--rule); font-weight: 700; background: var(--cream);
}
.ka-table tbody td { padding: 12px; border-bottom: 1px solid var(--rule); vertical-align: middle; }
.ka-table tbody tr:hover { background: var(--cream); }
.ka-status-pill { display: inline-block; padding: 3px 10px; border-radius: var(--r-pill); font-size: 12px; font-weight: 700; }
.ka-status-active    { background: rgba(88,120,102,.14); color: var(--sage); }
.ka-status-suspended { background: var(--ember-soft); color: var(--ember-deep); }

@media (max-width: 768px) {
    .ka-table { display: block; }
    .ka-table thead { display: none; }
    .ka-table tbody, .ka-table tr, .ka-table td { display: block; width: 100%; }
    .ka-table tbody tr { border: 1px solid var(--rule); border-radius: var(--r); margin-bottom: 10px; padding: 6px 4px; background: var(--paper); }
    .ka-table tbody td { display: flex; justify-content: space-between; padding: 8px 12px; border: 0; }
    .ka-table tbody td::before {
        content: attr(data-label); color: var(--muted); font-weight: 700;
        font-size: 11.5px; text-transform: uppercase; letter-spacing: .08em; margin-right: 12px;
    }
    .ka-table tbody td[data-label="Actions"] { justify-content: flex-end; gap: 8px; padding-top: 6px; }
    .ka-table tbody td[data-label="Actions"]::before { display: none; }
}

.ka-btn-sm { padding: 6px 10px; min-height: 32px; font-size: 13px; border-radius: var(--r-sm); }
.ka-btn-danger { background: var(--ember-deep); color: var(--paper); }
.ka-btn-danger:hover:not(:disabled) { background: var(--ink); }
.ka-btn-warn { background: var(--ember); color: var(--paper); }
.ka-btn-warn:hover:not(:disabled) { background: var(--ember-deep); }
.ka-btn-ok { background: var(--sage); color: var(--paper); }
.ka-btn-ok:hover:not(:disabled) { background: #3F5C4D; }

/* form layout */
.ka-form-grid { display: grid; gap: 14px; }
@media (min-width: 768px) { .ka-form-grid.two-col { grid-template-columns: 1fr 1fr; } }

.ka-fieldset { border: 1px solid var(--rule); border-radius: var(--r); padding: 14px 16px; background: var(--paper); }
.ka-fieldset legend { font-weight: 700; font-size: 13px; padding: 0 8px; color: var(--ink); font-family: var(--font-display); }
.ka-switch-grid { display: grid; grid-template-columns: 1fr; gap: 6px; margin-top: 6px; }
@media (min-width: 640px) { .ka-switch-grid { grid-template-columns: 1fr 1fr; } }
.ka-switch {
    display: flex; align-items: center; gap: 10px; padding: 8px 10px;
    border: 1px solid var(--rule); border-radius: var(--r); cursor: pointer; background: var(--cream);
}
.ka-switch input { accent-color: var(--ember); }
.ka-switch span  { font-size: 14px; }

/* copy field */
.ka-copy-row { display: flex; gap: 8px; align-items: stretch; }
.ka-copy-row input, .ka-copy-row textarea {
    flex: 1; min-width: 0; background: var(--cream); color: var(--ink); font-family: var(--font-mono); font-size: 13px;
    padding: 10px 12px; border: 1px solid var(--rule); border-radius: var(--r);
}
.ka-copy-btn {
    flex: 0 0 auto; padding: 0 14px; border-radius: var(--r); border: 0; cursor: pointer;
    background: var(--ink); color: var(--paper); font-weight: 700; font-size: 13px; font-family: var(--font-body);
}
.ka-copy-btn:hover:not(:disabled) { background: #000; }
.ka-copy-btn:disabled { opacity: .7; cursor: default; }
.ka-copy-block textarea { min-height: 180px; resize: vertical; }
.ka-copy-block { display: grid; gap: 8px; }
.ka-copy-block .ka-copy-btn { width: 100%; min-height: 40px; }

/* modal */
.ka-modal-back { position: fixed; inset: 0; background: rgba(24,22,20,.55); display: grid; place-items: center; padding: 16px; z-index: 60; }
.ka-modal { background: var(--paper); border-radius: var(--r-lg); max-width: 460px; width: 100%; padding: 22px; box-shadow: var(--shadow-lg); }
.ka-modal h3 { font-size: 19px; font-weight: 800; margin: 0 0 6px; font-family: var(--font-display); }
.ka-modal p  { color: var(--muted); font-size: 14px; margin: 0 0 14px; }
.ka-modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; }

/* activity */
.ka-act-row td.act-actor { font-weight: 700; }
.ka-act-row code { font-family: var(--font-mono); font-size: 12px; background: var(--cream); padding: 2px 6px; border-radius: var(--r-sm); }
.ka-act-filter {
    display: grid; grid-template-columns: 1fr; gap: 10px;
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 14px; margin-bottom: 12px; box-shadow: var(--shadow-sm);
}
@media (min-width: 768px) { .ka-act-filter { grid-template-columns: repeat(5, 1fr) auto; align-items: end; } }
.ka-act-filter label { display: grid; gap: 4px; font-size: 12px; color: var(--muted); font-weight: 700; }
.ka-act-filter select, .ka-act-filter input {
    padding: 9px 10px; border: 1px solid var(--rule); border-radius: var(--r-sm); min-height: 38px; font-size: 14px; background: var(--paper); font-family: inherit; color: var(--ink);
}

/* =================================================================
   KP2 — PHASE 12 FUTURISTIC PUBLIC SITE DESIGN SYSTEM
   Inspired by klippa.com / yoti.com
   ================================================================= */

/* ---------- KP2 layout helpers ---------- */
.kp2 { --kp2-r: 18px; --kp2-r-lg: 26px; --kp2-r-sm: 10px; }
.kp2-wrap   { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.kp2-wrap-narrow { max-width: 920px; margin: 0 auto; padding: 0 20px; }
.kp2-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 14px; background: rgba(var(--ember-rgb),.12);
    color: var(--ember-deep);
    font-weight: 700; font-size: 11.5px; letter-spacing: .16em; text-transform: uppercase;
    border-radius: 999px;
}
.kp2-eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ember); box-shadow: 0 0 0 4px rgba(var(--ember-rgb),.18); }
.kp2-eyebrow--dark { background: rgba(255,252,244,.12); color: var(--paper); }
.kp2-eyebrow--dark .kp2-eyebrow-dot { background: var(--paper); box-shadow: 0 0 0 4px rgba(255,252,244,.18); }

.kp2-sec        { padding: 96px 0; position: relative; }
.kp2-sec--alt   { background: var(--cream); }
.kp2-sec--bone  { background: var(--bone); }
.kp2-sec--ink   { background: var(--ink); color: var(--paper); }
.kp2-sec--ink h1, .kp2-sec--ink h2, .kp2-sec--ink h3 { color: var(--paper); }
.kp2-sec--gradient {
    background:
        radial-gradient(900px 460px at 84% 0%, rgba(var(--ember-rgb),.10), transparent 70%),
        radial-gradient(700px 360px at 0% 100%, rgba(88,120,102,.10), transparent 70%),
        var(--bone);
}
@media (max-width: 720px) { .kp2-sec { padding: 64px 0; } }

.kp2-sec-head {
    text-align: center; max-width: 680px; margin: 0 auto 56px;
}
.kp2-sec-head h2 {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(28px, 4.4vw, 46px); line-height: 1.05; letter-spacing: -0.025em;
    margin: 14px 0 14px;
}
.kp2-sec-head p {
    color: var(--ink-soft); font-size: 17px; line-height: 1.6; margin: 0;
}
.kp2-sec--ink .kp2-sec-head p { color: rgba(255,252,244,.78); }
.kp2-sec-head--left { text-align: left; margin-left: 0; }

/* ---------- HERO V3 — futuristic with animated grid ---------- */
.kp2-hero {
    position: relative; overflow: hidden;
    background: linear-gradient(180deg, #0E0C0B 0%, #181614 70%, #1F1B17 100%);
    color: var(--paper);
    padding: 120px 0 90px; min-height: 740px;
    /* block (not flex) — flex was squeezing .kp2-hero-inner because the
       absolutely-positioned background layers were collapsing to zero-width
       flex items, forcing the inner column to share the leftover space. */
}
@media (max-width: 900px) { .kp2-hero { padding: 90px 0 60px; min-height: 0; } }

.kp2-hero-grid {
    position: absolute; inset: 0; z-index: 0; opacity: .35;
    background-image:
        linear-gradient(to right, rgba(255,252,244,.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,252,244,.06) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, #000 30%, transparent 80%);
}
.kp2-hero-orb {
    position: absolute; z-index: 0; pointer-events: none; border-radius: 50%;
    filter: blur(60px); opacity: .55;
}
.kp2-hero-orb--a { width: 520px; height: 520px; top: -120px; right: -120px; background: radial-gradient(circle at 30% 30%, var(--ember), transparent 70%); }
.kp2-hero-orb--b { width: 420px; height: 420px; bottom: -160px; left: -100px; background: radial-gradient(circle at 50% 50%, #587866, transparent 70%); opacity: .35; }

.kp2-hero-inner {
    position: relative; z-index: 2;
    width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px;
    display: grid; grid-template-columns: 1fr; gap: 48px; align-items: center;
}
@media (min-width: 980px) {
    .kp2-hero-inner { grid-template-columns: 1.08fr 1fr; gap: 56px; }
}

.kp2-hero-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(255,252,244,.08); border: 1px solid rgba(255,252,244,.14);
    padding: 7px 14px; border-radius: 999px;
    font-size: 12px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700;
    color: rgba(255,252,244,.88); backdrop-filter: blur(8px);
}
.kp2-hero-eyebrow-dot { width: 8px; height: 8px; border-radius: 50%; background: #5DD39E; box-shadow: 0 0 0 4px rgba(93,211,158,.22); animation: kp2-pulse 2s ease-in-out infinite; }
@keyframes kp2-pulse { 0%,100% { transform: scale(1); opacity:1 } 50% { transform: scale(1.18); opacity:.7 } }

.kp2-hero-h {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(36px, 5.4vw, 64px); line-height: 1.02; letter-spacing: -0.03em;
    margin: 18px 0 18px; color: var(--paper);
}
.kp2-hero-h .kp2-grad {
    background: linear-gradient(100deg, var(--ember) 0%, #FF9B7A 50%, var(--ember) 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    background-size: 200% auto;
    animation: kp2-shimmer 6s linear infinite;
}
@keyframes kp2-shimmer { to { background-position: 200% center; } }
.kp2-hero-h .kp2-strike { position: relative; color: rgba(255,252,244,.45); }
.kp2-hero-h .kp2-strike::after {
    content: ''; position: absolute; left: -4%; right: -4%; top: 56%; height: 4px;
    background: var(--ember); border-radius: 4px; transform: rotate(-3deg);
}

.kp2-hero-sub {
    color: rgba(255,252,244,.78); font-size: 18px; line-height: 1.6;
    max-width: 52ch; margin: 0 0 28px;
}

.kp2-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin-bottom: 32px; }
.kp2-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 22px; border-radius: 999px; font-weight: 700; font-size: 15px;
    border: 0; cursor: pointer; transition: all .2s var(--ease-out-expo); font-family: inherit; text-decoration: none;
}
.kp2-btn--primary {
    background: var(--ember); color: var(--paper);
    box-shadow: 0 10px 32px -8px rgba(var(--ember-rgb),.55), inset 0 1px 0 rgba(255,255,255,.18);
}
.kp2-btn--primary:hover { background: var(--ember-deep); transform: translateY(-2px); box-shadow: 0 14px 36px -8px rgba(var(--ember-rgb),.65); }
.kp2-btn--glass {
    background: rgba(255,252,244,.08); color: var(--paper);
    border: 1px solid rgba(255,252,244,.22); backdrop-filter: blur(10px);
}
.kp2-btn--glass:hover { background: rgba(255,252,244,.14); border-color: rgba(255,252,244,.36); }
.kp2-btn--ghost-light { background: var(--paper); color: var(--ink); border: 1px solid var(--rule); }
.kp2-btn--ghost-light:hover { background: var(--bone); transform: translateY(-1px); }
.kp2-btn--lg { padding: 16px 28px; font-size: 16px; }
.kp2-btn-arrow { transition: transform .2s; }
.kp2-btn:hover .kp2-btn-arrow { transform: translateX(3px); }

.kp2-hero-trust {
    display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
    color: rgba(255,252,244,.62); font-size: 13px;
}
.kp2-hero-trust strong { color: var(--paper); font-size: 15px; font-weight: 700; }
.kp2-hero-trust-stars { color: #FFC940; letter-spacing: 2px; font-size: 15px; }
.kp2-hero-trust-sep { width: 1px; height: 22px; background: rgba(255,252,244,.18); }

/* hero floating UI mock */
.kp2-hero-mock {
    position: relative; min-height: 520px;
    perspective: 1200px;
}
@media (max-width: 980px) { .kp2-hero-mock { min-height: 460px; margin-top: 8px; } }
@media (max-width: 520px) { .kp2-hero-mock { min-height: 420px; transform: scale(.9); transform-origin: top center; } }

.kp2-mock-card {
    position: absolute; background: var(--paper); color: var(--ink);
    border-radius: 18px; box-shadow: 0 30px 60px -20px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.04);
    transform-style: preserve-3d;
}
.kp2-mock--main {
    top: 30px; left: 50%; transform: translateX(-50%) rotateY(-5deg) rotateX(2deg);
    width: 86%; max-width: 420px; padding: 22px;
    z-index: 3;
}
.kp2-mock-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.kp2-mock-logo {
    width: 42px; height: 42px; border-radius: 11px;
    background: linear-gradient(135deg, #1E3A8A, #587866);
    color: var(--paper); display: grid; place-items: center;
    font-weight: 800; font-family: var(--font-display); font-size: 17px;
}
.kp2-mock-titles { flex: 1; min-width: 0; }
.kp2-mock-titles strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--ink); }
.kp2-mock-titles span { display: block; color: var(--muted); font-size: 11.5px; }
.kp2-mock-verified {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(93,211,158,.18); color: #1F6A4B;
    padding: 5px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase;
}
.kp2-mock-person {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 0 14px; border-bottom: 1px dashed var(--rule);
}
.kp2-mock-avatar {
    width: 56px; height: 56px; border-radius: 14px;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); display: grid; place-items: center;
    font-weight: 800; font-family: var(--font-display); font-size: 22px;
}
.kp2-mock-person-meta strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink); }
.kp2-mock-person-meta span { display: block; color: var(--muted); font-size: 12.5px; margin-top: 2px; }
.kp2-mock-rows { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 18px; margin: 14px 0 0; }
.kp2-mock-rows > div { display: flex; flex-direction: column; gap: 2px; }
.kp2-mock-rows dt { font-size: 10.5px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.kp2-mock-rows dd { margin: 0; font-family: var(--font-mono); font-size: 12.5px; color: var(--ink); }
.kp2-mock-foot {
    display: flex; align-items: center; justify-content: space-between; gap: 8px;
    padding-top: 14px; margin-top: 14px; border-top: 1px solid var(--rule);
    font-size: 11px; color: var(--muted);
}

.kp2-mock--qr {
    bottom: 10px; right: 0;
    width: 200px; padding: 14px;
    transform: rotate(6deg);
    z-index: 4;
    display: flex; align-items: center; gap: 12px;
}
.kp2-mock-qr-img {
    width: 64px; height: 64px; border-radius: 8px;
    background-color: var(--ink);
    background-image:
        linear-gradient(45deg, var(--paper) 25%, transparent 25%, transparent 75%, var(--paper) 75%),
        linear-gradient(45deg, var(--paper) 25%, transparent 25%, transparent 75%, var(--paper) 75%);
    background-size: 16px 16px; background-position: 0 0, 8px 8px;
    box-shadow: inset 0 0 0 4px var(--ink);
    flex-shrink: 0;
}
.kp2-mock-qr-meta strong { display: block; font-family: var(--font-display); font-size: 13px; }
.kp2-mock-qr-meta span { display: block; font-size: 11px; color: var(--muted); }

.kp2-mock-chip {
    position: absolute;
    background: var(--paper); color: var(--ink);
    padding: 10px 14px; border-radius: 999px;
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 12.5px; font-weight: 700;
    box-shadow: 0 18px 40px -12px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.06);
    z-index: 5;
}
.kp2-mock-chip--a {
    top: 0; right: 18px;
    color: #1F6A4B; background: rgba(245,255,250,1);
    animation: kp2-float-a 5s ease-in-out infinite;
}
.kp2-mock-chip--b {
    bottom: 80px; left: 0;
    color: var(--ember-deep); background: #FFF;
    animation: kp2-float-b 6s ease-in-out infinite;
}
@keyframes kp2-float-a { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-10px); } }
@keyframes kp2-float-b { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(8px); } }

/* ---------- LOGO MARQUEE / TRUST STRIP ---------- */
.kp2-strip {
    background: var(--paper); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
    padding: 36px 20px;
}
.kp2-strip-inner {
    max-width: 1200px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center;
}
@media (min-width: 900px) { .kp2-strip-inner { grid-template-columns: 220px 1fr; gap: 36px; } }
.kp2-strip-label {
    font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--muted); font-weight: 700;
}
.kp2-strip-label strong { display: block; color: var(--ink); font-family: var(--font-display); font-size: 18px; letter-spacing: -.01em; text-transform: none; margin-bottom: 4px; }
.kp2-strip-items {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
}
@media (min-width: 600px) { .kp2-strip-items { grid-template-columns: repeat(4, 1fr); } }
.kp2-strip-item {
    display: flex; flex-direction: column; gap: 4px; padding: 14px 16px;
    background: var(--cream); border-radius: 12px; border: 1px solid var(--rule);
}
.kp2-strip-item strong {
    font-family: var(--font-display); font-weight: 800; font-size: 22px;
    color: var(--ink); letter-spacing: -.015em;
}
.kp2-strip-item span { font-size: 12.5px; color: var(--muted); }

/* ---------- 3-BENEFIT CARDS ---------- */
.kp2-bens { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 800px) { .kp2-bens { grid-template-columns: repeat(3, 1fr); } }
.kp2-ben {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 32px 28px;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
    position: relative; overflow: hidden;
}
.kp2-ben::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--ember), var(--ember-deep));
    transform: scaleX(0); transform-origin: left;
    transition: transform .35s var(--ease-out-expo);
}
.kp2-ben:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -20px rgba(24,22,20,.18); border-color: rgba(var(--ember-rgb),.3); }
.kp2-ben:hover::before { transform: scaleX(1); }
.kp2-ben-icon {
    width: 56px; height: 56px; border-radius: 16px;
    background: linear-gradient(135deg, rgba(var(--ember-rgb),.12), rgba(var(--ember-rgb),.04));
    color: var(--ember-deep); display: grid; place-items: center;
    margin-bottom: 18px; box-shadow: inset 0 0 0 1px rgba(var(--ember-rgb),.18);
}
.kp2-ben-icon svg { width: 26px; height: 26px; }
.kp2-ben h3 { font-family: var(--font-display); font-weight: 800; font-size: 19px; margin: 0 0 8px; letter-spacing: -.01em; }
.kp2-ben p { color: var(--ink-soft); font-size: 14.5px; line-height: 1.6; margin: 0 0 14px; }
.kp2-ben-points { list-style: none; padding: 0; margin: 14px 0 0; display: grid; gap: 8px; }
.kp2-ben-points li {
    font-size: 13.5px; color: var(--ink-soft);
    padding-left: 22px; position: relative; line-height: 1.5;
}
.kp2-ben-points li::before {
    content: ''; position: absolute; left: 0; top: 6px;
    width: 14px; height: 8px;
    border-left: 2px solid var(--ember);
    border-bottom: 2px solid var(--ember);
    transform: rotate(-45deg);
}

/* ---------- INTERACTIVE STEP CAROUSEL (How-it-works) ---------- */
.kp2-steps {
    display: grid; grid-template-columns: 1fr; gap: 28px;
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r-lg); padding: 28px;
    box-shadow: 0 24px 60px -30px rgba(24,22,20,.18);
}
@media (min-width: 900px) { .kp2-steps { grid-template-columns: 320px 1fr; gap: 40px; padding: 36px; } }
.kp2-steps-tabs { display: flex; flex-direction: column; gap: 6px; }
@media (max-width: 899px) { .kp2-steps-tabs { flex-direction: row; overflow-x: auto; scrollbar-width: none; padding-bottom: 4px; } .kp2-steps-tabs::-webkit-scrollbar { display: none; } }
.kp2-step-tab {
    appearance: none; border: 0; background: transparent;
    text-align: left; padding: 14px 16px; border-radius: 12px;
    display: flex; gap: 14px; cursor: pointer;
    transition: background .2s, color .2s;
    color: var(--ink-soft); font-family: inherit; flex-shrink: 0;
    min-width: 220px;
}
.kp2-step-tab:hover { background: var(--cream); }
.kp2-step-tab.is-on { background: linear-gradient(135deg, rgba(var(--ember-rgb),.08), rgba(var(--ember-rgb),.02)); color: var(--ink); box-shadow: inset 0 0 0 1px rgba(var(--ember-rgb),.2); }
.kp2-step-tab-num {
    width: 34px; height: 34px; border-radius: 10px;
    background: var(--bone); color: var(--ink-light);
    display: grid; place-items: center; flex-shrink: 0;
    font-family: var(--font-display); font-weight: 800; font-size: 14px;
    transition: background .2s, color .2s;
}
.kp2-step-tab.is-on .kp2-step-tab-num { background: var(--ember); color: var(--paper); box-shadow: 0 4px 14px -4px rgba(var(--ember-rgb),.6); }
.kp2-step-tab-meta { min-width: 0; flex: 1; }
.kp2-step-tab-meta strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 15px; }
.kp2-step-tab-meta span { display: block; font-size: 13px; color: var(--muted); margin-top: 2px; line-height: 1.4; }

.kp2-step-panels { position: relative; min-height: 360px; }
.kp2-step-panel { display: none; }
.kp2-step-panel.is-on { display: block; animation: kp2-fade .35s var(--ease-out-expo); }
@keyframes kp2-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.kp2-step-eyebrow {
    display: inline-block; padding: 4px 10px; background: var(--cream);
    border: 1px solid var(--rule); border-radius: 999px;
    font-size: 11px; font-weight: 700; color: var(--ink-soft);
    letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px;
}
.kp2-step-panel h3 { font-family: var(--font-display); font-weight: 800; font-size: 24px; letter-spacing: -.015em; margin: 0 0 10px; }
.kp2-step-panel p { color: var(--ink-soft); font-size: 15px; line-height: 1.6; margin: 0 0 18px; max-width: 56ch; }
.kp2-step-panel ul { padding: 0; margin: 18px 0 0; list-style: none; display: grid; gap: 10px; }
.kp2-step-panel ul li { padding-left: 26px; position: relative; font-size: 14px; color: var(--ink-soft); line-height: 1.55; }
.kp2-step-panel ul li::before {
    content: ''; position: absolute; left: 0; top: 4px;
    width: 16px; height: 16px; border-radius: 50%;
    background: rgba(var(--ember-rgb),.15);
    background-image: linear-gradient(135deg, var(--ember), var(--ember-deep));
}
.kp2-step-panel ul li::after {
    content: ''; position: absolute; left: 4px; top: 7px;
    width: 8px; height: 4px;
    border-left: 1.6px solid var(--paper); border-bottom: 1.6px solid var(--paper);
    transform: rotate(-45deg);
}
.kp2-step-visual {
    margin-top: 22px; padding: 22px; border-radius: 14px;
    background: linear-gradient(135deg, var(--ink) 0%, #2A2622 100%);
    color: var(--paper); position: relative; overflow: hidden;
}
.kp2-step-visual::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(400px 200px at 80% 0%, rgba(var(--ember-rgb),.20), transparent 70%),
        linear-gradient(180deg, transparent, rgba(0,0,0,.18));
    pointer-events: none;
}
.kp2-step-vis-row { position: relative; z-index: 1; display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.kp2-step-vis-row:last-child { margin-bottom: 0; }
.kp2-step-vis-row .pill {
    padding: 6px 12px; border-radius: 999px;
    background: rgba(255,252,244,.10); font-size: 12px; font-weight: 700;
    color: rgba(255,252,244,.86); border: 1px solid rgba(255,252,244,.14);
}
.kp2-step-vis-row .pill--ok { background: rgba(93,211,158,.18); color: #5DD39E; border-color: rgba(93,211,158,.32); }
.kp2-step-vis-row .pill--ember { background: rgba(var(--ember-rgb),.18); color: #FF9B7A; border-color: rgba(var(--ember-rgb),.32); }
.kp2-step-vis-row code { font-size: 12px; font-family: var(--font-mono); color: rgba(255,252,244,.7); }

/* ---------- MODULES DEEP GRID ---------- */
.kp2-mods { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; }
.kp2-mod {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 24px 22px 22px;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
    position: relative; overflow: hidden;
}
.kp2-mod:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -20px rgba(24,22,20,.18); border-color: rgba(var(--ember-rgb),.3); }
.kp2-mod-tag {
    position: absolute; top: 16px; right: 16px;
    padding: 3px 9px; border-radius: 999px;
    background: var(--cream); border: 1px solid var(--rule);
    font-size: 10.5px; font-weight: 700; color: var(--muted); letter-spacing: .06em; text-transform: uppercase;
}
.kp2-mod-icon {
    width: 52px; height: 52px; border-radius: 14px;
    color: var(--paper); display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 800; font-size: 17px;
    margin-bottom: 16px;
    box-shadow: 0 10px 24px -8px rgba(0,0,0,.25);
}
.kp2-mod h3 { font-family: var(--font-display); font-weight: 800; font-size: 17px; margin: 0 0 6px; }
.kp2-mod p { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; margin: 0 0 14px; }
.kp2-mod-meta {
    display: flex; align-items: center; gap: 6px;
    font-size: 11.5px; color: var(--muted); font-weight: 600;
    padding-top: 14px; border-top: 1px solid var(--rule);
}

/* ---------- INDUSTRY CARDS (image hero per card) ---------- */
.kp2-inds { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 700px) { .kp2-inds { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .kp2-inds { grid-template-columns: repeat(3, 1fr); } }
.kp2-ind {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); overflow: hidden;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s;
}
.kp2-ind:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -20px rgba(24,22,20,.22); }
.kp2-ind-img {
    height: 180px; background-size: cover; background-position: center; position: relative;
}
.kp2-ind-img::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 0%, transparent 50%, rgba(24,22,20,.65) 100%);
}
.kp2-ind-tag {
    position: absolute; bottom: 14px; left: 14px; z-index: 1;
    padding: 5px 12px; border-radius: 999px;
    background: rgba(255,252,244,.92); backdrop-filter: blur(4px);
    font-size: 11px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--ink);
}
.kp2-ind-body { padding: 22px 22px 24px; }
.kp2-ind-body h3 { font-family: var(--font-display); font-weight: 800; font-size: 19px; letter-spacing: -.01em; margin: 0 0 8px; }
.kp2-ind-body p { color: var(--ink-soft); font-size: 14px; line-height: 1.6; margin: 0 0 14px; }
.kp2-ind-uses { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.kp2-ind-uses li {
    padding: 4px 10px; background: var(--cream); border: 1px solid var(--rule);
    border-radius: 999px; font-size: 11.5px; color: var(--ink-soft); font-weight: 600;
}

/* ---------- TRUST BADGE DASHBOARD ---------- */
.kp2-trust-grid { display: grid; gap: 22px; grid-template-columns: 1fr; }
@media (min-width: 760px) { .kp2-trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .kp2-trust-grid { grid-template-columns: repeat(3, 1fr); } }
.kp2-trust {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 24px;
    transition: border-color .2s, transform .25s var(--ease-out-expo);
}
.kp2-trust:hover { border-color: rgba(var(--ember-rgb),.32); transform: translateY(-3px); }
.kp2-trust-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.kp2-trust-icon {
    width: 44px; height: 44px; border-radius: 12px;
    background: var(--ink); color: var(--paper); display: grid; place-items: center;
}
.kp2-trust-icon svg { width: 22px; height: 22px; }
.kp2-trust-head h3 { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 0; }
.kp2-trust-head span { display: block; font-size: 11.5px; color: var(--muted); margin-top: 2px; letter-spacing: .04em; text-transform: uppercase; font-weight: 700; }
.kp2-trust-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.kp2-trust-list li {
    padding-left: 22px; position: relative;
    font-size: 13.5px; color: var(--ink-soft); line-height: 1.5;
}
.kp2-trust-list li::before {
    content: ''; position: absolute; left: 0; top: 7px;
    width: 12px; height: 6px;
    border-left: 2px solid var(--sage);
    border-bottom: 2px solid var(--sage);
    transform: rotate(-45deg);
}

/* ---------- TESTIMONIAL CARDS ---------- */
.kp2-tests { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 800px) { .kp2-tests { grid-template-columns: repeat(3, 1fr); } }
.kp2-test {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 28px;
    display: flex; flex-direction: column; gap: 18px;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s;
}
.kp2-test:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -20px rgba(24,22,20,.18); }
.kp2-test-stars { color: #FFC940; letter-spacing: 3px; font-size: 16px; }
.kp2-test-quote {
    font-family: var(--font-display); font-weight: 600; font-size: 16.5px;
    line-height: 1.5; color: var(--ink); margin: 0; flex: 1;
}
.kp2-test-quote::before { content: '"'; font-size: 1.4em; color: var(--ember); margin-right: 2px; }
.kp2-test-quote::after { content: '"'; font-size: 1.4em; color: var(--ember); }
.kp2-test-author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--rule); }
.kp2-test-avatar {
    width: 44px; height: 44px; border-radius: 50%;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    color: var(--paper); display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 800; font-size: 16px;
}
.kp2-test-author-meta strong { display: block; font-family: var(--font-display); font-size: 14.5px; font-weight: 700; }
.kp2-test-author-meta span { display: block; color: var(--muted); font-size: 12.5px; }

/* ---------- COMPARISON TABLE (Before / After) ---------- */
.kp2-compare {
    display: grid; grid-template-columns: 1fr; gap: 22px;
}
@media (min-width: 800px) { .kp2-compare { grid-template-columns: 1fr 1fr; gap: 22px; align-items: stretch; } }
.kp2-compare-col {
    border-radius: var(--kp2-r); padding: 32px 28px;
    border: 1px solid var(--rule);
}
.kp2-compare-col--bad {
    background: var(--paper);
    border-style: dashed; border-color: rgba(24,22,20,.18);
    opacity: .9;
}
.kp2-compare-col--good {
    background: linear-gradient(135deg, var(--ink) 0%, #2A2622 100%);
    color: var(--paper);
    border-color: rgba(255,252,244,.10);
    position: relative; overflow: hidden;
}
.kp2-compare-col--good::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(500px 250px at 90% 0%, rgba(var(--ember-rgb),.22), transparent 70%);
    pointer-events: none;
}
.kp2-compare-col > * { position: relative; z-index: 1; }
.kp2-compare-eyebrow {
    display: inline-block; padding: 5px 12px; border-radius: 999px;
    font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
    margin-bottom: 14px;
}
.kp2-compare-col--bad  .kp2-compare-eyebrow { background: var(--cream); color: var(--ink-soft); border: 1px solid var(--rule); }
.kp2-compare-col--good .kp2-compare-eyebrow { background: rgba(var(--ember-rgb),.18); color: #FF9B7A; }
.kp2-compare-col h3 { font-family: var(--font-display); font-weight: 800; font-size: 22px; margin: 0 0 18px; letter-spacing: -.015em; }
.kp2-compare-col--good h3 { color: var(--paper); }
.kp2-compare-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.kp2-compare-list li {
    display: flex; gap: 12px; align-items: flex-start;
    font-size: 14.5px; line-height: 1.55;
}
.kp2-compare-list li .ico {
    width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
    display: grid; place-items: center; margin-top: 1px;
}
.kp2-compare-col--bad  .kp2-compare-list li .ico { background: rgba(214,60,24,.14); color: #D63C18; }
.kp2-compare-col--good .kp2-compare-list li .ico { background: rgba(93,211,158,.22); color: #5DD39E; }
.kp2-compare-col--bad  .kp2-compare-list li { color: var(--ink-soft); }
.kp2-compare-col--good .kp2-compare-list li { color: rgba(255,252,244,.86); }

/* ---------- FAQ ACCORDION (refined) ---------- */
.kp2-faq { display: grid; gap: 10px; }
.kp2-faq-item {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: 14px; padding: 0; overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
}
.kp2-faq-item[open] { border-color: rgba(var(--ember-rgb),.32); box-shadow: 0 16px 36px -16px rgba(24,22,20,.16); }
.kp2-faq-item summary {
    cursor: pointer; padding: 22px 24px;
    display: flex; align-items: center; gap: 16px;
    font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink);
    list-style: none;
}
.kp2-faq-item summary::-webkit-details-marker { display: none; }
.kp2-faq-q { flex: 1; }
.kp2-faq-toggle {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--cream); border: 1px solid var(--rule);
    display: grid; place-items: center;
    transition: background .2s, transform .25s var(--ease-out-expo); flex-shrink: 0;
}
.kp2-faq-toggle svg { width: 14px; height: 14px; }
.kp2-faq-item[open] .kp2-faq-toggle { background: var(--ember); border-color: var(--ember); color: var(--paper); transform: rotate(45deg); }
.kp2-faq-a { padding: 0 24px 22px 24px; color: var(--ink-soft); font-size: 14.5px; line-height: 1.65; }
.kp2-faq-a a { color: var(--ember-deep); text-decoration: underline; }
.kp2-faq-a code { font-family: var(--font-mono); font-size: 13px; background: var(--bone); padding: 2px 6px; border-radius: 4px; }

/* ---------- BIG CTA (Klippa-style) ---------- */
.kp2-cta {
    position: relative; overflow: hidden;
    background: linear-gradient(135deg, #181614 0%, #2A2622 60%, #181614 100%);
    color: var(--paper); padding: 88px 20px;
}
.kp2-cta::before {
    content: ''; position: absolute; inset: 0; opacity: .35;
    background-image:
        linear-gradient(to right, rgba(255,252,244,.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,252,244,.06) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, #000 30%, transparent 80%);
    pointer-events: none;
}
.kp2-cta-orb {
    position: absolute; width: 480px; height: 480px;
    border-radius: 50%; filter: blur(80px); opacity: .45; pointer-events: none;
    background: radial-gradient(circle, var(--ember), transparent 70%);
    top: -180px; right: -120px;
}
.kp2-cta-inner {
    position: relative; z-index: 1;
    max-width: 880px; margin: 0 auto; text-align: center;
}
.kp2-cta-inner h2 {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(30px, 4.4vw, 44px); line-height: 1.05; letter-spacing: -.025em;
    margin: 16px 0 14px; color: var(--paper);
}
.kp2-cta-inner p {
    color: rgba(255,252,244,.78); font-size: 17px; line-height: 1.6;
    margin: 0 0 28px; max-width: 56ch; margin-left: auto; margin-right: auto;
}
.kp2-cta-buttons { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.kp2-cta-foot { color: rgba(255,252,244,.5); font-size: 13px; margin-top: 18px; }

/* ---------- SECONDARY HERO (used on sub-pages) ---------- */
.kp2-shero {
    position: relative; overflow: hidden;
    background: linear-gradient(180deg, #0E0C0B 0%, #181614 100%);
    color: var(--paper); padding: 100px 20px 80px;
}
.kp2-shero::before {
    content: ''; position: absolute; inset: 0; opacity: .30;
    background-image:
        linear-gradient(to right, rgba(255,252,244,.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,252,244,.06) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 30%, #000 30%, transparent 80%);
}
.kp2-shero-orb {
    position: absolute; width: 460px; height: 460px;
    top: -180px; right: -120px;
    border-radius: 50%; filter: blur(70px); opacity: .42; pointer-events: none;
    background: radial-gradient(circle, var(--ember), transparent 70%);
}
.kp2-shero-inner {
    position: relative; z-index: 1;
    max-width: 920px; margin: 0 auto; text-align: center;
}
.kp2-shero-inner h1 {
    font-family: var(--font-display); font-weight: 800;
    font-size: clamp(34px, 5.4vw, 58px); line-height: 1.04; letter-spacing: -.03em;
    margin: 18px 0 18px; color: var(--paper);
}
.kp2-shero-inner h1 .kp2-grad {
    background: linear-gradient(100deg, var(--ember), #FF9B7A, var(--ember));
    -webkit-background-clip: text; background-clip: text; color: transparent;
    background-size: 200% auto; animation: kp2-shimmer 6s linear infinite;
}
.kp2-shero-inner p {
    color: rgba(255,252,244,.78); font-size: 18px; line-height: 1.6;
    max-width: 60ch; margin: 0 auto 28px;
}
.kp2-shero-cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ---------- TIMELINE (About story) ---------- */
.kp2-timeline { position: relative; max-width: 760px; margin: 0 auto; padding-left: 32px; }
.kp2-timeline::before {
    content: ''; position: absolute; left: 14px; top: 4px; bottom: 4px; width: 2px;
    background: linear-gradient(180deg, var(--ember), rgba(var(--ember-rgb),.1));
}
.kp2-tl-item { position: relative; padding: 0 0 32px; }
.kp2-tl-item:last-child { padding-bottom: 0; }
.kp2-tl-dot {
    position: absolute; left: -32px; top: 4px;
    width: 30px; height: 30px; border-radius: 50%;
    background: var(--paper); border: 2px solid var(--ember);
    display: grid; place-items: center;
    color: var(--ember-deep); font-family: var(--font-display); font-weight: 800; font-size: 11px;
    box-shadow: 0 0 0 4px var(--bone);
}
.kp2-tl-year { font-size: 12px; font-weight: 700; color: var(--ember-deep); letter-spacing: .08em; text-transform: uppercase; }
.kp2-tl-h { font-family: var(--font-display); font-weight: 800; font-size: 19px; margin: 6px 0 8px; letter-spacing: -.01em; }
.kp2-tl-p { color: var(--ink-soft); font-size: 14.5px; line-height: 1.6; margin: 0; }

/* ---------- PRINCIPLE CARDS (About) ---------- */
.kp2-principles { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 700px) { .kp2-principles { grid-template-columns: repeat(2, 1fr); } }
.kp2-pri {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 26px;
    display: flex; gap: 18px; align-items: flex-start;
}
.kp2-pri-ic {
    width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
    background: rgba(var(--ember-rgb),.10); color: var(--ember-deep);
    display: grid; place-items: center;
}
.kp2-pri-ic svg { width: 24px; height: 24px; }
.kp2-pri h3 { font-family: var(--font-display); font-weight: 800; font-size: 17px; margin: 0 0 6px; }
.kp2-pri p { color: var(--ink-soft); font-size: 14px; line-height: 1.6; margin: 0; }

/* ---------- CONTACT METHODS (Contact) ---------- */
.kp2-contact-grid {
    display: grid; grid-template-columns: 1fr; gap: 28px;
}
@media (min-width: 900px) { .kp2-contact-grid { grid-template-columns: 0.95fr 1.05fr; align-items: start; } }
.kp2-cm-list { display: grid; gap: 14px; }
.kp2-cm {
    display: flex; gap: 14px; padding: 22px;
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); transition: border-color .2s, transform .25s var(--ease-out-expo);
}
.kp2-cm:hover { border-color: rgba(var(--ember-rgb),.3); transform: translateY(-2px); }
.kp2-cm-ic {
    width: 46px; height: 46px; border-radius: 12px; flex-shrink: 0;
    background: rgba(var(--ember-rgb),.10); color: var(--ember-deep);
    display: grid; place-items: center;
}
.kp2-cm-ic svg { width: 22px; height: 22px; }
.kp2-cm h3 { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 0 0 4px; }
.kp2-cm p { color: var(--ink-soft); font-size: 14px; line-height: 1.55; margin: 0 0 6px; }
.kp2-cm a { color: var(--ember-deep); font-weight: 700; font-size: 14px; }
.kp2-cm-meta { color: var(--muted); font-size: 12.5px; font-weight: 600; }

.kp2-form-card {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r-lg); padding: 32px 30px;
    box-shadow: 0 24px 50px -20px rgba(24,22,20,.14);
}
.kp2-form-card h3 { font-family: var(--font-display); font-weight: 800; font-size: 22px; margin: 0 0 4px; letter-spacing: -.015em; }
.kp2-form-card .sub { color: var(--muted); font-size: 14px; margin: 0 0 22px; }
.kp2-form-row { display: grid; gap: 16px; margin-bottom: 14px; }
@media (min-width: 600px) { .kp2-form-row.two { grid-template-columns: 1fr 1fr; } }
.kp2-field { display: grid; gap: 6px; }
.kp2-field label { font-size: 12.5px; color: var(--ink-soft); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.kp2-field input, .kp2-field select, .kp2-field textarea {
    width: 100%; padding: 12px 14px; border: 1px solid var(--rule);
    border-radius: 12px; background: var(--cream); color: var(--ink);
    font-family: inherit; font-size: 14.5px; transition: border-color .2s, background .2s;
}
.kp2-field input:focus, .kp2-field select:focus, .kp2-field textarea:focus {
    outline: 0; border-color: var(--ember); background: var(--paper);
    box-shadow: 0 0 0 4px rgba(var(--ember-rgb),.12);
}
.kp2-field textarea { resize: vertical; min-height: 140px; }
.kp2-form-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 18px; flex-wrap: wrap; }
.kp2-form-foot .note { color: var(--muted); font-size: 12.5px; }

/* ---------- PRICING (Premium card) ---------- */
.kp2-pricing-wrap { display: grid; grid-template-columns: 1fr; gap: 22px; max-width: 980px; margin: 0 auto; }
@media (min-width: 900px) { .kp2-pricing-wrap { grid-template-columns: 1fr 1fr; } }
.kp2-price-card {
    background: linear-gradient(180deg, var(--paper), var(--cream));
    border: 1px solid var(--rule); border-radius: var(--kp2-r-lg);
    padding: 36px 32px; position: relative; overflow: hidden;
    box-shadow: 0 30px 60px -30px rgba(24,22,20,.2);
}
.kp2-price-card--feat {
    background: linear-gradient(180deg, #181614 0%, #2A2622 100%);
    color: var(--paper); border-color: rgba(255,252,244,.10);
    position: relative;
}
.kp2-price-card--feat::before {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(500px 260px at 90% 0%, rgba(var(--ember-rgb),.22), transparent 70%);
}
.kp2-price-card--feat > * { position: relative; z-index: 1; }
.kp2-price-flag {
    position: absolute; top: 20px; right: 20px;
    padding: 5px 12px; border-radius: 999px;
    background: var(--ember); color: var(--paper);
    font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
}
.kp2-price-eyebrow {
    font-size: 12px; color: var(--muted); font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
}
.kp2-price-card--feat .kp2-price-eyebrow { color: rgba(255,252,244,.7); }
.kp2-price-h { font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -.02em; margin: 8px 0 4px; }
.kp2-price-card--feat .kp2-price-h { color: var(--paper); }
.kp2-price-amt { font-family: var(--font-display); font-weight: 800; font-size: 44px; letter-spacing: -.02em; margin: 12px 0 4px; }
.kp2-price-card--feat .kp2-price-amt { color: var(--paper); }
.kp2-price-amt small { font-size: 16px; color: var(--muted); font-weight: 600; }
.kp2-price-card--feat .kp2-price-amt small { color: rgba(255,252,244,.7); }
.kp2-price-sub { color: var(--ink-soft); font-size: 14.5px; margin: 0 0 20px; line-height: 1.55; }
.kp2-price-card--feat .kp2-price-sub { color: rgba(255,252,244,.78); }
.kp2-price-features { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 10px; }
.kp2-price-features li { padding-left: 26px; position: relative; font-size: 14px; color: var(--ink-soft); line-height: 1.55; }
.kp2-price-features li::before {
    content: ''; position: absolute; left: 0; top: 5px;
    width: 16px; height: 16px; border-radius: 50%;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
}
.kp2-price-features li::after {
    content: ''; position: absolute; left: 4px; top: 8px;
    width: 8px; height: 4px;
    border-left: 1.6px solid var(--paper); border-bottom: 1.6px solid var(--paper);
    transform: rotate(-45deg);
}
.kp2-price-card--feat .kp2-price-features li { color: rgba(255,252,244,.85); }

/* ---------- FEATURE GRID v2 (Features page) ---------- */
.kp2-feats { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 700px) { .kp2-feats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .kp2-feats { grid-template-columns: repeat(3, 1fr); } }
.kp2-feat {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 24px;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
    position: relative; overflow: hidden;
}
.kp2-feat:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -20px rgba(24,22,20,.16); border-color: rgba(var(--ember-rgb),.3); }
.kp2-feat-ic {
    width: 46px; height: 46px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(var(--ember-rgb),.10), transparent);
    color: var(--ember-deep); display: grid; place-items: center;
    margin-bottom: 14px; box-shadow: inset 0 0 0 1px rgba(var(--ember-rgb),.16);
}
.kp2-feat-ic svg { width: 22px; height: 22px; }
.kp2-feat h3 { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 0 0 6px; }
.kp2-feat p { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; margin: 0; }

/* ---------- LARGE CAPABILITY ROW (Features) ---------- */
.kp2-cap { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; padding: 36px 0; }
@media (min-width: 900px) { .kp2-cap { grid-template-columns: 1fr 1fr; gap: 60px; } .kp2-cap--flip > .kp2-cap-vis { order: -1; } }
.kp2-cap + .kp2-cap { border-top: 1px solid var(--rule); }
.kp2-cap-copy h3 { font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -.02em; margin: 12px 0 12px; line-height: 1.1; }
.kp2-cap-copy p  { color: var(--ink-soft); font-size: 15.5px; line-height: 1.65; margin: 0 0 18px; max-width: 52ch; }
.kp2-cap-points { list-style: none; padding: 0; margin: 0 0 18px; display: grid; gap: 10px; }
.kp2-cap-points li { padding-left: 26px; position: relative; font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; }
.kp2-cap-points li::before {
    content: ''; position: absolute; left: 0; top: 5px;
    width: 16px; height: 16px; border-radius: 50%;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
}
.kp2-cap-points li::after {
    content: ''; position: absolute; left: 4px; top: 8px;
    width: 8px; height: 4px;
    border-left: 1.6px solid var(--paper); border-bottom: 1.6px solid var(--paper);
    transform: rotate(-45deg);
}
.kp2-cap-vis {
    background: linear-gradient(135deg, var(--ink) 0%, #2A2622 100%);
    color: var(--paper); padding: 28px; border-radius: var(--kp2-r-lg);
    position: relative; overflow: hidden;
    min-height: 280px; display: flex; align-items: center; justify-content: center;
}
.kp2-cap-vis::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(400px 200px at 80% 10%, rgba(var(--ember-rgb),.20), transparent 70%),
        radial-gradient(300px 150px at 10% 100%, rgba(88,120,102,.18), transparent 70%);
    pointer-events: none;
}
.kp2-cap-vis-card {
    position: relative; z-index: 1; max-width: 360px;
    background: rgba(255,252,244,.06); border: 1px solid rgba(255,252,244,.10);
    border-radius: 14px; padding: 18px;
    backdrop-filter: blur(8px);
}
.kp2-cap-vis-card pre {
    margin: 0; font-family: var(--font-mono); font-size: 12px; color: rgba(255,252,244,.86);
    line-height: 1.65; overflow-x: auto; white-space: pre-wrap; word-break: break-word;
}
.kp2-cap-vis-card .tag {
    display: inline-block; padding: 4px 10px; border-radius: 999px;
    background: rgba(var(--ember-rgb),.22); color: #FF9B7A;
    font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
    margin-bottom: 12px;
}

/* ---------- ABOUT — large stat strip ---------- */
.kp2-stats {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
    max-width: 880px; margin: 0 auto;
}
@media (min-width: 700px) { .kp2-stats { grid-template-columns: repeat(4, 1fr); } }
.kp2-stat {
    background: var(--paper); border: 1px solid var(--rule);
    border-radius: var(--kp2-r); padding: 22px;
    text-align: center;
}
.kp2-stat-num {
    font-family: var(--font-display); font-weight: 800;
    font-size: 36px; letter-spacing: -.02em; line-height: 1;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.kp2-stat-l { display: block; color: var(--muted); font-size: 12.5px; margin-top: 6px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }

/* =================================================================
   KP2 / PHASE 13 — CINEMATIC HERO PHOTO + RICHER PAGE COMPONENTS
   ================================================================= */

/* ---------- HERO PHOTO LAYER (used by .kp2-hero AND .kp2-shero) ---------- */
.kp2-hero-photo,
.kp2-shero-photo {
    position: absolute; inset: 0; z-index: 0;
    background-size: cover; background-position: center;
    opacity: .42; mix-blend-mode: luminosity;
    transform: scale(1.04);
    filter: saturate(.85) contrast(1.05);
}
.kp2-hero-veil,
.kp2-shero-veil {
    position: absolute; inset: 0; z-index: 1; pointer-events: none;
    background:
        linear-gradient(180deg, rgba(8,7,6,.62) 0%, rgba(14,12,11,.92) 100%),
        radial-gradient(700px 380px at 85% 12%, rgba(var(--ember-rgb),.18), transparent 70%);
}
/* Z-stack only — do NOT change `position` on background layers (would collapse
   absolute children into the flex parent and squash the inner column). */
.kp2-hero-photo  { z-index: 0; }
.kp2-hero-veil   { z-index: 1; }
.kp2-shero-photo { z-index: 0; }
.kp2-shero-veil  { z-index: 1; }

/* ---------- LOGO MARQUEE (industry-types scrolling) ---------- */
.kp2-marquee {
    position: relative; z-index: 3;
    margin-top: 48px; padding: 18px 0;
    border-top: 1px solid rgba(255,252,244,.10);
    border-bottom: 1px solid rgba(255,252,244,.10);
    overflow: hidden;
    background: rgba(0,0,0,.18); backdrop-filter: blur(8px);
}
.kp2-marquee-label {
    text-align: center; font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
    color: rgba(255,252,244,.46); font-weight: 700; margin-bottom: 14px;
}
.kp2-marquee-track {
    display: flex; gap: 56px; width: max-content;
    animation: kp2-marq 40s linear infinite;
}
.kp2-marquee:hover .kp2-marquee-track { animation-play-state: paused; }
@keyframes kp2-marq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.kp2-marquee-item {
    display: inline-flex; align-items: center; gap: 10px;
    color: rgba(255,252,244,.66); font-family: var(--font-display); font-weight: 600;
    font-size: 16px; letter-spacing: -.01em; white-space: nowrap;
}
.kp2-marquee-item svg { width: 22px; height: 22px; opacity: .8; }

/* ---------- HERO RATING BADGE ---------- */
.kp2-hero-rating {
    display: inline-flex; align-items: center; gap: 14px;
    margin-top: 28px; padding: 12px 16px 12px 12px; border-radius: 999px;
    background: rgba(255,252,244,.06); border: 1px solid rgba(255,252,244,.14);
    backdrop-filter: blur(10px);
}
.kp2-hero-rating-avs { display: inline-flex; }
.kp2-hero-rating-avs span {
    width: 30px; height: 30px; border-radius: 50%;
    border: 2px solid #0E0C0B; margin-left: -8px;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
    display: grid; place-items: center;
    color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 11px;
}
.kp2-hero-rating-avs span:first-child { margin-left: 0; }
.kp2-hero-rating-avs span:nth-child(2) { background: linear-gradient(135deg,#1E3A8A,#587866); }
.kp2-hero-rating-avs span:nth-child(3) { background: linear-gradient(135deg,#C9A227,#D63C18); }
.kp2-hero-rating-meta { color: rgba(255,252,244,.86); font-size: 13px; line-height: 1.3; }
.kp2-hero-rating-meta strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--paper); }
.kp2-hero-rating-stars { color: #FFC940; letter-spacing: 2px; font-size: 13px; }

/* ---------- THIRD FLOATING MOCK (live ticker) ---------- */
.kp2-mock--ticker {
    top: -10px; left: 0; z-index: 2;
    width: 230px; padding: 12px 14px;
    transform: rotate(-4deg);
    display: flex; flex-direction: column; gap: 6px;
    background: rgba(20, 17, 15, .92); color: var(--paper);
    border: 1px solid rgba(255,252,244,.10);
}
.kp2-ticker-row { display: flex; align-items: center; gap: 8px; font-size: 11.5px; }
.kp2-ticker-row .ticker-dot { width: 7px; height: 7px; border-radius: 50%; background: #5DD39E; box-shadow: 0 0 0 3px rgba(93,211,158,.22); flex-shrink: 0; }
.kp2-ticker-row .ticker-name { color: var(--paper); font-weight: 700; }
.kp2-ticker-row .ticker-time { color: rgba(255,252,244,.46); margin-left: auto; font-family: var(--font-mono); font-size: 10.5px; }
.kp2-ticker-head { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; font-size: 11px; color: rgba(255,252,244,.62); letter-spacing: .08em; text-transform: uppercase; font-weight: 700; }
.kp2-ticker-head .ticker-live { width: 6px; height: 6px; border-radius: 50%; background: #5DD39E; animation: kp2-pulse 2s ease-in-out infinite; }

/* ---------- FEATURE SPOTLIGHT (big card, image + copy) ---------- */
.kp2-spot {
    display: grid; grid-template-columns: 1fr; gap: 0;
    background: linear-gradient(135deg, #181614 0%, #2A2622 100%);
    color: var(--paper); border-radius: var(--kp2-r-lg); overflow: hidden;
    position: relative;
    box-shadow: 0 30px 60px -30px rgba(24,22,20,.3);
}
.kp2-spot::before {
    content:''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(600px 280px at 80% 0%, rgba(var(--ember-rgb),.22), transparent 70%);
}
@media (min-width: 900px) { .kp2-spot { grid-template-columns: 1fr 1fr; align-items: stretch; } }
.kp2-spot-copy { padding: 36px 32px; position: relative; z-index: 1; }
.kp2-spot-copy h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 3vw, 32px); letter-spacing: -.02em; margin: 12px 0 12px; line-height: 1.1; color: var(--paper); }
.kp2-spot-copy p  { color: rgba(255,252,244,.78); font-size: 15.5px; line-height: 1.6; margin: 0 0 18px; }
.kp2-spot-list { list-style: none; padding: 0; margin: 0 0 22px; display: grid; gap: 10px; }
.kp2-spot-list li { padding-left: 26px; position: relative; font-size: 14px; color: rgba(255,252,244,.82); line-height: 1.5; }
.kp2-spot-list li::before {
    content: ''; position: absolute; left: 0; top: 4px;
    width: 16px; height: 16px; border-radius: 50%;
    background: linear-gradient(135deg, var(--ember), var(--ember-deep));
}
.kp2-spot-list li::after {
    content: ''; position: absolute; left: 4px; top: 7px;
    width: 8px; height: 4px;
    border-left: 1.6px solid var(--paper); border-bottom: 1.6px solid var(--paper);
    transform: rotate(-45deg);
}
.kp2-spot-img {
    background-size: cover; background-position: center;
    min-height: 280px; position: relative;
}
.kp2-spot-img::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(90deg, rgba(20,17,15,.55) 0%, transparent 30%);
}

/* ---------- INTEGRATIONS STRIP ---------- */
.kp2-integ { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 600px) { .kp2-integ { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px) { .kp2-integ { grid-template-columns: repeat(6, 1fr); } }
.kp2-integ-item {
    background: var(--paper); border: 1px solid var(--rule); border-radius: 14px;
    padding: 18px 14px; text-align: center;
    transition: transform .2s var(--ease-out-expo), border-color .2s;
}
.kp2-integ-item:hover { transform: translateY(-3px); border-color: rgba(var(--ember-rgb),.32); }
.kp2-integ-icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: var(--cream); color: var(--ink); display: grid; place-items: center;
    margin: 0 auto 10px;
    font-family: var(--font-display); font-weight: 800; font-size: 16px;
}
.kp2-integ-item h4 { font-family: var(--font-display); font-weight: 700; font-size: 13px; margin: 0 0 2px; color: var(--ink); }
.kp2-integ-item span { color: var(--muted); font-size: 11.5px; }

/* ---------- QUICK-START 5-STEP STRIP ---------- */
.kp2-quick { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 760px) { .kp2-quick { grid-template-columns: repeat(5, 1fr); } }
.kp2-quick-step {
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--kp2-r);
    padding: 22px 20px; position: relative;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s;
}
.kp2-quick-step:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.kp2-quick-num {
    position: absolute; top: -14px; left: 18px;
    width: 32px; height: 32px; border-radius: 8px;
    background: var(--ember); color: var(--paper);
    display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 800; font-size: 14px;
    box-shadow: 0 8px 18px -4px rgba(var(--ember-rgb),.55);
}
.kp2-quick-step h4 { font-family: var(--font-display); font-weight: 800; font-size: 15px; margin: 12px 0 6px; }
.kp2-quick-step p  { color: var(--ink-soft); font-size: 13px; line-height: 1.5; margin: 0; }
.kp2-quick-step time { display: block; margin-top: 10px; font-size: 11.5px; color: var(--ember-deep); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }

/* ---------- FOUNDER STORY CARD ---------- */
.kp2-founder {
    display: grid; grid-template-columns: 1fr; gap: 28px;
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--kp2-r-lg);
    padding: 32px; align-items: center;
    box-shadow: 0 24px 50px -30px rgba(24,22,20,.18);
}
@media (min-width: 760px) { .kp2-founder { grid-template-columns: 180px 1fr; gap: 36px; padding: 40px; } }
.kp2-founder-photo {
    width: 180px; height: 180px; border-radius: 50%;
    background-size: cover; background-position: center;
    box-shadow: 0 16px 40px -16px rgba(0,0,0,.35), 0 0 0 6px var(--paper), 0 0 0 7px rgba(var(--ember-rgb),.20);
    margin: 0 auto;
}
.kp2-founder-meta strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 22px; letter-spacing: -.01em; }
.kp2-founder-meta .role { display: block; color: var(--ember-deep); font-weight: 700; font-size: 13.5px; margin-top: 2px; letter-spacing: .04em; }
.kp2-founder-meta p { color: var(--ink-soft); font-size: 15px; line-height: 1.65; margin: 14px 0 14px; }
.kp2-founder-meta .signature {
    font-family: var(--font-display); font-style: italic; font-size: 18px; color: var(--ember-deep); margin-top: 12px;
}

/* ---------- MANIFESTO BLOCK ---------- */
.kp2-manifesto {
    background: linear-gradient(135deg, var(--ink) 0%, #2A2622 100%);
    color: var(--paper); border-radius: var(--kp2-r-lg);
    padding: 44px 36px; position: relative; overflow: hidden;
    text-align: center;
}
.kp2-manifesto::before {
    content: ''; position: absolute; inset: 0; opacity: .25;
    background-image:
        linear-gradient(to right, rgba(255,252,244,.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,252,244,.06) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, #000 30%, transparent 80%);
}
.kp2-manifesto > * { position: relative; z-index: 1; }
.kp2-manifesto p {
    font-family: var(--font-display); font-weight: 700;
    font-size: clamp(22px, 3vw, 30px); line-height: 1.35; letter-spacing: -.015em;
    color: var(--paper); max-width: 760px; margin: 14px auto;
}
.kp2-manifesto .sig { color: rgba(255,252,244,.62); font-size: 13.5px; margin-top: 18px; }

/* ---------- PRESS / AWARDS STRIP ---------- */
.kp2-press {
    display: grid; gap: 14px;
    grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 700px) { .kp2-press { grid-template-columns: repeat(4, 1fr); } }
.kp2-press-item {
    background: var(--paper); border: 1px solid var(--rule); border-radius: 14px;
    padding: 18px 16px; text-align: center;
}
.kp2-press-item strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 17px; letter-spacing: -.01em; color: var(--ink); }
.kp2-press-item span  { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; letter-spacing: .06em; text-transform: uppercase; font-weight: 700; }

/* ---------- ROADMAP CARDS ---------- */
.kp2-road { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 700px) { .kp2-road { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .kp2-road { grid-template-columns: repeat(3, 1fr); } }
.kp2-road-card {
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--kp2-r);
    padding: 24px; position: relative; overflow: hidden;
    transition: transform .25s var(--ease-out-expo), box-shadow .25s, border-color .25s;
}
.kp2-road-card:hover { transform: translateY(-3px); box-shadow: 0 16px 36px -16px rgba(24,22,20,.18); border-color: rgba(var(--ember-rgb),.32); }
.kp2-road-status {
    display: inline-block; padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
    margin-bottom: 12px;
}
.kp2-road-status--ship { background: rgba(93,211,158,.18); color: #1F6A4B; }
.kp2-road-status--soon { background: rgba(var(--ember-rgb),.18); color: var(--ember-deep); }
.kp2-road-status--plan { background: var(--cream); color: var(--ink-soft); border: 1px solid var(--rule); }
.kp2-road-card h3 { font-family: var(--font-display); font-weight: 800; font-size: 17px; margin: 0 0 6px; letter-spacing: -.01em; }
.kp2-road-card p  { color: var(--ink-soft); font-size: 13.5px; line-height: 1.55; margin: 0 0 10px; }
.kp2-road-card time { color: var(--muted); font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }

/* ---------- SISTER PRODUCTS GRID ---------- */
.kp2-sis { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 700px) { .kp2-sis { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .kp2-sis { grid-template-columns: repeat(3, 1fr); } }
.kp2-sis-item {
    display: flex; align-items: center; gap: 14px;
    background: var(--paper); border: 1px solid var(--rule); border-radius: 14px;
    padding: 16px 18px;
    transition: transform .2s var(--ease-out-expo), border-color .2s;
}
.kp2-sis-item:hover { transform: translateX(3px); border-color: rgba(var(--ember-rgb),.32); }
.kp2-sis-mark {
    width: 42px; height: 42px; border-radius: 10px;
    display: grid; place-items: center; flex-shrink: 0;
    color: var(--paper); font-family: var(--font-display); font-weight: 800; font-size: 16px;
}
.kp2-sis-meta strong { display: block; font-family: var(--font-display); font-weight: 800; font-size: 14.5px; color: var(--ink); }
.kp2-sis-meta span { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; }

/* ---------- FEATURE COMPARISON TABLE (Features page) ---------- */
.kp2-cmp-table {
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--kp2-r); overflow: hidden;
    box-shadow: 0 16px 40px -20px rgba(24,22,20,.12);
}
.kp2-cmp-row {
    display: grid; grid-template-columns: 2fr 1fr 1fr;
    border-bottom: 1px solid var(--rule);
    font-size: 14px; align-items: center;
}
.kp2-cmp-row:last-child { border-bottom: 0; }
.kp2-cmp-row > div { padding: 14px 18px; }
.kp2-cmp-row.head {
    background: linear-gradient(135deg, var(--ink), #2A2622); color: var(--paper);
    font-family: var(--font-display); font-weight: 800;
}
.kp2-cmp-row.head > div { padding: 18px; }
.kp2-cmp-row .lbl { color: var(--ink); font-weight: 600; }
.kp2-cmp-row .yes { color: #1F6A4B; font-weight: 800; }
.kp2-cmp-row .no  { color: #D63C18; font-weight: 800; }
.kp2-cmp-row .mid { color: var(--muted); font-weight: 700; }
.kp2-cmp-row.alt { background: var(--cream); }
.kp2-cmp-row.head .ember { color: #FF9B7A; }

/* ---------- TECH STACK STRIP ---------- */
.kp2-tech {
    display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
    margin-top: 24px;
}
.kp2-tech span {
    padding: 8px 14px; border-radius: 999px;
    background: var(--paper); border: 1px solid var(--rule);
    font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); font-weight: 600;
}
.kp2-tech span strong { color: var(--ember-deep); font-weight: 800; }
