/* ============================================================
 * Concierge · Portal do Formando — Bootstrap 5 safe stylesheet
 * ============================================================
 * Drop-in replacement for concierge.css that can be loaded
 * AFTER Bootstrap 5 (and alongside other frameworks/themes)
 * without trampling their rules.
 *
 * How to use:
 *   <body class="concierge-ui"> ... </body>
 *   or wrap the concierge UI region in any element with
 *   class="concierge-ui"
 *
 * Isolation model:
 *   - Every selector (classes, element resets, utilities) is
 *     scoped under `.concierge-ui`, so rules only apply inside
 *     that wrapper. Nothing leaks to the rest of the page.
 *   - Classes that collide with Bootstrap 5 are additionally
 *     renamed with a `cz-` prefix, so Bootstrap's own classes
 *     (e.g. `.btn`, `.card`, `.nav`, `.nav-item`) remain usable
 *     inside the concierge scope if you want to mix.
 *
 * Renames (Bootstrap collisions):
 *     .card         -> .cz-card
 *     .card--pad-sm -> .cz-card--pad-sm
 *     .card--pad-lg -> .cz-card--pad-lg
 *     .card-head    -> .cz-card-head
 *     .card-kicker  -> .cz-card-kicker
 *     .card-title   -> .cz-card-title
 *     .card-cta     -> .cz-card-cta
 *     .btn          -> .cz-btn
 *     .btn--primary -> .cz-btn--primary
 *     .btn--success -> .cz-btn--success
 *     .btn--violet  -> .cz-btn--violet
 *     .btn--ghost   -> .cz-btn--ghost
 *     .btn-row      -> .cz-btn-row
 *     .nav          -> .cz-nav
 *     .nav-kicker   -> .cz-nav-kicker
 *     .nav-item     -> .cz-nav-item
 *     .nav-item--on -> .cz-nav-item--on
 *     .nav-item__label -> .cz-nav-item__label
 *     .nav-badge    -> .cz-nav-badge
 *
 * Tokens (`:root` CSS custom properties) remain global — their
 * names (`--m-*`, `--ink-*`, `--radius-*`, `--shadow-*`) do not
 * collide with Bootstrap's `--bs-*` namespace.
 * ============================================================ */

/* --- Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Cabin:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

/* --- Tokens (global: CSS custom properties do not conflict with --bs-*) --- */
:root {
  --m-green: #12C679;
  --m-green-deep: #0FA565;
  --m-green-soft: #E3F9EE;
  --m-blue: #2C5CFF;
  --m-blue-deep: #1E3FB8;
  --m-blue-soft: #E6ECFF;
  --m-amber: #F59E0B;
  --m-amber-deep: #EA580C;
  --m-amber-soft: #FFF3DB;
  --m-violet: #A855F7;
  --m-violet-deep: #7C3AED;
  --m-violet-soft: #F3EEFF;
  --m-red: #EF4444;
  --m-red-soft: #FEE6E6;

  --ink: #1A1B1F;
  --ink-2: #49505E;
  --ink-3: #7A7F8A;
  --ink-4: #B4B8C2;
  --ink-5: #D7DAE2;

  --bg: #EDEEF2;
  --bg-2: #F7F8FB;
  --card: #FFFFFF;
  --soft: #F1F3F7;
  --softer: #F4F5F9;
  --line: #E4E6EC;
  --line-soft: #EEF0F5;

  --radius-sm: 9px;
  --radius-md: 12px;
  --radius: 14px;
  --radius-lg: 18px;
  --radius-xl: 22px;
  --radius-2xl: 28px;
  --radius-pill: 999px;

  --shadow-xs: 0 1px 2px rgba(15,20,40,.04);
  --shadow-sm: 0 1px 2px rgba(15,20,40,.03), 0 6px 14px rgba(15,20,40,.04);
  --shadow-md: 0 1px 2px rgba(15,20,40,.03), 0 12px 28px rgba(15,20,40,.05);
  --shadow-lg: 0 18px 44px rgba(15,20,40,.12);
  --shadow-green: 0 10px 22px rgba(18,198,121,.3);
  --shadow-blue: 0 10px 22px rgba(44,92,255,.3);
  --shadow-violet: 0 10px 22px rgba(124,58,237,.32);
}

/* --- Scoped reset --- */
.concierge-ui,
.concierge-ui *,
.concierge-ui *::before,
.concierge-ui *::after { box-sizing: border-box; }

body.concierge-ui {
  margin: 0;
  padding: 0;
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #EDEEF2 0%, #F7F8FB 100%);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

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

.concierge-ui ::-webkit-scrollbar { width: 10px; height: 10px; }
.concierge-ui ::-webkit-scrollbar-thumb { background: var(--ink-5); border-radius: 10px; }
.concierge-ui ::-webkit-scrollbar-track { background: transparent; }
.concierge-ui ::selection { background: var(--m-green); color: #fff; }

.concierge-ui .uc { text-transform: uppercase; letter-spacing: .12em; }
.concierge-ui .tab-num { font-variant-numeric: tabular-nums; }
.concierge-ui .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* =============================================================
 * LAYOUT
 * ============================================================= */
.concierge-ui .app {
  display: flex;
  min-height: 100vh;
}
.concierge-ui .main-col {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.concierge-ui .main-content {
  padding: 18px 32px 40px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  margin: 0 auto;
  max-width: 1460px;
}
.concierge-ui .footer {
  padding: 20px 4px;
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--ink-3);
  font-weight: 600;
}

/* =============================================================
 * SIDEBAR
 * ============================================================= */
.concierge-ui .sidebar {
  width: 262px;
  flex-shrink: 0;
  background: #fff;
  border-right: 1px solid var(--line);
  padding: 22px 16px 18px;
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: sticky;
  top: 0;
}
.concierge-ui .sidebar-logo { padding: 4px 10px 22px; }
.concierge-ui .wordmark {
  display: flex;
  align-items: center;
  gap: 10px;
}
.concierge-ui .wordmark__dot {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--m-green), var(--m-blue));
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 12px;
}
.concierge-ui .wordmark__name {
  font-weight: 800;
  letter-spacing: -0.3px;
  font-size: 17px;
  color: var(--ink);
}
.concierge-ui .wordmark__sub {
  font-size: 9.5px;
  color: var(--ink-3);
  font-weight: 700;
  letter-spacing: 1.4px;
  margin-top: 1px;
}

.concierge-ui .student-card {
  padding: 14px;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, #ECFBF3 0%, #EEF1FF 100%);
  border: 1px solid rgba(18,198,121,.15);
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 18px;
}
.concierge-ui .avatar {
  width: 42px; height: 42px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--m-green), var(--m-blue));
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.3px;
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px rgba(18,198,121,.2);
  flex-shrink: 0;
}
.concierge-ui .avatar--lg { width: 96px; height: 96px; border-radius: 28px; font-size: 34px; border-width: 4px; box-shadow: 0 0 0 1px var(--line), 0 10px 24px rgba(15,20,40,.1); }
.concierge-ui .avatar--md { width: 64px; height: 64px; border-radius: 20px; font-size: 22px; border-width: 3px; }

.concierge-ui .student-card__name { font-size: 13px; font-weight: 700; letter-spacing: -0.2px; }
.concierge-ui .student-card__status { font-size: 10px; color: var(--m-green-deep); font-weight: 700; letter-spacing: .5px; margin-top: 2px; }

.concierge-ui .cz-nav-kicker {
  font-size: 10px;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: 1.2px;
  padding: 0 12px 8px;
}
.concierge-ui .cz-nav { display: flex; flex-direction: column; gap: 3px; }
.concierge-ui .cz-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: var(--radius);
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.2px;
  width: 100%;
}
.concierge-ui .cz-nav-item:hover { background: var(--softer); }
.concierge-ui .cz-nav-item--on {
  background: linear-gradient(135deg, var(--m-green), var(--m-blue));
  color: #fff;
  font-weight: 700;
  box-shadow: 0 6px 16px rgba(44,92,255,.28);
}
.concierge-ui .cz-nav-item__label { flex: 1; }
.concierge-ui .cz-nav-badge {
  background: var(--m-red-soft);
  color: #B42318;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  min-width: 20px;
  text-align: center;
}
.concierge-ui .cz-nav-item--on .cz-nav-badge { background: rgba(255,255,255,.25); color: #fff; }

/* Streak card */
.concierge-ui .streak-card {
  margin-top: auto;
  padding: 18px;
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, var(--m-green) 0%, var(--m-green-deep) 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(18,198,121,.35);
}
.concierge-ui .streak-card__kicker { font-size: 10px; font-weight: 800; opacity: .85; letter-spacing: 1.2px; }
.concierge-ui .streak-card__value { font-size: 34px; font-weight: 800; letter-spacing: -1px; line-height: 1; margin-top: 4px; }
.concierge-ui .streak-card__sub { font-size: 11px; font-weight: 600; opacity: .9; margin-top: 6px; }
.concierge-ui .streak-card__blob {
  position: absolute;
  width: 120px; height: 120px;
  border-radius: 60px;
  background: rgba(255,255,255,.1);
  top: -40px; right: -40px;
  filter: blur(20px);
}

/* =============================================================
 * TOPBAR
 * ============================================================= */
.concierge-ui .topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 32px 8px;
  gap: 16px;
}
.concierge-ui .search {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  padding: 10px 16px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--line);
  min-width: 340px;
  max-width: 460px;
  flex: 1;
}
.concierge-ui .search input {
  flex: 1;
  border: 0; outline: 0;
  font-size: 13px;
  color: var(--ink);
  background: transparent;
}
.concierge-ui .search kbd {
  background: var(--soft);
  color: var(--ink-3);
  font-size: 10px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 6px;
  letter-spacing: .4px;
}

.concierge-ui .topbar-actions { display: flex; align-items: center; gap: 10px; }
.concierge-ui .icon-btn {
  width: 40px; height: 40px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  position: relative;
}
.concierge-ui .icon-btn--sm { width: 36px; height: 36px; border-radius: 18px; }
.concierge-ui .icon-btn--ghost { background: transparent; border: 0; }

.concierge-ui .icon-btn .dot {
  position: absolute;
  top: 8px; right: 8px;
  width: 8px; height: 8px;
  border-radius: 4px;
  background: var(--m-green);
  border: 2px solid #fff;
}
.concierge-ui .user-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 14px 5px 5px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  cursor: pointer;
}
.concierge-ui .user-chip .avatar { width: 30px; height: 30px; border-radius: 15px; font-size: 11px; border: 0; box-shadow: none; }
.concierge-ui .user-chip__name { font-size: 12.5px; font-weight: 700; letter-spacing: -0.2px; }

/* =============================================================
 * CHIPS
 * ============================================================= */
.concierge-ui .chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .3px;
}
.concierge-ui .chip--sm { padding: 3px 8px; font-size: 9.5px; }
.concierge-ui .chip--green { background: var(--m-green-soft); color: var(--m-green-deep); }
.concierge-ui .chip--blue  { background: var(--m-blue-soft);  color: var(--m-blue-deep); }
.concierge-ui .chip--amber { background: var(--m-amber-soft); color: #A86A00; }
.concierge-ui .chip--violet{ background: var(--m-violet-soft);color: var(--m-violet-deep); }
.concierge-ui .chip--ghost { background: var(--soft);         color: var(--ink-2); }

.concierge-ui .chip__dot { width: 6px; height: 6px; border-radius: 3px; background: currentColor; }

/* =============================================================
 * CARD (renamed: cz-card to avoid Bootstrap .card collision)
 * ============================================================= */
.concierge-ui .cz-card {
  background: var(--card);
  border-radius: var(--radius-2xl);
  padding: 24px;
  border: 1px solid var(--line-soft);
  box-shadow: var(--shadow-md);
}
.concierge-ui .cz-card--pad-sm { padding: 18px; }
.concierge-ui .cz-card--pad-lg { padding: 22px; }

/* Soft tinted backgrounds */
.concierge-ui .cz-card--tint-green  { background: linear-gradient(160deg, #F3FBF6 0%, #E6F7EE 100%); border-color: rgba(18,198,121,.2); }
.concierge-ui .cz-card--tint-blue   { background: linear-gradient(160deg, #EEF1FF 0%, #E6ECFF 100%); border-color: rgba(44,92,255,.2); }
.concierge-ui .cz-card--tint-amber  { background: linear-gradient(160deg, #FFFBEF 0%, #FEF3D7 100%); border-color: rgba(245,158,11,.25); }
.concierge-ui .cz-card--tint-violet { background: linear-gradient(160deg, #F8F3FF 0%, #EFE6FF 100%); border-color: rgba(168,85,247,.25); }

/* Bold gradients with layered radial glows — text goes white */
.concierge-ui .cz-card--hero-green,
.concierge-ui .cz-card--hero-blue,
.concierge-ui .cz-card--hero-amber,
.concierge-ui .cz-card--hero-violet {
  color: #fff;
  border: 0;
  position: relative;
  overflow: hidden;
}
.concierge-ui .cz-card--hero-green {
  background:
    radial-gradient(circle at 85% 15%, rgba(255,255,255,.18), transparent 45%),
    radial-gradient(circle at 10% 90%, rgba(255,255,255,.08), transparent 55%),
    linear-gradient(135deg, #12C679 0%, #0FA565 45%, #2C5CFF 120%);
  box-shadow: var(--shadow-green);
}
.concierge-ui .cz-card--hero-blue {
  background:
    radial-gradient(ellipse at 85% 15%, rgba(255,255,255,.2), transparent 55%),
    radial-gradient(ellipse at 10% 110%, rgba(0,0,0,.12), transparent 60%),
    linear-gradient(135deg, #2C5CFF 0%, #1E3FB8 100%);
  box-shadow: var(--shadow-blue);
}
.concierge-ui .cz-card--hero-amber {
  background:
    radial-gradient(ellipse at 90% 50%, rgba(255,255,255,.3), transparent 65%),
    radial-gradient(circle at 10% 10%, rgba(0,0,0,.06), transparent 45%),
    linear-gradient(135deg, #F59E0B 0%, #EA580C 100%);
  box-shadow: 0 10px 22px rgba(234,88,12,.3);
}
.concierge-ui .cz-card--hero-violet {
  background:
    radial-gradient(circle at 70% 20%, rgba(255,255,255,.2), transparent 55%),
    radial-gradient(circle at 15% 95%, rgba(0,0,0,.12), transparent 55%),
    linear-gradient(135deg, #A855F7 0%, #7C3AED 100%);
  box-shadow: var(--shadow-violet);
}

/* Readability overrides for muted text tokens inside hero cards */
.concierge-ui [class*="cz-card--hero-"] .cz-card-kicker,
.concierge-ui [class*="cz-card--hero-"] .stat__label,
.concierge-ui [class*="cz-card--hero-"] .stat__sub { color: rgba(255,255,255,.85); }
.concierge-ui [class*="cz-card--hero-"] .cz-card-title,
.concierge-ui [class*="cz-card--hero-"] .stat__value { color: #fff; }

/* Colored left stripe (subtle accent, keeps white background) */
.concierge-ui .cz-card--stripe { position: relative; overflow: hidden; padding-left: 28px; }
.concierge-ui .cz-card--stripe::before {
  content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%;
  background: linear-gradient(180deg, var(--m-green), var(--m-green-deep));
}
.concierge-ui .cz-card--stripe-blue::before   { background: linear-gradient(180deg, var(--m-blue),   var(--m-blue-deep)); }
.concierge-ui .cz-card--stripe-amber::before  { background: linear-gradient(180deg, var(--m-amber),  var(--m-amber-deep)); }
.concierge-ui .cz-card--stripe-violet::before { background: linear-gradient(180deg, var(--m-violet-deep), var(--m-violet)); }

.concierge-ui .cz-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}
.concierge-ui .cz-card-kicker {
  font-size: 10.5px;
  font-weight: 800;
  color: var(--ink-3);
  letter-spacing: 1.3px;
  text-transform: uppercase;
}
.concierge-ui .cz-card-title {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.8px;
  margin-top: 4px;
  line-height: 1.15;
}
.concierge-ui .cz-card-cta {
  color: var(--m-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -0.1px;
}

/* Stat cell */
.concierge-ui .stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.concierge-ui .stat {
  background: var(--card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--line-soft);
  box-shadow: var(--shadow-sm);
  padding: 18px;
}
.concierge-ui .stat__label { font-size: 10.5px; font-weight: 800; color: var(--ink-3); letter-spacing: 1.3px; text-transform: uppercase; }
.concierge-ui .stat__value { font-size: 36px; font-weight: 800; letter-spacing: -1.4px; line-height: 1; margin-top: 6px; color: var(--ink); }
.concierge-ui .stat__value--green { color: var(--m-green); }
.concierge-ui .stat__value--blue  { color: var(--m-blue); }
.concierge-ui .stat__value--amber { color: var(--m-amber); }
.concierge-ui .stat__value--violet{ color: var(--m-violet); }
.concierge-ui .stat__value--sm { font-size: 22px; letter-spacing: -0.6px; }
.concierge-ui .stat__sub { font-size: 11.5px; color: var(--ink-3); font-weight: 600; margin-top: 6px; }
.concierge-ui .stat-row--3 { grid-template-columns: repeat(3, 1fr); }
.concierge-ui .stat--link {
  display: block;
  color: inherit;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.concierge-ui .stat--link:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--ink-5);
}

/* =============================================================
 * PAGE HERO (shared across sub-pages)
 * ============================================================= */
.concierge-ui .page-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-2xl);
  padding: 30px 36px;
  color: #fff;
  box-shadow: var(--shadow-lg);
}
.concierge-ui .page-hero--green  { background: linear-gradient(135deg, #12C679 0%, #0FA565 60%, #2C5CFF 120%); }
.concierge-ui .page-hero--blue   { background: linear-gradient(135deg, #2C5CFF 0%, #1E3FB8 100%); }
.concierge-ui .page-hero--amber  { background: linear-gradient(135deg, #F59E0B 0%, #EA580C 100%); }
.concierge-ui .page-hero--violet { background: linear-gradient(135deg, #A855F7 0%, #7C3AED 100%); }

.concierge-ui .page-hero__blobs {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: .85;
  pointer-events: none;
}
.concierge-ui .page-hero__inner {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 30px;
}
.concierge-ui .page-hero__kicker { font-size: 11px; font-weight: 800; letter-spacing: 1.4px; opacity: .85; }
.concierge-ui .page-hero__title {
  font-size: 44px;
  font-weight: 800;
  letter-spacing: -1.4px;
  line-height: 1.05;
  margin: 6px 0 0;
}
.concierge-ui .page-hero__subtitle {
  font-size: 14px;
  margin-top: 10px;
  opacity: .92;
  font-weight: 500;
  max-width: 640px;
}

/* Hero actions */
.concierge-ui .hero-btn {
  padding: 12px 18px;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.2px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.concierge-ui .hero-btn--light {
  background: #fff;
  color: var(--m-green-deep);
  box-shadow: 0 8px 22px rgba(0,0,0,.15);
}
.concierge-ui .hero-btn--light.accent-violet { color: var(--m-violet-deep); }
.concierge-ui .hero-btn--light.accent-blue   { color: var(--m-blue-deep); }

.concierge-ui .hero-paginator { display: flex; gap: 8px; }
.concierge-ui .hero-pg-btn {
  padding: 10px 14px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.2);
  color: #fff;
  border: 1px solid rgba(255,255,255,.3);
  font-size: 12.5px;
  font-weight: 700;
  backdrop-filter: blur(10px);
}
.concierge-ui .hero-pg-label {
  padding: 10px 16px;
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--m-blue-deep);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.2px;
}

.concierge-ui .hero-meter {
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: var(--radius-lg);
  padding: 18px;
  text-align: center;
  min-width: 180px;
  color: #fff;
}
.concierge-ui .hero-meter__kicker { font-size: 10px; font-weight: 800; letter-spacing: 1.3px; opacity: .9; }
.concierge-ui .hero-meter__value  { font-size: 44px; font-weight: 800; letter-spacing: -1.5px; line-height: 1; margin-top: 4px; }
.concierge-ui .hero-meter__bar    { height: 6px; background: rgba(255,255,255,.3); border-radius: var(--radius-pill); margin-top: 10px; overflow: hidden; }
.concierge-ui .hero-meter__bar > span { display: block; height: 100%; background: #fff; border-radius: var(--radius-pill); }
.concierge-ui .hero-meter__sub    { font-size: 11px; font-weight: 600; margin-top: 8px; opacity: .9; }

/* =============================================================
 * BACK BUTTON
 * ============================================================= */
.concierge-ui .back-btn {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px 9px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink-2);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: -0.1px;
  box-shadow: var(--shadow-xs);
}

/* =============================================================
 * FILTER BAR
 * ============================================================= */
.concierge-ui .filter-bar {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 10px;
  border: 1px solid var(--line-soft);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.concierge-ui .seg {
  display: flex;
  gap: 4px;
  background: var(--soft);
  border-radius: 11px;
  padding: 3px;
}
.concierge-ui .seg button, .concierge-ui .seg a {
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--ink-2);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: -0.1px;
  display: inline-block;
}
.concierge-ui .seg button.on, .concierge-ui .seg a.on {
  background: #fff;
  color: var(--m-blue);
  box-shadow: 0 1px 2px rgba(15,20,40,.08);
}
.concierge-ui .filter-right {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-3);
  font-size: 12.5px;
  font-weight: 600;
}
/* Form-control polish inside the filter bar */
.concierge-ui .filter-bar .form-control,
.concierge-ui .filter-bar .form-control-sm {
  background: var(--bg-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-md);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink);
  height: 36px;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.concierge-ui .filter-bar .form-control:focus {
  background: #fff;
  border-color: var(--m-blue);
  box-shadow: 0 0 0 3px rgba(44,92,255,.12);
  outline: 0;
}
.concierge-ui .filter-bar .form-control::placeholder { color: var(--ink-4); font-weight: 500; }

/* View-toggle button group — pill segmented look */
.concierge-ui .filter-bar .btn-group {
  background: var(--soft);
  border-radius: 10px;
  padding: 3px;
  gap: 2px;
}
.concierge-ui .filter-bar .btn-group .btn {
  border: 0;
  border-radius: 7px !important;
  padding: 6px 10px;
  background: transparent;
  color: var(--ink-3);
  font-size: 12.5px;
  font-weight: 700;
  box-shadow: none;
  transition: background .15s ease, color .15s ease;
}
.concierge-ui .filter-bar .btn-group .btn:hover { color: var(--ink); }
.concierge-ui .filter-bar .btn-group .btn.btn-primary {
  background: #fff;
  color: var(--m-blue);
  box-shadow: 0 1px 2px rgba(15,20,40,.08);
}
.concierge-ui .filter-bar .btn-group .btn.btn-outline-primary {
  background: transparent;
  color: var(--ink-3);
}

/* Inscrever (info) and other small Bootstrap buttons inside filter bar */
.concierge-ui .filter-bar .btn.btn-info,
.concierge-ui .filter-bar .btn.btn-primary:not(.btn-group .btn) {
  background: linear-gradient(135deg, var(--m-green), var(--m-green-deep));
  border: 0;
  color: #fff;
  font-weight: 800;
  font-size: 12.5px;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px rgba(18,198,121,.28);
  transition: transform .15s ease, filter .15s ease, box-shadow .15s ease;
}
.concierge-ui .filter-bar .btn.btn-info:hover,
.concierge-ui .filter-bar .btn.btn-primary:not(.btn-group .btn):hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
  color: #fff;
  box-shadow: 0 8px 18px rgba(18,198,121,.4);
}

/* Seg tabs: count after dot picks up muted accent */
.concierge-ui .seg a, .concierge-ui .seg button { transition: background .15s ease, color .15s ease; }
.concierge-ui .seg a:hover:not(.on), .concierge-ui .seg button:hover:not(.on) {
  background: rgba(255,255,255,.6);
  color: var(--ink);
}
.concierge-ui .legend-row {
  display: flex;
  gap: 12px;
  align-items: center;
}
.concierge-ui .legend {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink-2);
}
.concierge-ui .legend__swatch {
  width: 8px; height: 8px; border-radius: 4px;
  background: var(--m-green);
}

/* =============================================================
 * INSCRIÇÕES — enrollment cards
 * ============================================================= */
.concierge-ui .enrol-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
}
.concierge-ui .enrol-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: 20px;
  border: 1px solid var(--line-soft);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.concierge-ui .enrol-card__stripe {
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: linear-gradient(180deg, var(--m-amber), var(--m-amber-deep));
}
.concierge-ui .enrol-card--ok .enrol-card__stripe {
  background: linear-gradient(180deg, var(--m-green), var(--m-green-deep));
}
.concierge-ui .enrol-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}
.concierge-ui .enrol-card__code { font-size: 10.5px; font-weight: 800; color: var(--ink-4); letter-spacing: .7px; }
.concierge-ui .enrol-card__title {
  font-size: 17px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.4px;
  margin-top: 3px;
  color: var(--ink);
}
.concierge-ui .enrol-card__trainer { font-size: 12px; color: var(--ink-3); font-weight: 600; margin-top: 5px; }

.concierge-ui .meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.concierge-ui .meta {
  background: var(--bg-2);
  border-radius: 11px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.concierge-ui .meta__label { font-size: 9.5px; color: var(--ink-3); font-weight: 700; letter-spacing: .6px; text-transform: uppercase; }
.concierge-ui .meta__value { font-size: 12px; font-weight: 700; color: var(--ink); margin-top: 1px; }

.concierge-ui .payment-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: var(--m-amber-soft);
  color: #A86A00;
}
.concierge-ui .payment-strip--ok { background: var(--m-green-soft); color: var(--m-green-deep); }
.concierge-ui .payment-strip__kicker { font-size: 10px; font-weight: 800; letter-spacing: .7px; text-transform: uppercase; }
.concierge-ui .payment-strip__value  { font-size: 12.5px; font-weight: 800; margin-top: 1px; }

/* =============================================================
 * BUTTONS (renamed: cz-btn to avoid Bootstrap .btn collision)
 * ============================================================= */
.concierge-ui .cz-btn-row { display: flex; gap: 8px; align-items: stretch; }
.concierge-ui .cz-btn {
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .2s ease, filter .2s ease, background .2s ease, border-color .2s ease;
  white-space: nowrap;
  line-height: 1.2;
}
.concierge-ui .cz-btn:focus-visible {
  outline: 2px solid var(--m-blue);
  outline-offset: 2px;
}
.concierge-ui .cz-btn--primary {
  background: linear-gradient(135deg, var(--m-blue), var(--m-blue-deep));
  color: #fff;
  flex: 1;
  font-weight: 800;
  box-shadow: 0 6px 16px rgba(44,92,255,.3);
}
.concierge-ui .cz-btn--primary:hover {
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(44,92,255,.42);
  transform: translateY(-1px);
  color: #fff;
}
.concierge-ui .cz-btn--primary:active { transform: translateY(0); filter: brightness(.96); }
.concierge-ui .cz-btn--success {
  background: linear-gradient(135deg, var(--m-green), var(--m-green-deep));
  color: #fff;
  font-weight: 800;
  box-shadow: var(--shadow-green);
}
.concierge-ui .cz-btn--success:hover {
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(18,198,121,.42);
  transform: translateY(-1px);
  color: #fff;
}
.concierge-ui .cz-btn--violet {
  background: linear-gradient(135deg, var(--m-violet-deep), var(--m-violet));
  color: #fff;
  font-weight: 800;
  box-shadow: var(--shadow-violet);
}
.concierge-ui .cz-btn--violet:hover {
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(124,58,237,.42);
  transform: translateY(-1px);
  color: #fff;
}
.concierge-ui .cz-btn--ghost {
  background: #fff;
  border: 1px solid var(--line);
  color: var(--ink-2);
  box-shadow: var(--shadow-xs);
}
.concierge-ui .cz-btn--ghost:hover {
  background: var(--bg-2);
  border-color: var(--ink-5);
  color: var(--ink);
  transform: translateY(-1px);
}
/* Square / icon-only ghost button (matches the small file/3-dots button in the design) */
.concierge-ui .cz-btn--icon {
  padding: 0;
  width: 44px;
  flex: 0 0 44px;
  font-size: 16px;
}
/* When wrapped in a Bootstrap .dropdown inside a button row, stretch the
   trigger so it matches the height of the sibling CTA button. */
.concierge-ui .cz-btn-row .dropdown { display: flex; }
.concierge-ui .cz-btn-row .dropdown > .cz-btn--icon { height: 100%; }
.concierge-ui .cz-btn[disabled],
.concierge-ui .cz-btn.is-disabled {
  opacity: .55;
  cursor: not-allowed;
  filter: grayscale(.2);
  box-shadow: none;
  transform: none;
}

/* Dropdown menu polish (Bootstrap dropdowns inside concierge cards) */
.concierge-ui .dropdown-menu {
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 6px;
  font-size: 13px;
  min-width: 200px;
  margin-top: 6px !important;
}
.concierge-ui .dropdown-item {
  border-radius: var(--radius-sm);
  padding: 9px 12px;
  font-weight: 600;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: background .12s ease, color .12s ease;
}
.concierge-ui .dropdown-item:hover,
.concierge-ui .dropdown-item:focus {
  background: var(--bg-2);
  color: var(--ink);
}
.concierge-ui .dropdown-item.text-danger:hover { background: var(--m-red-soft); color: #B42318; }
.concierge-ui .dropdown-item.text-warning:hover { background: var(--m-amber-soft); color: #A86A00; }
.concierge-ui .dropdown-divider { margin: 6px 0; border-color: var(--line-soft); }

/* Payment strip sized + payment-strip click affordance */
.concierge-ui .payment-strip { transition: filter .15s ease, transform .15s ease; }
.concierge-ui .payment-strip[data-bs-toggle="modal"]:hover { filter: brightness(.97); }

/* =============================================================
 * CALENDÁRIO
 * ============================================================= */
.concierge-ui .cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 8px;
}
.concierge-ui .cal-grid-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.concierge-ui .cal-dow { font-size: 10.5px; font-weight: 800; color: var(--ink-3); letter-spacing: 1.2px; padding: 6px 10px; }
.concierge-ui .cal-cell {
  min-height: 96px;
  padding: 10px;
  border-radius: var(--radius);
  background: var(--bg-2);
  color: var(--ink);
  border: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.concierge-ui .cal-cell--empty { background: transparent; border: 0; }
.concierge-ui .cal-cell--today {
  background: linear-gradient(160deg, var(--m-green) 0%, var(--m-green-deep) 100%);
  color: #fff;
  border: 0;
  box-shadow: 0 10px 22px rgba(18,198,121,.3);
}
.concierge-ui .cal-cell__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.concierge-ui .cal-cell__num { font-size: 18px; font-weight: 800; letter-spacing: -0.5px; line-height: 1; }
.concierge-ui .cal-cell__count { font-size: 9.5px; font-weight: 800; color: var(--ink-3); }
.concierge-ui .cal-event {
  background: #fff;
  border-left: 3px solid var(--m-green);
  border: 1px solid rgba(18,198,121,.2);
  border-left: 3px solid var(--m-green);
  border-radius: 7px;
  padding: 3px 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: -0.1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.concierge-ui .cal-event--blue   { border-color: var(--m-blue);   border-left-color: var(--m-blue); }
.concierge-ui .cal-event--amber  { border-color: var(--m-amber);  border-left-color: var(--m-amber); }
.concierge-ui .cal-event--violet { border-color: var(--m-violet); border-left-color: var(--m-violet); }
.concierge-ui .cal-cell--today .cal-event {
  background: rgba(255,255,255,.25);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
}
.concierge-ui .cal-more { font-size: 9.5px; font-weight: 700; color: var(--ink-3); }
.concierge-ui .cal-cell--today .cal-more { color: rgba(255,255,255,.85); }

/* Time row */
.concierge-ui .time-row {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--line-soft);
  align-items: center;
}
.concierge-ui .time-row:first-child { border-top: 0; }
.concierge-ui .time-badge {
  width: 62px;
  text-align: center;
  flex-shrink: 0;
  padding: 8px;
  border-radius: var(--radius-md);
  background: var(--m-green-soft);
  color: var(--m-green-deep);
}
.concierge-ui .time-badge--violet { background: var(--m-violet-soft); color: var(--m-violet-deep); }
.concierge-ui .time-badge--blue   { background: var(--m-blue-soft);   color: var(--m-blue-deep); }
.concierge-ui .time-badge__hour { font-size: 16px; font-weight: 800; letter-spacing: -0.5px; line-height: 1; }
.concierge-ui .time-badge__dur  { font-size: 9.5px; font-weight: 700; letter-spacing: .5px; margin-top: 3px; }

.concierge-ui .day-row {
  display: flex;
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid var(--line-soft);
  align-items: center;
}
.concierge-ui .day-row:first-child { border-top: 0; }
.concierge-ui .day-row__dow { font-size: 10.5px; font-weight: 800; color: var(--ink-3); letter-spacing: .6px; width: 60px; }
.concierge-ui .day-row__accent { width: 3px; height: 32px; border-radius: 3px; background: var(--m-green); }
.concierge-ui .day-row__accent--blue { background: var(--m-blue); }
.concierge-ui .day-row__accent--amber{ background: var(--m-amber); }

/* =============================================================
 * CERTIFICADOS
 * ============================================================= */
.concierge-ui .cert-list { display: flex; flex-direction: column; gap: 10px; }
.concierge-ui .cert-list-item {
  display: flex;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius-lg);
  background: var(--bg-2);
  border-left: 4px solid transparent;
  align-items: center;
  width: 100%;
  text-align: left;
  transition: background .15s;
}
.concierge-ui .cert-list-item:hover { background: var(--soft); }
.concierge-ui .cert-list-item--on {
  background: linear-gradient(160deg, #FFFBEF 0%, #FEF3D7 100%);
  border-left-color: var(--m-amber);
}
.concierge-ui .cert-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius);
  background: var(--m-amber);
  display: grid;
  place-items: center;
  box-shadow: 0 6px 14px rgba(245,158,11,.25);
  flex-shrink: 0;
}
.concierge-ui .cert-icon--blue   { background: var(--m-blue);   box-shadow: 0 6px 14px rgba(44,92,255,.25); }
.concierge-ui .cert-icon--violet { background: var(--m-violet); box-shadow: 0 6px 14px rgba(168,85,247,.25); }
.concierge-ui .cert-list-item__meta { flex: 1; min-width: 0; }
.concierge-ui .cert-list-item__code  { font-size: 10.5px; font-weight: 800; color: var(--ink-4); letter-spacing: .6px; }
.concierge-ui .cert-list-item__title { font-size: 14px; font-weight: 800; letter-spacing: -0.3px; color: var(--ink); margin-top: 2px; }
.concierge-ui .cert-list-item__sub   { font-size: 11.5px; color: var(--ink-3); font-weight: 600; margin-top: 3px; }

.concierge-ui .cert-preview {
  background: #fff;
  border-radius: var(--radius-2xl);
  padding: 30px;
  border: 1px solid var(--line-soft);
  box-shadow: 0 1px 2px rgba(15,20,40,.04), 0 20px 50px rgba(15,20,40,.08);
  aspect-ratio: 1.414 / 1;
  position: relative;
  overflow: hidden;
}
.concierge-ui .cert-preview__bg {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, transparent, transparent 20px, var(--bg-2) 20px, var(--bg-2) 21px);
  opacity: .7;
}
.concierge-ui .cert-preview__wm { position: absolute; top: 22px; right: 22px; }
.concierge-ui .cert-preview__tags { position: absolute; top: 22px; left: 22px; display: flex; gap: 8px; }
.concierge-ui .cert-preview__body {
  position: absolute;
  inset: 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.concierge-ui .cert-preview__kicker { font-size: 10px; font-weight: 800; color: var(--ink-3); letter-spacing: 2.5px; }
.concierge-ui .cert-preview__title {
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -1.2px;
  line-height: 1.05;
  color: var(--ink);
  margin-top: 10px;
  text-wrap: balance;
}
.concierge-ui .cert-preview__prelude { font-size: 12px; color: var(--ink-3); font-weight: 600; margin-top: 14px; }
.concierge-ui .cert-preview__name {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.8px;
  margin-top: 2px;
  font-style: italic;
  color: var(--m-amber);
}
.concierge-ui .cert-preview__name--blue   { color: var(--m-blue); }
.concierge-ui .cert-preview__name--violet { color: var(--m-violet); }
.concierge-ui .cert-preview__desc { font-size: 12px; color: var(--ink-3); font-weight: 500; margin-top: 8px; max-width: 430px; line-height: 1.5; }
.concierge-ui .cert-preview__foot {
  position: absolute;
  bottom: 22px;
  left: 22px;
  right: 22px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.concierge-ui .cert-preview__sig {
  font-family: "Brush Script MT", cursive;
  font-size: 26px;
  color: var(--m-amber);
  transform: rotate(-4deg);
}
.concierge-ui .cert-preview__sig-line {
  border-top: 1px solid var(--line);
  padding-top: 3px;
  font-size: 10px;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .8px;
}
.concierge-ui .cert-preview__seal {
  width: 56px; height: 56px;
  border-radius: 28px;
  border: 2px dashed var(--m-amber);
  display: grid;
  place-items: center;
  color: var(--m-amber);
  font-size: 8px;
  font-weight: 800;
  letter-spacing: .4px;
  text-align: center;
  line-height: 1.2;
}

/* =============================================================
 * MENSAGENS
 * ============================================================= */
.concierge-ui .messages-shell {
  background: #fff;
  border-radius: var(--radius-2xl);
  border: 1px solid var(--line-soft);
  box-shadow: var(--shadow-md);
  display: grid;
  grid-template-columns: 340px 1fr;
  min-height: 640px;
  overflow: hidden;
}
.concierge-ui .thread-list { border-right: 1px solid var(--line-soft); display: flex; flex-direction: column; }
.concierge-ui .thread-list__head { padding: 16px; border-bottom: 1px solid var(--line-soft); }
.concierge-ui .thread-list__search {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-2);
  border-radius: var(--radius-md);
  padding: 9px 12px;
}
.concierge-ui .thread-list__search input {
  flex: 1;
  border: 0; outline: 0;
  background: transparent;
  font-size: 12.5px;
  color: var(--ink);
}
.concierge-ui .thread-tags { display: flex; gap: 6px; margin-top: 12px; flex-wrap: wrap; }
.concierge-ui .thread-tag {
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--bg-2);
  color: var(--ink-2);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .2px;
}
.concierge-ui .thread-tag--on { background: var(--m-violet-soft); color: var(--m-violet-deep); }

.concierge-ui .thread-scroll { flex: 1; overflow-y: auto; }
.concierge-ui .thread-item {
  width: 100%;
  text-align: left;
  background: transparent;
  border-left: 3px solid transparent;
  padding: 14px 16px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  border-bottom: 1px solid var(--softer);
}
.concierge-ui .thread-item--on { background: var(--m-violet-soft); border-left-color: var(--m-violet-deep); }
.concierge-ui .thread-item:hover:not(.thread-item--on) { background: var(--bg-2); }

.concierge-ui .thread-avatar {
  position: relative;
  flex-shrink: 0;
}
.concierge-ui .thread-avatar .avatar { background: var(--m-green); width: 42px; height: 42px; border-radius: var(--radius); font-size: 13px; border: 0; box-shadow: none; }
.concierge-ui .thread-avatar--blue  .avatar { background: var(--m-blue); }
.concierge-ui .thread-avatar--violet .avatar { background: var(--m-violet); }
.concierge-ui .thread-avatar--amber .avatar { background: var(--m-amber); }
.concierge-ui .thread-avatar--green .avatar { background: var(--m-green); }
.concierge-ui .thread-avatar__online {
  position: absolute;
  bottom: -2px; right: -2px;
  width: 12px; height: 12px;
  border-radius: 6px;
  background: var(--m-green);
  border: 2px solid #fff;
}
.concierge-ui .thread-item__body { flex: 1; min-width: 0; }
.concierge-ui .thread-item__row {
  display: flex;
  justify-content: space-between;
  gap: 6px;
}
.concierge-ui .thread-item__name {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.concierge-ui .thread-item__time { font-size: 10.5px; font-weight: 800; color: var(--ink-3); flex-shrink: 0; }
.concierge-ui .thread-item__time--unread { color: var(--m-violet-deep); }
.concierge-ui .thread-item__role { font-size: 11px; color: var(--ink-3); font-weight: 600; margin-top: 1px; }
.concierge-ui .thread-item__last {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 500;
  margin-top: 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 6px;
}
.concierge-ui .thread-item__last--unread { color: var(--ink); font-weight: 700; }
.concierge-ui .thread-badge {
  margin-left: auto;
  background: var(--m-violet-deep);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  padding: 0 5px;
  display: inline-grid;
  place-items: center;
}

/* Conversation */
.concierge-ui .convo { display: flex; flex-direction: column; background: var(--bg-2); }
.concierge-ui .convo__head {
  padding: 16px 22px;
  background: #fff;
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  align-items: center;
  gap: 14px;
}
.concierge-ui .convo__head .thread-avatar .avatar { width: 44px; height: 44px; border-radius: 15px; font-size: 14px; }
.concierge-ui .convo__name { font-size: 15px; font-weight: 800; letter-spacing: -0.3px; }
.concierge-ui .convo__status { font-size: 11.5px; color: var(--ink-3); font-weight: 700; margin-top: 1px; }
.concierge-ui .convo__status--online { color: var(--m-green-deep); }

.concierge-ui .convo__messages {
  flex: 1;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow-y: auto;
}
.concierge-ui .msg-row { display: flex; gap: 10px; }
.concierge-ui .msg-row--me { justify-content: flex-end; }
.concierge-ui .msg-avatar {
  width: 32px; height: 32px;
  border-radius: 11px;
  background: var(--m-green);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 10.5px;
  font-weight: 800;
  flex-shrink: 0;
  align-self: flex-end;
}
.concierge-ui .msg-bubble-wrap { max-width: 68%; }
.concierge-ui .msg-bubble {
  padding: 12px 16px;
  border-radius: 18px;
  background: #fff;
  color: var(--ink);
  font-size: 13.5px;
  line-height: 1.5;
  font-weight: 500;
  border: 1px solid var(--line-soft);
  box-shadow: 0 1px 2px rgba(15,20,40,.04);
  text-wrap: pretty;
  border-bottom-left-radius: 4px;
}
.concierge-ui .msg-bubble--me {
  background: linear-gradient(135deg, var(--m-violet-deep), var(--m-violet));
  color: #fff;
  border: 0;
  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 4px;
}
.concierge-ui .msg-time { font-size: 10.5px; color: var(--ink-3); font-weight: 700; margin-top: 4px; }
.concierge-ui .msg-row--me .msg-time { text-align: right; }

.concierge-ui .attachment {
  background: #fff;
  border-radius: 18px;
  border-bottom-left-radius: 4px;
  border: 1px solid var(--line-soft);
  padding: 12px;
  display: flex;
  gap: 12px;
  align-items: center;
  max-width: 320px;
}
.concierge-ui .attachment__icon {
  width: 44px; height: 44px;
  border-radius: var(--radius);
  background: var(--m-red-soft);
  display: grid;
  place-items: center;
}
.concierge-ui .attachment__name { font-size: 13px; font-weight: 800; letter-spacing: -0.2px; }
.concierge-ui .attachment__meta { font-size: 11px; color: var(--ink-3); font-weight: 600; margin-top: 2px; }

.concierge-ui .composer {
  padding: 16px;
  background: #fff;
  border-top: 1px solid var(--line-soft);
}
.concierge-ui .composer__inner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg-2);
  border-radius: var(--radius-lg);
  padding: 6px 6px 6px 14px;
  border: 1px solid var(--line-soft);
}
.concierge-ui .composer__inner input {
  flex: 1;
  border: 0; outline: 0;
  background: transparent;
  font-size: 13.5px;
  color: var(--ink);
  padding: 10px 0;
}

/* =============================================================
 * INFO TILES (used on profile / dashboards)
 * ============================================================= */
.concierge-ui .info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.concierge-ui .info-grid--5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
@media (max-width: 1200px) {
  .concierge-ui .info-grid--5 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 800px) {
  .concierge-ui .info-grid--5 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .concierge-ui .profile-head { gap: 14px; }
  .concierge-ui .profile-head__actions { margin-left: 0; width: 100%; }
}
@media (max-width: 480px) {
  .concierge-ui .info-grid--5 { grid-template-columns: 1fr; }
}
.concierge-ui .info-tile {
  background: #fff;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  height: 100%;
  box-shadow: var(--shadow-xs);
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.concierge-ui .info-tile:hover {
  border-color: var(--ink-5);
  box-shadow: var(--shadow-sm);
}
.concierge-ui .info-tile__label {
  font-size: 10px;
  font-weight: 800;
  color: var(--ink-3);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.concierge-ui .info-tile__value {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  letter-spacing: -0.2px;
}
.concierge-ui .info-tile__value--muted { color: var(--ink-4); font-weight: 600; }
.concierge-ui .info-tile__value--green { color: var(--m-green-deep); }
.concierge-ui .info-tile__value--blue  { color: var(--m-blue-deep); }
.concierge-ui .info-tile__value--amber { color: #A86A00; }
.concierge-ui .info-tile__value--red   { color: #B42318; }
.concierge-ui .info-tile__sub {
  font-size: 11px;
  color: var(--ink-3);
  font-weight: 600;
}
.concierge-ui .info-tile__chip {
  background: var(--bg-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-pill);
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink-2);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
  flex: 1;
  justify-content: center;
}
.concierge-ui .info-tile__chip:hover {
  background: #fff;
  border-color: var(--ink-5);
  color: var(--ink);
}
.concierge-ui .info-tile__chip--green { color: var(--m-green-deep); }
.concierge-ui .info-tile__chip--blue  { color: var(--m-blue-deep); }
.concierge-ui .info-tile__chip--icon  { flex: 0 0 auto; padding: 6px 10px; }

/* Identity / profile header */
.concierge-ui .profile-head {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}
.concierge-ui .profile-head__avatar {
  width: 96px; height: 96px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #fff;
  box-shadow: 0 0 0 1px var(--line), 0 10px 24px rgba(15,20,40,.08);
  flex-shrink: 0;
}
.concierge-ui .profile-head__meta { flex: 1; min-width: 0; }
.concierge-ui .profile-head__name {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.6px;
  color: var(--ink);
  margin: 0;
}
.concierge-ui .profile-head__chips { display: flex; gap: 8px; margin-top: 6px; flex-wrap: wrap; }
.concierge-ui .profile-head__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-left: auto;
}

/* Compact action button used on profile page (smaller cz-btn variant) */
.concierge-ui .cz-btn--sm {
  padding: 8px 12px;
  font-size: 12.5px;
  border-radius: var(--radius-sm);
}

/* Pills/tabs: nav-pills inside concierge → render as `.seg` look */
.concierge-ui .nav-pills.nav-justified {
  background: var(--soft);
  border-radius: 12px;
  padding: 4px;
  gap: 0 !important;
  border: 1px solid var(--line-soft);
}
.concierge-ui .nav-pills .nav-link {
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--ink-2);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.1px;
  padding: 8px 14px;
  border: 0;
  transition: background .15s ease, color .15s ease;
}
.concierge-ui .nav-pills .nav-link:hover { color: var(--ink); }
.concierge-ui .nav-pills .nav-link.active {
  background: linear-gradient(135deg, var(--m-blue), var(--m-blue-deep));
  color: #fff;
  box-shadow: 0 4px 12px rgba(44,92,255,.28);
}
.concierge-ui .nav-pills .nav-link .badge {
  font-size: 10.5px;
  font-weight: 800;
  padding: 3px 7px;
  border-radius: var(--radius-pill);
  margin-left: 6px;
}
.concierge-ui .nav-pills .nav-link.active .badge {
  background: rgba(255,255,255,.25) !important;
  color: #fff !important;
}

/* Soft empty-state band */
.concierge-ui .empty-band {
  background: var(--bg-2);
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
  padding: 22px;
  text-align: center;
  color: var(--ink-3);
  font-weight: 600;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.concierge-ui .empty-band i { font-size: 18px; opacity: .65; }

/* =============================================================
 * EDITAR PERFIL
 * ============================================================= */
.concierge-ui .profile-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 18px;
}
.concierge-ui .profile-nav {
  background: #fff;
  border-radius: 20px;
  padding: 10px;
  border: 1px solid var(--line-soft);
  height: fit-content;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.concierge-ui .profile-nav__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.2px;
  width: 100%;
}
.concierge-ui .profile-nav__item--on {
  background: #F3FBF6;
  color: var(--m-green-deep);
  font-weight: 800;
}
.concierge-ui .profile-nav__icon {
  width: 32px; height: 32px;
  border-radius: 10px;
  background: var(--soft);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.concierge-ui .profile-nav__item--on .profile-nav__icon {
  background: linear-gradient(135deg, var(--m-green), var(--m-green-deep));
  color: #fff;
}
.concierge-ui .profile-nav__icon svg { stroke: currentColor; }
.concierge-ui .profile-nav__item--on .profile-nav__icon svg { stroke: #fff; }

.concierge-ui .identity-card {
  display: flex;
  align-items: center;
  gap: 20px;
}
.concierge-ui .identity-card__meta { flex: 1; }
.concierge-ui .identity-card__name { font-size: 24px; font-weight: 800; letter-spacing: -0.8px; }
.concierge-ui .identity-card__sub  { font-size: 13px; color: var(--ink-3); font-weight: 600; margin-top: 3px; }
.concierge-ui .identity-card__chips { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.concierge-ui .avatar-action {
  position: absolute;
  bottom: -4px; right: -4px;
  width: 34px; height: 34px;
  border-radius: 17px;
  background: #fff;
  border: 2px solid var(--line);
  display: grid;
  place-items: center;
  color: var(--m-blue);
  box-shadow: 0 4px 10px rgba(15,20,40,.1);
}

.concierge-ui .form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.concierge-ui .field { display: flex; flex-direction: column; gap: 6px; }
.concierge-ui .field--full { grid-column: span 2; }
.concierge-ui .field__label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink-2);
  letter-spacing: -0.1px;
}
.concierge-ui .field__required { color: var(--m-red); }
.concierge-ui .field__input {
  display: flex;
  align-items: center;
  background: var(--bg-2);
  border-radius: var(--radius-md);
  border: 1px solid var(--line-soft);
  padding: 2px 4px;
}
.concierge-ui .field__input input, .concierge-ui .field__input select {
  flex: 1;
  border: 0; outline: 0;
  background: transparent;
  padding: 11px 12px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
}
.concierge-ui .field__hint { font-size: 11px; color: var(--ink-3); font-weight: 500; }

.concierge-ui .upload-card {
  background: var(--bg-2);
  border: 2px dashed var(--ink-5);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.concierge-ui .upload-card--ok {
  background: #F3FBF6;
  border-color: var(--m-green);
}
.concierge-ui .upload-card__icon {
  width: 46px; height: 46px;
  border-radius: var(--radius);
  background: #fff;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.concierge-ui .upload-card--ok .upload-card__icon { background: var(--m-green); border: 0; color: #fff; }
.concierge-ui .upload-card__label { font-size: 13px; font-weight: 800; letter-spacing: -0.2px; }
.concierge-ui .upload-card__meta  { font-size: 11.5px; color: var(--ink-3); font-weight: 600; margin-top: 2px; }
.concierge-ui .upload-card--ok .upload-card__meta { color: var(--m-green-deep); font-weight: 700; }

.concierge-ui .toggle-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  background: var(--bg-2);
  border-radius: var(--radius);
  border: 1px solid var(--line-soft);
  grid-column: span 2;
}
.concierge-ui .toggle-row__label { font-size: 13px; font-weight: 800; letter-spacing: -0.2px; }
.concierge-ui .toggle-row__sub   { font-size: 11.5px; color: var(--ink-3); font-weight: 600; margin-top: 2px; }
.concierge-ui .toggle {
  width: 48px; height: 28px;
  border-radius: 14px;
  background: var(--ink-5);
  position: relative;
  border: 0; padding: 0;
  transition: background .2s;
  flex-shrink: 0;
}
.concierge-ui .toggle::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 22px; height: 22px;
  border-radius: 11px;
  background: #fff;
  transition: left .2s;
  box-shadow: 0 2px 4px rgba(0,0,0,.15);
}
.concierge-ui .toggle--on {
  background: linear-gradient(135deg, var(--m-green), var(--m-green-deep));
}
.concierge-ui .toggle--on::after { left: 23px; }

.concierge-ui .form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line-soft);
}

/* =============================================================
 * CHARTS
 * ============================================================= */

/* Donut (SVG) */
.concierge-ui .donut {
  --size: 160px;
  width: var(--size);
  height: var(--size);
  position: relative;
  flex-shrink: 0;
}
.concierge-ui .donut svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.concierge-ui .donut__track { fill: none; stroke: var(--soft); stroke-width: 12; }
.concierge-ui .donut__arc {
  fill: none;
  stroke-width: 12;
  stroke-linecap: round;
  stroke: var(--m-green);
  transition: stroke-dashoffset .6s ease;
}
.concierge-ui .donut__arc--blue   { stroke: var(--m-blue); }
.concierge-ui .donut__arc--amber  { stroke: var(--m-amber); }
.concierge-ui .donut__arc--violet { stroke: var(--m-violet); }
.concierge-ui .donut__arc--grad-green  { stroke: url(#donut-grad-green); }
.concierge-ui .donut__arc--grad-blue   { stroke: url(#donut-grad-blue); }
.concierge-ui .donut__arc--grad-amber  { stroke: url(#donut-grad-amber); }
.concierge-ui .donut__arc--grad-violet { stroke: url(#donut-grad-violet); }
.concierge-ui .donut__center {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  text-align: center;
}
.concierge-ui .donut__value {
  font-size: 30px; font-weight: 800; letter-spacing: -1px; line-height: 1;
}
.concierge-ui .donut__label {
  font-size: 10px; font-weight: 800; color: var(--ink-3);
  letter-spacing: 1.1px; text-transform: uppercase; margin-top: 4px;
}
.concierge-ui .donut--sm { --size: 84px; }
.concierge-ui .donut--sm .donut__track, .concierge-ui .donut--sm .donut__arc { stroke-width: 9; }
.concierge-ui .donut--sm .donut__value { font-size: 17px; }
.concierge-ui .donut--sm .donut__label { font-size: 8.5px; margin-top: 2px; }
.concierge-ui .donut--lg { --size: 220px; }
.concierge-ui .donut--lg .donut__track, .concierge-ui .donut--lg .donut__arc { stroke-width: 14; }
.concierge-ui .donut--lg .donut__value { font-size: 40px; }

/* Ring row (3 donuts side by side) */
.concierge-ui .ring-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.concierge-ui .ring-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px;
  background: var(--bg-2);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line-soft);
}
.concierge-ui .ring-cell__caption {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -0.2px;
  margin-top: 10px;
  text-align: center;
  color: var(--ink);
}
.concierge-ui .ring-cell__delta {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--m-green-deep);
  margin-top: 3px;
}

/* Bar chart (column) */
.concierge-ui .bars {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  height: 160px;
  padding: 10px 4px 24px;
  position: relative;
}
.concierge-ui .bars--tall { height: 200px; }
.concierge-ui .bars__grid {
  position: absolute;
  inset: 10px 0 24px;
  background-image: linear-gradient(var(--line-soft) 1px, transparent 1px);
  background-size: 100% 25%;
  pointer-events: none;
}
.concierge-ui .bar {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  min-width: 0;
}
.concierge-ui .bar__col {
  width: 100%;
  max-width: 28px;
  border-radius: 8px 8px 3px 3px;
  background: linear-gradient(180deg, var(--m-green) 0%, var(--m-green-deep) 100%);
  min-height: 4px;
  position: relative;
  transition: transform .2s;
}
.concierge-ui .bar__col:hover { transform: translateY(-2px); }
.concierge-ui .bar__col--blue   { background: linear-gradient(180deg, var(--m-blue), var(--m-blue-deep)); }
.concierge-ui .bar__col--amber  { background: linear-gradient(180deg, var(--m-amber), var(--m-amber-deep)); }
.concierge-ui .bar__col--violet { background: linear-gradient(180deg, var(--m-violet), var(--m-violet-deep)); }
.concierge-ui .bar__col--muted  { background: linear-gradient(180deg, #E4E6EC, #CFD2DA); }
.concierge-ui .bar__col--stack {
  border-radius: 3px;
}
.concierge-ui .bar__col--stack:first-child { border-radius: 8px 8px 3px 3px; }
.concierge-ui .bar__val {
  position: absolute;
  top: -18px; left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 800;
  color: var(--ink);
  white-space: nowrap;
}
.concierge-ui .bar__label {
  position: absolute;
  bottom: -20px;
  font-size: 10px;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .3px;
}

/* Horizontal bar (progress list) */
.concierge-ui .hbar-list { display: flex; flex-direction: column; gap: 12px; }
.concierge-ui .hbar {
  display: grid;
  grid-template-columns: 110px 1fr 46px;
  gap: 12px;
  align-items: center;
}
.concierge-ui .hbar__label { font-size: 12px; font-weight: 700; color: var(--ink); letter-spacing: -0.2px; }
.concierge-ui .hbar__track {
  height: 10px;
  border-radius: 5px;
  background: var(--soft);
  overflow: hidden;
  position: relative;
}
.concierge-ui .hbar__fill {
  height: 100%;
  border-radius: 5px;
  background: linear-gradient(90deg, var(--m-green) 0%, var(--m-green-deep) 100%);
  transition: width .5s ease;
}
.concierge-ui .hbar__fill--blue   { background: linear-gradient(90deg, var(--m-blue), var(--m-blue-deep)); }
.concierge-ui .hbar__fill--amber  { background: linear-gradient(90deg, var(--m-amber), var(--m-amber-deep)); }
.concierge-ui .hbar__fill--violet { background: linear-gradient(90deg, var(--m-violet), var(--m-violet-deep)); }
.concierge-ui .hbar__value {
  font-size: 12px;
  font-weight: 800;
  color: var(--ink);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Line chart (SVG) */
.concierge-ui .line-chart {
  width: 100%;
  height: 180px;
  position: relative;
}
.concierge-ui .line-chart svg { width: 100%; height: 100%; }
.concierge-ui .line-chart__grid line { stroke: var(--line-soft); stroke-width: 1; }
.concierge-ui .line-chart__axis-label {
  font-size: 10px;
  font-weight: 700;
  fill: var(--ink-3);
  letter-spacing: .3px;
}
.concierge-ui .line-chart__path {
  fill: none;
  stroke: var(--m-blue);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.concierge-ui .line-chart__area { fill: url(#line-grad); opacity: .18; }
.concierge-ui .line-chart__dot { fill: #fff; stroke: var(--m-blue); stroke-width: 2.5; }

/* Sparkline (inline small trend) */
.concierge-ui .sparkline {
  width: 100px;
  height: 28px;
  display: inline-block;
  vertical-align: middle;
}
.concierge-ui .sparkline path { fill: none; stroke: var(--m-green); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.concierge-ui .sparkline path.area { fill: var(--m-green); fill-opacity: .12; stroke: none; }
.concierge-ui .sparkline--blue path:not(.area) { stroke: var(--m-blue); }
.concierge-ui .sparkline--blue path.area { fill: var(--m-blue); }
.concierge-ui .sparkline--amber path:not(.area) { stroke: var(--m-amber); }
.concierge-ui .sparkline--amber path.area { fill: var(--m-amber); }

/* Attendance streak (heatmap row) */
.concierge-ui .heatmap {
  display: grid;
  grid-template-columns: repeat(20, 1fr);
  gap: 4px;
}
.concierge-ui .heatmap__cell {
  aspect-ratio: 1 / 1;
  border-radius: 4px;
  background: var(--softer);
}
.concierge-ui .heatmap__cell--l1 { background: #D1F3E1; }
.concierge-ui .heatmap__cell--l2 { background: #7CDDA8; }
.concierge-ui .heatmap__cell--l3 { background: #34C77D; }
.concierge-ui .heatmap__cell--l4 { background: var(--m-green-deep); }
.concierge-ui .heatmap__cell--miss { background: #FFDADA; }

/* Progress step (roadmap) */
.concierge-ui .steps { display: flex; gap: 14px; align-items: flex-start; }
.concierge-ui .step {
  flex: 1;
  padding: 14px;
  background: var(--bg-2);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line-soft);
  position: relative;
}
.concierge-ui .step--done {
  background: linear-gradient(160deg, #F3FBF6 0%, #E6F7EE 100%);
  border-color: rgba(18,198,121,.25);
}
.concierge-ui .step--on {
  background: linear-gradient(160deg, #EEF1FF 0%, #E6ECFF 100%);
  border-color: rgba(44,92,255,.25);
  box-shadow: 0 10px 20px rgba(44,92,255,.14);
}
.concierge-ui .step__num {
  width: 28px; height: 28px;
  border-radius: 14px;
  background: var(--ink-5);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 12px;
  font-weight: 800;
}
.concierge-ui .step--done .step__num { background: var(--m-green); }
.concierge-ui .step--on .step__num { background: var(--m-blue); box-shadow: 0 6px 14px rgba(44,92,255,.3); }
.concierge-ui .step__label {
  font-size: 12.5px;
  font-weight: 800;
  letter-spacing: -0.2px;
  margin-top: 10px;
}
.concierge-ui .step__meta { font-size: 10.5px; color: var(--ink-3); font-weight: 600; margin-top: 2px; }

/* Legend */
.concierge-ui .chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line-soft);
  margin-top: 14px;
}
.concierge-ui .chart-legend__item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink-2);
}
.concierge-ui .chart-legend__swatch {
  width: 12px; height: 12px;
  border-radius: 4px;
  background: var(--m-green);
}

/* =============================================================
 * MOBILE TOGGLE (hidden on desktop)
 * ============================================================= */
.concierge-ui .menu-btn {
  display: none;
  width: 40px; height: 40px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--line);
  place-items: center;
}
.concierge-ui .menu-scrim {
  display: none;
  position: fixed; inset: 0;
  background: rgba(15,20,40,.35);
  z-index: 40;
  border: 0;
  cursor: pointer;
}

/* =============================================================
 * RESPONSIVE BREAKPOINTS
 * ============================================================= */

/* ── Tablet (≤ 1100px) ── */
@media (max-width: 1100px) {
  .concierge-ui .sidebar { width: 82px; padding: 18px 10px; }
  .concierge-ui .sidebar-logo .wordmark__name,
  .concierge-ui .sidebar-logo .wordmark__sub,
  .concierge-ui .student-card__name, .concierge-ui .student-card__status,
  .concierge-ui .cz-nav-kicker, .concierge-ui .cz-nav-item__label,
  .concierge-ui .streak-card__kicker, .concierge-ui .streak-card__sub { display: none; }
  .concierge-ui .student-card { padding: 6px; justify-content: center; background: transparent; border: 0; }
  .concierge-ui .streak-card { padding: 12px; text-align: center; }
  .concierge-ui .streak-card__value { font-size: 22px; }
  .concierge-ui .cz-nav-item { justify-content: center; padding: 12px 8px; }
  .concierge-ui .cz-nav-item .cz-nav-badge { position: absolute; top: 4px; right: 4px; }

  .concierge-ui .main-content { padding: 16px 20px 32px; gap: 14px; }
  .concierge-ui .topbar { padding: 14px 20px 6px; }
  .concierge-ui .search { min-width: 0; max-width: none; }

  .concierge-ui .stat-row { grid-template-columns: repeat(2, 1fr); }
  .concierge-ui .stat-row--3 { grid-template-columns: repeat(3, 1fr); }
  .concierge-ui .page-hero { padding: 24px; }
  .concierge-ui .page-hero__title { font-size: 34px; }
  .concierge-ui .page-hero__inner { flex-direction: column; align-items: flex-start; gap: 18px; }

  .concierge-ui .profile-shell { grid-template-columns: 1fr; }
  .concierge-ui .profile-nav { flex-direction: row; overflow-x: auto; gap: 4px; padding: 8px; }
  .concierge-ui .profile-nav__item { flex-shrink: 0; padding: 9px 14px; }
  .concierge-ui .profile-nav__item .profile-nav__icon { display: none; }

  .concierge-ui .messages-shell { grid-template-columns: 280px 1fr; }

  .concierge-ui .cal-cell { min-height: 76px; padding: 6px; }
  .concierge-ui .cal-cell__num { font-size: 14px; }
  .concierge-ui .cal-event { font-size: 9px; padding: 2px 4px; }
}

/* ── Mobile (≤ 760px) ── */
@media (max-width: 760px) {
  /* Drawer sidebar */
  .concierge-ui .menu-btn { display: grid; }

  .concierge-ui .sidebar {
    position: fixed;
    top: 0; left: 0;
    width: 280px;
    height: 100vh;
    z-index: 50;
    padding: 22px 14px 18px;
    transform: translateX(-100%);
    transition: transform .25s ease;
    box-shadow: 0 24px 60px rgba(15,20,40,.2);
  }
  .concierge-ui .sidebar-logo .wordmark__name,
  .concierge-ui .sidebar-logo .wordmark__sub,
  .concierge-ui .student-card__name, .concierge-ui .student-card__status,
  .concierge-ui .cz-nav-kicker, .concierge-ui .cz-nav-item__label,
  .concierge-ui .streak-card__kicker, .concierge-ui .streak-card__sub { display: initial; }
  .concierge-ui .student-card { padding: 14px; background: linear-gradient(160deg, #ECFBF3 0%, #EEF1FF 100%); border: 1px solid rgba(18,198,121,.15); }
  .concierge-ui .streak-card { padding: 18px; text-align: left; }
  .concierge-ui .streak-card__value { font-size: 34px; }
  .concierge-ui .cz-nav-item { justify-content: flex-start; padding: 11px 12px; }
  .concierge-ui .cz-nav-item .cz-nav-badge { position: static; }

  .concierge-ui .app[data-menu-open] .sidebar { transform: translateX(0); }
  .concierge-ui .app[data-menu-open] .menu-scrim { display: block; }

  /* Content full width */
  .concierge-ui .main-content { padding: 14px 14px 28px; gap: 12px; }
  .concierge-ui .topbar { padding: 12px 14px 4px; gap: 10px; flex-wrap: wrap; }
  .concierge-ui .topbar .search { order: 3; flex-basis: 100%; min-width: 0; }
  .concierge-ui .topbar .search kbd { display: none; }
  .concierge-ui .topbar-actions { gap: 6px; }
  .concierge-ui .user-chip__name { display: none; }

  /* Cards */
  .concierge-ui .cz-card { padding: 18px; border-radius: 22px; }
  .concierge-ui .cz-card-title { font-size: 19px; }
  .concierge-ui .cz-card-head { margin-bottom: 14px; flex-direction: column; align-items: flex-start; gap: 8px; }

  /* Stats → single column, tighter */
  .concierge-ui .stat-row { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .concierge-ui .stat-row--3 { grid-template-columns: 1fr; gap: 10px; }
  .concierge-ui .stat { padding: 14px; border-radius: 18px; }
  .concierge-ui .stat__value { font-size: 26px; }

  /* Hero */
  .concierge-ui .page-hero { padding: 22px; border-radius: 22px; }
  .concierge-ui .page-hero__title { font-size: 28px; }
  .concierge-ui .page-hero__subtitle { font-size: 13px; }
  .concierge-ui .hero-meter { min-width: 0; width: 100%; }
  .concierge-ui .hero-meter__value { font-size: 34px; }

  /* Enrol grid → one column */
  .concierge-ui .enrol-grid { grid-template-columns: 1fr; gap: 10px; }
  .concierge-ui .enrol-card { padding: 16px; border-radius: 18px; }
  .concierge-ui .meta-grid { grid-template-columns: 1fr; }

  /* Filter bar stacks */
  .concierge-ui .filter-bar { flex-direction: column; align-items: stretch; gap: 8px; padding: 8px; }
  .concierge-ui .seg { overflow-x: auto; }
  .concierge-ui .seg button, .concierge-ui .seg a { white-space: nowrap; }

  /* Calendar → compact month + stacks */
  .concierge-ui .cal-cell { min-height: 58px; padding: 4px; gap: 2px; border-radius: 9px; }
  .concierge-ui .cal-cell__num { font-size: 12px; }
  .concierge-ui .cal-cell__count { font-size: 8.5px; }
  .concierge-ui .cal-event, .concierge-ui .cal-more { display: none; }
  .concierge-ui .cal-cell--has-events::after {
    content: '';
    width: 5px; height: 5px;
    border-radius: 3px;
    background: var(--m-green);
    margin-top: auto;
  }
  .concierge-ui .cal-cell--today.cal-cell--has-events::after { background: #fff; }

  /* Certificados preview */
  .concierge-ui .cert-preview { padding: 18px; }
  .concierge-ui .cert-preview__body { inset: 40px 30px; }
  .concierge-ui .cert-preview__title { font-size: 22px; }
  .concierge-ui .cert-preview__name { font-size: 20px; }
  .concierge-ui .cert-preview__kicker { font-size: 8.5px; letter-spacing: 1.6px; }
  .concierge-ui .cert-preview__desc { display: none; }
  .concierge-ui .cert-preview__seal { width: 40px; height: 40px; font-size: 6.5px; }

  /* Messages: list stacks above thread, or hide thread by default */
  .concierge-ui .messages-shell {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  .concierge-ui .messages-shell[data-view="list"] .convo { display: none; }
  .concierge-ui .messages-shell[data-view="convo"] .thread-list { display: none; }
  .concierge-ui .convo__messages { padding: 14px; }
  .concierge-ui .msg-bubble-wrap { max-width: 82%; }
  .concierge-ui .convo__head { padding: 12px 14px; }

  /* Profile edit: form full width */
  .concierge-ui .form-grid { grid-template-columns: 1fr; }
  .concierge-ui .field--full { grid-column: auto; }
  .concierge-ui .identity-card { flex-direction: column; text-align: center; align-items: center; }
  .concierge-ui .identity-card__chips { justify-content: center; }

  /* Charts: shrink */
  .concierge-ui .ring-row { grid-template-columns: 1fr; }
  .concierge-ui .ring-cell { padding: 14px; }
  .concierge-ui .donut { --size: 140px; }
  .concierge-ui .donut__value { font-size: 26px; }
  .concierge-ui .bars { height: 140px; }
  .concierge-ui .bar__col { max-width: 22px; }
  .concierge-ui .hbar { grid-template-columns: 86px 1fr 40px; gap: 8px; }

  .concierge-ui .steps { flex-direction: column; }

  /* Footer */
  .concierge-ui .footer { flex-direction: column; gap: 6px; }
}

/* ── Narrow mobile (≤ 380px) tweaks ── */
@media (max-width: 380px) {
  .concierge-ui .stat-row { grid-template-columns: 1fr; }
  .concierge-ui .page-hero__title { font-size: 24px; }
  .concierge-ui .hero-btn, .concierge-ui .cz-btn { padding: 10px 12px; font-size: 12px; }
}

/* Reduced motion — scoped so it does not disable Bootstrap animations globally */
@media (prefers-reduced-motion: reduce) {
  .concierge-ui,
  .concierge-ui *,
  .concierge-ui *::before,
  .concierge-ui *::after {
    transition: none !important;
    animation: none !important;
  }
}
