/* ═══════════════════════════════════════════════════════════════
   KABAL PUMPS® — DESIGN SYSTEM v1.0
   Unified design tokens + components for all pages
   ═══════════════════════════════════════════════════════════════ */

/* ─── FONTS (self-hosted) ─── */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/inter-700.woff2') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/geistmono-400.woff2') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/geistmono-500.woff2') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/geistmono-600.woff2') format('woff2')}
@font-face{font-family:'Syne';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/syne-700.woff2') format('woff2')}
@font-face{font-family:'Syne';font-style:normal;font-weight:800;font-display:swap;src:url('/static/fonts/syne-800.woff2') format('woff2')}

/* ═══════════════════════════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════════════════════════ */

:root{
  /* Brand (same in both themes) */
  --am:#f0b428;
  --am2:#e8a010;
  --am3:#d89200;

  /* Semantic colors */
  --gn:#22d47a;
  --gn-bg:rgba(34,212,122,.12);
  --gn-bg-solid:#0f7a3e;
  --rd:#f04f4f;
  --rd-bg:rgba(240,79,79,.12);
  --bl:#3d9be8;
  --bl-bg:rgba(61,155,232,.12);
  --or:#f08c3d;
  --or-bg:rgba(240,140,61,.12);

  /* Typography */
  --font-sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'Geist Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --font-display:'Syne','Inter',system-ui,sans-serif;

  /* Radius */
  --r-xs:4px;
  --r-sm:6px;
  --r-md:8px;
  --r-lg:10px;
  --r-xl:14px;
  --r-2xl:18px;
  --r-full:9999px;

  /* Spacing scale */
  --s-xs:4px;
  --s-sm:8px;
  --s-md:12px;
  --s-lg:16px;
  --s-xl:20px;
  --s-2xl:24px;
  --s-3xl:32px;
  --s-4xl:48px;

  /* Motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-in-out:cubic-bezier(.65,0,.35,1);
  --t-fast:120ms;
  --t-base:180ms;
  --t-slow:280ms;

  /* Z-index */
  --z-nav:100;
  --z-sticky:200;
  --z-dropdown:300;
  --z-modal:400;
  --z-toast:500;
}

/* ─── DARK THEME ─── */
[data-theme="dark"]{
  --bg:#080a0e;
  --sf:#0d1117;
  --sf2:#131920;
  --sf3:#1a2230;
  --sf-hover:#1e2636;
  --bd:#1c2a3a;
  --bd2:#243347;
  --bd-strong:#2e4055;
  --tx:#e2eaf6;
  --tx2:#8899b4;
  --tx3:#4a5a72;
  --tx-inv:#0a0e14;
  --glow:rgba(240,180,40,.12);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 4px 12px rgba(0,0,0,.5);
  --shadow-lg:0 12px 28px rgba(0,0,0,.6);
  --focus-ring:rgba(240,180,40,.35);
  --am-ink:#1a1200;  /* text on gold button */
  --overlay:rgba(0,0,0,.65);
}

/* ─── LIGHT THEME (warm, invested) ─── */
[data-theme="light"]{
  --bg:#fafaf7;
  --sf:#ffffff;
  --sf2:#f2efe6;
  --sf3:#e8e4d9;
  --sf-hover:#f5f2e8;
  --bd:#e8e4d9;
  --bd2:#d8d2c2;
  --bd-strong:#b8b0a0;
  --tx:#1a1611;
  --tx2:#5a524a;
  --tx3:#948a7d;
  --tx-inv:#fafaf7;
  --glow:rgba(224,154,12,.08);
  --shadow-sm:0 1px 2px rgba(20,16,8,.05);
  --shadow-md:0 2px 8px rgba(20,16,8,.08);
  --shadow-lg:0 8px 24px rgba(20,16,8,.12);
  --focus-ring:rgba(224,154,12,.3);
  --am:#e09a0c;
  --am2:#c98808;
  --am3:#a57004;
  --am-ink:#fafaf7;
  --gn:#0f7a3e;
  --gn-bg:#e6f5ea;
  --rd:#c43333;
  --rd-bg:#fbe8e8;
  --bl:#2278c9;
  --bl-bg:#e4f0fb;
  --or:#c86e1c;
  --or-bg:#fbeddf;
  --overlay:rgba(26,22,17,.5);
}

/* ═══════════════════════════════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--tx);
  font-family:var(--font-sans);
  font-size:13px;
  line-height:1.5;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  transition:background var(--t-slow) var(--ease-out),color var(--t-slow) var(--ease-out);
  overflow-x:hidden;
}

button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
input,textarea,select{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* Scrollbars */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--bd-strong)}

/* Selection */
::selection{background:var(--am);color:var(--am-ink)}

/* Focus — accessible by default */
:focus-visible{outline:2px solid var(--am);outline-offset:2px;border-radius:var(--r-sm)}
input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}

/* ═══════════════════════════════════════════════════════════════
   TYPOGRAPHY
   ═══════════════════════════════════════════════════════════════ */

.t-display{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.02em;line-height:1.15;color:var(--tx)}
.t-h1{font-weight:600;font-size:18px;letter-spacing:-.015em;line-height:1.25;color:var(--tx)}
.t-h2{font-weight:600;font-size:15px;letter-spacing:-.01em;line-height:1.3;color:var(--tx)}
.t-h3{font-weight:600;font-size:13px;line-height:1.35;color:var(--tx)}
.t-body{font-weight:400;font-size:13px;line-height:1.5;color:var(--tx)}
.t-small{font-weight:500;font-size:12px;line-height:1.45;color:var(--tx2)}
.t-micro{font-weight:600;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx3)}
.t-label{font-weight:500;font-size:11px;color:var(--tx2)}
.t-hint{font-weight:400;font-size:11px;color:var(--tx3);line-height:1.5}

/* Numeric — for all numbers, prices, amounts */
.t-num{font-family:var(--font-mono);font-weight:500;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.t-num-lg{font-family:var(--font-mono);font-weight:500;font-size:22px;letter-spacing:-.02em;color:var(--tx);font-variant-numeric:tabular-nums}
.t-num-xl{font-family:var(--font-mono);font-weight:500;font-size:28px;letter-spacing:-.025em;color:var(--tx);font-variant-numeric:tabular-nums;line-height:1.1}

/* Semantic colors */
.c-mute{color:var(--tx2)}
.c-dim{color:var(--tx3)}
.c-gn{color:var(--gn)}
.c-rd{color:var(--rd)}
.c-bl{color:var(--bl)}
.c-am{color:var(--am)}

/* ═══════════════════════════════════════════════════════════════
   LAYOUT HELPERS
   ═══════════════════════════════════════════════════════════════ */

.kp-container{max-width:1280px;margin:0 auto;padding:0 var(--s-xl)}
.kp-container-sm{max-width:720px;margin:0 auto;padding:0 var(--s-xl)}
.kp-container-md{max-width:960px;margin:0 auto;padding:0 var(--s-xl)}
@media(max-width:640px){.kp-container,.kp-container-sm,.kp-container-md{padding:0 var(--s-lg)}}

.kp-stack{display:flex;flex-direction:column;gap:var(--s-md)}
.kp-stack-lg{display:flex;flex-direction:column;gap:var(--s-xl)}
.kp-row{display:flex;align-items:center;gap:var(--s-md);flex-wrap:wrap}
.kp-row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--s-md)}

.kp-grid{display:grid;gap:var(--s-lg)}
.kp-grid-2{grid-template-columns:repeat(2,1fr)}
.kp-grid-3{grid-template-columns:repeat(3,1fr)}
.kp-grid-4{grid-template-columns:repeat(4,1fr)}
.kp-grid-auto{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
@media(max-width:768px){.kp-grid-2,.kp-grid-3,.kp-grid-4{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   HEADER / NAV
   ═══════════════════════════════════════════════════════════════ */

.kp-header{position:sticky;top:0;z-index:var(--z-sticky);background:color-mix(in srgb,var(--sf) 95%,transparent);border-bottom:1px solid var(--bd);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background var(--t-slow) var(--ease-out),border-color var(--t-slow) var(--ease-out)}
.kp-header-inner{max-width:1280px;margin:0 auto;padding:12px var(--s-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--s-lg)}
@media(max-width:640px){.kp-header-inner{padding:10px var(--s-lg)}}

.kp-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--tx)}
.kp-logo-mark{width:32px;height:32px;background:var(--am);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:transform var(--t-base) var(--ease-out)}
.kp-logo:hover .kp-logo-mark{transform:scale(1.05)}
.kp-logo-name{font-family:var(--font-display);font-weight:700;font-size:15px;line-height:1.1;letter-spacing:-.015em;color:var(--tx)}
.kp-logo-sub{font-size:10px;color:var(--tx3);font-weight:500;margin-top:1px;letter-spacing:.02em}

.kp-nav{display:flex;align-items:center;gap:4px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}
.kp-nav::-webkit-scrollbar{display:none;height:0}
.kp-nav-item{padding:7px 12px;border-radius:var(--r-md);font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;transition:all var(--t-fast) var(--ease-out);white-space:nowrap;display:flex;align-items:center;gap:6px;border:1px solid transparent;flex-shrink:0}
.kp-nav-item:hover{color:var(--tx);background:var(--sf2)}
.kp-nav-item.is-active{color:var(--am);background:var(--glow);border-color:color-mix(in srgb,var(--am) 30%,transparent)}
@media(max-width:640px){.kp-nav-item{padding:6px 10px;font-size:11px}}

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */

.kp-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:-.005em;padding:8px 14px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;transition:all var(--t-fast) var(--ease-out);white-space:nowrap;user-select:none;line-height:1;min-height:34px}
.kp-btn:active{transform:scale(.97)}
.kp-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Primary — gold */
.kp-btn-primary{background:var(--am);color:var(--am-ink);border-color:var(--am)}
.kp-btn-primary:hover:not(:disabled){background:var(--am2);border-color:var(--am2);box-shadow:0 4px 12px color-mix(in srgb,var(--am) 30%,transparent)}

/* Secondary — surface */
.kp-btn-secondary{background:var(--sf2);color:var(--tx);border-color:var(--bd)}
.kp-btn-secondary:hover:not(:disabled){background:var(--sf-hover);border-color:var(--bd2)}

/* Ghost */
.kp-btn-ghost{background:transparent;color:var(--tx2);border-color:transparent}
.kp-btn-ghost:hover:not(:disabled){color:var(--tx);background:var(--sf2)}

/* Danger */
.kp-btn-danger{background:var(--rd-bg);color:var(--rd);border-color:color-mix(in srgb,var(--rd) 20%,transparent)}
.kp-btn-danger:hover:not(:disabled){background:var(--rd);color:#fff;border-color:var(--rd)}

/* Success */
.kp-btn-success{background:var(--gn);color:#fff;border-color:var(--gn)}
.kp-btn-success:hover:not(:disabled){filter:brightness(.92)}

/* Sizes */
.kp-btn-sm{padding:6px 10px;font-size:11px;min-height:28px}
.kp-btn-lg{padding:11px 20px;font-size:13px;min-height:42px}
.kp-btn-icon{padding:7px;min-height:32px;min-width:32px}
.kp-btn-block{width:100%}

/* ═══════════════════════════════════════════════════════════════
   INPUTS
   ═══════════════════════════════════════════════════════════════ */

.kp-field{display:flex;flex-direction:column;gap:6px}
.kp-field-label{font-size:11px;font-weight:500;color:var(--tx2);letter-spacing:.01em}
.kp-field-label-req::after{content:' *';color:var(--rd)}
.kp-field-hint{font-size:11px;color:var(--tx3);line-height:1.5}
.kp-field-error{font-size:11px;color:var(--rd);line-height:1.5}

.kp-input,.kp-select,.kp-textarea{width:100%;background:var(--sf2);color:var(--tx);border:1px solid var(--bd);border-radius:var(--r-md);padding:9px 12px;font-size:13px;font-family:var(--font-sans);transition:all var(--t-fast) var(--ease-out);min-height:38px}
.kp-input:hover,.kp-select:hover,.kp-textarea:hover{border-color:var(--bd2)}
.kp-input:focus,.kp-select:focus,.kp-textarea:focus{outline:none;border-color:var(--am);box-shadow:0 0 0 3px var(--focus-ring)}
.kp-input::placeholder,.kp-textarea::placeholder{color:var(--tx3)}
.kp-input:disabled,.kp-select:disabled,.kp-textarea:disabled{opacity:.6;cursor:not-allowed}

.kp-input-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}

.kp-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238899b4' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}

.kp-textarea{resize:vertical;min-height:80px;line-height:1.5;padding-top:10px;padding-bottom:10px}

/* Checkbox — custom */
.kp-checkbox{display:flex;align-items:flex-start;gap:10px;cursor:pointer;user-select:none;padding:6px 0}
.kp-checkbox input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}
.kp-checkbox-box{flex-shrink:0;width:18px;height:18px;border-radius:5px;background:var(--sf2);border:1.5px solid var(--bd2);display:flex;align-items:center;justify-content:center;transition:all var(--t-fast) var(--ease-out);margin-top:1px}
.kp-checkbox:hover .kp-checkbox-box{border-color:var(--am)}
.kp-checkbox input:checked+.kp-checkbox-box{background:var(--am);border-color:var(--am)}
.kp-checkbox input:checked+.kp-checkbox-box::after{content:'';width:10px;height:10px;background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10' fill='none'%3E%3Cpath d='M2 5.5L4 7.5L8 3' stroke='%231a1200' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/contain}
.kp-checkbox input:focus-visible+.kp-checkbox-box{box-shadow:0 0 0 3px var(--focus-ring)}
.kp-checkbox-label{font-size:12px;color:var(--tx);line-height:1.5}
.kp-checkbox-label-hint{font-size:11px;color:var(--tx3);margin-top:2px;line-height:1.45}

/* Toggle switch */
.kp-toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.kp-toggle-track{position:relative;width:36px;height:20px;background:var(--bd2);border-radius:var(--r-full);transition:background var(--t-base) var(--ease-out);flex-shrink:0}
.kp-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:left var(--t-base) var(--ease-out);box-shadow:0 1px 3px rgba(0,0,0,.3)}
.kp-toggle input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}
.kp-toggle input:checked~.kp-toggle-track{background:var(--am)}
.kp-toggle input:checked~.kp-toggle-track .kp-toggle-thumb{left:18px}
.kp-toggle input:focus-visible~.kp-toggle-track{box-shadow:0 0 0 3px var(--focus-ring)}
.kp-toggle-label{font-size:12px;color:var(--tx);font-weight:500}

/* ═══════════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════════ */

.kp-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-xl);padding:var(--s-xl);position:relative;transition:border-color var(--t-base) var(--ease-out),background var(--t-slow) var(--ease-out)}
.kp-card-accent{position:relative;overflow:hidden}
.kp-card-accent::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--am) 0%,color-mix(in srgb,var(--am) 0%,transparent) 70%);pointer-events:none}
.kp-card-hover{cursor:pointer}
.kp-card-hover:hover{border-color:var(--bd2);box-shadow:var(--shadow-md)}

.kp-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s-md);margin-bottom:var(--s-lg)}
.kp-card-title{font-weight:600;font-size:14px;letter-spacing:-.01em;color:var(--tx);line-height:1.3}
.kp-card-desc{font-size:11px;color:var(--tx3);margin-top:3px;line-height:1.5}
.kp-card-body{display:flex;flex-direction:column;gap:var(--s-md)}

.kp-card-compact{padding:var(--s-lg)}
.kp-card-ghost{background:transparent;border:none;padding:0}

/* Stat card */
.kp-stat{background:var(--sf2);border-radius:var(--r-lg);padding:14px 16px;display:flex;flex-direction:column;gap:4px;min-width:0;transition:background var(--t-slow) var(--ease-out)}
.kp-stat-label{font-size:11px;color:var(--tx2);font-weight:500}
.kp-stat-value{font-family:var(--font-mono);font-size:18px;font-weight:500;letter-spacing:-.015em;color:var(--tx);font-variant-numeric:tabular-nums;line-height:1.2;word-break:break-word}
.kp-stat-delta{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:11px;font-weight:500;margin-top:2px}
.kp-stat-hero .kp-stat-value{font-size:26px;letter-spacing:-.025em}

/* ═══════════════════════════════════════════════════════════════
   BADGES & PILLS
   ═══════════════════════════════════════════════════════════════ */

.kp-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-sm);font-size:10px;font-weight:600;letter-spacing:.02em;line-height:1.3;white-space:nowrap}
.kp-badge-gn{background:var(--gn-bg);color:var(--gn)}
.kp-badge-rd{background:var(--rd-bg);color:var(--rd)}
.kp-badge-bl{background:var(--bl-bg);color:var(--bl)}
.kp-badge-am{background:var(--glow);color:var(--am)}
.kp-badge-or{background:var(--or-bg);color:var(--or)}
.kp-badge-neutral{background:var(--sf2);color:var(--tx2);border:1px solid var(--bd)}

/* Pill — larger */
.kp-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--r-full);font-size:11px;font-weight:500;white-space:nowrap;line-height:1.3}
.kp-pill-gn{background:var(--gn-bg);color:var(--gn)}
.kp-pill-rd{background:var(--rd-bg);color:var(--rd)}
.kp-pill-neutral{background:var(--sf2);color:var(--tx2);border:1px solid var(--bd)}

/* Dot indicator */
.kp-dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}
.kp-dot-live{background:var(--gn);box-shadow:0 0 0 0 color-mix(in srgb,var(--gn) 40%,transparent);animation:kp-pulse 2s var(--ease-out) infinite}
.kp-dot-pending{background:var(--or)}
.kp-dot-closed{background:var(--tx3)}
@keyframes kp-pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--gn) 40%,transparent)}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* ═══════════════════════════════════════════════════════════════
   TABLES
   ═══════════════════════════════════════════════════════════════ */

.kp-table-wrap{width:100%;overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--bd);background:var(--sf)}
.kp-table{width:100%;border-collapse:collapse;font-size:12px}
.kp-table th{padding:10px 14px;text-align:left;font-weight:600;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);background:var(--sf2);border-bottom:1px solid var(--bd);white-space:nowrap}
.kp-table td{padding:11px 14px;border-bottom:1px solid var(--bd);color:var(--tx);white-space:nowrap;vertical-align:middle}
.kp-table tr:last-child td{border-bottom:none}
.kp-table tr:hover td{background:var(--sf2)}
.kp-table .td-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:500}
.kp-table .td-action{text-align:right;width:1%}

/* ═══════════════════════════════════════════════════════════════
   ALERTS / BANNERS
   ═══════════════════════════════════════════════════════════════ */

.kp-alert{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--r-md);font-size:12px;line-height:1.5;border:1px solid transparent}
.kp-alert-icon{flex-shrink:0;margin-top:1px;font-size:13px}
.kp-alert-body{flex:1;min-width:0}
.kp-alert-title{font-weight:600;margin-bottom:2px}

.kp-alert-info{background:var(--bl-bg);color:var(--bl);border-color:color-mix(in srgb,var(--bl) 20%,transparent)}
.kp-alert-success{background:var(--gn-bg);color:var(--gn);border-color:color-mix(in srgb,var(--gn) 20%,transparent)}
.kp-alert-warning{background:var(--or-bg);color:var(--or);border-color:color-mix(in srgb,var(--or) 20%,transparent)}
.kp-alert-danger{background:var(--rd-bg);color:var(--rd);border-color:color-mix(in srgb,var(--rd) 20%,transparent)}

/* Inline banner — full width page notice */
.kp-banner{padding:10px var(--s-xl);display:flex;align-items:center;justify-content:center;gap:var(--s-sm);font-size:12px;font-weight:500;border-bottom:1px solid var(--bd)}
.kp-banner-info{background:var(--bl-bg);color:var(--bl)}
.kp-banner-warning{background:var(--or-bg);color:var(--or)}

/* ═══════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════ */

.kp-modal-backdrop{position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--s-lg);opacity:0;pointer-events:none;transition:opacity var(--t-base) var(--ease-out)}
.kp-modal-backdrop.is-open{opacity:1;pointer-events:auto}

.kp-modal{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-xl);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translateY(8px) scale(.98);transition:transform var(--t-base) var(--ease-out)}
.kp-modal-backdrop.is-open .kp-modal{transform:translateY(0) scale(1)}
.kp-modal-lg{max-width:640px}
.kp-modal-sm{max-width:360px}

.kp-modal-header{padding:var(--s-lg) var(--s-xl);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;gap:var(--s-md)}
.kp-modal-title{font-weight:600;font-size:14px;color:var(--tx)}
.kp-modal-close{width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--tx3);background:transparent;transition:all var(--t-fast) var(--ease-out);cursor:pointer;font-size:16px;line-height:1}
.kp-modal-close:hover{color:var(--tx);background:var(--sf2)}

.kp-modal-body{padding:var(--s-xl);display:flex;flex-direction:column;gap:var(--s-md)}
.kp-modal-footer{padding:var(--s-md) var(--s-xl);border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:var(--s-sm);background:var(--sf2)}

/* ═══════════════════════════════════════════════════════════════
   TABS
   ═══════════════════════════════════════════════════════════════ */

.kp-tabs{display:flex;gap:2px;padding:3px;background:var(--sf2);border-radius:var(--r-md);border:1px solid var(--bd)}
.kp-tab{flex:1;padding:6px 12px;font-size:12px;font-weight:500;color:var(--tx2);border-radius:var(--r-sm);cursor:pointer;transition:all var(--t-fast) var(--ease-out);text-align:center;white-space:nowrap;background:transparent;border:none}
.kp-tab:hover{color:var(--tx)}
.kp-tab.is-active{background:var(--sf);color:var(--tx);box-shadow:var(--shadow-sm)}

/* Tabs — underlined style */
.kp-tabs-underline{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-bottom:var(--s-lg)}
.kp-tab-underline{padding:10px 16px;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;transition:color var(--t-fast) var(--ease-out);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;position:relative}
.kp-tab-underline:hover{color:var(--tx)}
.kp-tab-underline.is-active{color:var(--am);border-bottom-color:var(--am)}

/* ═══════════════════════════════════════════════════════════════
   DROPDOWN
   ═══════════════════════════════════════════════════════════════ */

.kp-dropdown{position:relative;display:inline-block}
.kp-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-md);box-shadow:var(--shadow-md);z-index:var(--z-dropdown);padding:4px;display:none;animation:kp-fade-in var(--t-fast) var(--ease-out)}
.kp-dropdown-menu.is-open{display:block}
@keyframes kp-fade-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

.kp-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 10px;font-size:12px;color:var(--tx);border-radius:var(--r-sm);cursor:pointer;transition:background var(--t-fast) var(--ease-out);white-space:nowrap;background:transparent;border:none;width:100%;text-align:left}
.kp-dropdown-item:hover{background:var(--sf2)}
.kp-dropdown-item-danger{color:var(--rd)}
.kp-dropdown-item-danger:hover{background:var(--rd-bg)}
.kp-dropdown-divider{height:1px;background:var(--bd);margin:4px 0}

/* ═══════════════════════════════════════════════════════════════
   LOADING & SKELETONS
   ═══════════════════════════════════════════════════════════════ */

.kp-skel{background:linear-gradient(90deg,var(--sf2) 0%,var(--sf3) 50%,var(--sf2) 100%);background-size:200% 100%;border-radius:var(--r-sm);animation:kp-shimmer 1.4s ease-in-out infinite}
.kp-skel-text{height:12px;width:100%}
.kp-skel-title{height:18px;width:60%}
.kp-skel-num{height:24px;width:120px}
@keyframes kp-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.kp-spinner{width:16px;height:16px;border:2px solid var(--bd2);border-top-color:var(--am);border-radius:50%;animation:kp-spin .7s linear infinite;display:inline-block}
@keyframes kp-spin{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════════════════════════════
   FLASH ANIMATIONS (for value updates)
   ═══════════════════════════════════════════════════════════════ */

@keyframes kp-flash-up{0%{background:transparent}20%{background:var(--gn-bg)}100%{background:transparent}}
@keyframes kp-flash-down{0%{background:transparent}20%{background:var(--rd-bg)}100%{background:transparent}}
.kp-flash-up{animation:kp-flash-up 1.2s var(--ease-out)}
.kp-flash-down{animation:kp-flash-down 1.2s var(--ease-out)}

/* ═══════════════════════════════════════════════════════════════
   UTILITIES
   ═══════════════════════════════════════════════════════════════ */

.kp-hide{display:none !important}
.kp-show{display:block !important}
.kp-text-center{text-align:center}
.kp-text-right{text-align:right}
.kp-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kp-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.kp-nowrap{white-space:nowrap}
.kp-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Gap helpers */
.kp-gap-xs{gap:var(--s-xs)}
.kp-gap-sm{gap:var(--s-sm)}
.kp-gap-md{gap:var(--s-md)}
.kp-gap-lg{gap:var(--s-lg)}

/* Margin helpers — use sparingly */
.kp-mt-sm{margin-top:var(--s-sm)}
.kp-mt-md{margin-top:var(--s-md)}
.kp-mt-lg{margin-top:var(--s-lg)}
.kp-mb-sm{margin-bottom:var(--s-sm)}
.kp-mb-md{margin-bottom:var(--s-md)}
.kp-mb-lg{margin-bottom:var(--s-lg)}

/* ═══════════════════════════════════════════════════════════════
   MOBILE REFINEMENTS
   ═══════════════════════════════════════════════════════════════ */

@media(max-width:640px){
  body{font-size:13px}
  .kp-card{padding:var(--s-lg);border-radius:var(--r-lg)}
  .kp-card-compact{padding:var(--s-md)}
  .kp-btn{min-height:38px;padding:9px 14px}
  .kp-btn-sm{min-height:32px}
  .kp-input,.kp-select,.kp-textarea{min-height:42px;font-size:14px}
  .kp-modal{border-radius:var(--r-lg)}
  .kp-modal-header,.kp-modal-body{padding:var(--s-lg)}
  /* Header — compact on mobile to fit nav */
  .kp-header-inner{padding:8px 12px;gap:8px;flex-wrap:wrap;row-gap:6px}
  .kp-logo-sub{display:none}
  .kp-logo-mark{width:28px;height:28px;font-size:14px}
  .kp-logo-name{font-size:13px}
  .kp-logo{flex-shrink:0}
  /* Nav goes to second row, scrollable */
  .kp-nav{order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}
  .kp-nav::-webkit-scrollbar{display:none}
  .kp-nav-item{flex-shrink:0;padding:6px 10px;font-size:11px;white-space:nowrap}
  /* Right side group stays compact */
  .kp-header-inner > .kp-row{flex-shrink:0;gap:6px !important}
  /* Hide refresh button in header on mobile (mobile-refresh icon already exists in dashboard) */
  .kp-header-inner > .kp-row > .kp-btn-secondary{display:none !important}
  /* Compact Sign out */
  .kp-header-inner > .kp-row > .kp-btn-ghost{padding:6px 10px;font-size:11px;min-height:30px}
}

/* Very small screens — hide logo text, keep only mark */
@media(max-width:420px){
  .kp-logo-name{display:none}
}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}

/* ═══════════════════════════════════════════════════════════════
   THEME TOGGLE (modern switch with sun/moon)
   ═══════════════════════════════════════════════════════════════ */

.kp-theme-toggle{background:none;border:none;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.kp-tt-track{position:relative;display:flex;align-items:center;width:50px;height:26px;border-radius:13px;background:var(--sf2);border:1px solid var(--bd2);transition:all var(--t-base) var(--ease-out);box-shadow:inset 0 1px 2px rgba(0,0,0,.05)}
[data-theme="dark"] .kp-tt-track{box-shadow:inset 0 1px 2px rgba(0,0,0,.4)}
.kp-tt-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--sf);border:1px solid var(--bd2);box-shadow:0 1px 3px rgba(0,0,0,.15),0 1px 1px rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;transition:transform var(--t-base) cubic-bezier(.4,0,.2,1),background var(--t-base) var(--ease-out),border-color var(--t-base) var(--ease-out);overflow:hidden}
[data-theme="dark"] .kp-tt-thumb{transform:translateX(0)}
[data-theme="light"] .kp-tt-thumb{transform:translateX(24px)}
.kp-tt-icon{position:absolute;width:12px;height:12px;transition:opacity var(--t-base) var(--ease-out),transform var(--t-base) var(--ease-out)}
.kp-tt-sun{color:var(--am);opacity:0;transform:rotate(-45deg) scale(.5)}
.kp-tt-moon{color:var(--tx2);opacity:1;transform:rotate(0) scale(1)}
[data-theme="light"] .kp-tt-sun{opacity:1;transform:rotate(0) scale(1)}
[data-theme="light"] .kp-tt-moon{opacity:0;transform:rotate(45deg) scale(.5)}
.kp-theme-toggle:hover .kp-tt-track{border-color:var(--am);box-shadow:0 0 0 3px color-mix(in srgb,var(--am) 12%,transparent),inset 0 1px 2px rgba(0,0,0,.04)}
.kp-theme-toggle:hover .kp-tt-thumb{border-color:var(--am)}
.kp-theme-toggle:active .kp-tt-thumb{width:22px}

/* Hide theme toggle on mobile by default — only settings/login override */
@media(max-width:640px){
  .kp-theme-toggle:not(.kp-tt-mobile-show){display:none !important}
}

/* Theme toggle inside header — pin to far right of viewport (escapes the 1280px wrap) */
.kp-header{position:sticky}
.kp-header .kp-theme-toggle{position:absolute;right:18px;top:50%;transform:translateY(-50%);z-index:5}
@media(max-width:640px){
  .kp-header .kp-theme-toggle{right:12px}
}

/* Floating fixed position (top-right) — used on every page */
.theme-toggle-fixed{position:fixed;top:14px;right:18px;z-index:200;transition:transform var(--t-fast) var(--ease-out)}
.theme-toggle-fixed:hover{transform:translateY(-1px)}
@media(max-width:640px){
  .theme-toggle-fixed{top:10px;right:12px}
}
