/* ================================================================
   NÚCLEO CRM — Design System
   AC Soluções Digitais
   ----------------------------------------------------------------
   - Sem build: editar este arquivo afeta o sistema imediatamente.
   - Centraliza tokens (cores, espaçamentos, sombras, radius).
   - Tema dark padrão + tema claro via [data-theme="light"].
   - Pensado para Bootstrap 5 (sobrescreve onde necessário).
   ================================================================ */

/* ---------- 1. TOKENS ---------- */
:root {
    /* Paleta primária */
    --nc-primary-50:  #e8eef4;
    --nc-primary-100: #c3d2e0;
    --nc-primary-200: #8da8c1;
    --nc-primary-300: #4d7ba0;
    --nc-primary-400: #1e4f7d;
    --nc-primary-500: #092746;
    --nc-primary-600: #061b32;
    --nc-primary-700: #03101e;

    --nc-accent-blue:   #3b82f6;
    --nc-accent-cyan:   #06b6d4;
    --nc-accent-pink:   #ec4899;

    --nc-success: #22c55e;
    --nc-warning: #f59e0b;
    --nc-danger:  #ef4444;
    --nc-info:    #3b82f6;

    /* Dark — padrão */
    --nc-bg:          #0f1020;
    --nc-bg-elev-1:   #17182b;
    --nc-bg-elev-2:   #1f2035;
    --nc-bg-elev-3:   #262842;
    --nc-surface:     #1f2035;
    --nc-surface-hover: #262842;
    --nc-sidebar-bg:  #0c0d1c;
    --nc-topbar-bg:   #14152690;

    --nc-text:           #ffffff;
    --nc-text-muted:     #a5a7c5;
    --nc-text-soft:      #7b7d9e;
    --nc-text-on-primary: #ffffff;

    --nc-border:       rgba(255,255,255,0.08);
    --nc-border-strong: rgba(255,255,255,0.16);
    --nc-divider:      rgba(255,255,255,0.06);

    --nc-input-bg:     #14152a;
    --nc-input-border: rgba(255,255,255,0.10);
    --nc-input-focus:  var(--nc-primary-400);

    --nc-shadow-sm: 0 1px 2px rgba(0,0,0,.25);
    --nc-shadow-md: 0 4px 12px rgba(0,0,0,.35);
    --nc-shadow-lg: 0 20px 50px rgba(0,0,0,.45);
    --nc-glow-primary: 0 0 0 3px rgba(30,79,125,.18);

    --nc-radius-sm: 6px;
    --nc-radius:    10px;
    --nc-radius-lg: 14px;
    --nc-radius-xl: 18px;

    --nc-sidebar-w: 264px;
    --nc-sidebar-w-collapsed: 76px;
    --nc-topbar-h: 64px;

    --nc-font:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Tema claro */
[data-theme="light"] {
    --nc-bg:          #f5f7fb;
    --nc-bg-elev-1:   #ffffff;
    --nc-bg-elev-2:   #ffffff;
    --nc-bg-elev-3:   #f1f3f9;
    --nc-surface:     #ffffff;
    --nc-surface-hover: #f6f7fb;
    --nc-sidebar-bg:  #ffffff;
    --nc-topbar-bg:   #ffffffcc;

    --nc-text:        #111827;
    --nc-text-muted:  #6b7280;
    --nc-text-soft:   #9ca3af;

    --nc-border:        #e5e7eb;
    --nc-border-strong: #d1d5db;
    --nc-divider:       #eef0f4;

    --nc-input-bg:      #ffffff;
    --nc-input-border:  #d1d5db;

    --nc-shadow-sm: 0 1px 2px rgba(15,16,32,.06);
    --nc-shadow-md: 0 4px 14px rgba(15,16,32,.07);
    --nc-shadow-lg: 0 20px 50px rgba(15,16,32,.10);
}

/* ---------- 2. BASE ---------- */
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    font-family: var(--nc-font);
    background-color: var(--nc-bg);
    color: var(--nc-text);
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100vh;
}

a { color: var(--nc-primary-400); text-decoration: none; }
a:hover { color: var(--nc-primary-300); }

::selection { background: rgba(30,79,125,.35); color: #fff; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--nc-border-strong); border-radius: 10px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--nc-text-soft); background-clip: padding-box; border: 2px solid transparent; }

/* ---------- 3. LAYOUT ---------- */
.nc-shell { display: flex; min-height: 100vh; }

.nc-sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--nc-sidebar-w);
    background: var(--nc-sidebar-bg);
    border-right: 1px solid var(--nc-border);
    display: flex; flex-direction: column;
    z-index: 1030;
    transition: width .3s cubic-bezier(.4, 0, .2, 1), transform .25s ease;
}

.nc-sidebar__header {
    display: flex; align-items: center;
    height: var(--nc-topbar-h);
    border-bottom: 1px solid var(--nc-divider);
    transition: padding .2s ease;
}
.nc-sidebar__brand {
    flex: 1;
    height: 100%;
    display: flex; align-items: center; gap: .65rem;
    padding: 0 1rem 0 1.25rem;
    color: var(--nc-text);
    font-weight: 700; font-size: 1.05rem; letter-spacing: -0.01em;
    min-width: 0;
}
.nc-sidebar__brand-text { min-width: 0; flex: 1; line-height: 1.15; }
.nc-sidebar__brand-text small { display: block; }
.nc-sidebar__collapse-btn {
    flex-shrink: 0;
    width: 30px; height: 30px;
    margin-right: .5rem;
    border-radius: 8px;
    background: transparent;
    color: var(--nc-text-soft);
    border: 1px solid var(--nc-border);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .15s, color .15s, transform .25s ease;
}
.nc-sidebar__collapse-btn:hover { background: var(--nc-surface-hover); color: var(--nc-text); }
.nc-sidebar__collapse-btn i { font-size: .85rem; transition: transform .25s ease; }
.nc-sidebar__brand-mark {
    width: 32px; height: 32px;
    border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--nc-primary-500), var(--nc-accent-blue));
    box-shadow: 0 6px 16px rgba(30,79,125,.45);
    color: #fff; font-size: 1rem;
}
.nc-sidebar__brand-mark::before {
    content: ""; width: 12px; height: 12px; border-radius: 50%;
    background: rgba(255,255,255,.92);
    box-shadow: 0 0 12px rgba(255,255,255,.75);
}
.nc-sidebar__brand small { display: block; font-size: .68rem; font-weight: 400; color: var(--nc-text-muted); margin-top: 2px; }

.nc-sidebar__user { min-width: 0; }

.nc-sidebar__scroll { flex: 1; overflow-y: auto; padding: .75rem .5rem 1rem; }
.nc-sidebar__section {
    text-transform: uppercase;
    font-size: .65rem;
    letter-spacing: .12em;
    color: var(--nc-text-soft);
    padding: 1rem .85rem .4rem;
    font-weight: 600;
}

.nc-nav { display: flex; flex-direction: column; gap: 2px; }
.nc-nav__link {
    display: flex; align-items: center; gap: .75rem;
    padding: .55rem .85rem;
    color: var(--nc-text-muted);
    border-radius: var(--nc-radius);
    font-size: .9rem;
    font-weight: 500;
    transition: background .15s, color .15s;
    position: relative;
}
.nc-nav__link i { font-size: 1.05rem; width: 20px; text-align: center; color: var(--nc-text-soft); }
.nc-nav__link:hover { background: var(--nc-surface-hover); color: var(--nc-text); }
.nc-nav__link:hover i { color: var(--nc-primary-300); }
.nc-nav__link.is-active {
    background: linear-gradient(90deg, rgba(30,79,125,.18), rgba(30,79,125,0));
    color: var(--nc-text);
}
.nc-nav__link.is-active i { color: var(--nc-primary-400); }
.nc-nav__link.is-active::before {
    content: ""; position: absolute; left: -8px; top: 25%; bottom: 25%;
    width: 3px; background: var(--nc-primary-400); border-radius: 0 3px 3px 0;
}
.nc-nav__badge {
    margin-left: auto; font-size: .7rem; font-weight: 600;
    background: var(--nc-primary-500); color: #fff;
    padding: 1px 7px; border-radius: 999px;
}

.nc-sidebar__footer {
    padding: .85rem 1rem;
    border-top: 1px solid var(--nc-divider);
    display: flex; align-items: center; gap: .7rem;
}
.nc-sidebar__avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: linear-gradient(135deg, var(--nc-primary-500), var(--nc-accent-blue));
    color: #fff; display: inline-flex; align-items: center; justify-content: center;
    font-weight: 600; font-size: .85rem;
    flex-shrink: 0;
    position: relative;
}
.nc-sidebar__user-name { font-size: .85rem; color: var(--nc-text); font-weight: 600; line-height: 1.2; }
.nc-sidebar__user-mail { font-size: .72rem; color: var(--nc-text-soft); line-height: 1.2; }

/* Conteúdo */
.nc-main {
    flex: 1;
    margin-left: var(--nc-sidebar-w);
    min-height: 100vh;
    display: flex; flex-direction: column;
    transition: margin-left .3s cubic-bezier(.4, 0, .2, 1);
}

.nc-topbar {
    height: var(--nc-topbar-h);
    padding: 0 1.5rem;
    background: var(--nc-topbar-bg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--nc-border);
    display: flex; align-items: center; gap: 1rem;
    position: sticky; top: 0; z-index: 1020;
}
.nc-topbar__search {
    flex: 1; max-width: 420px;
    position: relative;
}
.nc-topbar__search i {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: var(--nc-text-soft); font-size: .95rem;
}
.nc-topbar__search input {
    width: 100%;
    background: var(--nc-input-bg);
    border: 1px solid var(--nc-input-border);
    border-radius: var(--nc-radius);
    color: var(--nc-text);
    padding: .55rem .85rem .55rem 2.4rem;
    font-size: .88rem;
    transition: border-color .15s, box-shadow .15s;
}
.nc-topbar__search input::placeholder { color: var(--nc-text-soft); }
.nc-topbar__search input:focus { outline: none; border-color: var(--nc-primary-400); box-shadow: var(--nc-glow-primary); }

.nc-icon-btn {
    width: 38px; height: 38px;
    background: transparent;
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
    color: var(--nc-text-muted);
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s, color .15s, border-color .15s;
    position: relative;
}
.nc-icon-btn:hover { background: var(--nc-surface-hover); color: var(--nc-text); border-color: var(--nc-border-strong); }
.nc-icon-btn__dot {
    position: absolute; top: 6px; right: 6px;
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--nc-danger);
    border: 2px solid var(--nc-topbar-bg);
}

.nc-content { padding: 1.5rem 1.75rem 2rem; flex: 1; }

/* ---------- 4. PAGE HEADER ---------- */
.nc-page-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.nc-page-header__title { font-size: 1.55rem; font-weight: 700; letter-spacing: -0.01em; margin: 0; color: var(--nc-text); }
.nc-page-header__subtitle { color: var(--nc-text-muted); margin-top: .25rem; font-size: .9rem; }
.nc-breadcrumb { display: flex; align-items: center; gap: .35rem; font-size: .8rem; color: var(--nc-text-soft); margin-bottom: .35rem; }
.nc-breadcrumb a { color: var(--nc-text-muted); }
.nc-breadcrumb .sep { opacity: .5; }

/* ---------- 5. CARDS ---------- */
.nc-card {
    background: var(--nc-surface);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-lg);
    box-shadow: var(--nc-shadow-sm);
    overflow: hidden;
}
.nc-card__header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--nc-divider);
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.nc-card__title { font-size: .95rem; font-weight: 600; margin: 0; color: var(--nc-text); }
.nc-card__subtitle { font-size: .8rem; color: var(--nc-text-muted); margin-top: 2px; }
.nc-card__body { padding: 1.25rem; }
.nc-card__footer { padding: .85rem 1.25rem; border-top: 1px solid var(--nc-divider); }

.nc-stat {
    background: var(--nc-surface);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-lg);
    padding: 1.1rem 1.2rem;
    display: flex; flex-direction: column; gap: .35rem;
    box-shadow: var(--nc-shadow-sm);
    position: relative; overflow: hidden;
    transition: transform .15s, box-shadow .15s;
}
.nc-stat:hover { transform: translateY(-1px); box-shadow: var(--nc-shadow-md); }
.nc-stat__head { display: flex; align-items: center; gap: .65rem; color: var(--nc-text-muted); font-size: .82rem; font-weight: 500; }
.nc-stat__icon {
    width: 32px; height: 32px;
    border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(30,79,125,.14);
    color: var(--nc-primary-300);
    font-size: 1rem;
}
.nc-stat__icon--blue { background: rgba(59,130,246,.14); color: #60a5fa; }
.nc-stat__icon--green { background: rgba(34,197,94,.14); color: #4ade80; }
.nc-stat__icon--orange { background: rgba(245,158,11,.14); color: #fbbf24; }
.nc-stat__icon--pink { background: rgba(236,72,153,.14); color: #f472b6; }
.nc-stat__value { font-size: 1.7rem; font-weight: 700; letter-spacing: -0.02em; color: var(--nc-text); line-height: 1.15; }
.nc-stat__hint { display: flex; align-items: center; gap: .35rem; font-size: .78rem; color: var(--nc-text-soft); }

/* ---------- 6. BADGES ---------- */
.nc-badge {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .2rem .55rem;
    border-radius: 999px;
    font-size: .72rem; font-weight: 600;
    line-height: 1.4;
    border: 1px solid transparent;
}
.nc-badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: .9; }
.nc-badge--neutral { background: rgba(255,255,255,.06); color: var(--nc-text-muted); }
.nc-badge--primary { background: rgba(30,79,125,.16); color: var(--nc-primary-300); }
.nc-badge--success { background: rgba(34,197,94,.14); color: #4ade80; }
.nc-badge--warning { background: rgba(245,158,11,.14); color: #fbbf24; }
.nc-badge--danger  { background: rgba(239,68,68,.14); color: #fca5a5; }
.nc-badge--info    { background: rgba(59,130,246,.14); color: #60a5fa; }
[data-theme="light"] .nc-badge--neutral { background: #f1f3f9; color: #4b5563; }

/* ---------- 7. BUTTONS ---------- */
.nc-btn {
    display: inline-flex; align-items: center; gap: .45rem;
    padding: .55rem 1rem;
    border-radius: var(--nc-radius);
    font-size: .88rem; font-weight: 600;
    border: 1px solid transparent;
    cursor: pointer; user-select: none;
    transition: background .15s, color .15s, border-color .15s, box-shadow .15s, transform .05s;
    white-space: nowrap;
}
.nc-btn:active { transform: translateY(1px); }
.nc-btn--primary { background: var(--nc-primary-500); color: #fff; }
.nc-btn--primary:hover { background: var(--nc-primary-600); color: #fff; box-shadow: 0 6px 18px rgba(30,79,125,.35); }
.nc-btn--secondary { background: var(--nc-surface); color: var(--nc-text); border-color: var(--nc-border-strong); }
.nc-btn--secondary:hover { background: var(--nc-surface-hover); color: var(--nc-text); }
.nc-btn--ghost { background: transparent; color: var(--nc-text-muted); }
.nc-btn--ghost:hover { background: var(--nc-surface-hover); color: var(--nc-text); }
.nc-btn--danger { background: var(--nc-danger); color: #fff; }
.nc-btn--danger:hover { background: #dc2626; color: #fff; box-shadow: 0 6px 18px rgba(239,68,68,.35); }
.nc-btn--sm { padding: .38rem .7rem; font-size: .8rem; }
.nc-btn--lg { padding: .75rem 1.25rem; font-size: .95rem; }

/* ---------- 8. FORMS ---------- */
.nc-form-label { display: block; font-size: .82rem; font-weight: 500; color: var(--nc-text-muted); margin-bottom: .35rem; }
.nc-form-control,
.form-control, .form-select {
    background: var(--nc-input-bg);
    border: 1px solid var(--nc-input-border);
    color: var(--nc-text);
    border-radius: var(--nc-radius);
    padding: .55rem .85rem;
    font-size: .9rem;
    transition: border-color .15s, box-shadow .15s, background .15s;
    width: 100%;
}
.form-control::placeholder { color: var(--nc-text-soft); }
.form-control:focus, .form-select:focus, .nc-form-control:focus {
    background: var(--nc-input-bg);
    border-color: var(--nc-primary-400);
    box-shadow: var(--nc-glow-primary);
    color: var(--nc-text);
    outline: none;
}
.form-control:disabled { opacity: .6; }

textarea.form-control { min-height: 110px; }
.form-check-input { background-color: var(--nc-input-bg); border-color: var(--nc-input-border); }
.form-check-input:checked { background-color: var(--nc-primary-500); border-color: var(--nc-primary-500); }

.nc-form-error { color: #fca5a5; font-size: .78rem; margin-top: .3rem; }
[data-theme="light"] .nc-form-error { color: #b91c1c; }
.is-invalid { border-color: var(--nc-danger) !important; }

/* ---------- 9. TABLES ---------- */
.nc-table-wrap { background: var(--nc-surface); border: 1px solid var(--nc-border); border-radius: var(--nc-radius-lg); overflow: hidden; }
.nc-table-toolbar {
    display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
    padding: 1rem 1.25rem; border-bottom: 1px solid var(--nc-divider);
}
.nc-table { width: 100%; border-collapse: collapse; }
.nc-table thead th {
    text-align: left;
    background: transparent;
    color: var(--nc-text-soft);
    font-weight: 600; font-size: .76rem;
    text-transform: uppercase; letter-spacing: .06em;
    padding: .85rem 1.25rem;
    border-bottom: 1px solid var(--nc-divider);
}
.nc-table tbody td {
    padding: .9rem 1.25rem;
    border-bottom: 1px solid var(--nc-divider);
    color: var(--nc-text); font-size: .88rem;
    vertical-align: middle;
}
.nc-table tbody tr:last-child td { border-bottom: 0; }
.nc-table tbody tr:hover { background: var(--nc-surface-hover); }

.nc-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--nc-primary-500), var(--nc-accent-blue));
    color: #fff; font-size: .75rem; font-weight: 600;
    flex-shrink: 0;
    overflow: hidden;
}
.nc-avatar--xs { width: 22px; height: 22px; font-size: .58rem; }
.nc-avatar--sm { width: 26px; height: 26px; font-size: .65rem; }
.nc-avatar--md { width: 32px; height: 32px; font-size: .75rem; }
.nc-avatar--lg { width: 48px; height: 48px; font-size: 1.05rem; }

/* Quando renderiza <img>: ocupa todo o circulo + cover */
.nc-avatar--img { background: transparent; padding: 0; }
.nc-avatar--img img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}

/* ---------- 10. EMPTY STATE ---------- */
.nc-empty { padding: 3rem 1.5rem; text-align: center; color: var(--nc-text-muted); }
.nc-empty__icon {
    width: 64px; height: 64px; border-radius: 16px;
    background: var(--nc-bg-elev-3);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--nc-text-soft); font-size: 1.5rem;
    margin-bottom: 1rem;
}
.nc-empty__title { color: var(--nc-text); font-weight: 600; margin-bottom: .35rem; }
.nc-empty__desc { font-size: .88rem; max-width: 380px; margin: 0 auto; }

/* ---------- 11. ALERTS / FLASH ---------- */
.nc-alert {
    display: flex; align-items: flex-start; gap: .65rem;
    padding: .85rem 1rem;
    border-radius: var(--nc-radius);
    border: 1px solid transparent;
    margin-bottom: 1rem;
    font-size: .88rem;
}
.nc-alert i { font-size: 1.05rem; margin-top: 1px; }
.nc-alert--success { background: rgba(34,197,94,.10); border-color: rgba(34,197,94,.35); color: #86efac; }
.nc-alert--danger  { background: rgba(239,68,68,.10); border-color: rgba(239,68,68,.35); color: #fca5a5; }
.nc-alert--warning { background: rgba(245,158,11,.10); border-color: rgba(245,158,11,.35); color: #fbbf24; }
.nc-alert--info    { background: rgba(59,130,246,.10); border-color: rgba(59,130,246,.35); color: #93c5fd; }

/* ---------- 12. MODAL (sobrescreve Bootstrap) ---------- */
.modal-content {
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-lg);
    color: var(--nc-text);
    box-shadow: var(--nc-shadow-lg);
}
.modal-header, .modal-footer { border-color: var(--nc-divider); }
.modal-backdrop.show { opacity: .65; }

/* Dropdown */
.dropdown-menu {
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
    box-shadow: var(--nc-shadow-md);
    padding: .35rem;
}
.dropdown-item {
    color: var(--nc-text-muted);
    border-radius: 6px;
    padding: .4rem .65rem;
    font-size: .85rem;
}
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--nc-surface-hover);
    color: var(--nc-text);
}
.dropdown-divider { border-color: var(--nc-divider); }

/* ---------- 13. UTILS ---------- */
.nc-divider { height: 1px; background: var(--nc-divider); margin: 1rem 0; }
.nc-tag { display: inline-flex; align-items: center; gap: .3rem; padding: .15rem .5rem; border-radius: 6px; background: var(--nc-bg-elev-3); color: var(--nc-text-muted); font-size: .72rem; font-weight: 500; }
.nc-text-muted { color: var(--nc-text-muted) !important; }
.nc-text-soft  { color: var(--nc-text-soft) !important; }
.nc-link { color: var(--nc-primary-300); }
.nc-link:hover { color: var(--nc-primary-200); }

/* Pagination Bootstrap */
.pagination { gap: 3px; }
.page-link {
    background: transparent; border: 1px solid var(--nc-border);
    color: var(--nc-text-muted); border-radius: 8px !important;
    padding: .35rem .7rem; font-size: .85rem;
}
.page-link:hover { background: var(--nc-surface-hover); color: var(--nc-text); border-color: var(--nc-border-strong); }
.page-item.active .page-link { background: var(--nc-primary-500); border-color: var(--nc-primary-500); color: #fff; }
.page-item.disabled .page-link { opacity: .4; }

/* ---------- 14. AUTH ---------- */
.nc-auth-shell {
    min-height: 100vh;
    display: flex; align-items: center; justify-content: center;
    padding: 2rem 1rem;
    background:
        radial-gradient(900px 600px at 10% 10%, rgba(30,79,125,.18), transparent 60%),
        radial-gradient(900px 600px at 90% 90%, rgba(59,130,246,.12), transparent 60%),
        var(--nc-bg);
}
[data-theme="light"] .nc-auth-shell {
    background:
        radial-gradient(900px 600px at 10% 10%, rgba(30,79,125,.10), transparent 60%),
        radial-gradient(900px 600px at 90% 90%, rgba(59,130,246,.08), transparent 60%),
        var(--nc-bg);
}
.nc-auth-card {
    width: 100%; max-width: 420px;
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-xl);
    padding: 2rem;
    box-shadow: var(--nc-shadow-lg);
}
.nc-auth-card--wide { max-width: 540px; }
.nc-auth-brand { text-align: center; margin-bottom: 1.5rem; }
.nc-auth-brand-mark {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--nc-primary-500), var(--nc-accent-blue));
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: .85rem;
    box-shadow: 0 12px 32px rgba(30,79,125,.45);
    position: relative;
}
.nc-auth-brand-mark::before {
    content: ""; width: 20px; height: 20px; border-radius: 50%;
    background: rgba(255,255,255,.94);
    box-shadow: 0 0 18px rgba(255,255,255,.65);
}
.nc-auth-brand-title { color: var(--nc-text); font-size: 1.25rem; font-weight: 700; letter-spacing: -0.01em; }
.nc-auth-brand-sub   { color: var(--nc-text-muted); font-size: .82rem; margin-top: 2px; }

/* ---------- 14B. SIDEBAR COLAPSADA (desktop, padrão Larafood) ----------
   Aplicado quando o <html> tem .nc-sidebar-collapsed e a viewport >= 992px.
   No mobile, a sidebar usa o comportamento de overlay (seção 15). */
@media (min-width: 992px) {
    html.nc-sidebar-collapsed .nc-sidebar { width: var(--nc-sidebar-w-collapsed); }
    html.nc-sidebar-collapsed .nc-main    { margin-left: var(--nc-sidebar-w-collapsed); }

    /* Header vira coluna: logo em cima, botão embaixo (como no Larafood). */
    html.nc-sidebar-collapsed .nc-sidebar__header {
        flex-direction: column;
        height: auto;
        padding: .65rem .35rem;
        gap: .35rem;
    }
    html.nc-sidebar-collapsed .nc-sidebar__brand {
        padding: 0;
        justify-content: center;
        gap: 0;
        height: auto;
    }
    html.nc-sidebar-collapsed .nc-sidebar__brand-text { display: none; }
    html.nc-sidebar-collapsed .nc-sidebar__collapse-btn { margin: 0; }
    html.nc-sidebar-collapsed .nc-sidebar__collapse-btn i { transform: rotate(180deg); }

    /* Section labels viram divisores discretos */
    html.nc-sidebar-collapsed .nc-sidebar__section {
        padding: .6rem 0 .3rem;
        text-align: center;
    }
    html.nc-sidebar-collapsed .nc-sidebar__section span { display: none; }
    html.nc-sidebar-collapsed .nc-sidebar__section::after {
        content: ""; display: block;
        height: 1px; margin: 0 .85rem;
        background: var(--nc-divider);
    }

    /* Links: só ícones centralizados */
    html.nc-sidebar-collapsed .nc-sidebar__scroll { padding: .75rem .35rem 1rem; }
    html.nc-sidebar-collapsed .nc-nav__link {
        justify-content: center;
        padding: .6rem 0;
        gap: 0;
    }
    html.nc-sidebar-collapsed .nc-nav__link .nc-nav__label { display: none; }
    html.nc-sidebar-collapsed .nc-nav__link i { width: 22px; font-size: 1.1rem; margin: 0; }
    html.nc-sidebar-collapsed .nc-nav__link.is-active::before { left: -6px; top: 30%; bottom: 30%; }

    /* Footer: só avatar centralizado */
    html.nc-sidebar-collapsed .nc-sidebar__footer {
        flex-direction: column;
        padding: .75rem .35rem;
        gap: .5rem;
    }
    html.nc-sidebar-collapsed .nc-sidebar__user,
    html.nc-sidebar-collapsed .nc-sidebar__profile-btn { display: none; }
}

/* Tooltip global da sidebar colapsada (position: fixed para escapar do scroll clipping) */
.nc-sidebar-tooltip {
    position: fixed;
    transform: translateY(-50%);
    background: var(--nc-surface);
    color: var(--nc-text);
    padding: .4rem .7rem;
    border-radius: 6px;
    border: 1px solid var(--nc-border);
    font-size: .8rem;
    font-weight: 500;
    line-height: 1.2;
    white-space: nowrap;
    box-shadow: 0 8px 22px rgba(0,0,0,.35);
    z-index: 10000;
    opacity: 0;
    pointer-events: none;
    transition: opacity .12s ease-out, transform .12s ease-out;
}
.nc-sidebar-tooltip.is-visible {
    opacity: 1;
}
.nc-sidebar-tooltip::before {
    content: "";
    position: absolute;
    right: 100%;
    top: 50%;
    transform: translateY(-50%);
    border: 5px solid transparent;
    border-right-color: var(--nc-surface);
}

/* ---------- 15. RESPONSIVO ---------- */
@media (max-width: 1199.98px) {
    .nc-content { padding: 1.25rem; }
}

@media (max-width: 991.98px) {
    .nc-sidebar { transform: translateX(-100%); }
    .nc-sidebar.is-open { transform: translateX(0); }
    .nc-main { margin-left: 0; }
    .nc-topbar { padding: 0 1rem; }
    .nc-topbar__search { max-width: 100%; }
}

@media (max-width: 575.98px) {
    .nc-page-header { flex-direction: column; align-items: flex-start; }
    .nc-content { padding: 1rem; }
    .nc-stat__value { font-size: 1.4rem; }
}

/* Overlay para sidebar mobile */
.nc-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 1025;
    opacity: 0; pointer-events: none;
    transition: opacity .2s;
}
.nc-overlay.is-active { opacity: 1; pointer-events: auto; }
[data-theme="light"] .nc-overlay { background: rgba(15,16,32,.35); }

/* ---------- 16. TICKET REPLY (editor Quill + anexos + áudio) ---------- */
/* Quill 2 — overrides para tema dark do Núcleo */
.ql-toolbar.ql-snow {
    background: var(--nc-input-bg);
    border: 1px solid var(--nc-input-border);
    border-radius: var(--nc-radius) var(--nc-radius) 0 0;
    border-bottom: 0;
}
.ql-container.ql-snow {
    background: var(--nc-input-bg);
    border: 1px solid var(--nc-input-border);
    border-radius: 0 0 var(--nc-radius) var(--nc-radius);
    color: var(--nc-text);
    font-family: var(--nc-font);
    font-size: 14px;
}
.ql-editor { min-height: 160px; color: var(--nc-text); }
.ql-snow .ql-editor.ql-blank::before { color: var(--nc-text) !important; font-style: normal !important; opacity: .85 !important; }
/* Toolbar: usa --nc-text (branco no dark, escuro no light). !important + maior
   especificidade pra vencer a CSS do Quill via CDN. */
.ql-toolbar.ql-snow .ql-stroke,
.ql-snow .ql-toolbar .ql-stroke,
.ql-snow .ql-stroke { stroke: var(--nc-text) !important; }
.ql-toolbar.ql-snow .ql-fill,
.ql-snow .ql-toolbar .ql-fill,
.ql-snow .ql-fill { fill: var(--nc-text) !important; }
.ql-toolbar.ql-snow .ql-picker,
.ql-toolbar.ql-snow .ql-picker-label,
.ql-snow .ql-picker { color: var(--nc-text) !important; }
.ql-toolbar.ql-snow button:hover,
.ql-toolbar.ql-snow button.ql-active,
.ql-toolbar.ql-snow .ql-picker-label:hover,
.ql-toolbar.ql-snow .ql-picker-label.ql-active { color: var(--nc-primary-300) !important; }
.ql-toolbar.ql-snow button:hover .ql-stroke,
.ql-toolbar.ql-snow button.ql-active .ql-stroke { stroke: var(--nc-primary-300) !important; }
.ql-toolbar.ql-snow button:hover .ql-fill,
.ql-toolbar.ql-snow button.ql-active .ql-fill { fill: var(--nc-primary-300) !important; }
.ql-snow .ql-picker-options {
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border) !important;
    color: var(--nc-text);
}
.ql-snow .ql-tooltip {
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    color: var(--nc-text);
    box-shadow: var(--nc-shadow-md);
}
.ql-snow .ql-tooltip input[type=text] {
    background: var(--nc-input-bg);
    border: 1px solid var(--nc-input-border);
    color: var(--nc-text);
}
.ql-editor a { color: var(--nc-primary-300); }
.ql-editor blockquote {
    border-left: 4px solid var(--nc-border-strong);
    padding-left: 1rem;
    color: var(--nc-text-muted);
}
.ql-editor pre.ql-syntax,
.ql-editor pre {
    background: var(--nc-bg-elev-3);
    color: var(--nc-text);
    border-radius: 6px;
    padding: .75rem 1rem;
}

/* ============================================================
   Wave Player (WhatsApp-style com wavesurfer.js)
   ============================================================ */
.nc-wave-player {
    display: flex;
    align-items: center;
    gap: .75rem;
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: 22px;
    padding: .5rem .85rem .5rem .55rem;
    max-width: 420px;
    margin: 6px 0;
}
.nc-wave-player__play {
    flex: 0 0 36px;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--nc-primary-300);
    color: #ffffff;
    border: 0;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: transform .15s, background .15s;
    font-size: 1.1rem;
}
.nc-wave-player__play:hover { transform: scale(1.05); }
.nc-wave-player__wave {
    flex: 1 1 auto;
    min-width: 120px;
    height: 38px;
    cursor: pointer;
}
.nc-wave-player__time {
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
    font-size: .78rem;
    color: var(--nc-text-soft);
    min-width: 38px;
    text-align: right;
}
.nc-wave-player__dl {
    flex: 0 0 auto;
}

/* Renderização das mensagens no histórico */
.nc-ticket-content { color: var(--nc-text); line-height: 1.55; font-size: .92rem; word-wrap: break-word; }
.nc-ticket-content p { margin: 0 0 .65rem; }
.nc-ticket-content p:last-child { margin-bottom: 0; }
.nc-ticket-content a { color: var(--nc-primary-300); }
.nc-ticket-content blockquote {
    margin: .5rem 0;
    padding: .35rem 1rem;
    border-left: 3px solid var(--nc-primary-400);
    color: var(--nc-text-muted);
}
.nc-ticket-content ul, .nc-ticket-content ol { padding-left: 1.25rem; margin: .35rem 0 .85rem; }
.nc-ticket-content pre, .nc-ticket-content code {
    background: var(--nc-bg-elev-3);
    border-radius: 6px;
    padding: 2px 6px;
    font-size: .85em;
}
.nc-ticket-content pre { padding: .75rem 1rem; overflow-x: auto; }
.nc-ticket-content img { max-width: 100%; border-radius: 6px; }
.nc-ticket-content table { border-collapse: collapse; margin: .5rem 0; }
.nc-ticket-content table td, .nc-ticket-content table th {
    border: 1px solid var(--nc-border);
    padding: .35rem .65rem;
}

/* Chips de arquivos selecionados antes do envio */
.nc-file-chips { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .5rem; }
.nc-file-chip {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .35rem .6rem;
    background: var(--nc-bg-elev-3);
    border: 1px solid var(--nc-border);
    border-radius: 999px;
    font-size: .8rem;
    color: var(--nc-text);
    max-width: 100%;
}
.nc-file-chip i { color: var(--nc-primary-300); }
.nc-file-chip__name {
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 220px;
}
.nc-file-chip__size { color: var(--nc-text-soft); font-size: .7rem; }
.nc-file-chip__remove {
    background: transparent; border: 0; color: var(--nc-text-soft);
    cursor: pointer; padding: 0 2px; line-height: 1;
    display: inline-flex; align-items: center;
}
.nc-file-chip__remove:hover { color: var(--nc-danger); }

/* Anexos no histórico */
.nc-attachment-list { display: flex; flex-direction: column; gap: .4rem; margin-top: .6rem; }
.nc-attachment-item {
    display: flex; align-items: center; gap: .55rem;
    padding: .45rem .65rem;
    background: var(--nc-bg-elev-1);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
    font-size: .82rem;
    color: var(--nc-text);
    text-decoration: none;
}
.nc-attachment-item:hover {
    background: var(--nc-surface-hover); color: var(--nc-text);
    border-color: var(--nc-border-strong);
}
.nc-attachment-item i { color: var(--nc-primary-300); font-size: 1rem; }
.nc-attachment-item__name {
    flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nc-attachment-item__meta { color: var(--nc-text-soft); font-size: .72rem; }

/* Player de áudio inline (histórico e preview) */
.nc-audio-inline audio { width: 100%; max-width: 360px; height: 36px; }
.nc-audio-block {
    display: flex; align-items: center; gap: .65rem; margin-top: .6rem;
    padding: .5rem .65rem;
    background: var(--nc-bg-elev-3);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
}
.nc-audio-block audio { flex: 1; height: 36px; }
.nc-audio-timer {
    font-variant-numeric: tabular-nums; margin-left: .25rem; font-size: .85rem;
}

/* Imagem inline (anexo de ticket) */
.nc-attachment-image {
    margin: .6rem 0 0;
    max-width: 320px;
    background: var(--nc-bg-elev-1);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
    overflow: hidden;
    display: inline-flex; flex-direction: column;
}
.nc-attachment-image__thumb {
    padding: 0; border: 0; background: transparent; cursor: zoom-in;
    display: block; line-height: 0;
}
.nc-attachment-image__thumb img {
    width: 100%; max-height: 220px; object-fit: cover;
    display: block; transition: transform .2s;
}
.nc-attachment-image__thumb:hover img { transform: scale(1.02); }
.nc-attachment-image__caption {
    display: flex; align-items: center; gap: .5rem;
    padding: .4rem .6rem; font-size: .78rem;
    border-top: 1px solid var(--nc-border);
}
.nc-attachment-image__name {
    flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    color: var(--nc-text-soft);
}

/* Vídeo inline (anexo de ticket) */
.nc-attachment-video {
    margin: .6rem 0 0;
    max-width: 480px;
    background: var(--nc-bg-elev-1);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
    overflow: hidden;
}
.nc-attachment-video video {
    width: 100%; max-height: 320px; display: block; background: #000;
}
.nc-attachment-video__caption {
    display: flex; align-items: center; gap: .5rem;
    padding: .45rem .6rem; font-size: .8rem;
    border-top: 1px solid var(--nc-border);
}
.nc-attachment-video__caption i { color: var(--nc-primary-300); }
.nc-attachment-video__name {
    flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    color: var(--nc-text-soft);
}

/* Lightbox: modal Bootstrap com fundo escuro */
#nc-image-lightbox .modal-content {
    background: transparent; border: 0; box-shadow: none;
}
#nc-image-lightbox .modal-body {
    padding: 0;
    display: flex; align-items: center; justify-content: center;
}
#nc-image-lightbox img {
    max-width: 100%;
    max-height: 86vh;
    border-radius: var(--nc-radius);
    box-shadow: 0 30px 60px rgba(0,0,0,.6);
}
#nc-image-lightbox .nc-lightbox-close {
    position: absolute; top: -42px; right: 0;
    background: transparent; border: 0; color: #fff;
    font-size: 1.6rem; cursor: pointer; opacity: .85;
}
#nc-image-lightbox .nc-lightbox-close:hover { opacity: 1; }
#nc-image-lightbox .nc-lightbox-caption {
    position: absolute; bottom: -34px; left: 0; right: 0;
    text-align: center; color: rgba(255,255,255,.75);
    font-size: .85rem;
}

/* Toolbar inferior do formulário de resposta */
.nc-reply-actions {
    display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
    margin-top: .65rem;
}
.nc-reply-actions__spacer { flex: 1; }

/* ---------- 17. TOM SELECT (selects com busca) ---------- */
/* Tom Select 2.x aplica .ts-wrapper.form-select e .ts-wrapper.form-control com
   estilo Bootstrap (fundo branco). Por isso os overrides precisam ter pelo
   menos a mesma especificidade — replicamos os 3 seletores. */
.ts-wrapper,
.ts-wrapper.form-select,
.ts-wrapper.form-control { font-family: var(--nc-font); }

.ts-wrapper .ts-control,
.ts-wrapper.form-select .ts-control,
.ts-wrapper.form-control .ts-control {
    background: var(--nc-input-bg) !important;
    border: 1px solid var(--nc-input-border) !important;
    color: var(--nc-text) !important;
    border-radius: var(--nc-radius);
    padding: .42rem .85rem;
    min-height: 38px;
    font-size: .9rem;
    box-shadow: none;
}
.ts-wrapper .ts-control input,
.ts-wrapper.form-select .ts-control input,
.ts-wrapper.form-control .ts-control input {
    color: var(--nc-text) !important;
    font-family: var(--nc-font);
    font-size: .9rem;
    background: transparent !important;
}
.ts-wrapper .ts-control input::placeholder { color: var(--nc-text-soft); opacity: 1; }
.ts-wrapper.single .ts-control > .item,
.ts-wrapper.form-select.single .ts-control > .item { color: var(--nc-text) !important; }
.ts-wrapper.focus .ts-control,
.ts-wrapper.dropdown-active .ts-control,
.ts-wrapper.form-select.focus .ts-control,
.ts-wrapper.form-select.dropdown-active .ts-control {
    border-color: var(--nc-primary-400) !important;
    box-shadow: var(--nc-glow-primary) !important;
}
.ts-wrapper .ts-control::after { border-top-color: var(--nc-text-muted) !important; }

.ts-dropdown,
.ts-dropdown.form-select,
.ts-dropdown.form-control {
    background: var(--nc-bg-elev-2) !important;
    border: 1px solid var(--nc-border) !important;
    color: var(--nc-text) !important;
    box-shadow: var(--nc-shadow-md);
    border-radius: var(--nc-radius);
    margin-top: 4px;
    overflow: hidden;
    z-index: 1060 !important;
}
.ts-dropdown .ts-dropdown-content { max-height: 320px; background: transparent !important; }
.ts-dropdown [data-selectable],
.ts-dropdown .option {
    color: var(--nc-text) !important;
    background: transparent !important;
    padding: .5rem .75rem;
    font-size: .88rem;
    cursor: pointer;
}
.ts-dropdown [data-selectable]:hover,
.ts-dropdown .option:hover,
.ts-dropdown .active { background: var(--nc-surface-hover) !important; color: var(--nc-text) !important; }
.ts-dropdown [data-selectable].selected,
.ts-dropdown .option.selected { background: var(--nc-primary-500) !important; color: #fff !important; }
.ts-dropdown .no-results { color: var(--nc-text-muted) !important; padding: .75rem; font-size: .85rem; font-style: italic; }
.input-group .ts-wrapper { flex: 1; min-width: 0; }
.input-group .ts-wrapper .ts-control {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

/* ---------- 18. TASK DETAIL (modal AJAX + página show) ---------- */
.nc-task-detail { color: var(--nc-text); }
.nc-task-detail__head {
    padding-bottom: .85rem;
    border-bottom: 1px solid var(--nc-divider);
}
.nc-task-detail__section { margin-top: 1.25rem; }
.nc-task-detail__section-title {
    font-size: .75rem; font-weight: 600;
    color: var(--nc-text-soft);
    text-transform: uppercase; letter-spacing: .08em;
    margin-bottom: .65rem;
}

.nc-task-prop { display: flex; flex-direction: column; }
.nc-task-prop__row {
    padding: .65rem 0;
    border-bottom: 1px solid var(--nc-divider);
}
.nc-task-prop__row:last-child { border-bottom: 0; }
.nc-task-prop__label {
    font-size: .68rem; color: var(--nc-text-soft);
    text-transform: uppercase; letter-spacing: .06em;
    margin-bottom: .3rem;
}
.nc-task-prop__value { color: var(--nc-text); font-size: .9rem; }

.nc-checklist { list-style: none; padding: 0; margin: 0; }
.nc-checklist li {
    display: flex; align-items: center; gap: .6rem;
    padding: .35rem 0;
    color: var(--nc-text);
    font-size: .9rem;
}
.nc-checklist li i { font-size: 1rem; color: var(--nc-text-soft); }
.nc-checklist li.is-done { color: var(--nc-text-soft); text-decoration: line-through; }
.nc-checklist li.is-done i { color: #4ade80; }

.nc-task-comments { display: flex; flex-direction: column; gap: .85rem; }
.nc-task-comment {
    display: flex; gap: .65rem;
    padding: .65rem .75rem;
    background: var(--nc-bg-elev-1);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius);
}

#nc-task-modal .modal-dialog { max-width: 960px; }
#nc-task-modal .modal-content {
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-lg);
}
#nc-task-modal-body { padding: 1.25rem; min-height: 320px; }
.nc-task-modal__loading {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 3rem 1rem; color: var(--nc-text-muted); gap: .65rem;
}
.nc-task-modal__loading .spinner {
    width: 32px; height: 32px;
    border: 3px solid rgba(30,79,125,.25);
    border-top-color: var(--nc-primary-400);
    border-radius: 50%;
    animation: nc-spin .8s linear infinite;
}
@keyframes nc-spin { to { transform: rotate(360deg); } }

/* Paginação Bootstrap 5 com tema Núcleo */
.pagination { --bs-pagination-padding-x: .7rem; --bs-pagination-padding-y: .35rem; gap: 2px; margin: 0; }
.pagination .page-link {
    background: var(--nc-bg-elev-1);
    border: 1px solid var(--nc-border);
    color: var(--nc-text-muted);
    border-radius: var(--nc-radius-sm);
    font-size: .85rem;
}
.pagination .page-link:hover {
    background: var(--nc-surface-hover);
    color: var(--nc-text);
    border-color: var(--nc-border-strong);
}
.pagination .page-item.active .page-link {
    background: var(--nc-primary-500);
    border-color: var(--nc-primary-500);
    color: #fff;
}
.pagination .page-item.disabled .page-link {
    background: transparent;
    color: var(--nc-text-soft);
    opacity: .55;
}
.pagination svg { width: 14px; height: 14px; }

/* ===== Notificações: bell + dropdown + page index ===== */
.nc-notif { position: relative; }
.nc-notif__toggle { position: relative; }
.nc-notif__badge {
    position: absolute; top: -3px; right: -3px;
    min-width: 18px; height: 18px; padding: 0 5px;
    background: var(--nc-danger);
    color: #fff;
    font-size: .68rem; font-weight: 700;
    border-radius: 999px;
    display: inline-flex; align-items: center; justify-content: center;
    line-height: 1;
}
.nc-notif__menu {
    width: 380px; max-width: calc(100vw - 24px);
    padding: 0;
    background: var(--nc-bg-elev-2);
    border: 1px solid var(--nc-border);
    border-radius: var(--nc-radius-lg);
    box-shadow: var(--nc-shadow-lg);
    overflow: hidden;
}
.nc-notif__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: .8rem 1rem;
    border-bottom: 1px solid var(--nc-divider);
    font-size: .9rem;
    color: var(--nc-text);
}
.nc-notif__menu .nc-notif__mark-all,
button.nc-notif__mark-all {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: var(--nc-primary-300);
    font-size: .78rem;
    font-weight: 500;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}
.nc-notif__menu .nc-notif__mark-all:hover { color: var(--nc-primary-400); }
.nc-notif__menu .nc-notif__mark-all[disabled] { opacity: .4; cursor: not-allowed; }
.nc-notif__list { max-height: 420px; overflow-y: auto; }
a.nc-notif__item,
.nc-notif__menu a.nc-notif__item {
    display: flex; align-items: flex-start; gap: .6rem;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--nc-divider);
    color: var(--nc-text);
    text-decoration: none;
    transition: background .12s;
}
a.nc-notif__item:hover,
.nc-notif__menu a.nc-notif__item:hover {
    background: var(--nc-surface-hover);
    color: var(--nc-text);
    text-decoration: none;
}
.nc-notif__menu a.nc-notif__item:last-child { border-bottom: 0; }
.nc-notif__menu a.nc-notif__item .nc-notif__text { color: var(--nc-text); }
.nc-notif__menu a.nc-notif__item .nc-notif__time { color: var(--nc-text-soft); }
.nc-notif__dot {
    flex-shrink: 0; width: 8px; height: 8px; margin-top: 6px;
    border-radius: 50%; background: transparent;
}
.nc-notif__item.is-unread .nc-notif__dot { background: var(--nc-primary-400); }
.nc-notif__item.is-unread .nc-notif__text { font-weight: 600; }
.nc-notif__body { flex: 1; min-width: 0; }
.nc-notif__text {
    display: block; font-size: .85rem; color: var(--nc-text);
    line-height: 1.35;
    overflow: hidden; display: -webkit-box;
    -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.nc-notif__time {
    display: block; font-size: .72rem; color: var(--nc-text-soft);
    margin-top: .2rem;
}
.nc-notif__empty {
    padding: 2.25rem 1rem;
    text-align: center; color: var(--nc-text-soft);
    font-size: .85rem;
}
.nc-notif__empty i { font-size: 1.6rem; display: block; margin-bottom: .5rem; opacity: .6; }
.nc-notif__foot {
    padding: .65rem 1rem;
    text-align: center;
    border-top: 1px solid var(--nc-divider);
    background: var(--nc-bg-elev-1);
}
.nc-notif__foot .nc-link { font-size: .85rem; }

/* Página index das notificações */
.nc-notif-list {
    background: var(--nc-bg-elev-1);
    border-top: 1px solid var(--nc-border);
}
a.nc-notif-row {
    display: flex; align-items: flex-start; gap: .85rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--nc-divider);
    color: var(--nc-text);
    text-decoration: none;
    transition: background .12s;
}
a.nc-notif-row:hover {
    background: var(--nc-surface-hover);
    color: var(--nc-text);
    text-decoration: none;
}
a.nc-notif-row .nc-notif-row__text { color: var(--nc-text); }
a.nc-notif-row .nc-notif-row__time,
a.nc-notif-row .nc-notif-row__meta { color: var(--nc-text-soft); }
.nc-notif-row__dot {
    flex-shrink: 0; width: 10px; height: 10px; margin-top: 7px;
    border-radius: 50%; background: transparent;
}
.nc-notif-row.is-unread .nc-notif-row__dot { background: var(--nc-primary-400); }
.nc-notif-row.is-unread .nc-notif-row__text { font-weight: 600; }
.nc-notif-row__body { flex: 1; min-width: 0; }
.nc-notif-row__text { font-size: .92rem; color: var(--nc-text); }
.nc-notif-row__meta { font-size: .76rem; color: var(--nc-text-soft); margin-top: .15rem; }
.nc-notif-row__time {
    font-size: .76rem; color: var(--nc-text-soft);
    text-align: right; flex-shrink: 0;
    display: flex; flex-direction: column; align-items: flex-end; gap: .15rem;
}
.nc-notif-row__mark {
    background: transparent; border: 0; padding: 0;
    color: var(--nc-primary-300); font-size: .72rem; cursor: pointer;
}

/* ===== Cadastro de cliente: design clean (PF/PJ + stepper + medidor) ===== */

/* --- Título + subtítulo da página --- */
.nc-reg-heading {
    text-align: center;
    margin: .25rem 0 1.5rem;
}
.nc-reg-heading h2 {
    margin: 0 0 .35rem;
    font-size: 1.45rem; font-weight: 700;
    color: var(--nc-text);
    letter-spacing: -0.01em;
}
.nc-reg-heading p {
    margin: 0;
    color: var(--nc-text-muted);
    font-size: .9rem;
}

/* --- Stepper clean (bolinhas + linha + label embaixo) --- */
.nc-stepper {
    display: flex; align-items: flex-start;
    padding: 0 .5rem 1.5rem;
    margin: 0 auto;
    max-width: 360px;
}
.nc-stepper__item {
    display: flex; flex-direction: column; align-items: center; gap: .4rem;
    color: var(--nc-text-soft);
    font-size: .78rem; font-weight: 500;
    flex-shrink: 0; position: relative; z-index: 1;
    transition: color .25s;
    min-width: 70px;
}
.nc-stepper__num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--nc-bg-elev-3);
    color: var(--nc-text-soft);
    font-weight: 700; font-size: .88rem;
    border: 0;
    transition: all .3s ease;
}
.nc-stepper__item.is-active .nc-stepper__num {
    background: var(--nc-primary-500); color: #fff;
}
.nc-stepper__item.is-active .nc-stepper__label { color: var(--nc-text); font-weight: 600; }
.nc-stepper__item.is-done .nc-stepper__num {
    background: var(--nc-success); color: #fff; font-size: 0;
}
.nc-stepper__item.is-done .nc-stepper__num::before {
    content: "\F26B"; font-family: 'bootstrap-icons'; font-size: 1rem;
}
.nc-stepper__bar {
    flex: 1; height: 2px; background: var(--nc-divider); border-radius: 2px;
    margin: 16px -10px 0;     /* alinha com o centro vertical das bolinhas */
    position: relative;
    min-width: 30px;
}
.nc-stepper__bar::after {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0%;
    background: var(--nc-success); border-radius: 2px;
    transition: width .5s ease;
}
.nc-stepper.is-step-2 .nc-stepper__bar::after { width: 100%; }

/* --- Tile picker PF/PJ (estilo clean) --- */
.nc-segmented {
    display: grid; grid-template-columns: 1fr 1fr; gap: .75rem;
    margin-bottom: 1.25rem;
}
.nc-segmented__item { cursor: pointer; user-select: none; position: relative; }
.nc-segmented__item input { position: absolute; opacity: 0; pointer-events: none; }
.nc-segmented__item span {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: .5rem;
    padding: 1.15rem .75rem 1rem;
    background: var(--nc-input-bg);
    border: 1.5px solid var(--nc-input-border);
    border-radius: var(--nc-radius);
    color: var(--nc-text-muted);
    font-size: .9rem; font-weight: 500;
    transition: all .2s ease;
    text-align: center;
}
.nc-segmented__item span i {
    font-size: 1.6rem; line-height: 1;
    color: var(--nc-text-soft);
    transition: all .2s ease;
}
.nc-segmented__item:hover span { border-color: var(--nc-border-strong); }
.nc-segmented__item input:checked + span {
    background: rgba(30,79,125,.08);
    border-color: var(--nc-primary-400);
    color: var(--nc-text);
    font-weight: 600;
}
.nc-segmented__item input:checked + span i { color: var(--nc-primary-300); }

/* --- Inputs com ícone à esquerda (input group estilo clean) --- */
.nc-input {
    position: relative;
    margin-bottom: 1rem;
}
.nc-input__icon {
    position: absolute;
    left: 14px;
    /* Slot de altura fixa = altura do input (46px). Como display flex centraliza
       verticalmente DENTRO desse slot, o ícone fica sempre no meio do input,
       mesmo que abaixo do input haja medidor de senha ou hints. */
    top: 0;
    height: 46px;
    display: inline-flex;
    align-items: center;
    color: var(--nc-text-soft);
    font-size: 1.05rem;
    pointer-events: none;
    z-index: 2;
}
.nc-input .form-control,
.nc-input .form-select {
    padding-left: 42px;
    height: 46px;
    border-radius: var(--nc-radius);
    background: var(--nc-input-bg);
    border: 1.5px solid var(--nc-input-border);
    color: var(--nc-text);
    font-size: .92rem;
}
.nc-input .form-control::placeholder { color: var(--nc-text-soft); }
.nc-input .form-control:focus,
.nc-input .form-select:focus {
    border-color: var(--nc-primary-400);
    box-shadow: var(--nc-glow-primary);
}
.nc-input.is-loading::after {
    content: "";
    position: absolute; right: 14px; top: 16px; /* (46-14)/2 = 16 */
    width: 14px; height: 14px;
    border: 2px solid rgba(30,79,125,.25);
    border-top-color: var(--nc-primary-400);
    border-radius: 50%;
    animation: nc-spin .8s linear infinite;
}
.nc-input__error {
    font-size: .76rem; color: var(--nc-danger);
    margin-top: .3rem; padding-left: 4px;
}
.nc-input__hint {
    font-size: .72rem; color: var(--nc-text-soft);
    margin-top: .25rem; padding-left: 4px; min-height: 1em;
}
.nc-input__hint.is-error { color: var(--nc-danger); }
.nc-input__hint.is-ok    { color: var(--nc-success); }

/* Linha sutil divisora entre senha e confirmar senha */
.nc-soft-divider {
    height: 1px; background: var(--nc-divider);
    margin: .25rem 0 1rem;
}

/* --- Medidor de força de senha (compacto) --- */
.nc-password-meter { margin-top: .55rem; padding-left: 4px; }
.nc-password-meter__bars {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
    margin-bottom: .35rem;
}
.nc-password-meter__seg {
    height: 3px; border-radius: 2px;
    background: var(--nc-bg-elev-3);
    transition: background .25s ease;
}
.nc-password-meter[data-strength="1"] .nc-password-meter__seg:nth-child(1) { background: var(--nc-danger); }
.nc-password-meter[data-strength="2"] .nc-password-meter__seg:nth-child(-n+2) { background: var(--nc-warning); }
.nc-password-meter[data-strength="3"] .nc-password-meter__seg:nth-child(-n+3) { background: #3b82f6; }
.nc-password-meter[data-strength="4"] .nc-password-meter__seg { background: var(--nc-success); }
.nc-password-meter__label {
    font-size: .72rem; font-weight: 600; color: var(--nc-text-soft);
    display: flex; align-items: center; gap: .3rem;
}
.nc-password-meter[data-strength="1"] .nc-password-meter__label { color: var(--nc-danger); }
.nc-password-meter[data-strength="2"] .nc-password-meter__label { color: var(--nc-warning); }
.nc-password-meter[data-strength="3"] .nc-password-meter__label { color: #3b82f6; }
.nc-password-meter[data-strength="4"] .nc-password-meter__label { color: var(--nc-success); }
.nc-password-meter__criteria {
    display: grid; grid-template-columns: 1fr 1fr; gap: 2px 12px;
    margin: .4rem 0 0;
    padding: 0;
    font-size: .7rem; color: var(--nc-text-soft);
}
.nc-password-meter__criteria li {
    list-style: none;
    display: flex; align-items: center; gap: .35rem;
}
.nc-password-meter__criteria li::before {
    content: "\F4F2"; font-family: 'bootstrap-icons';
    color: var(--nc-text-soft); font-size: .85rem;
    transition: all .2s;
}
.nc-password-meter__criteria li.ok { color: var(--nc-success); }
.nc-password-meter__criteria li.ok::before {
    content: "\F26A"; color: var(--nc-success);
}

/* --- Botão CTA do cadastro --- */
.nc-cta-btn {
    height: 50px;
    border-radius: 999px;
    font-size: .95rem; font-weight: 600;
    background: var(--nc-primary-500);
    border: 0; color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    gap: .5rem;
    transition: all .2s ease;
    width: 100%;
}
.nc-cta-btn:hover { background: var(--nc-primary-400); transform: translateY(-1px); }
.nc-cta-btn:active { transform: translateY(0); }
.nc-cta-btn:disabled { opacity: .65; cursor: not-allowed; transform: none; }
.nc-cta-btn--ghost {
    background: transparent; color: var(--nc-text-muted);
    border: 1.5px solid var(--nc-border-strong);
}
.nc-cta-btn--ghost:hover { background: var(--nc-surface-hover); color: var(--nc-text); }

/* --- Animação de troca de step --- */
[data-step] { animation: nc-step-in .35s ease both; }
@keyframes nc-step-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Card mais largo no auth para acomodar 2 colunas --- */
.nc-auth-card--wide { max-width: 520px; }

.is-invalid { border-color: var(--nc-danger) !important; }

/* X de fechar visível em qualquer tema */
.modal .btn-close,
.modal .nc-modal-close {
    filter: invert(85%);
    opacity: .8;
    transition: opacity .15s;
}
[data-theme="light"] .modal .btn-close,
[data-theme="light"] .modal .nc-modal-close {
    filter: none;
    opacity: .65;
}
.modal .btn-close:hover,
.modal .nc-modal-close:hover { opacity: 1; }
