/* ============================================================
   HABITAT DESIGN — Gestão de Empresa | Premium CSS
   Cores: Slate sidebar, Amber/Orange primary, system-ui
   ============================================================ */

/* ── Reset & Vars ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root {
    --sidebar-w: 260px;
    --primary: #d97706;
    --primary-hover: #b45309;
    --primary-light: #fef3c7;
    --primary-50: rgba(217,119,6,.08);
    --danger: #dc2626;
    --danger-hover: #b91c1c;
    --success: #16a34a;
    --success-light: #dcfce7;
    --warning: #eab308;
    --warning-light: #fef9c3;
    --info: #2563eb;
    --info-light: #dbeafe;
    --bg: #f8fafc;
    --surface: #ffffff;
    --surface-hover: #f1f5f9;
    --border: #e2e8f0;
    --text: #1e293b;
    --text-secondary: #64748b;
    --text-muted: #94a3b8;
    --sidebar-bg: #0f172a;
    --sidebar-text: #cbd5e1;
    --sidebar-hover: #1e293b;
    --sidebar-active: rgba(217,119,6,.15);
    --sidebar-active-text: #f59e0b;
    --radius: 8px;
    --radius-sm: 6px;
    --radius-lg: 12px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
    --shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
    --shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);
    --shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);
    --transition: 200ms ease;
    --font: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-mono: 'SF Mono', Menlo, Consolas, monospace;
}

html{font-size:14px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.5;overflow-x:hidden;
    -webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;
}
/* Allow text selection inside form inputs */
input,textarea,select,[contenteditable]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}
/* Hide page when printing — unless printing a document */
@media print{
    /* Default: hide everything */
    body:not(.printing-pd){display:none!important}

    /* When printing a doc: hide UI chrome, keep only pd-page */
    body.printing-pd .sidebar,
    body.printing-pd .topbar,
    body.printing-pd .modal-backdrop,
    body.printing-pd .pd-modal-header,
    body.printing-pd .pd-modal-actions,
    body.printing-pd .btn-icon.modal-close,
    body.printing-pd .pd-btn-print { display:none!important }

    /* Unwrap modal layers so pd-page is visible */
    body.printing-pd .modal {
        position:static!important;
        background:transparent!important;
        overflow:visible!important;
        padding:0!important;
    }
    body.printing-pd .modal-backdrop { display:none!important }
    body.printing-pd .modal-content {
        max-width:none!important;
        box-shadow:none!important;
        background:transparent!important;
        border-radius:0!important;
        overflow:visible!important;
    }
    body.printing-pd .modal-body,
    body.printing-pd .pd-wrap {
        padding:0!important;
        max-height:none!important;
        overflow:visible!important;
        background:transparent!important;
    }

    /* The actual page */
    body.printing-pd .pd-page {
        box-shadow:none!important;
        width:210mm!important;
        min-height:297mm!important;
        margin:0 auto!important;
    }
    body.printing-pd { background:#131313!important }
    @page { size:A4; margin:0 }
}
a{color:inherit;text-decoration:none}
input,select,textarea,button{font:inherit;color:inherit}
table{border-collapse:collapse;width:100%}
img{max-width:100%}

/* ── Login Premium ───────────────────────────────────────── */
.login-screen{
    position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
    overflow:hidden;padding:1rem;
}
.login-screen[hidden]{display:none}
img.login-bg{
    position:absolute;inset:-16px;z-index:0;
    width:calc(100% + 32px);height:calc(100% + 32px);
    object-fit:cover;object-position:center;
    display:block;pointer-events:none;user-select:none;
    filter:blur(4px);
}
/* Dark overlay over blurred bg for readability */
.login-screen::after{
    content:'';position:absolute;inset:0;z-index:1;
    background:rgba(4,7,18,.52);
    pointer-events:none;
}

/* Clock top-right */
.login-clock{
    position:absolute;top:2rem;right:2.5rem;z-index:10;text-align:right;color:#fff;
}
.clock-time{
    font-size:3.5rem;font-weight:100;letter-spacing:4px;line-height:1;
    text-shadow:0 2px 20px rgba(0,0,0,.6);
    color:rgba(255,255,255,.95);
}
.clock-date{
    font-size:.82rem;color:rgba(255,255,255,.8);margin-top:.3rem;
    text-transform:capitalize;letter-spacing:.8px;
    text-shadow:0 1px 6px rgba(0,0,0,.6);
}

/* Weather bottom-left */
.login-weather{
    position:absolute;bottom:2rem;left:2.5rem;z-index:10;
    display:flex;align-items:center;gap:.65rem;color:#fff;
}
.weather-icon{font-size:1.6rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}
.weather-info{display:flex;flex-direction:column;gap:.05rem}
.weather-temp{font-size:1rem;font-weight:600;letter-spacing:.5px;text-shadow:0 1px 6px rgba(0,0,0,.7)}
.weather-desc{font-size:.72rem;color:rgba(255,255,255,.7);text-transform:capitalize;text-shadow:0 1px 4px rgba(0,0,0,.6)}

/* Brand */
.login-brand{
    position:absolute;bottom:2rem;left:2.5rem;z-index:10;
    display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-size:.78rem;
    text-shadow:0 1px 3px rgba(0,0,0,.6);
}
.login-brand svg{stroke:var(--primary);opacity:.7}
.login-weather ~ .login-brand{display:none}
.login-weather:empty ~ .login-brand{display:flex}

/* Secure badge */
.login-secure{
    position:absolute;bottom:2rem;right:2.5rem;z-index:10;
    display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-size:.72rem;
    text-shadow:0 1px 3px rgba(0,0,0,.6);
}
.secure-dot{
    width:7px;height:7px;border-radius:50%;background:#22c55e;
    box-shadow:0 0 8px rgba(34,197,94,.7);animation:pulse-dot 2s ease infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.35}}

/* Card */
.login-card{
    position:relative;z-index:10;width:100%;max-width:430px;
    animation:loginFadeIn .6s cubic-bezier(.22,.61,.36,1) both;
}
@keyframes loginFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.login-card-inner{
    background:linear-gradient(165deg,rgba(12,16,32,.88) 0%,rgba(6,9,18,.94) 100%);
    backdrop-filter:blur(24px) saturate(1.3);
    -webkit-backdrop-filter:blur(24px) saturate(1.3);
    border:1px solid rgba(255,255,255,.08);
    border-top:1px solid rgba(255,255,255,.13);
    border-radius:24px;
    padding:2.75rem 2.5rem 2.25rem;
    box-shadow:
        0 50px 120px rgba(0,0,0,.8),
        0 0 0 1px rgba(255,255,255,.03) inset,
        0 -1px 0 rgba(255,255,255,.06) inset;
    position:relative;
    overflow:hidden;
}
/* Subtle top-edge shimmer */
.login-card-inner::before{
    content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
    background:linear-gradient(90deg,transparent,rgba(217,119,6,.35),transparent);
}

/* Logo */
.login-logo{text-align:center;margin-bottom:1.85rem}
.login-logo-icon{
    width:68px;height:68px;margin:0 auto 1rem;
    border-radius:18px;
    background:linear-gradient(145deg,rgba(217,119,6,.22),rgba(217,119,6,.06));
    border:1px solid rgba(217,119,6,.32);
    display:flex;align-items:center;justify-content:center;
    position:relative;
    z-index:1;
}
/* Aura glow effect */
.login-logo-icon::before{
    content:'';position:absolute;inset:-12px;
    border-radius:28px;
    background:radial-gradient(circle,rgba(217,119,6,.25) 0%,rgba(217,119,6,.08) 50%,transparent 70%);
    z-index:-1;
    animation:auraGlow 3s ease-in-out infinite;
}
.login-logo-icon::after{
    content:'';position:absolute;inset:-24px;
    border-radius:38px;
    background:radial-gradient(circle,rgba(217,119,6,.1) 0%,rgba(217,119,6,.03) 40%,transparent 65%);
    z-index:-2;
    animation:auraGlow 3s ease-in-out infinite .5s;
}
@keyframes auraGlow{
    0%,100%{opacity:.6;transform:scale(.95)}
    50%{opacity:1;transform:scale(1.05)}
}
.login-logo-icon svg{color:var(--primary);filter:drop-shadow(0 0 6px rgba(217,119,6,.4))}
.login-logo h1{font-size:1.55rem;font-weight:700;color:#f1f5f9;letter-spacing:-.02em}
.login-logo .text-primary{color:var(--primary);text-shadow:0 0 18px rgba(217,119,6,.2)}
.login-logo p{
    color:rgba(255,255,255,.32);font-size:.72rem;margin-top:.3rem;
    letter-spacing:2.5px;text-transform:uppercase;font-weight:500;
}

/* Divider */
.login-divider{display:flex;align-items:center;gap:.85rem;margin-bottom:1.85rem}
.login-divider::before,.login-divider::after{
    content:'';flex:1;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
}
.login-divider span{font-size:.58rem;color:rgba(255,255,255,.22);letter-spacing:3px;font-weight:600}

/* Fields */
.login-field{margin-bottom:1.3rem}
.login-field label{
    display:block;font-size:.6rem;font-weight:700;color:rgba(255,255,255,.42);
    letter-spacing:2.2px;margin-bottom:.55rem;text-transform:uppercase;
    transition:color .25s,letter-spacing .25s;
}
.login-field:focus-within label{color:var(--primary);letter-spacing:2.6px}
.login-input-wrap{
    display:flex;align-items:center;
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.08);
    border-radius:12px;
    transition:border-color .25s,background .25s,box-shadow .25s;
    position:relative;
}
.login-input-wrap::before{
    content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
    background:linear-gradient(180deg,var(--primary),#f59e0b);opacity:0;
    transition:opacity .25s;
    border-radius:12px 0 0 12px;
}
.login-input-wrap:focus-within::before{opacity:1}
.login-input-wrap:focus-within{
    border-color:rgba(217,119,6,.35);
    box-shadow:0 0 0 3px rgba(217,119,6,.08),0 4px 16px rgba(0,0,0,.2);
    background:rgba(255,255,255,.065);
}
.login-input-icon{
    width:18px;height:18px;
    flex-shrink:0;
    color:rgba(255,255,255,.35);
    transition:color .25s;
    display:block;
    margin:0 .75rem;
}
.login-input-wrap:focus-within .login-input-icon{color:rgba(217,119,6,.65)}
/* Override global input styles + Chrome autocomplete */
.login-input-wrap input{
    flex:1 !important;
    background:transparent !important;
    border:none !important;
    outline:none !important;
    box-shadow:none !important;
    padding:.78rem .9rem !important;
    color:#f1f5f9 !important;
    font-size:.88rem !important;
    width:auto !important;
    border-radius:0 !important;
    letter-spacing:.2px !important;
}
.login-input-wrap input::placeholder{color:rgba(255,255,255,.22) !important}
.login-input-wrap input:focus{outline:none !important;box-shadow:none !important;border:none !important}
/* Chrome autocomplete dark override */
.login-input-wrap input:-webkit-autofill,
.login-input-wrap input:-webkit-autofill:hover,
.login-input-wrap input:-webkit-autofill:focus{
    -webkit-box-shadow:0 0 0 100px rgba(8,13,26,1) inset !important;
    -webkit-text-fill-color:#f1f5f9 !important;
    caret-color:#f1f5f9;
    transition:background-color 5000s ease-in-out 0s;
}

/* Password toggle */
.login-pw-toggle{
    background:none;border:none;cursor:pointer;padding:.5rem .8rem;
    color:rgba(255,255,255,.28);transition:color .2s;display:flex;flex-shrink:0;
}
.login-pw-toggle:hover{color:rgba(255,255,255,.6)}
.login-pw-toggle svg{width:16px;height:16px}

/* Remember */
.login-remember{
    display:flex;align-items:center;gap:.6rem;margin:.1rem 0 1.5rem;
    cursor:pointer;font-size:.8rem;color:rgba(255,255,255,.45);user-select:none;
}
.login-remember input[type="checkbox"]{
    appearance:none;-webkit-appearance:none;
    width:16px;height:16px;border-radius:4px;flex-shrink:0;
    border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.04);
    cursor:pointer;position:relative;transition:all .2s;
}
.login-remember input[type="checkbox"]:checked{
    background:var(--primary);border-color:var(--primary);
}
.login-remember input[type="checkbox"]:checked::after{
    content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:.65rem;font-weight:800;
}

/* Submit button */
.login-btn{
    width:100%;padding:.9rem;border:none;border-radius:12px;
    background:linear-gradient(135deg,#dc2626 0%,#b91c1c 60%,#991b1b 100%);
    color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;
    display:flex;align-items:center;justify-content:center;gap:.6rem;
    transition:box-shadow .3s,opacity .2s;
    box-shadow:0 4px 24px rgba(220,38,38,.35),0 0 0 0 rgba(220,38,38,0);
    letter-spacing:.4px;
    position:relative;overflow:hidden;
}
/* Shine sweep on hover */
.login-btn::after{
    content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
    transition:left .5s ease;
}
.login-btn:hover::after{left:120%}
.login-btn:hover{box-shadow:0 8px 32px rgba(220,38,38,.5),0 0 0 1px rgba(220,38,38,.15)}
.login-btn:active{opacity:.85}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-btn:disabled::after{display:none}
.login-btn svg{width:17px;height:17px;position:relative}

/* Error */
.login-error{
    color:#fca5a5;font-size:.78rem;text-align:center;margin-top:.85rem;
    background:rgba(220,38,38,.1);border-radius:8px;padding:.5rem .75rem;
    border:1px solid rgba(220,38,38,.18);
}

/* Footer */
.login-footer{
    text-align:center;margin-top:1.75rem;padding-top:1.1rem;
    border-top:1px solid rgba(255,255,255,.04);
    font-size:.65rem;color:rgba(255,255,255,.2);letter-spacing:.3px;
}
.login-footer .text-primary{color:var(--primary);opacity:.8}

/* Responsive */
@media(max-width:600px){
    .login-clock{top:1rem;right:1rem}
    .clock-time{font-size:2.2rem;letter-spacing:2px}
    .clock-date{font-size:.75rem}
    .login-weather,.login-brand,.login-secure{display:none!important}
    .login-card{max-width:100%}
    .login-card-inner{padding:2rem 1.5rem 1.75rem;border-radius:18px}
}

/* ── Sidebar ────────────────────────────────────────────── */
.app{display:flex;min-height:100vh}
.app[hidden]{display:none}
.login-screen[hidden]{display:none}
.sidebar{
    position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);
    background:var(--sidebar-bg);color:var(--sidebar-text);
    display:flex;flex-direction:column;z-index:100;
    transition:transform var(--transition);
}
.sidebar-header{
    display:flex;align-items:center;gap:.75rem;padding:1.15rem 1.1rem .9rem;
    font-weight:700;font-size:1rem;color:#f1f5f9;letter-spacing:-.01em;
    border-bottom:1px solid rgba(255,255,255,.06);
}
.sidebar-header svg{color:var(--primary);flex-shrink:0}
.sidebar-nav{
    flex:1;overflow-y:auto;padding:.75rem .65rem;
}
/* Grid layout for nav items */
.sidebar-nav{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:.5rem;
    align-content:start;
}
.nav-item{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:.4rem;padding:.7rem .35rem;
    border-radius:var(--radius);font-size:.68rem;cursor:pointer;
    transition:all var(--transition);
    text-align:center;line-height:1.2;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.04);
    min-height:72px;
    text-decoration:none;color:var(--sidebar-text);
}
.nav-item svg{
    width:20px;height:20px;flex-shrink:0;fill:none;stroke:currentColor;
    stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
    opacity:.7;transition:opacity var(--transition);
}
.nav-item span{font-weight:500;letter-spacing:.02em}
.nav-item:hover{
    background:var(--sidebar-hover);color:#e2e8f0;
    border-color:rgba(255,255,255,.08);
}
.nav-item:hover svg{opacity:1}
.nav-item.active{
    background:var(--sidebar-active);color:var(--sidebar-active-text);
    font-weight:600;border-color:rgba(217,119,6,.2);
}
.nav-item.active svg{opacity:1;color:var(--sidebar-active-text)}
.nav-divider{
    grid-column:1 / -1;
    height:1px;background:rgba(255,255,255,.06);margin:.15rem 0;
}
.sidebar-footer{
    padding:.85rem 1rem;border-top:1px solid rgba(255,255,255,.06);
    display:flex;align-items:center;justify-content:space-between;
}
.user-info{font-size:.8rem;color:var(--text-muted)}
.sidebar-footer .btn-icon{color:var(--text-muted)}
.sidebar-footer .btn-icon:hover{color:#ef4444}

/* ── Main Content ───────────────────────────────────────── */
.main-content{
    margin-left:var(--sidebar-w);flex:1;min-height:100vh;
    display:flex;flex-direction:column;
}
.content-wrapper{padding:1.5rem 2rem 2rem;flex:1}
.mobile-header{display:none}

/* ── Page Header ────────────────────────────────────────── */
.page-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:1.75rem;flex-wrap:wrap;gap:.75rem;
}
.page-title{font-size:1.4rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.page-subtitle{color:var(--text-secondary);font-size:.82rem;margin-top:.2rem}

/* ── Cards ──────────────────────────────────────────────── */
.card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:1.35rem;box-shadow:var(--shadow-sm);
    transition:box-shadow var(--transition);
}
.card:hover{box-shadow:var(--shadow)}
.card-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);
}
.card-title{font-size:.95rem;font-weight:700;letter-spacing:-.01em}

/* ── Stat Cards (Dashboard) ─────────────────────────────── */
.stats-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:1rem;margin-bottom:1.5rem;
}
.stat-card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:1.25rem;
    box-shadow:var(--shadow-sm);
    display:flex;align-items:flex-start;gap:.85rem;
    transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
    position:relative;overflow:hidden;
}
.stat-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    opacity:0;transition:opacity var(--transition);
}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.stat-card:hover::before{opacity:1}
.stat-card:nth-child(1)::before{background:linear-gradient(90deg,#d97706,#f59e0b)}
.stat-card:nth-child(2)::before{background:linear-gradient(90deg,#2563eb,#60a5fa)}
.stat-card:nth-child(3)::before{background:linear-gradient(90deg,#16a34a,#4ade80)}
.stat-card:nth-child(4)::before{background:linear-gradient(90deg,#eab308,#fde047)}
.stat-card:nth-child(5)::before{background:linear-gradient(90deg,#dc2626,#f87171)}
.stat-card:nth-child(6)::before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}
.stat-card-urgent{border-color:rgba(220,38,38,.3);animation:urgentPulse 2s ease-in-out infinite}
@keyframes urgentPulse{0%,100%{border-color:rgba(220,38,38,.3)}50%{border-color:rgba(220,38,38,.6)}}
.stat-icon{
    width:44px;height:44px;border-radius:var(--radius);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.stat-icon svg{width:20px;height:20px;stroke-width:1.8}
.stat-icon.orange{background:linear-gradient(135deg,rgba(217,119,6,.15),rgba(217,119,6,.06));color:#d97706}
.stat-icon.green{background:linear-gradient(135deg,rgba(22,163,74,.15),rgba(22,163,74,.06));color:#16a34a}
.stat-icon.blue{background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(37,99,235,.06));color:#2563eb}
.stat-icon.yellow{background:linear-gradient(135deg,rgba(234,179,8,.15),rgba(234,179,8,.06));color:#eab308}
.stat-icon.red{background:linear-gradient(135deg,rgba(220,38,38,.15),rgba(220,38,38,.06));color:#dc2626}
.stat-icon.purple{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(139,92,246,.06));color:#8b5cf6}
.stat-info{flex:1;min-width:0}
.stat-label{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.stat-value{font-size:1.4rem;font-weight:800;line-height:1.2;margin-top:.15rem;letter-spacing:-.02em}
.stat-sub{font-size:.7rem;font-weight:500;color:var(--text-muted)}
.stat-detail{font-size:.72rem;color:var(--text-secondary);margin-top:.2rem;line-height:1.35;display:flex;align-items:center;gap:.3rem}
.stat-detail svg{flex-shrink:0}

/* ── Dashboard Welcome ──────────────────────────────────── */
.dash-welcome{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem;
}
.dash-greeting-text{font-size:1.4rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.dash-greeting-date{color:var(--text-secondary);font-size:.8rem;margin-top:.15rem;text-transform:capitalize}
.dash-quick-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.dash-quick-btn{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.45rem .85rem;border:1px solid var(--border);
    border-radius:var(--radius);background:var(--surface);
    font-size:.78rem;font-weight:500;color:var(--text);
    cursor:pointer;transition:all var(--transition);
    position:relative;overflow:hidden;
}
.dash-quick-btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;color:var(--primary)}
.dash-quick-btn:hover{border-color:var(--primary);background:var(--primary-50);color:var(--primary)}
.dash-quick-btn::after{
    content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(217,119,6,.06),transparent);
    transition:left .4s ease;
}
.dash-quick-btn:hover::after{left:100%}

/* ── Dashboard Filters ──────────────────────────────────── */
.dash-filters{
    display:flex;align-items:center;gap:.75rem;
    margin-bottom:1.25rem;flex-wrap:wrap;
}
.dash-pills{display:flex;gap:.35rem;flex-wrap:wrap}
.dash-pill{
    padding:.35rem .75rem;border:1px solid var(--border);
    border-radius:20px;background:var(--surface);
    font-size:.75rem;font-weight:500;color:var(--text-secondary);
    cursor:pointer;transition:all var(--transition);
    white-space:nowrap;
}
.dash-pill:hover{border-color:var(--primary);color:var(--primary)}
.dash-pill.active{
    background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600;
}
.dash-date-range{display:flex;align-items:center;gap:.4rem}
.dash-date-input{
    padding:.3rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);
    font-size:.78rem;background:var(--surface);color:var(--text);
}
.dash-date-sep{font-size:.75rem;color:var(--text-muted)}

/* ── Chart Cards ────────────────────────────────────────── */
.chart-card .card-title{display:flex;align-items:center;gap:.4rem}
.chart-card .card-title svg{color:var(--primary);flex-shrink:0}

/* ── Dashboard Activity ─────────────────────────────────── */
.dash-activity-card{padding:0;overflow:hidden}
.dash-activity-card .card-header{padding:1rem 1.25rem .7rem;margin-bottom:0;border-bottom:none}
.dash-activity-list{padding:0 .25rem .5rem}
.dash-activity-row{
    display:grid;grid-template-columns:70px 1fr 1fr 85px;
    align-items:center;gap:.5rem;
    padding:.55rem 1rem;font-size:.78rem;border-radius:var(--radius-sm);
    transition:background var(--transition);
}
.dash-activity-row:hover{background:var(--surface-hover)}
.dash-act-date{color:var(--text-muted);font-size:.72rem;font-weight:500}
.dash-act-desc{color:var(--text);font-weight:500}
.dash-act-extra{font-size:.72rem}
.dash-act-value{text-align:right;font-size:.8rem}
.dash-act-badge{text-align:right}
.empty-state-sm{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.8rem}

/* Activity with 5 columns (fatura proximas) */
.dash-activity-card:last-child .dash-activity-row{
    grid-template-columns:70px 90px 1fr 85px 70px;
}

/* ── Charts Dashboard ───────────────────────────────────── */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}
.chart-container{position:relative;height:280px}
.chart-container canvas{width:100%!important;height:100%!important}

/* ── Despesas Page Premium ───────────────────────────────── */
.desp-summary{
    display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem;
}
.desp-kpi{
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius);padding:.85rem 1rem;text-align:center;
    transition:box-shadow var(--transition),transform var(--transition);
}
.desp-kpi:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.desp-kpi-value{font-size:1.1rem;font-weight:800;color:var(--text);letter-spacing:-.02em}
.desp-kpi-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:.1rem}
.desp-date{font-size:.8rem;font-weight:500;white-space:nowrap}
.desp-fornecedor{font-weight:500}
.badge-cat{
    display:inline-block;padding:.12rem .5rem;border-radius:999px;
    font-size:.68rem;font-weight:600;background:var(--primary-50);
    color:var(--primary);border:1px solid rgba(217,119,6,.12);
    white-space:nowrap;
}
.badge-cat.badge-salary{background:rgba(16,185,129,.08);color:#059669;border-color:rgba(16,185,129,.15)}
.row-recibo{background:rgba(16,185,129,.03)}
.row-recibo:hover{background:rgba(16,185,129,.06)!important}
.desp-table-card{padding:0;overflow:hidden}
.desp-table-card .table-responsive{border:none;border-radius:0}
.input-with-action{display:flex;gap:.35rem}
.input-with-action select{flex:1}
.input-with-action .btn{flex-shrink:0}
.quick-add-panel{
    background:rgba(37,99,235,.03);border:1px dashed rgba(37,99,235,.2);
    border-radius:var(--radius);padding:.85rem;margin-top:.5rem;margin-bottom:.5rem;
}

/* ── Buttons ────────────────────────────────────────────── */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
    padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);
    font-size:.85rem;font-weight:500;cursor:pointer;
    transition:all var(--transition);white-space:nowrap;
}
.btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover)}
.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}
.btn-secondary:hover{background:var(--surface-hover)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:var(--danger-hover)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#15803d}
.btn-sm{padding:.35rem .65rem;font-size:.8rem}
.btn-block{width:100%}
.btn-icon{
    background:none;border:none;cursor:pointer;padding:.35rem;
    border-radius:var(--radius-sm);transition:all var(--transition);
    display:inline-flex;align-items:center;justify-content:center;
}
.btn-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-icon:hover{background:var(--surface-hover)}
.btn-group{display:flex;gap:.5rem;flex-wrap:wrap}

/* ── Forms ──────────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.3rem}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
input[type="text"],input[type="number"],input[type="date"],input[type="email"],
input[type="tel"],input[type="password"],input[type="search"],
select,textarea{
    width:100%;padding:.55rem .75rem;border:1px solid var(--border);
    border-radius:var(--radius-sm);background:var(--surface);
    transition:border-color var(--transition),box-shadow var(--transition);
    font-size:.87rem;
}
input:focus,select:focus,textarea:focus{
    outline:none;border-color:var(--primary);
    box-shadow:0 0 0 3px var(--primary-50);
}
textarea{resize:vertical;min-height:80px}
select{cursor:pointer}

/* ── Tables ─────────────────────────────────────────────── */
.table-responsive{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}
.table{width:100%;font-size:.85rem}
.table th{
    background:var(--surface-hover);font-weight:600;font-size:.75rem;
    text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);
    padding:.65rem .75rem;text-align:left;border-bottom:1px solid var(--border);
    position:sticky;top:0;z-index:1;
}
.table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}
.table tbody tr:hover{background:var(--primary-50)}
.table tbody tr:last-child td{border-bottom:none}
.table .actions{display:flex;gap:.25rem;justify-content:flex-end}
.text-right{text-align:right}
.text-center{text-align:center}

/* ── Badges ─────────────────────────────────────────────── */
.badge{
    display:inline-block;padding:.15rem .5rem;border-radius:999px;
    font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;
}
.badge-success{background:var(--success-light);color:var(--success)}
.badge-warning{background:var(--warning-light);color:#a16207}
.badge-danger{background:#fee2e2;color:var(--danger)}
.badge-info{background:var(--info-light);color:var(--info)}
.badge-neutral{background:#f1f5f9;color:var(--text-secondary)}

/* ── Modal ──────────────────────────────────────────────── */
.modal[hidden]{display:none!important}
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.5)}
.modal-content{
    position:relative;background:var(--surface);border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;
    overflow-y:auto;animation:modalIn .2s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:none}}
.modal-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);
}
.modal-header h3{font-size:1.05rem;font-weight:600}
.modal-body{padding:1.5rem}
.modal-footer{
    display:flex;justify-content:flex-end;gap:.5rem;
    padding:1rem 1.5rem;border-top:1px solid var(--border);
}
.modal-lg .modal-content{max-width:900px}

/* ── Toast ──────────────────────────────────────────────── */
.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.5rem}
.toast{
    padding:.75rem 1rem;border-radius:var(--radius-sm);color:#fff;
    font-size:.85rem;box-shadow:var(--shadow-md);min-width:260px;
    animation:toastIn .3s ease;display:flex;align-items:center;gap:.5rem;
}
.toast svg{width:18px;height:18px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast-success{background:var(--success)}
.toast-error{background:var(--danger)}
.toast-info{background:var(--info)}

/* ── Filters bar ────────────────────────────────────────── */
.filters-bar{
    display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap;
    padding:1rem;background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius);margin-bottom:1rem;
}
.filters-bar .form-group{margin-bottom:0;min-width:140px}
.filters-bar .form-group label{font-size:.72rem}

/* ── Empty state ────────────────────────────────────────── */
.empty-state{
    text-align:center;padding:3rem 1rem;color:var(--text-muted);
}
.empty-state svg{width:48px;height:48px;margin-bottom:.75rem;opacity:.4}
.empty-state p{font-size:.9rem}

/* ── Print recibo ───────────────────────────────────────── */
.recibo-print{display:none}
@media print{
    body>*{display:none!important}
    .recibo-print{display:block!important;padding:2rem}
    .recibo-print table{border-collapse:collapse;width:100%}
    .recibo-print th,.recibo-print td{border:1px solid #333;padding:.4rem .6rem;font-size:12px}
    .recibo-print h2{font-size:16px;margin-bottom:.5rem}
    .recibo-print h3{font-size:13px;margin-bottom:.3rem}
}

/* ── Document Premium (Orçamento/Fatura) ─ Black & Gold ─── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

.modal-pd .modal-content{max-width:860px;background:transparent;box-shadow:none;border:none}
.pd-modal-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;background:#0d0d0d;border-bottom:1px solid #2a2a2a}
.pd-modal-title{font-size:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:#c9a84c}
.pd-modal-actions{display:flex;align-items:center;gap:.5rem}
.pd-btn-print{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:linear-gradient(135deg,#c9a84c,#e8c97e);color:#0a0a0a;border:none;border-radius:3px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;font-family:inherit}
.pd-btn-print svg{width:13px;height:13px}
.pd-btn-print:hover{opacity:.85}

.pd-wrap{padding:0;background:#0d0d0d;overflow-y:auto;max-height:85vh}

/* The A4 page */
.pd-page{
    width:794px;margin:0 auto;background:#131313;position:relative;
    box-shadow:0 0 0 1px rgba(201,168,76,.18),0 24px 80px rgba(0,0,0,.8);
    font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;
}
.pd-topbar,.pd-bottombar{height:2px;background:linear-gradient(90deg,transparent 0%,#c9a84c 20%,#e8c97e 50%,#c9a84c 80%,transparent 100%)}
.pd-corners{position:absolute;inset:0;pointer-events:none}
.pd-corners::before,.pd-corners::after,.pd-corners span::before,.pd-corners span::after{content:'';position:absolute;width:20px;height:20px}
.pd-corners::before{top:12px;left:12px;border-top:1px solid #c9a84c;border-left:1px solid #c9a84c}
.pd-corners::after{top:12px;right:12px;border-top:1px solid #c9a84c;border-right:1px solid #c9a84c}
.pd-corners span::before{bottom:12px;left:12px;border-bottom:1px solid #c9a84c;border-left:1px solid #c9a84c}
.pd-corners span::after{bottom:12px;right:12px;border-bottom:1px solid #c9a84c;border-right:1px solid #c9a84c}

/* Header */
.pd-header{padding:36px 48px 28px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid #242424}
.pd-brand-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:24px;font-weight:600;color:#f0f0f0;letter-spacing:.3px}
.pd-brand-name em{color:#c9a84c;font-style:normal}
.pd-brand-tag{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:#c9a84c;opacity:.75;margin-top:4px}
.pd-brand-contacts{margin-top:12px;display:flex;flex-direction:column;gap:2px}
.pd-brand-contacts span{font-size:10px;color:#666}
.pd-docref{text-align:right}
.pd-doc-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:34px;font-weight:700;background:linear-gradient(145deg,#f5e4b0,#e8c97e,#c9a84c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.pd-doc-num{font-size:10px;color:#666;letter-spacing:2px;margin-top:5px}
.pd-doc-dates{margin-top:10px;display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.pd-doc-dates span{font-size:10px;color:#666}
.pd-doc-dates strong{color:#e8c97e;font-weight:500}

/* Parties */
.pd-parties{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#222;border-bottom:1px solid #222}
.pd-party{background:#131313;padding:18px 48px}
.pd-party-r{padding-left:28px}
.pd-party-label{font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:#c9a84c;font-weight:600;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #222}
.pd-party-name{font-size:13px;font-weight:500;color:#f0f0f0;margin-bottom:3px}
.pd-party-detail{font-size:10px;color:#666;line-height:1.6}

/* Section */
.pd-section{padding:22px 48px 0}
.pd-sec-label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:#c9a84c;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(201,168,76,.2)}

/* Table */
.pd-table{width:100%;border-collapse:collapse}
.pd-table thead th{background:rgba(201,168,76,.06);border-top:1px solid rgba(201,168,76,.22);border-bottom:1px solid rgba(201,168,76,.22);font-size:8px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:#c9a84c;padding:9px 12px;text-align:left}
.pd-table tbody .pd-row{border-bottom:1px solid #1f1f1f}
.pd-table tbody .pd-row:last-child{border-bottom:none}
.pd-table tbody .pd-row:hover{background:rgba(255,255,255,.012)}
.pd-table td{padding:13px 12px;font-size:11px;color:#c8c8c8;vertical-align:top}
.ta-c{text-align:center;color:#666!important;padding-top:14px!important}
.ta-r{text-align:right;color:#666!important;padding-top:14px!important}
.pd-table td:last-child{text-align:right;font-weight:600;font-size:12px;color:#e8c97e!important;padding-top:14px!important}
.pd-num{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border:1px solid rgba(201,168,76,.3);font-size:8px;font-weight:700;color:#c9a84c;float:left;margin-right:9px;margin-top:1px;flex-shrink:0}
.pd-body{overflow:hidden}
.pd-title{font-weight:500;color:#f0f0f0;font-size:12px;line-height:1.3}
.pd-desc{font-size:10px;color:#555;margin-top:3px;line-height:1.5}

/* Totals */
.pd-totals-wrap{padding:18px 48px 0;display:flex;justify-content:flex-end}
.pd-totals{width:248px;border:1px solid #222}
.pd-tot-row{display:flex;justify-content:space-between;padding:8px 14px;font-size:11px;border-bottom:1px solid #222;color:#666}
.pd-tot-row span:last-child{color:#c8c8c8;font-weight:500}
.pd-tot-grand{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:linear-gradient(90deg,rgba(201,168,76,.1),rgba(201,168,76,.05));border-top:1px solid rgba(201,168,76,.35)}
.pd-tot-grand span:first-child{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:#c9a84c;font-weight:600}
.pd-tot-grand span:last-child{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:700;color:#e8c97e}

/* Conditions */
.pd-conds{padding:22px 48px 0;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pd-cond{border:1px solid #1f1f1f;padding:12px 14px;background:rgba(255,255,255,.01)}
.pd-cond h4{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:#c9a84c;font-weight:600;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #1f1f1f}
.pd-cond li{list-style:none;font-size:10px;color:#555;padding:2px 0 2px 10px;position:relative;line-height:1.5}
.pd-cond li::before{content:'›';position:absolute;left:0;color:#c9a84c}

/* Signatures */
.pd-sigs{padding:20px 48px 0;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pd-sig{border:1px solid #1f1f1f;padding:16px 14px 12px}
.pd-sig-space{height:38px}
.pd-sig-line{height:1px;background:linear-gradient(90deg,rgba(201,168,76,.45),transparent);margin-bottom:8px}
.pd-sig-name{font-size:11px;color:#f0f0f0;font-weight:500}
.pd-sig-role{font-size:9px;color:#555;margin-top:2px}

/* Footer */
.pd-footer{margin:20px 48px 36px}
.pd-footer-rule{height:1px;background:linear-gradient(90deg,transparent,#c9a84c,transparent);margin-bottom:12px}
.pd-footer-row{display:flex;justify-content:space-between}
.pd-footer-row span{font-size:9px;color:#3a3a3a;letter-spacing:.3px}

/* ── Line items editor ──────────────────────────────────── */
.line-items{margin-bottom:1rem}
.line-item{display:grid;grid-template-columns:2fr 80px 60px 100px 70px 1fr 40px;gap:.5rem;align-items:end;margin-bottom:.5rem}
.line-item input,.line-item select{padding:.4rem .5rem;font-size:.82rem}
.line-item .li-total{font-size:.85rem;font-weight:600;padding:.4rem 0;text-align:right}
.line-items-header{display:grid;grid-template-columns:2fr 80px 60px 100px 70px 1fr 40px;gap:.5rem;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;padding:0 0 .25rem}

/* ── Utilities ──────────────────────────────────────────── */
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.gap-1{gap:.5rem}.gap-2{gap:1rem}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}
.justify-between{justify-content:space-between}.flex-1{flex:1}
.font-mono{font-family:var(--font-mono)}
.text-sm{font-size:.8rem}.text-xs{font-size:.72rem}
.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}
.text-primary{color:var(--primary)}.text-success{color:var(--success)}
.text-danger{color:var(--danger)}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hidden{display:none!important}

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width:768px) {
    .sidebar{transform:translateX(-100%)}
    .sidebar.open{transform:translateX(0)}
    .sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99}
    .main-content{margin-left:0}
    .mobile-header{
        display:flex;align-items:center;gap:.75rem;
        padding:.75rem 1rem;background:var(--surface);
        border-bottom:1px solid var(--border);
        position:sticky;top:0;z-index:50;
    }
    .mobile-title{font-weight:600;font-size:1rem}
    .content-wrapper{padding:1rem}
    .stats-grid{grid-template-columns:1fr 1fr}
    .charts-grid{grid-template-columns:1fr}
    .page-header{flex-direction:column;align-items:flex-start}
    .filters-bar{flex-direction:column;align-items:stretch}
    .filters-bar .form-group{min-width:100%}
    .line-item{grid-template-columns:1fr 1fr;gap:.35rem}
    .line-items-header{display:none}
    .form-row{grid-template-columns:1fr}
    .doc-parties{grid-template-columns:1fr}
    .sidebar-nav{grid-template-columns:repeat(3,1fr);gap:.4rem;padding:.5rem .5rem}
    .nav-item{min-height:60px;padding:.5rem .25rem;font-size:.62rem}
    .dash-welcome{flex-direction:column;align-items:flex-start}
    .dash-quick-actions{width:100%}
    .dash-quick-btn{flex:1;justify-content:center;font-size:.72rem;padding:.4rem .5rem}
    .dash-pills{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:.2rem}
    .dash-date-range{width:100%}
    .dash-activity-row{grid-template-columns:55px 1fr 75px!important;font-size:.72rem}
    .dash-act-extra{display:none}
    .dash-act-badge{display:none}
    .desp-summary{grid-template-columns:1fr 1fr}
}
@media (max-width:480px) {
    .stats-grid{grid-template-columns:1fr}
    .stat-card{padding:1rem}
    .stat-value{font-size:1.2rem}
    .dash-greeting-text{font-size:1.15rem}
    .dash-quick-btn span{display:none}
}

/* Autocomplete client selector */
.autocomplete-wrapper { position: relative; }
.autocomplete-wrapper input[type="text"] { width: 100%; }
.ac-list {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--card-bg, #fff); border: 1px solid var(--border, #e2e8f0);
    border-radius: 0 0 8px 8px; max-height: 200px; overflow-y: auto;
    z-index: 1000; box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.ac-item {
    padding: 8px 12px; cursor: pointer; font-size: .9rem;
    border-bottom: 1px solid var(--border, #f0f0f0);
    transition: background .15s;
}
.ac-item:last-child { border-bottom: none; }
.ac-item:hover, .ac-item.ac-sel { background: var(--primary-light, #ebf5ff); }
.ac-new { color: var(--primary, #2563eb); font-weight: 500; }
.ac-new:hover, .ac-new.ac-sel { background: var(--primary-light, #dbeafe); }

/* ── Recibos Page Enhanced ──────────────────────────────── */
.rec-summary-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:.85rem;margin-bottom:1.25rem;
}
.rec-emp-card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:1rem 1.15rem;
    display:flex;align-items:center;gap:.85rem;
    box-shadow:var(--shadow-sm);transition:all var(--transition);
}
.rec-emp-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.rec-emp-avatar{
    width:42px;height:42px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:.85rem;flex-shrink:0;
}
.rec-emp-info{flex:1;min-width:0}
.rec-emp-name{font-weight:700;font-size:.9rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-emp-detail{font-size:.73rem;color:var(--text-muted);margin-top:.1rem}
.rec-emp-balance{text-align:right;flex-shrink:0}
.rec-emp-balance-label{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.rec-emp-balance-value{display:block;font-size:1.1rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}
.rec-emp-balance.positive .rec-emp-balance-label{color:var(--primary)}
.rec-emp-balance.positive .rec-emp-balance-value{color:var(--primary)}
.rec-emp-balance.negative .rec-emp-balance-label{color:var(--danger)}
.rec-emp-balance.negative .rec-emp-balance-value{color:var(--danger)}

.rec-table-card{padding:0;overflow:hidden}
.rec-table-card .table-responsive{border:none;border-radius:0}
.rec-table th{white-space:nowrap}
.rec-month-badge{
    display:inline-block;padding:.2rem .55rem;border-radius:999px;
    background:var(--primary-50);color:var(--primary-hover);
    font-size:.75rem;font-weight:600;white-space:nowrap;
}
.rec-row-negative{background:rgba(220,38,38,.03)}
.rec-row-negative:hover{background:rgba(220,38,38,.06)!important}
.btn-action-view:hover{color:var(--info)}
.btn-action-edit:hover{color:var(--primary)}
.btn-action-delete:hover{color:var(--danger)}

/* ── Dashboard Employee Balance ─────────────────────────── */
.dash-emp-saldos{display:flex;flex-direction:column;gap:.6rem}
.dash-emp-row{
    display:flex;align-items:center;gap:.85rem;
    padding:.75rem .85rem;border-radius:var(--radius);
    border:1px solid var(--border);transition:all var(--transition);
}
.dash-emp-row:hover{background:var(--surface-hover);border-color:var(--text-muted)}
.dash-emp-avatar{
    width:40px;height:40px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:.82rem;flex-shrink:0;
}
.dash-emp-info{flex:1;min-width:0}
.dash-emp-name{font-weight:700;font-size:.88rem;color:var(--text)}
.dash-emp-meta{font-size:.72rem;color:var(--text-muted);margin-top:.1rem}
.dash-emp-bar-wrap{
    height:4px;background:var(--border);border-radius:999px;
    margin-top:.45rem;overflow:hidden;
}
.dash-emp-bar{height:100%;border-radius:999px;transition:width .5s ease}
.dash-emp-amounts{
    display:flex;justify-content:space-between;
    font-size:.68rem;color:var(--text-muted);margin-top:.2rem;
}
.dash-emp-saldo{text-align:right;flex-shrink:0;min-width:95px}
.dash-emp-saldo-label{display:block;font-size:.63rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.dash-emp-saldo-value{display:block;font-size:1.15rem;font-weight:800;letter-spacing:-.02em;line-height:1.25}
.dash-emp-saldo.positive .dash-emp-saldo-label{color:var(--primary)}
.dash-emp-saldo.positive .dash-emp-saldo-value{color:var(--primary)}
.dash-emp-saldo.negative .dash-emp-saldo-label{color:var(--danger)}
.dash-emp-saldo.negative .dash-emp-saldo-value{color:var(--danger)}

@media(max-width:640px){
    .rec-summary-grid{grid-template-columns:1fr}
    .dash-emp-row{flex-wrap:wrap}
    .dash-emp-saldo{width:100%;text-align:left;margin-top:.3rem}
}
