/* ╔════════════════════════════════════════════════════════════════════╗
   ║                                                                    ║
   ║   מכון קשר · Keshet Design System  v1.0                            ║
   ║                                                                    ║
   ║   Drop-in stylesheet. All classes are prefixed with .k- to avoid   ║
   ║   collisions with Django admin / Bootstrap / etc.                  ║
   ║                                                                    ║
   ║   Usage:                                                           ║
   ║     <link rel="stylesheet" href="{% static 'css/keshet.css' %}">  ║
   ║                                                                    ║
   ║   Pair with Google Fonts:                                          ║
   ║     Rubik 400/500/600/700 + Heebo 400/500/600/700                  ║
   ║                                                                    ║
   ╚════════════════════════════════════════════════════════════════════╝ */


/* ═══════════════════════════════════════════════════════════════════════
   1. DESIGN TOKENS
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* ─── Brand colors (from the מכון קשר logo / tallit stripes) ───────── */
  --k-cocoa:       #2c1e10;   /* deep chocolate — primary surface for hero/cta */
  --k-cocoa-soft:  #4d2f17;   /* hero gradient end */
  --k-terra:       #dd6a37;   /* terracotta — primary accent, attention */
  --k-terra-soft:  #fbe7da;   /* terra @ 14% */
  --k-teal:        #1ea9ac;   /* teal — interactive, links, success-ish */
  --k-teal-soft:   #d8edee;
  --k-gold:        #dba134;   /* gold — scores, highlights */
  --k-gold-soft:   #f7ead0;
  --k-sage:        #82a948;   /* sage — positive, completed, growth */
  --k-sage-soft:   #ebf2dd;

  /* ─── Surfaces (backgrounds) ──────────────────────────────────────── */
  --k-bg:          #fbf5e7;   /* page background — warm cream */
  --k-bg-alt:      #f7eed4;   /* secondary surface (testimonial bg, etc.) */
  --k-card:        #ffffff;
  --k-card-warm:   #fffdf7;

  /* ─── Ink (text colors built on top of cocoa for warmth) ──────────── */
  --k-ink:         #2a1a0e;
  --k-ink-70:      rgba(42, 26, 14, 0.70);
  --k-ink-50:      rgba(42, 26, 14, 0.50);
  --k-ink-25:      rgba(42, 26, 14, 0.18);
  --k-rule:        rgba(42, 26, 14, 0.08);

  /* ─── Status colors (for messages / form validation) ──────────────── */
  --k-success:     #5a8a2e;
  --k-warning:     #b6781b;
  --k-danger:      #b04428;
  --k-info:        var(--k-teal);

  /* ─── Typography ──────────────────────────────────────────────────── */
  --k-font:        "Rubik", "Heebo", "Assistant", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --k-font-display:"Rubik", "Heebo", sans-serif;
  --k-font-mono:   "JetBrains Mono", ui-monospace, "Menlo", monospace;

  /* ─── Spacing scale (use these, not magic numbers) ────────────────── */
  --k-space-1: 4px;
  --k-space-2: 8px;
  --k-space-3: 12px;
  --k-space-4: 16px;
  --k-space-5: 20px;
  --k-space-6: 24px;
  --k-space-8: 32px;
  --k-space-10: 40px;
  --k-space-12: 48px;
  --k-space-16: 64px;

  /* ─── Radii ───────────────────────────────────────────────────────── */
  --k-radius-sm:   8px;
  --k-radius-md:   12px;
  --k-radius-lg:   16px;
  --k-radius-xl:   22px;
  --k-radius-full: 999px;

  /* ─── Shadows ─────────────────────────────────────────────────────── */
  --k-shadow-sm:   0 1px 0 rgba(42,26,14,0.04);
  --k-shadow-md:   0 8px 24px -16px rgba(42,26,14,0.18);
  --k-shadow-lg:   0 12px 32px -12px rgba(42,26,14,0.20);
  --k-shadow-pop:  0 6px 24px -8px rgba(42,26,14,0.30);

  /* ─── Motion ──────────────────────────────────────────────────────── */
  --k-ease:        cubic-bezier(.2,.7,.3,1);
  --k-duration:    .18s;
}


/* ═══════════════════════════════════════════════════════════════════════
   2. BASE / RESET
   ═══════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; }

html { font-family: var(--k-font); color: var(--k-ink); -webkit-font-smoothing: antialiased; }
body { margin: 0; background: var(--k-bg); }

a { color: var(--k-teal); text-decoration: none; }
a:hover { text-decoration: underline; text-decoration-color: var(--k-teal-soft); text-underline-offset: 3px; }

img, svg { max-width: 100%; display: block; }

button { font-family: inherit; }

::selection { background: var(--k-gold-soft); color: var(--k-ink); }

/* When the document is RTL, default block alignment to right */
html[dir="rtl"] body { text-align: right; }


/* ═══════════════════════════════════════════════════════════════════════
   3. TYPOGRAPHY
   ═══════════════════════════════════════════════════════════════════════ */

.k-display-1 { font-size: 40px; font-weight: 700; letter-spacing: -.02em; line-height: 1.1; margin: 0; }
.k-display-2 { font-size: 32px; font-weight: 700; letter-spacing: -.02em; line-height: 1.15; margin: 0; }
.k-h1        { font-size: 24px; font-weight: 700; line-height: 1.3; margin: 0; }
.k-h2        { font-size: 19px; font-weight: 700; line-height: 1.3; margin: 0; }
.k-h3        { font-size: 16px; font-weight: 700; line-height: 1.4; margin: 0; }
.k-body      { font-size: 14px; line-height: 1.6; color: var(--k-ink-70); margin: 0; }
.k-body-lg   { font-size: 16px; line-height: 1.6; color: var(--k-ink-70); margin: 0; }
.k-small     { font-size: 12px; color: var(--k-ink-50); margin: 0; }
.k-micro     { font-size: 11px; color: var(--k-ink-50); letter-spacing: .06em; text-transform: none; margin: 0; }
.k-kicker    { font-size: 11px; font-weight: 600; color: var(--k-ink-50); letter-spacing: .18em; }

.k-muted     { color: var(--k-ink-50); }
.k-strong    { color: var(--k-ink); font-weight: 700; }
.k-num       { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }


/* ═══════════════════════════════════════════════════════════════════════
   4. LAYOUT HELPERS
   ═══════════════════════════════════════════════════════════════════════ */

.k-container { max-width: 1280px; margin: 0 auto; padding: 0 var(--k-space-6); }
.k-stack     { display: flex; flex-direction: column; }
.k-row       { display: flex; align-items: center; }
.k-row--baseline { align-items: baseline; }
.k-row--start { align-items: flex-start; }
.k-grow      { flex: 1; min-width: 0; }
.k-grid      { display: grid; }
.k-grid--2   { grid-template-columns: repeat(2, 1fr); }
.k-grid--3   { grid-template-columns: repeat(3, 1fr); }
.k-grid--4   { grid-template-columns: repeat(4, 1fr); }
.k-grid--5   { grid-template-columns: repeat(5, 1fr); }

.k-gap-1 { gap: 4px; }
.k-gap-2 { gap: 8px; }
.k-gap-3 { gap: 12px; }
.k-gap-4 { gap: 16px; }
.k-gap-5 { gap: 20px; }
.k-gap-6 { gap: 24px; }
.k-gap-8 { gap: 32px; }


/* ═══════════════════════════════════════════════════════════════════════
   5. TALLIT STRIPE MOTIF
   Signature brand element — borrowed from the colored stripes in the
   logo's tallit. Use it as a top edge on hero cards, a divider in
   footers, or a vertical accent on the side of a panel.
   ═══════════════════════════════════════════════════════════════════════ */

.k-tallit {
  display: flex;
  height: 6px;
  border-radius: 4px;
  overflow: hidden;
}
.k-tallit > span { flex: 1; display: block; }
.k-tallit > span:nth-child(1) { background: var(--k-teal); }
.k-tallit > span:nth-child(2) { background: var(--k-sage); }
.k-tallit > span:nth-child(3) { background: var(--k-gold); }
.k-tallit > span:nth-child(4) { background: var(--k-terra); }

.k-tallit--thin  { height: 4px; }
.k-tallit--lg    { height: 20px; border-radius: 6px; }
.k-tallit--vertical {
  flex-direction: column;
  height: auto; width: 6px;
  align-self: stretch;
  border-radius: 0;
}


/* ═══════════════════════════════════════════════════════════════════════
   6. BUTTONS
   ═══════════════════════════════════════════════════════════════════════ */

.k-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 18px;
  border: none;
  border-radius: var(--k-radius-full);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--k-duration) var(--k-ease),
              background var(--k-duration),
              box-shadow var(--k-duration);
}
.k-btn:hover { transform: translateY(-1px); text-decoration: none; }
.k-btn:active { transform: translateY(0); }
.k-btn:focus-visible { outline: 2px solid var(--k-teal); outline-offset: 2px; }
.k-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.k-btn--primary  { background: var(--k-cocoa); color: #fff; }
.k-btn--primary:hover  { background: #1f140a; box-shadow: var(--k-shadow-pop); }

.k-btn--accent   { background: var(--k-terra); color: #fff; }
.k-btn--accent:hover   { background: #c95f30; box-shadow: var(--k-shadow-pop); }

.k-btn--teal     { background: var(--k-teal); color: #fff; }
.k-btn--teal:hover     { background: #198d90; box-shadow: var(--k-shadow-pop); }

.k-btn--ghost    { background: #fff; color: var(--k-ink-70); border: 1.5px solid var(--k-rule); }
.k-btn--ghost:hover    { color: var(--k-ink); border-color: var(--k-ink-25); }

.k-btn--outline  { background: transparent; color: var(--k-teal); border: 1.5px solid var(--k-teal); }
.k-btn--outline:hover  { background: var(--k-teal-soft); }

.k-btn--link     { background: transparent; color: var(--k-teal); padding: 6px 8px; }
.k-btn--link:hover { background: var(--k-teal-soft); }

.k-btn--sm { padding: 7px 14px; font-size: 12px; }
.k-btn--lg { padding: 13px 22px; font-size: 14px; }
.k-btn--block { display: flex; width: 100%; }


/* ═══════════════════════════════════════════════════════════════════════
   7. CARDS
   ═══════════════════════════════════════════════════════════════════════ */

.k-card {
  background: var(--k-card);
  border: 1px solid var(--k-rule);
  border-radius: var(--k-radius-lg);
  padding: var(--k-space-6);
}
.k-card--xl { border-radius: var(--k-radius-xl); }
.k-card--flat { padding: 0; overflow: hidden; }
.k-card--bare { background: transparent; border: 1px dashed var(--k-ink-25); }
.k-card--warm { background: var(--k-card-warm); }
.k-card--lift { box-shadow: var(--k-shadow-md); }
.k-card--lift:hover { box-shadow: var(--k-shadow-lg); transform: translateY(-1px); transition: var(--k-duration) var(--k-ease); }

.k-card__head {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--k-rule);
}
.k-card__head--terra { background: linear-gradient(90deg, rgba(221,106,55,.10), transparent); }
.k-card__head--teal  { background: linear-gradient(90deg, rgba(30,169,172,.10), transparent); }
.k-card__head--gold  { background: linear-gradient(90deg, rgba(219,161,52,.10), transparent); }
.k-card__head--sage  { background: linear-gradient(90deg, rgba(130,169,72,.10), transparent); }

.k-card__title { font-size: 15px; font-weight: 700; color: var(--k-ink); }
.k-card__sub { font-size: 11px; color: var(--k-ink-50); margin-top: 2px; }
.k-card__body { padding: 22px; }
.k-card__foot { padding: 14px 22px; border-top: 1px solid var(--k-rule); font-size: 12px; color: var(--k-ink-50); }


/* ═══════════════════════════════════════════════════════════════════════
   8. STAT CARDS — big numbers with a colored icon chip and bg ghost number
   ═══════════════════════════════════════════════════════════════════════ */

.k-stat {
  position: relative;
  overflow: hidden;
  background: var(--k-card);
  border: 1px solid var(--k-rule);
  border-radius: var(--k-radius-lg);
  padding: 20px 18px;
}
.k-stat__icon {
  width: 38px; height: 38px;
  border-radius: var(--k-radius-md);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.k-stat__icon--terra { background: var(--k-terra-soft); color: var(--k-terra); }
.k-stat__icon--teal  { background: var(--k-teal-soft);  color: var(--k-teal); }
.k-stat__icon--gold  { background: var(--k-gold-soft);  color: #a07d22; }
.k-stat__icon--sage  { background: var(--k-sage-soft);  color: #5a7d2f; }

.k-stat__value {
  font-size: 36px; font-weight: 700; letter-spacing: -.02em;
  line-height: 1; color: var(--k-ink);
  font-variant-numeric: tabular-nums;
}
.k-stat__suffix { font-size: 13px; color: var(--k-ink-50); font-weight: 500; }
.k-stat__label { font-size: 12px; color: var(--k-ink-50); margin-top: 8px; font-weight: 500; }
.k-stat__ghost {
  position: absolute;
  inset-inline-start: -8px;
  bottom: -34px;
  font-size: 100px; font-weight: 800;
  opacity: .08; line-height: 1; letter-spacing: -.05em;
  color: currentColor;
  pointer-events: none;
}
.k-stat--terra .k-stat__ghost { color: var(--k-terra); }
.k-stat--teal  .k-stat__ghost { color: var(--k-teal); }
.k-stat--gold  .k-stat__ghost { color: var(--k-gold); }
.k-stat--sage  .k-stat__ghost { color: var(--k-sage); }


/* ═══════════════════════════════════════════════════════════════════════
   9. PILLS / BADGES / SCORES
   ═══════════════════════════════════════════════════════════════════════ */

.k-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px;
  border-radius: var(--k-radius-full);
  font-size: 12px; font-weight: 600;
  background: var(--k-bg-alt);
  color: var(--k-ink-70);
}
.k-pill--score    { background: var(--k-sage-soft); color: #4a6826; }
.k-pill--warning  { background: var(--k-terra-soft); color: var(--k-terra); }
.k-pill--info     { background: var(--k-teal-soft); color: var(--k-teal); }
.k-pill--gold     { background: var(--k-gold-soft); color: #7a5d12; }
.k-pill--cocoa    { background: var(--k-cocoa); color: #fff; }
.k-pill--dot::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px;
  background: currentColor; display: inline-block;
}


/* ═══════════════════════════════════════════════════════════════════════
   10. AVATARS
   ═══════════════════════════════════════════════════════════════════════ */

.k-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 42px; height: 42px;
  border-radius: 999px;
  background: var(--k-terra);
  color: #fff;
  font-weight: 700; font-size: 17px;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.10);
  flex-shrink: 0;
}
.k-avatar--sm { width: 32px; height: 32px; font-size: 13px; }
.k-avatar--lg { width: 56px; height: 56px; font-size: 22px; }
.k-avatar--xl { width: 72px; height: 72px; font-size: 28px; }

.k-avatar--terra { background: var(--k-terra); }
.k-avatar--teal  { background: var(--k-teal); }
.k-avatar--gold  { background: var(--k-gold); }
.k-avatar--sage  { background: var(--k-sage); }
.k-avatar--cocoa { background: var(--k-cocoa); }


/* ═══════════════════════════════════════════════════════════════════════
   11. SECTION HEADERS
   ═══════════════════════════════════════════════════════════════════════ */

.k-section-head {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
.k-section-head__title { font-size: 18px; font-weight: 700; color: var(--k-ink); }
.k-section-head__count {
  font-size: 11px; font-weight: 700;
  background: var(--k-terra-soft); color: var(--k-terra);
  padding: 2px 8px; border-radius: var(--k-radius-full);
}
.k-section-head__action {
  margin-inline-start: auto;
  font-size: 12px; color: var(--k-teal); cursor: pointer;
  text-decoration: none;
}


/* ═══════════════════════════════════════════════════════════════════════
   12. EMPTY STATES
   ═══════════════════════════════════════════════════════════════════════ */

.k-empty {
  padding: 40px 28px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.k-empty__icon {
  width: 88px; height: 88px;
  border-radius: 999px;
  background: radial-gradient(circle, var(--k-bg-alt) 0%, var(--k-bg) 100%);
  display: flex; align-items: center; justify-content: center;
  border: 1px dashed var(--k-ink-25);
}
.k-empty__title { font-size: 16px; font-weight: 700; color: var(--k-ink); }
.k-empty__sub   { font-size: 13px; color: var(--k-ink-70); max-width: 360px; line-height: 1.5; }


/* ═══════════════════════════════════════════════════════════════════════
   13. HERO BANNER — the "good morning" brown panel from the dashboard
   ═══════════════════════════════════════════════════════════════════════ */

.k-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--k-cocoa) 0%, var(--k-cocoa-soft) 100%);
  color: #fff;
  border-radius: var(--k-radius-xl);
  padding: 28px 32px;
  padding-inline-start: 44px;
}
.k-hero__stripes {
  position: absolute;
  inset-inline-start: 0;
  top: 0; bottom: 0;
  width: 12px;
  display: flex; flex-direction: column;
}
.k-hero__stripes > span { flex: 1; display: block; }
.k-hero__stripes > span:nth-child(1) { background: var(--k-teal); }
.k-hero__stripes > span:nth-child(2) { background: var(--k-sage); }
.k-hero__stripes > span:nth-child(3) { background: var(--k-gold); }
.k-hero__stripes > span:nth-child(4) { background: var(--k-terra); }
.k-hero__kicker {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  letter-spacing: .18em;
  font-weight: 600;
}
.k-hero__title {
  font-size: 28px;
  font-weight: 600;
  margin-top: 10px;
  letter-spacing: -.01em;
  line-height: 1.3;
}
.k-hero__circle {
  position: absolute;
  inset-inline-start: -60px;
  bottom: -90px;
  width: 260px; height: 260px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.08);
  pointer-events: none;
}


/* ═══════════════════════════════════════════════════════════════════════
   14. FORMS
   ═══════════════════════════════════════════════════════════════════════ */

.k-form-group { margin-bottom: 18px; }

.k-label {
  display: block;
  font-size: 13px; font-weight: 600;
  color: var(--k-ink); margin-bottom: 6px;
}
.k-label--required::after {
  content: " *"; color: var(--k-terra);
}

.k-input, .k-select, .k-textarea {
  width: 100%;
  padding: 11px 14px;
  background: #fff;
  border: 1.5px solid var(--k-rule);
  border-radius: var(--k-radius-md);
  font-family: inherit;
  font-size: 14px;
  color: var(--k-ink);
  transition: border-color var(--k-duration), box-shadow var(--k-duration);
}
.k-input::placeholder, .k-textarea::placeholder { color: var(--k-ink-50); }
.k-input:hover, .k-select:hover, .k-textarea:hover { border-color: var(--k-ink-25); }
.k-input:focus, .k-select:focus, .k-textarea:focus {
  outline: none;
  border-color: var(--k-teal);
  box-shadow: 0 0 0 3px var(--k-teal-soft);
}
.k-textarea { min-height: 88px; resize: vertical; line-height: 1.6; }

.k-input--error,
.k-select--error,
.k-textarea--error {
  border-color: var(--k-danger);
  box-shadow: 0 0 0 3px rgba(176,68,40,.12);
}
.k-help { font-size: 12px; color: var(--k-ink-50); margin-top: 6px; }
.k-error { font-size: 12px; color: var(--k-danger); margin-top: 6px; font-weight: 500; }

/* Search field with leading icon */
.k-search {
  display: flex; align-items: center; gap: 8px;
  padding: 0 14px;
  background: #fff;
  border: 1.5px solid var(--k-rule);
  border-radius: var(--k-radius-md);
}
.k-search:focus-within { border-color: var(--k-teal); box-shadow: 0 0 0 3px var(--k-teal-soft); }
.k-search input {
  flex: 1; border: none; outline: none; background: transparent;
  font-family: inherit; font-size: 14px; padding: 11px 0; color: var(--k-ink);
}


/* ═══════════════════════════════════════════════════════════════════════
   15. NAVIGATION (sidebar)
   ═══════════════════════════════════════════════════════════════════════ */

.k-sidenav {
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px;
}
.k-nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  border-radius: var(--k-radius-md);
  color: var(--k-ink-70);
  font-weight: 500; font-size: 14px;
  cursor: pointer; text-decoration: none;
  transition: background var(--k-duration), color var(--k-duration);
}
.k-nav-item:hover { background: var(--k-bg); color: var(--k-ink); text-decoration: none; }
.k-nav-item--active {
  background: var(--k-teal-soft);
  color: var(--k-teal);
  font-weight: 600;
}
.k-nav-item__icon { display: inline-flex; width: 20px; height: 20px; flex-shrink: 0; }

/* Top bar */
.k-topbar {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 24px;
  background: #fff;
  border-bottom: 1px solid var(--k-rule);
}
.k-brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 16px; color: var(--k-ink);
  text-decoration: none;
}
.k-brand__mark {
  width: 38px; height: 38px;
  border-radius: var(--k-radius-md);
  background: var(--k-cocoa);
  display: flex; align-items: center; justify-content: center;
}


/* ═══════════════════════════════════════════════════════════════════════
   16. TABLES
   ═══════════════════════════════════════════════════════════════════════ */

.k-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: var(--k-radius-lg);
  overflow: hidden;
  border: 1px solid var(--k-rule);
}
.k-table th, .k-table td {
  padding: 14px 18px;
  text-align: start;
  border-top: 1px solid var(--k-rule);
  font-size: 14px;
  vertical-align: middle;
}
.k-table thead th {
  background: var(--k-bg-alt);
  border-top: none;
  font-size: 12px; font-weight: 700; color: var(--k-ink-70);
  letter-spacing: .04em;
}
.k-table tbody tr { transition: background .12s; }
.k-table tbody tr:hover { background: var(--k-bg); }


/* ═══════════════════════════════════════════════════════════════════════
   17. MESSAGES / ALERTS (for Django messages framework)
   Use Django's message_tags = {messages.SUCCESS: 'k-msg--success', ...}
   ═══════════════════════════════════════════════════════════════════════ */

.k-msg {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 18px;
  border-radius: var(--k-radius-md);
  border: 1px solid;
  font-size: 14px;
  margin-bottom: 12px;
}
.k-msg__icon { flex-shrink: 0; margin-top: 1px; }
.k-msg__title { font-weight: 700; margin: 0 0 2px; }
.k-msg__body { color: inherit; opacity: .85; margin: 0; }

.k-msg--success { background: var(--k-sage-soft); border-color: rgba(130,169,72,.35); color: #3d5b1c; }
.k-msg--warning { background: var(--k-gold-soft); border-color: rgba(219,161,52,.35); color: #6e5210; }
.k-msg--danger  { background: var(--k-terra-soft); border-color: rgba(221,106,55,.35); color: #7d3315; }
.k-msg--info    { background: var(--k-teal-soft);  border-color: rgba(30,169,172,.35); color: #105e5f; }


/* ═══════════════════════════════════════════════════════════════════════
   18. TESTIMONIAL / FEEDBACK CARD
   ═══════════════════════════════════════════════════════════════════════ */

.k-testimonial {
  position: relative; overflow: hidden;
  background: var(--k-bg-alt);
  border-radius: var(--k-radius-lg);
  padding: 18px 16px 16px;
}
.k-testimonial__stripe {
  position: absolute; top: 0; inset-inline: 0; height: 4px;
}
.k-testimonial__quote {
  position: absolute; top: 8px;
  inset-inline-start: 14px;
  font-size: 50px; line-height: 1; font-weight: 800;
  opacity: .18; font-family: serif;
  pointer-events: none;
}
.k-testimonial__head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.k-testimonial__name { font-size: 13px; font-weight: 700; }
.k-testimonial__when { font-size: 10px; color: var(--k-ink-50); }
.k-testimonial__text { font-size: 13px; color: var(--k-ink-70); line-height: 1.55; min-height: 80px; text-wrap: pretty; }
.k-testimonial__foot {
  margin-top: 12px; padding-top: 10px;
  border-top: 1px dashed var(--k-ink-25);
  display: flex; align-items: center; justify-content: space-between;
}


/* ═══════════════════════════════════════════════════════════════════════
   19. ATTENTION ROW (student-needs-attention list item)
   ═══════════════════════════════════════════════════════════════════════ */

.k-attention {
  padding: 16px 22px;
  border-top: 1px solid var(--k-rule);
  display: flex; align-items: center; gap: 14px;
}
.k-attention:first-of-type { border-top: none; }
.k-attention__name { font-size: 15px; font-weight: 600; color: var(--k-ink); }
.k-attention__reason { font-size: 12px; color: var(--k-ink-70); margin-top: 3px; }


/* ═══════════════════════════════════════════════════════════════════════
   20. DIVIDER
   ═══════════════════════════════════════════════════════════════════════ */

.k-divider { height: 1px; background: var(--k-rule); border: none; margin: 16px 0; }
.k-divider--dashed { background: none; border-top: 1px dashed var(--k-ink-25); }


/* ═══════════════════════════════════════════════════════════════════════
   21. FOOTER RIBBON
   ═══════════════════════════════════════════════════════════════════════ */

.k-footer-ribbon {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 22px;
  background: #fff;
  border-radius: var(--k-radius-md);
  border: 1px solid var(--k-rule);
}


/* ═══════════════════════════════════════════════════════════════════════
   22. UTILITIES
   ═══════════════════════════════════════════════════════════════════════ */

.k-mt-1 { margin-top: 4px; }   .k-mb-1 { margin-bottom: 4px; }
.k-mt-2 { margin-top: 8px; }   .k-mb-2 { margin-bottom: 8px; }
.k-mt-3 { margin-top: 12px; }  .k-mb-3 { margin-bottom: 12px; }
.k-mt-4 { margin-top: 16px; }  .k-mb-4 { margin-bottom: 16px; }
.k-mt-6 { margin-top: 24px; }  .k-mb-6 { margin-bottom: 24px; }
.k-mt-8 { margin-top: 32px; }  .k-mb-8 { margin-bottom: 32px; }

.k-text-terra { color: var(--k-terra); }
.k-text-teal  { color: var(--k-teal); }
.k-text-gold  { color: var(--k-gold); }
.k-text-sage  { color: var(--k-sage); }
.k-text-cocoa { color: var(--k-cocoa); }

.k-rounded-md { border-radius: var(--k-radius-md); }
.k-rounded-lg { border-radius: var(--k-radius-lg); }
.k-rounded-xl { border-radius: var(--k-radius-xl); }


/* ═══════════════════════════════════════════════════════════════════════
   23. RESPONSIVE BREAKPOINTS
   ═══════════════════════════════════════════════════════════════════════ */

@media (max-width: 960px) {
  .k-grid--5, .k-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .k-grid--3 { grid-template-columns: 1fr; }
  .k-hero { padding: 22px 22px; padding-inline-start: 32px; }
  .k-hero__title { font-size: 22px; }
}
@media (max-width: 640px) {
  .k-grid--5, .k-grid--4, .k-grid--2 { grid-template-columns: 1fr; }
  .k-display-1 { font-size: 28px; }
  .k-display-2 { font-size: 22px; }
}
