/* ═══════════════════════════════════════════════════════════
   KREW18 v12 — Premium Design System
   Fonts: Syne (logo) · Epilogue (headings) · DM Sans (body)
   Philosophy: Black luxury · Glass depth · Green accent ~40%
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Epilogue:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

/* ── Root tokens ── */
:root {
  /* Backgrounds — pure neutral black */
  --bg:          #050505;
  --bg-deep:     #0A0A0A;
  --bg-soft:     #101010;
  --bg-elevated: #151515;
  --bg-card:     rgba(255,255,255,.03);
  --bg-card-2:   rgba(255,255,255,.05);

  /* Greens — accent only */
  --green:       #22C55E;
  --green-soft:  #34D399;
  --green-hover: #4ADE80;
  --green-deep:  #16A34A;
  --green-neon:  #86EFAC;
  --green-glow:  rgba(34,197,94,.18);
  --green-dim:   rgba(34,197,94,.08);

  /* Supporting */
  --blue:        #60A5FA;
  --purple:      #A78BFA;
  --orange:      #F59E0B;
  --red:         #F87171;

  /* Typography */
  --text:        #F5F5F5;
  --text-2:      rgba(255,255,255,.72);
  --text-3:      rgba(255,255,255,.48);
  --text-4:      rgba(255,255,255,.28);

  /* Glass system */
  --glass:       rgba(255,255,255,.04);
  --glass-2:     rgba(255,255,255,.06);
  --glass-3:     rgba(255,255,255,.08);
  --blur:        blur(24px);
  --blur-2:      blur(32px);

  /* Borders */
  --border:      rgba(255,255,255,.06);
  --border-2:    rgba(255,255,255,.10);
  --border-3:    rgba(255,255,255,.14);

  /* Radius */
  --r-sm:  14px;
  --r-md:  20px;
  --r-lg:  28px;
  --r-xl:  36px;
  --r-full: 999px;

  /* Shadows */
  --shadow-sm:   0 4px 16px rgba(0,0,0,.35);
  --shadow-md:   0 8px 32px rgba(0,0,0,.45);
  --shadow-lg:   0 24px 80px rgba(0,0,0,.50);
  --shadow-glow: 0 10px 40px rgba(34,197,94,.22);

  /* Easing */
  --ease:  cubic-bezier(0.22,1,0.36,1);

  /* Fonts */
  --font-logo: 'Syne', system-ui, sans-serif;
  --font-head: 'Epilogue', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;
}

/* ── Reset ── */
.k18-page *, .k18d-wrap *, #krew18-login * {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 8px; background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.10); border-radius: var(--r-full); }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.18); }

/* ── Page shell ── */
.k18-page {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-2);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  position: relative;
}

/* Ambient background — one subtle glow at top */
.k18-page::before {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse 70% 40% at 50% 0%, rgba(34,197,94,.07), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

/* Noise grain — subtle luxury texture */
.k18-page::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}

.k18-page-in {
  position: relative;
  z-index: 1;
}

/* ════════════════════════════════════════════════════════════
   TYPOGRAPHY
   ════════════════════════════════════════════════════════════ */
.k18-h1 {
  font-family: var(--font-head);
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1.02;
  color: var(--text);
}
.k18-h2 {
  font-family: var(--font-head);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.05;
  color: var(--text);
}
.k18-h3 {
  font-family: var(--font-head);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.1;
  color: var(--text);
}
.k18-h4 {
  font-family: var(--font-head);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--text);
}
.k18-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-3);
}

/* ════════════════════════════════════════════════════════════
   GLASS CARD SYSTEM
   ════════════════════════════════════════════════════════════ */
.k18-card {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
  transition:
    transform .35s var(--ease),
    border-color .25s,
    box-shadow .35s var(--ease);
}
/* Subtle top light edge on cards */
.k18-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent,
    rgba(255,255,255,.07) 30%,
    rgba(255,255,255,.07) 70%,
    transparent
  );
  pointer-events: none;
}
.k18-card:hover {
  transform: translateY(-4px);
  border-color: rgba(52,211,153,.18);
  box-shadow: var(--shadow-lg);
}
/* Card with glow at top-left */
.k18-card-glow::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 60%; height: 60%;
  background: radial-gradient(circle at top left, rgba(52,211,153,.08), transparent 60%);
  pointer-events: none;
}

/* Elevated card variant */
.k18-card-elevated {
  background: var(--glass-2);
  backdrop-filter: var(--blur-2);
  -webkit-backdrop-filter: var(--blur-2);
  border-color: var(--border-2);
  box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,.04);
}

/* Inner card (nested) */
.k18-card-inner {
  background: rgba(0,0,0,.25);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 20px;
}

/* ════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════ */
.k18-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 48px;
  padding: 0 24px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  border: none;
  white-space: nowrap;
  transition:
    transform .35s var(--ease),
    filter .25s,
    box-shadow .35s var(--ease),
    background .2s;
}
/* Primary green button */
.k18-btn-primary {
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  box-shadow: var(--shadow-glow), inset 0 1px 0 rgba(255,255,255,.15);
}
.k18-btn-primary:hover {
  transform: translateY(-2px) scale(1.02);
  filter: brightness(1.08);
  box-shadow: 0 16px 48px rgba(34,197,94,.30), inset 0 1px 0 rgba(255,255,255,.15);
}
.k18-btn-primary:active {
  transform: scale(.98);
  box-shadow: var(--shadow-glow);
}

/* Ghost button */
.k18-btn-ghost {
  background: var(--glass);
  border: 1px solid var(--border-2);
  color: var(--text-2);
}
.k18-btn-ghost:hover {
  background: var(--glass-2);
  border-color: var(--border-3);
  transform: translateY(-1px);
  color: var(--text);
}

/* Danger button */
.k18-btn-danger {
  background: rgba(248,113,113,.10);
  border: 1px solid rgba(248,113,113,.20);
  color: var(--red);
}
.k18-btn-danger:hover {
  background: rgba(248,113,113,.18);
}

/* Full width */
.k18-btn-full { width: 100%; }

/* Small */
.k18-btn-sm { height: 36px; padding: 0 16px; font-size: 13px; border-radius: 10px; }

/* Focus */
.k18-btn:focus-visible {
  outline: 2px solid rgba(34,197,94,.6);
  outline-offset: 3px;
}

.k18-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none !important;
  filter: none !important;
}

/* ════════════════════════════════════════════════════════════
   INPUTS & FORMS
   ════════════════════════════════════════════════════════════ */
.k18-input,
.k18-select,
.k18-textarea {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 56px;
  padding: 0 16px 0 44px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  outline: none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s;
}
.k18-input:focus,
.k18-select:focus,
.k18-textarea:focus {
  border-color: var(--green-soft);
  box-shadow: 0 0 0 4px rgba(52,211,153,.12);
  background: rgba(255,255,255,.06);
}
.k18-input::placeholder,
.k18-textarea::placeholder {
  color: var(--text-4);
}
.k18-select option {
  background: var(--bg-soft);
  color: var(--text);
}
.k18-textarea {
  height: auto;
  padding: 14px 16px;
  resize: vertical;
  line-height: 1.6;
}
/* Input without icon */
.k18-input-bare { padding-left: 16px; }

/* Field wrapper */
.k18-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.k18-field > label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-3);
}
/* Icon in input */
.k18-input-wrap {
  position: relative;
}
.k18-input-wrap svg {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  opacity: .5;
  pointer-events: none;
}
.k18-input-wrap .k18-input { padding-left: 44px; }

/* Checkbox — styled */
.k18-check {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
}
.k18-check input[type=checkbox] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  margin-top: 2px;
  accent-color: var(--green);
  flex-shrink: 0;
  cursor: pointer;
}
.k18-check p, .k18-check span {
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.5;
}
.k18-check a {
  color: var(--green-soft);
  text-decoration: none;
  font-weight: 600;
}

/* Hint text */
.k18-hint {
  font-size: 12px;
  color: var(--text-4);
  margin-top: 4px;
}

/* Error text */
.k18-err {
  font-size: 13px;
  color: var(--red);
  padding: 10px 14px;
  background: rgba(248,113,113,.08);
  border: 1px solid rgba(248,113,113,.18);
  border-radius: 10px;
  display: none;
}

/* Chips */
.k18-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px;
  background: var(--glass);
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
}
.k18-chip {
  padding: 7px 14px;
  border-radius: var(--r-full);
  border: 1px solid var(--border-2);
  background: rgba(255,255,255,.03);
  color: var(--text-3);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s var(--ease);
  user-select: none;
}
.k18-chip[data-on="1"],
.k18-chip.active {
  border-color: rgba(52,211,153,.50);
  background: rgba(52,211,153,.10);
  color: var(--green-soft);
}

/* Form grid */
.k18-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.k18-form-grid-full { grid-column: 1 / -1; }
@media (max-width: 600px) {
  .k18-form-grid { grid-template-columns: 1fr; }
}

/* Step system */
.k18f-step { display: none; }
.k18f-step.on { display: block; }

/* ════════════════════════════════════════════════════════════
   CUSTOM MODAL — Glass blur overlay
   ════════════════════════════════════════════════════════════ */
#k18-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: var(--blur-2);
  -webkit-backdrop-filter: var(--blur-2);
}
.k18-modal-box {
  background: rgba(10,10,10,.97);
  border: 1px solid var(--border-3);
  border-radius: var(--r-lg);
  max-width: 420px;
  width: 100%;
  padding: 32px 28px;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.05);
  position: relative;
}
.k18-modal-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}
.k18-modal-icon  { font-size: 36px; text-align: center; margin-bottom: 12px; }
.k18-modal-title {
  font-family: var(--font-head);
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 10px;
  letter-spacing: -.01em;
}
.k18-modal-title.green  { color: var(--green-soft); }
.k18-modal-title.yellow { color: var(--orange); }
.k18-modal-title.red    { color: var(--red); }
.k18-modal-title.blue   { color: var(--blue); }
.k18-modal-title.white  { color: var(--text); }
.k18-modal-body {
  font-size: 14px;
  color: var(--text-3);
  text-align: center;
  line-height: 1.7;
  white-space: pre-line;
  margin-bottom: 24px;
}
.k18-modal-actions { display: flex; gap: 10px; justify-content: center; }
.k18-modal-cta {
  appearance: none;
  height: 48px;
  padding: 0 24px;
  border-radius: var(--r-sm);
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  transition: filter .2s, transform .2s var(--ease);
}
.k18-modal-cta.green  { background: linear-gradient(180deg,var(--green-soft),var(--green-deep)); color:#052e16; }
.k18-modal-cta.yellow { background: var(--orange); color:#fff; }
.k18-modal-cta.red    { background: var(--red); color:#fff; }
.k18-modal-cta.blue   { background: var(--blue); color:#fff; }
.k18-modal-cta:hover  { filter: brightness(1.08); transform: translateY(-1px); }
.k18-modal-close-btn {
  appearance: none;
  height: 48px;
  padding: 0 20px;
  border-radius: var(--r-sm);
  background: var(--glass);
  border: 1px solid var(--border-2);
  color: var(--text-3);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.k18-modal-close-btn:hover { background: var(--glass-2); color: var(--text); }

/* Toast bar */
.k18-toast-bar {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  width: min(520px, calc(100% - 32px));
  background: rgba(10,10,10,.95);
  border: 1px solid var(--border-3);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 14px 18px;
  display: none;
  gap: 12px;
  align-items: flex-start;
  z-index: 9999;
  backdrop-filter: var(--blur-2);
  -webkit-backdrop-filter: var(--blur-2);
}
.k18-toast-bar.show { display: flex; }
.k18-toast-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--r-full);
  background: var(--green-soft);
  box-shadow: 0 0 0 6px rgba(52,211,153,.12);
  margin-top: 5px;
  flex-shrink: 0;
}
.k18-toast-bar.bad .k18-toast-dot {
  background: var(--red);
  box-shadow: 0 0 0 6px rgba(248,113,113,.12);
}
.k18-toast-bar h4 {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
}
.k18-toast-bar p {
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.4;
}

/* ════════════════════════════════════════════════════════════
   LOGIN / SIGNUP PAGE
   ════════════════════════════════════════════════════════════ */
#krew18-login {
  font-family: var(--font-body);
  color: var(--text-2);
  width: 100%;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  padding: 48px 18px 64px;
  -webkit-font-smoothing: antialiased;
}
#krew18-login::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(34,197,94,.10), transparent 60%),
    var(--bg);
  z-index: 0;
}
#krew18-login::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}

.k18l-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  min-height: calc(100vh - 112px);
}

/* Brand block */
.k18l-brand {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.k18l-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.k18l-mark {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(52,211,153,.20), rgba(52,211,153,.04));
  border: 1px solid rgba(52,211,153,.35);
  box-shadow: 0 8px 24px rgba(34,197,94,.12);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.k18l-logo-text {
  font-family: var(--font-logo);
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: .01em;
}
.k18l-h1 {
  font-family: var(--font-head);
  font-size: clamp(32px, 5vw, 44px);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1.02;
  color: var(--text);
}
.k18l-sub {
  font-size: 15px;
  color: var(--text-3);
  max-width: 340px;
  line-height: 1.6;
}

/* Login card */
.k18l-card {
  width: min(560px, 100%);
  background: linear-gradient(180deg, var(--glass-2), var(--glass));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  padding: 20px;
  position: relative;
}
.k18l-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-lg);
  background: radial-gradient(600px 240px at 50% 0%, rgba(34,197,94,.09), transparent 60%);
  pointer-events: none;
}
.k18l-cin {
  position: relative;
  background: rgba(0,0,0,.30);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 24px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

/* Segment toggle */
.k18l-toggle-row {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 20px;
}
.k18l-toggle-label {
  font-size: 12px;
  color: var(--text-4);
  font-weight: 500;
  flex-shrink: 0;
}
.k18l-seg {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 4px;
  gap: 4px;
}
.k18l-seg button {
  appearance: none;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-3);
  padding: 10px 12px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 14px;
  font-family: var(--font-body);
  cursor: pointer;
  white-space: nowrap;
  min-height: 48px;
  line-height: 1.2;
  transition: all .25s var(--ease);
}
.k18l-seg button.active {
  color: var(--green-soft);
  border-color: rgba(52,211,153,.45);
  background: rgba(52,211,153,.09);
  box-shadow: 0 4px 16px rgba(34,197,94,.10);
}

/* Login tabs (sign in vs join) */
.k18l-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 20px;
}
.k18l-tab {
  flex: 1;
  height: 48px;
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--text-3);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all .25s var(--ease);
}
.k18l-tab.active {
  background: rgba(52,211,153,.09);
  border-color: rgba(52,211,153,.35);
  color: var(--green-soft);
}

/* Input fields in login/signup */
.k18l-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}
.k18l-field label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-3);
}
.k18l-ctrl { position: relative; }
.k18l-ctrl svg {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  opacity: .45;
  pointer-events: none;
  z-index: 2;
}
.k18l-ctrl input,
.k18l-ctrl select,
.k18l-ctrl textarea {
  appearance: none;
  -webkit-appearance: none;
  width: 100% !important;
  display: block;
  height: 56px;
  min-height: 56px;
  padding: 0 14px 0 42px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 400;
  outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.k18l-ctrl input:focus,
.k18l-ctrl select:focus {
  border-color: var(--green-soft);
  box-shadow: 0 0 0 4px rgba(52,211,153,.12);
  background: rgba(255,255,255,.06);
}
.k18l-ctrl input::placeholder { color: var(--text-4); opacity: 1; }
.k18l-ctrl select option { background: var(--bg-soft); }

.k18l-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.k18l-full { grid-column: 1 / -1; }
@media (max-width:560px) { .k18l-grid { grid-template-columns: 1fr; } }

/* Location chips in signup */
.k18l-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
}
.k18l-chip {
  padding: 7px 14px;
  border-radius: var(--r-full);
  border: 1px solid var(--border-2);
  background: rgba(255,255,255,.03);
  color: var(--text-3);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s var(--ease);
  user-select: none;
}
.k18l-chip[data-on="1"] {
  border-color: rgba(52,211,153,.50);
  background: rgba(52,211,153,.09);
  color: var(--green-soft);
}

/* Checkbox in signup */
.k18l-check {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  margin-bottom: 12px;
}
.k18l-check input[type=checkbox] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  margin-top: 2px;
  accent-color: var(--green);
  flex-shrink: 0;
}
.k18l-check p, .k18l-check span {
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.4;
}
.k18l-check a { color: var(--green-soft); text-decoration: none; font-weight: 600; }

/* Remember me row */
.k18l-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 12px 0 16px;
}
.k18l-chk {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-3);
  cursor: pointer;
}
.k18l-chk input[type=checkbox] {
  width: 16px !important;
  height: 16px !important;
  min-height: 16px !important;
  accent-color: var(--green);
  flex-shrink: 0;
}
.k18l-fp {
  color: var(--green-soft);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: color .2s;
}
.k18l-fp:hover { color: var(--green-hover); }

/* Hint */
.k18l-hint { font-size: 12px; color: var(--text-4); margin-top: 4px; }

/* Buttons */
.k18l-primary {
  appearance: none;
  width: 100%;
  height: 56px;
  border-radius: var(--r-sm);
  border: 1px solid rgba(52,211,153,.30);
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--shadow-glow), inset 0 1px 0 rgba(255,255,255,.15);
  transition: transform .3s var(--ease), filter .2s, box-shadow .3s var(--ease);
  margin-top: 16px;
  display: block;
}
.k18l-primary:hover {
  filter: brightness(1.06);
  transform: translateY(-2px);
  box-shadow: 0 16px 48px rgba(34,197,94,.28), inset 0 1px 0 rgba(255,255,255,.15);
}
.k18l-primary:active { transform: scale(.98); }
.k18l-primary:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.k18l-secondary {
  appearance: none;
  width: 100%;
  height: 52px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border-2);
  background: var(--glass);
  color: var(--text-2);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, color .2s;
}
.k18l-secondary:hover { background: var(--glass-2); color: var(--text); }

/* Errors / messages */
.k18l-err {
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(248,113,113,.08);
  border: 1px solid rgba(248,113,113,.18);
  color: var(--red);
  font-size: 13px;
  line-height: 1.4;
  display: none;
  margin-top: 8px;
}
.k18l-ok {
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(52,211,153,.08);
  border: 1px solid rgba(52,211,153,.20);
  color: var(--green-soft);
  font-size: 13px;
  line-height: 1.4;
  margin-top: 8px;
}
.k18l-foot {
  text-align: center;
  font-size: 14px;
  color: var(--text-3);
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}
.k18l-link {
  color: var(--green-soft);
  font-weight: 600;
  text-decoration: none;
}
.k18l-link:hover { color: var(--green-hover); }

/* Forgot password */
.k18l-fp-back {
  appearance: none;
  background: transparent;
  border: none;
  color: var(--text-4);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 16px;
  transition: color .2s;
}
.k18l-fp-back:hover { color: var(--green-soft); }

@media (max-width:600px) {
  #krew18-login { padding: 28px 14px 48px; }
  .k18l-h1 { font-size: 32px; }
  .k18l-cin { padding: 16px; }
}

/* ════════════════════════════════════════════════════════════
   DASHBOARD SHELL
   ════════════════════════════════════════════════════════════ */
.k18d-wrap {
  font-family: var(--font-body);
  color: var(--text-2);
  width: 100%;
  min-height: 100vh;
  position: relative;
  -webkit-font-smoothing: antialiased;
  background: var(--bg);
}
.k18d-wrap::before {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse 70% 45% at 50% 0%, rgba(34,197,94,.07), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
.k18d-wrap::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}
.k18d-wrap * { box-sizing: border-box; }
.k18d-in {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 24px 96px;
}

/* ── Dashboard top bar ── */
.k18d-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 24px;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.k18d-top::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07) 40%, rgba(255,255,255,.07) 60%, transparent);
}
.k18d-user { display: flex; align-items: center; gap: 14px; }
.k18d-av {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(52,211,153,.25), rgba(52,211,153,.05));
  border: 1.5px solid rgba(52,211,153,.30);
  display: grid;
  place-items: center;
  font-family: var(--font-head);
  font-size: 18px;
  font-weight: 800;
  color: var(--green-soft);
  flex-shrink: 0;
  overflow: hidden;
}
.k18d-av img { width: 100%; height: 100%; object-fit: cover; }
.k18d-nm {
  font-family: var(--font-head);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
  margin-bottom: 2px;
}
.k18d-ds { font-size: 13px; color: var(--text-3); }
.k18d-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

/* Verified badge */
.k18d-vbadge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: var(--bg);
  background: var(--green-soft);
  border-radius: var(--r-full);
  padding: 3px 9px;
  margin-left: 8px;
}

/* Credits pill */
.k18d-cpill {
  background: rgba(52,211,153,.07);
  border: 1px solid rgba(52,211,153,.18);
  border-radius: var(--r-md);
  padding: 10px 18px;
  text-align: center;
  min-width: 120px;
}
.k18d-cnum {
  font-family: var(--font-head);
  font-size: 28px;
  font-weight: 800;
  color: var(--green-soft);
  line-height: 1;
  letter-spacing: -.02em;
}
.k18d-clbl {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-4);
  margin: 3px 0 8px;
}
.k18d-bln {
  display: inline-block;
  border: 1px solid rgba(52,211,153,.30);
  background: rgba(52,211,153,.08);
  color: var(--green-soft);
  font-weight: 700;
  font-size: 11px;
  padding: 4px 12px;
  border-radius: var(--r-full);
  text-decoration: none;
  transition: background .2s;
}
.k18d-bln:hover { background: rgba(52,211,153,.15); }

/* Logout */
.k18d-lo {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  appearance: none;
  background: var(--glass);
  border: 1px solid var(--border-2);
  color: var(--text-4);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-body);
  padding: 8px 16px;
  border-radius: var(--r-full);
  cursor: pointer;
  text-decoration: none;
  transition: all .2s;
}
.k18d-lo:hover { border-color: rgba(248,113,113,.30); color: var(--red); }

/* Low credit warning */
.k18d-low-credits {
  background: rgba(245,158,11,.07);
  border: 1px solid rgba(245,158,11,.20);
  border-radius: var(--r-md);
  padding: 12px 18px;
  font-size: 14px;
  color: var(--orange);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ── Tabs ── */
.k18d-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 20px;
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 5px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.k18d-tabs::-webkit-scrollbar { display: none; }
.k18d-tab {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  color: var(--text-4);
  font-weight: 600;
  font-size: 13px;
  font-family: var(--font-body);
  padding: 10px 18px;
  border-radius: 12px;
  cursor: pointer;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: all .25s var(--ease);
  line-height: 1;
}
.k18d-tab:hover { color: var(--text-2); background: rgba(255,255,255,.04); }
.k18d-tab.on {
  color: var(--green-soft);
  background: rgba(52,211,153,.09);
  border-color: rgba(52,211,153,.22);
  box-shadow: 0 2px 12px rgba(34,197,94,.08);
}
.k18d-cnt {
  background: rgba(52,211,153,.15);
  color: var(--green-soft);
  border-radius: var(--r-full);
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 800;
}
.k18d-cnt-red {
  background: rgba(248,113,113,.15);
  color: var(--red);
  border-radius: var(--r-full);
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 800;
}

/* Panels */
.k18d-panel { display: none; }
.k18d-panel.on { display: block; }

/* ── Dashboard cards ── */
.k18d-card {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  margin-bottom: 16px;
  position: relative;
  overflow: hidden;
}
.k18d-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.06) 40%, rgba(255,255,255,.06) 60%, transparent);
}
.k18d-ch {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.k18d-ch h3, .k18d-ch h4 {
  font-family: var(--font-head);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
  margin: 0;
}

/* Edit forms inside cards */
.k18d-eg {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.k18d-ef { display: flex; flex-direction: column; gap: 7px; }
.k18d-eff { grid-column: 1 / -1; }
.k18d-ef label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-4);
}
.k18d-ef input,
.k18d-ef select,
.k18d-ef textarea {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 48px;
  border-radius: 12px;
  border: 1px solid var(--border-2);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-size: 14px;
  font-family: var(--font-body);
  padding: 0 14px;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.k18d-ef input:focus, .k18d-ef select:focus, .k18d-ef textarea:focus {
  border-color: rgba(52,211,153,.45);
  box-shadow: 0 0 0 3px rgba(52,211,153,.09);
}
.k18d-ef textarea { height: auto; padding: 12px 14px; resize: vertical; }
.k18d-ef select option { background: var(--bg-soft); color: var(--text); }
.k18d-ea { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; align-items: center; }
.k18d-sb {
  height: 48px;
  padding: 0 22px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  font-weight: 700;
  font-size: 14px;
  font-family: var(--font-body);
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  box-shadow: 0 6px 20px rgba(34,197,94,.18);
  transition: filter .2s, transform .25s var(--ease);
}
.k18d-sb:hover { filter: brightness(1.06); transform: translateY(-1px); }
.k18d-sb:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.k18d-cb {
  height: 48px;
  padding: 0 18px;
  border-radius: 14px;
  background: var(--glass);
  border: 1px solid var(--border-2);
  color: var(--text-3);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--font-body);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.k18d-cb:hover { background: var(--glass-2); color: var(--text); }
.k18d-save-status { font-size: 13px; font-weight: 600; }

/* Small edit button */
.k18d-eb {
  appearance: none;
  height: 36px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid rgba(52,211,153,.22);
  background: rgba(52,211,153,.06);
  color: var(--green-soft);
  font-weight: 700;
  font-size: 12px;
  font-family: var(--font-body);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background .2s;
}
.k18d-eb:hover { background: rgba(52,211,153,.12); }

/* Section heading */
.k18d-ph { margin-bottom: 14px; }
.k18d-ph h3 {
  font-family: var(--font-head);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
  letter-spacing: -.01em;
}
.k18d-ph p { font-size: 13px; color: var(--text-3); }

/* Filter bar */
.k18d-fb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 14px 18px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: 16px;
}
.k18d-fi, .k18d-fs {
  appearance: none;
  -webkit-appearance: none;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-2);
  border-radius: 10px;
  color: var(--text);
  font-size: 13px;
  font-family: var(--font-body);
  padding: 0 14px;
  height: 42px;
  outline: none;
  transition: border-color .2s;
}
.k18d-fi:focus, .k18d-fs:focus { border-color: rgba(52,211,153,.40); }
.k18d-fi::placeholder { color: var(--text-4); }
.k18d-fs option { background: var(--bg-soft); }
.k18d-fw { flex: 1; min-width: 150px; }
.k18d-fbt {
  appearance: none;
  border-radius: 10px;
  font-weight: 700;
  font-size: 13px;
  font-family: var(--font-body);
  cursor: pointer;
  padding: 0 16px;
  height: 42px;
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  border: none;
  transition: filter .2s;
}
.k18d-fbt:hover { filter: brightness(1.06); }
.k18d-rbt {
  appearance: none;
  border-radius: 10px;
  font-weight: 600;
  font-size: 13px;
  font-family: var(--font-body);
  cursor: pointer;
  padding: 0 14px;
  height: 42px;
  background: var(--glass);
  color: var(--text-3);
  border: 1px solid var(--border-2);
  transition: background .2s;
}
.k18d-rbt:hover { background: var(--glass-2); }

/* ════════════════════════════════════════════════════════════
   TALENT CARDS — PUBLIC INFO VISIBLE, CONTACT LOCKED
   ════════════════════════════════════════════════════════════ */
.k18d-tg {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
@media(min-width:520px) { .k18d-tg { grid-template-columns: repeat(2,1fr); } }
@media(min-width:960px) { .k18d-tg { grid-template-columns: repeat(3,1fr); } }

.k18d-tc {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition:
    transform .35s var(--ease),
    border-color .25s,
    box-shadow .35s var(--ease);
  position: relative;
  overflow: hidden;
}
.k18d-tc::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.05) 40%, rgba(255,255,255,.05) 60%, transparent);
}
.k18d-tc:hover {
  transform: translateY(-5px);
  border-color: rgba(52,211,153,.20);
  box-shadow: 0 20px 60px rgba(0,0,0,.45), 0 0 0 1px rgba(52,211,153,.06);
}
.k18d-tc.ulk {
  border-color: rgba(52,211,153,.25);
  background: linear-gradient(180deg, rgba(52,211,153,.04), rgba(52,211,153,.01));
}

/* Card head */
.k18d-tt {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

/* Name — always visible but masked when locked */
.k18d-tnm {
  font-family: var(--font-head);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
  margin-top: 2px;
}
.k18d-tnm.masked {
  filter: blur(6px);
  user-select: none;
  color: rgba(255,255,255,.3);
}

/* Designation — always visible */
.k18d-tds { font-size: 13px; color: var(--text-3); margin-top: 2px; }

/* Niche badge */
.k18d-ntag {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 10px;
  border-radius: var(--r-full);
  flex-shrink: 0;
}
.ns { background: rgba(96,165,250,.12); color: var(--blue); border: 1px solid rgba(96,165,250,.20); }
.no { background: rgba(245,158,11,.10); color: var(--orange); border: 1px solid rgba(245,158,11,.18); }
.nm { background: rgba(167,139,250,.10); color: var(--purple); border: 1px solid rgba(167,139,250,.16); }
.nn { background: rgba(52,211,153,.09); color: var(--green-soft); border: 1px solid rgba(52,211,153,.18); }
.k18d-ltag {
  font-size: 10px;
  color: var(--green-soft);
  background: rgba(52,211,153,.08);
  border: 1px solid rgba(52,211,153,.18);
  border-radius: var(--r-full);
  padding: 2px 8px;
}

/* Tags row */
.k18d-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.k18d-tag {
  font-size: 12px;
  color: var(--text-3);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: 4px 10px;
}

/* Public description section — the KEY fix from user feedback */
.k18d-pub-info {
  background: rgba(255,255,255,.02);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.k18d-pub-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
}
.k18d-pub-label {
  color: var(--text-4);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 10px;
  min-width: 80px;
  margin-top: 1px;
}
.k18d-pub-value { color: var(--text-2); flex: 1; }

/* Bottom CTC / status row */
.k18d-tbot {
  border-top: 1px solid var(--border);
  padding-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.k18d-tctc {
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  color: var(--green-soft);
}
.k18d-tnt { font-size: 11px; color: var(--text-4); }

/* Unlock button */
.k18d-ulk-btn {
  appearance: none;
  width: 100%;
  border-radius: 12px;
  height: 44px;
  font-size: 13px;
  font-weight: 700;
  font-family: var(--font-body);
  cursor: pointer;
  border: 1px solid rgba(52,211,153,.25);
  background: rgba(52,211,153,.07);
  color: var(--green-soft);
  transition: background .2s, transform .2s var(--ease), box-shadow .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.k18d-ulk-btn:hover {
  background: rgba(52,211,153,.13);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(34,197,94,.15);
}
.k18d-ulk-btn:disabled { opacity: .45; cursor: not-allowed; transform: none; }

/* Unlocked contact reveal */
.k18d-contact-reveal {
  background: rgba(52,211,153,.05);
  border: 1px solid rgba(52,211,153,.16);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.k18d-contact-reveal a {
  color: var(--green-soft);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.k18d-contact-reveal a:hover { text-decoration: underline; }

/* Shortlist star */
.k18-sl-star {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 18px;
  color: rgba(255,255,255,.18);
  padding: 2px;
  line-height: 1;
  transition: color .2s, transform .2s;
  flex-shrink: 0;
}
.k18-sl-star:hover { color: #fbbf24; transform: scale(1.15); }
.k18-sl-star.on { color: #fbbf24; }

/* Profile score bar */
.k18-pbar {
  height: 3px;
  background: rgba(255,255,255,.06);
  border-radius: var(--r-full);
  overflow: hidden;
}
.k18-pfill {
  height: 100%;
  background: linear-gradient(90deg, var(--green-soft), var(--green));
  border-radius: var(--r-full);
  transition: width .5s var(--ease);
}

/* View full profile button */
.k18d-view-btn {
  appearance: none;
  width: 100%;
  border-radius: 12px;
  height: 40px;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-body);
  cursor: pointer;
  border: 1px solid var(--border-2);
  background: var(--glass);
  color: var(--text-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: background .2s, color .2s;
}
.k18d-view-btn:hover { background: var(--glass-2); color: var(--text); }

/* ════════════════════════════════════════════════════════════
   JOB CARDS
   ════════════════════════════════════════════════════════════ */
.k18d-jg {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 16px;
}
@media(min-width:580px) { .k18d-jg { grid-template-columns: repeat(2,1fr); } }
@media(min-width:960px) { .k18d-jg { grid-template-columns: repeat(3,1fr); } }

.k18d-jc {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform .35s var(--ease), border-color .25s, box-shadow .35s var(--ease);
  position: relative;
  overflow: hidden;
}
.k18d-jc::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.05) 40%, rgba(255,255,255,.05) 60%, transparent);
}
.k18d-jc:hover {
  transform: translateY(-4px);
  border-color: rgba(52,211,153,.18);
  box-shadow: 0 16px 50px rgba(0,0,0,.45);
}
.k18d-jc.hi {
  border-color: rgba(52,211,153,.22);
  background: linear-gradient(180deg, rgba(52,211,153,.04), rgba(52,211,153,.01));
}
.k18d-jct { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.k18d-jcn {
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.01em;
  line-height: 1.3;
}
.k18d-jctype {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-3);
  background: var(--glass-2);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: 3px 9px;
  flex-shrink: 0;
}
.k18d-jctitle { font-size: 12px; color: var(--text-4); margin-top: 3px; }
.k18d-jbot {
  border-top: 1px solid var(--border);
  padding-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.k18d-jbudget {
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 700;
  color: var(--green-soft);
}
.k18d-jurg { font-size: 11px; color: var(--text-4); }
.k18d-vbadge-sm {
  font-size: 10px;
  color: var(--green-soft);
  background: rgba(52,211,153,.09);
  border: 1px solid rgba(52,211,153,.18);
  border-radius: var(--r-full);
  padding: 2px 7px;
  margin-left: 5px;
}

/* ════════════════════════════════════════════════════════════
   JOBS LIST (company posted jobs)
   ════════════════════════════════════════════════════════════ */
.k18d-jlist { display: flex; flex-direction: column; gap: 10px; }
.k18d-job-row {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  transition: border-color .2s;
}
.k18d-job-row:hover { border-color: var(--border-2); }
.k18d-job-row.paused { opacity: .50; }
.k18d-jri { flex: 1; min-width: 0; }
.k18d-jr-title {
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.k18d-jr-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.k18d-jr-acts { display: flex; gap: 8px; align-items: center; flex-shrink: 0; flex-wrap: wrap; }
.k18d-jr-btn {
  appearance: none;
  height: 34px;
  padding: 0 14px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  border: 1px solid var(--border-2);
  background: var(--glass);
  color: var(--text-3);
  transition: background .2s, color .2s;
}
.k18d-jr-btn:hover { background: var(--glass-2); color: var(--text); }
.k18d-add-btn {
  appearance: none;
  height: 36px;
  padding: 0 16px;
  border-radius: 10px;
  border: 1px solid rgba(52,211,153,.22);
  background: rgba(52,211,153,.07);
  color: var(--green-soft);
  font-weight: 700;
  font-size: 12px;
  font-family: var(--font-body);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background .2s;
}
.k18d-add-btn:hover { background: rgba(52,211,153,.13); }

/* ════════════════════════════════════════════════════════════
   RESUME PANEL
   ════════════════════════════════════════════════════════════ */
.k18d-rrow {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  background: rgba(52,211,153,.04);
  border: 1px solid rgba(52,211,153,.14);
  border-radius: var(--r-md);
  margin-bottom: 16px;
}
.k18d-dlb {
  background: rgba(52,211,153,.08);
  border: 1px solid rgba(52,211,153,.20);
  color: var(--green-soft);
  font-weight: 700;
  font-size: 12px;
  padding: 8px 14px;
  border-radius: 10px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  transition: background .2s;
}
.k18d-dlb:hover { background: rgba(52,211,153,.15); }
.k18d-drop {
  border: 2px dashed var(--border-2);
  border-radius: var(--r-md);
  padding: 28px;
  text-align: center;
  cursor: pointer;
  transition: all .2s;
  margin-bottom: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.k18d-drop:hover { border-color: rgba(52,211,153,.35); background: rgba(52,211,153,.03); }
.k18d-tips {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 18px;
  margin-top: 16px;
}
.k18d-tips strong {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-4);
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-bottom: 10px;
}
.k18d-tips ul { list-style: none; display: flex; flex-direction: column; gap: 6px; padding: 0; }
.k18d-tips li {
  font-size: 13px;
  color: var(--text-3);
  padding-left: 16px;
  position: relative;
}
.k18d-tips li::before { content: '✓'; position: absolute; left: 0; color: var(--green-soft); font-size: 11px; }

/* ════════════════════════════════════════════════════════════
   CREDITS / BUY PAGE
   ════════════════════════════════════════════════════════════ */
.k18d-pkgs {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 16px;
  margin-bottom: 24px;
}
@media(min-width:700px) { .k18d-pkgs { grid-template-columns: repeat(4,1fr); } }

.k18d-pkg {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px 16px;
  text-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: transform .35s var(--ease), border-color .25s, box-shadow .35s var(--ease);
  overflow: hidden;
}
.k18d-pkg::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.06), transparent);
}
.k18d-pkg:hover {
  transform: translateY(-5px);
  border-color: rgba(52,211,153,.25);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
}
.k18d-pkg-pop {
  border-color: rgba(52,211,153,.28);
  background: linear-gradient(180deg, rgba(52,211,153,.06), rgba(52,211,153,.01));
}
.k18d-pkg-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  font-size: 10px;
  font-weight: 800;
  padding: 4px 14px;
  border-radius: var(--r-full);
  white-space: nowrap;
}
.k18d-pkg-nm {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-4);
}
.k18d-pkg-cr {
  font-family: var(--font-head);
  font-size: 40px;
  font-weight: 800;
  color: var(--green-soft);
  line-height: 1;
  letter-spacing: -.02em;
}
.k18d-pkg-cr span { font-size: 13px; color: var(--text-4); font-weight: 500; }
.k18d-pkg-pr {
  font-family: var(--font-head);
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.01em;
}
.k18d-pkg-pp { font-size: 11px; color: var(--text-4); }
.k18d-buy-btn {
  appearance: none;
  width: 100%;
  margin-top: 6px;
  border-radius: 14px;
  height: 48px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font-body);
  cursor: pointer;
  border: 1px solid rgba(52,211,153,.28);
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  transition: filter .2s, transform .2s var(--ease);
}
.k18d-buy-btn:hover { filter: brightness(1.06); transform: translateY(-1px); }

/* Payment gateway selector */
.k18-gw-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.k18-gw-tab {
  height: 40px;
  padding: 0 16px;
  border: 1px solid var(--border-2);
  border-radius: 10px;
  background: var(--glass);
  color: var(--text-3);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  transition: all .2s;
}
.k18-gw-tab.active {
  border-color: rgba(52,211,153,.35);
  background: rgba(52,211,153,.08);
  color: var(--green-soft);
}

/* Transaction table */
.k18-txn {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.k18-txn th {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-4);
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
.k18-txn td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text-2);
}
.k18-txn tr:last-child td { border-bottom: none; }

/* Status badges */
.k18d-ok  { padding: 12px 16px; border-radius: 12px; background: rgba(52,211,153,.07); border: 1px solid rgba(52,211,153,.18); color: var(--green-soft); font-size: 13px; }
.k18d-err { padding: 12px 16px; border-radius: 12px; background: rgba(248,113,113,.07); border: 1px solid rgba(248,113,113,.18); color: var(--red); font-size: 13px; }

/* ════════════════════════════════════════════════════════════
   PROFILE COMPLETENESS
   ════════════════════════════════════════════════════════════ */
.k18-complete-bar {
  height: 5px;
  background: rgba(255,255,255,.06);
  border-radius: var(--r-full);
  overflow: hidden;
  max-width: 220px;
  margin: 6px 0 3px;
}
.k18-complete-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--green-soft), var(--green));
  border-radius: var(--r-full);
  transition: width .6s var(--ease);
}
.k18-complete-score { font-size: 12px; color: var(--text-4); }

/* ════════════════════════════════════════════════════════════
   NOTIFICATION BELL
   ════════════════════════════════════════════════════════════ */
.k18-nbell {
  position: relative;
  cursor: pointer;
  font-size: 20px;
  padding: 8px 10px;
  border-radius: 12px;
  transition: background .2s;
}
.k18-nbell:hover { background: var(--glass-2); }
.k18-ndot {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: var(--red);
  color: #fff;
  border-radius: var(--r-full);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}
.k18-npanel {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 300px;
  background: rgba(10,10,10,.97);
  border: 1px solid var(--border-3);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  z-index: 1000;
  overflow: hidden;
  backdrop-filter: var(--blur-2);
  -webkit-backdrop-filter: var(--blur-2);
}
.k18-npanel.open { display: block; }
.k18-nitem { padding: 12px 16px; border-bottom: 1px solid var(--border); }
.k18-nitem:last-child { border-bottom: none; }
.k18-nitem.unread { background: rgba(52,211,153,.05); }
.k18-nmsg  { font-size: 13px; color: var(--text-2); line-height: 1.4; }
.k18-ntime { font-size: 11px; color: var(--text-4); margin-top: 4px; }

/* ════════════════════════════════════════════════════════════
   SHORTLIST
   ════════════════════════════════════════════════════════════ */
.k18-sl-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 16px; }
.k18-sl-card {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px;
}
.k18-sl-head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.k18-sl-av {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(52,211,153,.10);
  color: var(--green-soft);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head);
  font-weight: 800; font-size: 15px; flex-shrink: 0;
}
.k18-sl-nm { font-family: var(--font-head); font-weight: 700; font-size: 14px; color: var(--text); }
.k18-sl-rl { font-size: 12px; color: var(--text-3); }
.k18-sl-meta { display: flex; gap: 8px; flex-wrap: wrap; font-size: 11px; color: var(--text-4); margin-bottom: 10px; }
.k18-sl-note-input {
  width: 100%;
  border-radius: 10px;
  border: 1px solid var(--border-2);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font-body);
  padding: 10px 12px;
  resize: vertical;
  outline: none;
}
.k18-sl-note-input:focus { border-color: rgba(52,211,153,.40); }

/* ════════════════════════════════════════════════════════════
   PHONE CONSENT CARDS
   ════════════════════════════════════════════════════════════ */
.k18-consent-list { display: flex; flex-direction: column; gap: 12px; }
.k18-consent-card {
  background: rgba(245,158,11,.04);
  border: 1px solid rgba(245,158,11,.16);
  border-radius: var(--r-md);
  padding: 16px 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.k18-consent-nm { font-family: var(--font-head); font-weight: 700; font-size: 15px; color: var(--text); }
.k18-consent-meta, .k18-consent-job { font-size: 13px; color: var(--text-3); margin-top: 2px; }
.k18-consent-acts { display: flex; gap: 8px; flex-shrink: 0; }
.k18-capprove {
  height: 36px; padding: 0 16px; border-radius: 10px;
  background: rgba(52,211,153,.10); border: 1px solid rgba(52,211,153,.28);
  color: var(--green-soft); font-family: var(--font-body); font-size: 13px;
  font-weight: 700; cursor: pointer; transition: background .2s;
  appearance: none;
}
.k18-capprove:hover { background: rgba(52,211,153,.18); }
.k18-cdeny {
  height: 36px; padding: 0 16px; border-radius: 10px;
  background: rgba(248,113,113,.08); border: 1px solid rgba(248,113,113,.20);
  color: var(--red); font-family: var(--font-body); font-size: 13px;
  font-weight: 700; cursor: pointer; transition: background .2s;
  appearance: none;
}
.k18-cdeny:hover { background: rgba(248,113,113,.15); }

/* ════════════════════════════════════════════════════════════
   REFERRAL
   ════════════════════════════════════════════════════════════ */
.k18-ref-box {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 18px;
  margin-top: 18px;
}
.k18-ref-row { display: flex; gap: 8px; margin-top: 10px; }
.k18-ref-input {
  flex: 1;
  height: 42px;
  padding: 0 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-2);
  border-radius: 10px;
  color: var(--text-3);
  font-size: 13px;
  font-family: var(--font-body);
  outline: none;
}

/* ════════════════════════════════════════════════════════════
   PRICING PAGE (public)
   ════════════════════════════════════════════════════════════ */
.k18-pricing-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 64px 24px;
}
.k18-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  margin: 48px 0;
}
.k18-plan-card {
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: transform .35s var(--ease), border-color .25s, box-shadow .35s var(--ease);
  overflow: hidden;
}
.k18-plan-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent);
}
.k18-plan-card:hover {
  transform: translateY(-6px);
  border-color: rgba(52,211,153,.22);
  box-shadow: 0 24px 80px rgba(0,0,0,.50);
}
.k18-plan-card.featured {
  border-color: rgba(52,211,153,.30);
  background: linear-gradient(180deg, rgba(52,211,153,.06), rgba(52,211,153,.01));
  box-shadow: 0 8px 40px rgba(34,197,94,.12);
}
.k18-plan-badge {
  position: absolute;
  top: -14px; left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep));
  color: #052e16;
  font-size: 11px;
  font-weight: 800;
  padding: 5px 16px;
  border-radius: var(--r-full);
  white-space: nowrap;
  letter-spacing: .02em;
}
.k18-plan-name {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-4);
}
.k18-plan-price {
  font-family: var(--font-head);
  font-size: 48px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.03em;
  line-height: 1;
}
.k18-plan-price span { font-size: 18px; color: var(--text-3); font-weight: 500; }
.k18-plan-credits {
  font-size: 15px;
  color: var(--green-soft);
  font-weight: 700;
}
.k18-plan-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.k18-plan-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--text-3);
}
.k18-plan-features li::before {
  content: '✓';
  color: var(--green-soft);
  font-weight: 700;
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ════════════════════════════════════════════════════════════
   MOBILE BOTTOM NAVIGATION (glass dock)
   ════════════════════════════════════════════════════════════ */
.k18-mobile-nav {
  display: none;
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  background: rgba(10,10,10,.85);
  backdrop-filter: var(--blur-2);
  -webkit-backdrop-filter: var(--blur-2);
  border: 1px solid var(--border-2);
  border-radius: var(--r-xl);
  padding: 8px 12px;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.05);
}
.k18-mobile-nav-inner {
  display: flex;
  gap: 4px;
  align-items: center;
}
.k18-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 8px 14px;
  border-radius: 14px;
  cursor: pointer;
  border: none;
  background: transparent;
  color: var(--text-4);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s var(--ease), color .2s;
  min-width: 56px;
}
.k18-nav-item svg { width: 22px; height: 22px; }
.k18-nav-item.on {
  background: rgba(52,211,153,.12);
  color: var(--green-soft);
}
@media (max-width: 768px) { .k18-mobile-nav { display: block; } }

/* ════════════════════════════════════════════════════════════
   PAGER
   ════════════════════════════════════════════════════════════ */
.k18d-pager {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin: 12px 0 20px;
}
.k18d-pg-btn {
  appearance: none;
  padding: 7px 14px;
  border-radius: 10px;
  border: 1px solid var(--border-2);
  background: var(--glass);
  color: var(--text-3);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-body);
  transition: all .2s var(--ease);
}
.k18d-pg-btn:hover, .k18d-pg-btn.on {
  background: rgba(52,211,153,.09);
  border-color: rgba(52,211,153,.25);
  color: var(--green-soft);
}

/* ════════════════════════════════════════════════════════════
   SKELETON LOADERS
   ════════════════════════════════════════════════════════════ */
.k18d-skel {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.03) 25%,
    rgba(255,255,255,.06) 50%,
    rgba(255,255,255,.03) 75%
  );
  background-size: 400% 100%;
  animation: k18-shimmer 1.6s ease infinite;
  border-radius: var(--r-lg);
}
@keyframes k18-shimmer {
  0%   { background-position: 100% 50%; }
  100% { background-position:   0% 50%; }
}

/* ════════════════════════════════════════════════════════════
   EMPTY STATES
   ════════════════════════════════════════════════════════════ */
.k18d-emp {
  text-align: center;
  padding: 64px 24px;
  color: var(--text-4);
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.k18d-emp-icon { font-size: 40px; opacity: .4; }
.k18d-emp-title { font-family: var(--font-head); font-size: 18px; font-weight: 700; color: var(--text-3); }
.k18d-emp-sub { font-size: 14px; max-width: 300px; }
.k18d-ld {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 64px 24px;
  color: var(--text-4);
  grid-column: 1 / -1;
  font-size: 14px;
}

/* ════════════════════════════════════════════════════════════
   UTILITY
   ════════════════════════════════════════════════════════════ */
.k18-dn { display: none !important; }
input[type="file"].k18-file { display: none; }
.k18-upload-lbl {
  appearance: none;
  height: 40px;
  padding: 0 18px;
  border-radius: 10px;
  background: var(--glass);
  border: 1px solid var(--border-2);
  color: var(--text-3);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: background .2s, color .2s;
}
.k18-upload-lbl:hover { background: var(--glass-2); color: var(--text); }
.k18-photo-prev {
  width: 72px; height: 72px; border-radius: 50%;
  object-fit: cover; display: block; margin-bottom: 12px;
  border: 2px solid rgba(52,211,153,.28);
}
.k18-logo-prev {
  width: 72px; height: 72px; border-radius: 14px;
  object-fit: cover; display: block; margin-bottom: 12px;
}

/* Badges */
.k18-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  border-radius: var(--r-full);
  padding: 3px 9px;
  white-space: nowrap;
}
.k18-badge-green  { background: rgba(52,211,153,.12); color: var(--green-soft); border: 1px solid rgba(52,211,153,.20); }
.k18-badge-orange { background: rgba(245,158,11,.10); color: var(--orange);     border: 1px solid rgba(245,158,11,.18); }
.k18-badge-red    { background: rgba(248,113,113,.10); color: var(--red);       border: 1px solid rgba(248,113,113,.18); }
.k18-badge-blue   { background: rgba(96,165,250,.10);  color: var(--blue);      border: 1px solid rgba(96,165,250,.18); }
.k18-badge-purple { background: rgba(167,139,250,.10); color: var(--purple);    border: 1px solid rgba(167,139,250,.18); }

/* ════════════════════════════════════════════════════════════
   JOB MATCH MODAL
   ════════════════════════════════════════════════════════════ */
#k18-jmatch-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.75);
  z-index: 9999;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 48px 16px;
  overflow-y: auto;
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
}
#k18-jmatch-modal.open { display: flex; }
.k18-jm-inner {
  background: rgba(8,8,8,.98);
  border: 1px solid var(--border-2);
  border-radius: var(--r-xl);
  width: 100%;
  max-width: 960px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.k18-jm-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-head);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.k18-jm-close {
  appearance: none;
  background: var(--glass-2);
  border: 1px solid var(--border-2);
  color: var(--text-3);
  width: 32px; height: 32px;
  border-radius: 10px;
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 16px;
}
.k18-jm-body { padding: 20px; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .k18d-in { padding: 16px 16px 96px; }
  .k18d-tabs { gap: 3px; padding: 4px; }
  .k18d-tab { padding: 9px 13px; font-size: 12px; }
  .k18d-eg { grid-template-columns: 1fr; }
  .k18d-pkgs { grid-template-columns: repeat(2,1fr); }
  .k18d-top { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
  .k18d-tab { padding: 8px 10px; font-size: 11px; }
  .k18-pricing-wrap { padding: 40px 16px; }
}

/* ════════════════════════════════════════════════════════════
   MOTION — respect prefers-reduced-motion
   ════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ════════════════════════════════════════════════════════════
   KREW18 — Missing Dashboard Components (v12 fix)
   All k18-dash-* and component classes
   ════════════════════════════════════════════════════════════ */

/* ── Wordmark (replaces bag icon) ── */
.k18l-logo { display:flex; align-items:center; justify-content:center; margin-bottom:8px; }
.k18l-wordmark {
  font-family: var(--font-logo);
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: 0.04em;
}

/* ── Dashboard top bar ── */
.k18-dash-top {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  background: var(--glass);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  padding: 16px 20px;
  margin-bottom: 14px;
  position: relative;
}
.k18-dash-top::after {
  content: "";
  position: absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg,transparent,rgba(34,197,94,.25),transparent);
  border-radius: var(--r) var(--r) 0 0;
}
.k18-dash-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--green-dim);
  border: 1.5px solid rgba(34,197,94,.28);
  display: grid; place-items: center;
  font-size: 18px; font-weight: 800;
  color: var(--green-soft);
  flex-shrink: 0;
  overflow: hidden;
}
.k18-dash-avatar img { width:100%; height:100%; object-fit:cover; }
.k18-dash-logo {
  width: 52px; height: 52px;
  border-radius: 12px;
  border: 1.5px solid var(--border-2);
  background: var(--bg-card);
  overflow: hidden;
  flex-shrink: 0;
}
.k18-dash-logo img { width:100%; height:100%; object-fit:contain; padding:2px; }
.k18-dash-logo span { font-size:20px; font-weight:800; color:var(--text-3); }
.k18-dash-meta { flex:1; min-width:0; }
.k18-dash-name {
  font-size: 16px; font-weight: 800;
  color: var(--text); line-height: 1.2;
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
.k18-dash-role { font-size:13px; color:var(--text-3); margin-top:2px; }
.k18-dash-credits { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-left:auto; }
.k18-dash-actions { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.k18-verified-badge {
  font-size:11px; font-weight:700;
  color: var(--green-soft);
  background: var(--green-dim);
  border: 1px solid rgba(34,197,94,.25);
  border-radius: 999px;
  padding: 2px 8px;
}

/* ── Profile completeness ── */
.k18-progress-bar {
  height:4px; background:var(--bg-elevated);
  border-radius:2px; overflow:hidden; margin-top:6px;
}
.k18-progress-fill {
  height:100%;
  background: linear-gradient(90deg, var(--green-deep), var(--green-soft));
  border-radius:2px;
  transition: width .4s ease;
}
.k18-alert {
  display:flex; align-items:flex-start; gap:10px;
  padding:12px 16px; border-radius:10px;
  font-size:13px; line-height:1.5;
  margin-bottom:14px;
}
.k18-alert-info    { background:rgba(96,165,250,.08); border:1px solid rgba(96,165,250,.18); color:#93c5fd; }
.k18-alert-success { background:var(--green-dim); border:1px solid rgba(34,197,94,.20); color:var(--green-soft); }
.k18-alert-warning { background:rgba(245,158,11,.08); border:1px solid rgba(245,158,11,.18); color:#fbbf24; }
.k18-alert-error   { background:rgba(248,113,113,.08); border:1px solid rgba(248,113,113,.18); color:#fca5a5; }

/* ── Credit pill ── */
.k18-credit-pill {
  display:inline-flex; align-items:center; gap:6px;
  background: var(--green-dim);
  border: 1px solid rgba(34,197,94,.18);
  border-radius: 999px;
  padding: 5px 12px;
  font-size:13px; font-weight:700; color:var(--green-soft);
}
.k18-credit-icon { font-size:14px; }
.k18-credit-val  { font-size:16px; font-weight:900; color:var(--green-soft); }
.k18-credit-lbl  { font-size:11px; color:var(--text-3); }

/* ── Buy credits button ── */
.k18-buy-credits-btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 14px; border-radius:999px;
  background:var(--green-dim);
  border:1px solid rgba(34,197,94,.25);
  color:var(--green-soft); font-weight:700; font-size:12px;
  text-decoration:none; cursor:pointer;
  transition:background .12s;
}
.k18-buy-credits-btn:hover { background:rgba(34,197,94,.14); }

/* ── Low credit warning ── */
.k18-low-credit {
  background:rgba(248,113,113,.08); border:1px solid rgba(248,113,113,.18);
  border-radius:10px; padding:10px 14px;
  font-size:13px; color:#fca5a5; margin-bottom:12px;
}
.k18-low-credit a { color:var(--green-soft); font-weight:700; }

/* ── Talent card grid ── */
.k18-talent-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(280px,1fr));
  gap:14px;
}

/* ── Logo preview in upload section ── */
.k18-logo-preview {
  width:80px; height:80px;
  object-fit:contain;
  border-radius:10px;
  border:1px solid var(--border-2);
  background:var(--bg-card);
  padding:4px;
  display:block;
}

/* ── Browse bar (recruiter search) ── */
.k18-browse-bar {
  display:flex; flex-wrap:wrap; gap:8px; align-items:center;
  padding:14px 16px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius: var(--r);
  margin-bottom:12px;
}
.k18-browse-sub { font-size:13px; color:var(--text-3); margin-bottom:12px; }

/* ── Auth heading ── */
.k18-auth-heading {
  font-size:22px; font-weight:800; color:var(--text);
  margin-bottom:16px;
}

/* ── Job form ── */
.k18-job-form-wrap {
  background:var(--glass); border:1px solid var(--border-2);
  border-radius:var(--r); padding:20px; margin-bottom:14px;
}
.k18-job-logo-ph {
  width:36px; height:36px;
  border-radius:8px;
  background:var(--bg-elevated);
  display:grid; place-items:center;
  font-size:14px; font-weight:800; color:var(--text-3);
  flex-shrink:0;
}

/* ── Shortlist grid ── */
.k18-shortlist-grid { display:flex; flex-direction:column; gap:10px; }
.k18-shortlist-card {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:14px 16px;
  display:flex; align-items:flex-start; gap:12px; flex-wrap:wrap;
}
.k18-sl-avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--green-dim); border:1px solid rgba(34,197,94,.18);
  display:grid; place-items:center;
  font-size:15px; font-weight:800; color:var(--green-soft);
  flex-shrink:0;
}
.k18-sl-head { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:3px; }
.k18-sl-name { font-size:14px; font-weight:700; color:var(--text); }
.k18-sl-role { font-size:12px; color:var(--text-3); }
.k18-sl-info { flex:1; min-width:0; }
.k18-sl-meta { display:flex; flex-wrap:wrap; gap:6px; margin-top:4px; }
.k18-sl-notes { width:100%; margin-top:8px; }
.k18-sl-notes-input {
  width:100%; background:var(--bg-elevated)!important;
  border:1px solid var(--border-2)!important;
  border-radius:8px!important; color:var(--text)!important;
  font-size:13px!important; padding:8px 10px!important;
  resize:vertical; min-height:60px;
}
.k18-sl-note-edit {
  font-size:12px; color:var(--green-soft); cursor:pointer;
  background:none; border:none; padding:0; font-family:inherit;
}

/* ── Unlocked contact ── */
.k18-unlocked-contact {
  background:var(--green-dim); border:1px solid rgba(34,197,94,.18);
  border-radius:9px; padding:10px 12px;
  font-size:13px; color:var(--green-soft); font-weight:600;
}
.k18-contact-item { display:flex; align-items:center; gap:6px; margin-bottom:4px; }

/* ── Copy row ── */
.k18-copy-row {
  display:flex; align-items:center; gap:8px;
  background:var(--bg-elevated); border:1px solid var(--border);
  border-radius:8px; padding:8px 12px;
  font-size:13px; color:var(--text-2);
}

/* ── Transaction table ── */
.k18-txn-table {
  width:100%; border-collapse:collapse;
  font-size:13px; color:var(--text-2);
}
.k18-txn-table th {
  text-align:left; font-size:11px; text-transform:uppercase;
  letter-spacing:.5px; color:var(--text-4); font-weight:700;
  padding:8px 12px; border-bottom:1px solid var(--border);
}
.k18-txn-table td { padding:10px 12px; border-bottom:1px solid var(--border); }

/* ── Resume / upload ── */
.k18-resume-icon {
  font-size:32px; margin-bottom:8px; display:block; text-align:center;
}
.k18-upload-section {
  background:var(--glass); border:2px dashed var(--border-2);
  border-radius:var(--r-sm); padding:24px; text-align:center;
  cursor:pointer; transition:border-color .15s;
}
.k18-upload-section:hover { border-color:rgba(34,197,94,.35); }

/* ── Tips box ── */
.k18-tips-box {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:14px; margin-top:12px;
}

/* ── Toast ── */
.k18-toast-bar {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%);
  background:var(--bg-elevated); border:1px solid var(--border-2);
  border-radius:12px; padding:10px 16px;
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--text);
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  z-index:9999; pointer-events:none; opacity:0;
  transition:opacity .2s; min-width:200px;
}
.k18-toast-bar.visible { opacity:1; pointer-events:auto; }
.k18-toast-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ── Views list ── */
.k18-views-list { display:flex; flex-direction:column; gap:8px; }
.k18-view-avatar {
  width:36px; height:36px; border-radius:50%;
  background:var(--bg-elevated); border:1px solid var(--border);
  display:grid; place-items:center;
  font-size:14px; font-weight:800; color:var(--text-3);
  flex-shrink:0;
}
.k18-view-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:9px;
}

/* ── Skeleton loaders ── */
.k18-skeleton {
  background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-soft) 50%,var(--bg-elevated) 75%);
  background-size:200% 100%;
  animation: k18shimmer 1.5s infinite;
  border-radius:6px;
}
.k18-skeleton-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px; }
.k18-card-skeleton { height:200px; border-radius:var(--r); }
.k18-job-skeleton  { height:120px; border-radius:var(--r); }
@keyframes k18shimmer { to { background-position:-200% 0; } }

/* ── Consent card ── */
.k18-consent-card { background:var(--glass-2); border:1px solid var(--border-2); border-radius:var(--r); padding:16px; margin-bottom:10px; }
.k18-consent-name  { font-size:14px; font-weight:700; color:var(--text); margin-bottom:4px; }
.k18-consent-job   { font-size:12px; color:var(--text-3); }
.k18-consent-info  { font-size:13px; color:var(--text-2); margin:8px 0; }
.k18-consent-meta  { display:flex; flex-wrap:wrap; gap:6px; margin:6px 0; }
.k18-consent-time  { font-size:11px; color:var(--text-4); margin-top:6px; }
.k18-consent-list  { display:flex; flex-direction:column; gap:10px; }
.k18-consent-actions { display:flex; gap:8px; margin-top:8px; }
.k18-consent-act   { flex:1; height:36px; border-radius:8px; font-size:13px; font-weight:700; font-family:inherit; cursor:pointer; border:none; }

/* ── Credit hero (buy page) ── */
.k18-credit-hero { text-align:center; margin-bottom:24px; }
.k18-credit-big  { font-size:48px; font-weight:900; color:var(--green-soft); line-height:1; }
.k18-credit-info { display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:10px; margin-top:16px; }
.k18-credit-info-item { background:var(--glass); border:1px solid var(--border); border-radius:10px; padding:12px; text-align:center; }

/* ── Verified SM badge ── */
.k18-verified-sm {
  font-size:10px; font-weight:700; color:var(--green-soft);
  background:var(--green-dim); border:1px solid rgba(34,197,94,.20);
  border-radius:999px; padding:1px 6px;
}

/* ── Button: danger ── */
.k18-btn-danger {
  background:rgba(248,113,113,.08); border:1px solid rgba(248,113,113,.18);
  color:#fca5a5;
}
.k18-btn-danger:hover { background:rgba(248,113,113,.16); }

/* ── Override: Elementor button reset ── */
/* Elementor aggressively resets buttons - override for all k18 buttons */
#krew18-login button,
#krew18-login input[type="submit"],
.k18d-wrap button,
.k18d-wrap input[type="submit"],
.k18-wrap button,
.k18-wrap input[type="submit"] {
  all: unset;
  box-sizing: border-box !important;
  cursor: pointer !important;
  display: inline-block !important;
  font-family: inherit !important;
}

/* Restore critical button styles after unset */
.k18l-primary,
#krew18-login .k18l-primary,
.k18-wrap .k18l-primary,
.k18d-wrap .k18l-primary {
  appearance: none !important;
  -webkit-appearance: none !important;
  display: block !important;
  width: 100% !important;
  height: 56px !important;
  border-radius: var(--r-sm) !important;
  border: 1px solid rgba(52,211,153,.30) !important;
  background: linear-gradient(180deg, var(--green-soft), var(--green-deep)) !important;
  color: #052e16 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-align: center !important;
  cursor: pointer !important;
  margin-top: 16px !important;
  line-height: 56px !important;
  box-shadow: 0 8px 32px rgba(34,197,94,.20) !important;
}
.k18l-primary:hover,
#krew18-login .k18l-primary:hover {
  filter: brightness(1.06) !important;
}

/* Fix inputs overridden by Elementor/Hello theme */
#krew18-login input[type="email"],
#krew18-login input[type="password"],
#krew18-login input[type="text"],
.k18-wrap input[type="email"],
.k18-wrap input[type="password"],
.k18-wrap input[type="text"],
.k18-wrap select,
.k18-wrap textarea {
  all: unset !important;
  box-sizing: border-box !important;
  display: block !important;
  width: 100% !important;
  height: 52px !important;
  min-height: 52px !important;
  padding: 0 14px 0 42px !important;
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: var(--r-sm) !important;
  color: var(--text) !important;
  font-size: 15px !important;
  font-family: inherit !important;
}
#krew18-login input:focus,
.k18-wrap input:focus,
.k18-wrap select:focus,
.k18-wrap textarea:focus {
  outline: none !important;
  border-color: rgba(34,197,94,.50) !important;
  box-shadow: 0 0 0 3px rgba(34,197,94,.10) !important;
}

/* ── Green "18" in logo ── */
.k18-green-18 {
  color: var(--green-soft);
}

/* ── Password show/hide toggle ── */
.k18l-ctrl {
  position: relative;
}
.k18-pw-toggle {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,.35);
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color .2s;
  z-index: 3;
  line-height: 1;
}
.k18-pw-toggle:hover { color: var(--green-soft); }
/* Give password inputs room for the toggle button */
.k18l-ctrl input[type=password],
.k18l-ctrl input[type=text] {
  padding-right: 44px;
}

/* ── Resume tab — override old tip box colour ── */
.k18-tips-box ul li {
  color: var(--text-3) !important;
}

/* ── Ensure panels hide correctly ── */
.k18d-panel { display: none !important; }
.k18d-panel.on { display: block !important; }
