:root{--primary:#6366f1;--primary-bg:rgba(99,102,241,0.1);--success:#10b981;--success-bg:rgba(16,185,129,0.1);--warning:#f59e0b;--warning-bg:rgba(245,158,11,0.1);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.1);--bg-primary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-card:#fff;--bg-input:#fff;--bg-hover:#f1f5f9;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--border-color:#e2e8f0;--shadow:0 4px 6px -1px rgba(0,0,0,0.1);--font-family:'DM Sans',sans-serif;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--sidebar-width:260px;--header-height:65px}
[data-theme="dark"]{--primary:#818cf8;--primary-bg:rgba(129,140,248,0.15);--bg-primary:#0f172a;--bg-tertiary:#334155;--bg-card:#1e293b;--bg-input:#1e293b;--bg-hover:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#334155}
*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);font-size:0.9375rem;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);min-height:100vh}a{color:var(--primary);text-decoration:none}h1,h2,h3,h4{font-weight:600;color:var(--text-primary);margin-bottom:0.5rem}
.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:300;transition:transform 0.3s}.sidebar-header{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:0.75rem;min-height:var(--header-height)}.sidebar-logo{width:40px;height:40px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.sidebar-brand{display:flex;flex-direction:column}.sidebar-brand-name{font-size:1rem;font-weight:700}.sidebar-brand-subtitle{font-size:0.7rem;color:var(--text-muted)}.sidebar-content{flex:1;overflow-y:auto;padding:0.75rem}.sidebar-footer{padding:0.75rem;border-top:1px solid var(--border-color)}
.nav-menu{list-style:none}.menu-label{font-size:0.65rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);padding:0.75rem 0.5rem 0.5rem;margin-top:0.5rem}.nav-item{margin-bottom:2px}.nav-link{display:flex;align-items:center;gap:0.75rem;padding:0.6rem 0.75rem;color:var(--text-secondary);border-radius:var(--radius);transition:all 0.2s;font-weight:500;font-size:0.875rem}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--primary-bg);color:var(--primary)}.nav-link-highlight{background:linear-gradient(135deg,rgba(245,158,11,0.15),rgba(217,119,6,0.1));color:#d97706;border:1px solid rgba(245,158,11,0.3)}.nav-link-highlight:hover{background:linear-gradient(135deg,rgba(245,158,11,0.25),rgba(217,119,6,0.2));color:#b45309}.nav-link-highlight.active{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#d97706}.nav-icon{width:20px;height:20px;flex-shrink:0}.nav-text{flex:1}.badge-info{background:rgba(59,130,246,0.1);color:#3b82f6}
.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:0 1.5rem;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;z-index:200}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.sidebar-toggle{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius);cursor:pointer;color:var(--text-secondary)}.page-title{font-size:1.125rem;font-weight:600;margin:0}
.control-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-secondary)}.control-btn:hover,.control-btn.active{background:var(--primary-bg);color:var(--primary);border-color:var(--primary)}.zoom-control{display:flex;align-items:center;gap:0.25rem;background:var(--bg-tertiary);border-radius:var(--radius);padding:4px}.zoom-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary)}.zoom-value{font-size:0.75rem;font-weight:600;min-width:36px;text-align:center}
.user-menu{display:flex;align-items:center;gap:0.5rem;padding:0.25rem 0.75rem 0.25rem 0.25rem;background:var(--bg-tertiary);border-radius:999px;cursor:pointer}.user-avatar{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:0.8rem}.user-info{display:flex;flex-direction:column}.user-name{font-size:0.8rem;font-weight:600;line-height:1.2}.user-role{font-size:0.65rem;color:var(--text-muted)}.content{flex:1;padding:1.5rem}
.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:1rem;font-weight:600;margin:0}.card-body{padding:1.25rem}.card-footer{padding:1rem 1.25rem;border-top:1px solid var(--border-color);background:var(--bg-tertiary)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;position:relative;overflow:hidden}.stat-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.stat-card.success::before{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.warning::before{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.danger::before{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-icon.primary{background:var(--primary-bg);color:var(--primary)}.stat-icon.success{background:var(--success-bg);color:var(--success)}.stat-icon.warning{background:var(--warning-bg);color:var(--warning)}.stat-icon.danger{background:var(--danger-bg);color:var(--danger)}.stat-icon svg{width:24px;height:24px}.stat-label{font-size:0.75rem;color:var(--text-muted);margin-bottom:4px}.stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.stat-change{font-size:0.7rem;font-weight:600;margin-top:4px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.5rem 1rem;font-size:0.875rem;font-weight:500;font-family:inherit;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all 0.2s;text-decoration:none}.btn:disabled{opacity:0.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:#6366f1}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.4)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--bg-hover)}.btn-sm{padding:0.375rem 0.75rem;font-size:0.8125rem}.btn-lg{padding:0.75rem 1.5rem;font-size:1rem}
.form-group{margin-bottom:1rem}.form-label{display:block;font-size:0.875rem;font-weight:500;margin-bottom:0.375rem}.form-control{width:100%;padding:0.5rem 0.75rem;font-size:0.9375rem;font-family:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius)}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-check{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.5rem}
.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:0.875rem}.table th,.table td{padding:0.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.table th{background:var(--bg-tertiary);font-weight:600;font-size:0.75rem;text-transform:uppercase}.table tbody tr:hover{background:var(--bg-hover)}
.badge{display:inline-flex;padding:4px 10px;font-size:0.75rem;font-weight:600;border-radius:999px}.badge-primary{background:var(--primary-bg);color:var(--primary)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;font-size:0.75rem;font-weight:600;border-radius:999px}.status-badge::before{content:'';width:6px;height:6px;border-radius:50%}.status-badge.pago,.status-badge.ativo{background:var(--success-bg);color:var(--success)}.status-badge.pago::before,.status-badge.ativo::before{background:var(--success)}.status-badge.em_aberto{background:var(--warning-bg);color:var(--warning)}.status-badge.em_aberto::before{background:var(--warning)}.status-badge.inativo{background:var(--danger-bg);color:var(--danger)}.status-badge.inativo::before{background:var(--danger)}
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);display:flex;align-items:center;justify-content:center;z-index:400;opacity:0;visibility:hidden;transition:all 0.2s;padding:1rem}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow:hidden;transform:scale(0.9);transition:transform 0.2s}.modal-overlay.active .modal{transform:scale(1)}.modal-lg{max-width:700px}.modal-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.1rem;font-weight:600;margin:0}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius);cursor:pointer;color:var(--text-muted);font-size:1.5rem}.modal-body{padding:1.25rem;overflow-y:auto;max-height:calc(90vh - 140px)}.modal-footer{padding:1rem 1.25rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:0.5rem;background:var(--bg-tertiary)}
.alert{padding:0.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.alert-success{background:var(--success-bg);color:var(--success)}.alert-warning{background:var(--warning-bg);color:var(--warning)}.alert-danger{background:var(--danger-bg);color:var(--danger)}.alert-message{font-size:0.875rem}
.empty-state{text-align:center;padding:3rem}.empty-state-icon{width:80px;height:80px;margin:0 auto 1rem;background:var(--bg-tertiary);border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.empty-state-icon svg{width:40px;height:40px}.empty-state-title{font-size:1.125rem;font-weight:600;margin-bottom:0.5rem}.empty-state-text{color:var(--text-muted);margin-bottom:1rem}
.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;min-width:180px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:0.25rem;opacity:0;visibility:hidden;transform:translateY(10px);transition:all 0.2s;z-index:100}.dropdown.active .dropdown-menu{opacity:1;visibility:visible;transform:translateY(4px)}.dropdown-item{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0.75rem;color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;font-size:0.875rem}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-divider{height:1px;background:var(--border-color);margin:0.25rem 0}
.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.d-flex{display:flex}.d-none{display:none}.flex-wrap{flex-wrap:wrap}.align-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:0.5rem}.gap-md{gap:1rem}.gap-lg{gap:1.5rem}.text-center{text-align:center}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.fw-semibold{font-weight:600}.mb-0{margin-bottom:0}.mb-lg{margin-bottom:1.5rem}.w-100{width:100%}.row{display:flex;flex-wrap:wrap;margin:0 -0.5rem}.col,.col-6{flex:1;padding:0 0.5rem}.col-6{flex:0 0 50%;max-width:50%}
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-primary)}.login-container{width:100%;max-width:400px}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.login-header{padding:2rem 1.5rem 1rem;text-align:center}.login-logo{width:60px;height:60px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.login-logo svg{width:30px;height:30px;color:#fff}.login-title{font-size:1.5rem;font-weight:700;margin-bottom:0.25rem}.login-subtitle{color:var(--text-muted);font-size:0.875rem;margin:0}.login-body{padding:1rem 1.5rem 2rem}.login-footer{padding:1rem;background:var(--bg-tertiary);text-align:center;border-top:1px solid var(--border-color)}.login-footer p{font-size:0.75rem;color:var(--text-muted);margin:0}
.mobile-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:299;opacity:0;visibility:hidden;transition:all 0.2s}.mobile-overlay.active{opacity:1;visibility:visible}

/* ===================== RESPONSIVO GLOBAL ===================== */

/* Tablet */
@media(max-width:1024px){
    .sidebar{transform:translateX(-100%)}
    .sidebar.mobile-open{transform:translateX(0)}
    .main-content{margin-left:0}
}

/* Mobile */
@media(max-width:768px){
    :root{--header-height:56px}

    /* Header */
    .header{padding:0 0.75rem;height:var(--header-height)}
    .page-title{font-size:0.95rem}
    .sidebar-toggle{width:36px;height:36px}
    .control-btn{width:36px;height:36px}
    .user-menu{padding:0.2rem 0.5rem 0.2rem 0.2rem}
    .user-avatar{width:30px;height:30px;font-size:0.7rem}
    .user-info{display:none}
    .zoom-control{display:none}

    /* Content */
    .content{padding:0.75rem}

    /* Stats */
    .stats-grid{grid-template-columns:1fr;gap:0.75rem;margin-bottom:1rem}
    .stat-card{padding:1rem;gap:0.75rem}
    .stat-icon{width:40px;height:40px}
    .stat-icon svg{width:20px;height:20px}
    .stat-value{font-size:1.25rem}

    /* Cards */
    .card{border-radius:var(--radius-lg)}
    .card-header{padding:0.75rem 1rem}
    .card-body{padding:1rem}
    .card-title{font-size:0.9rem}

    /* Forms */
    .form-group{margin-bottom:0.75rem}
    .form-control{padding:0.6rem 0.75rem;font-size:16px} /* 16px previne zoom iOS */
    .form-label{font-size:0.8rem}

    /* Buttons */
    .btn{padding:0.6rem 1rem;font-size:0.85rem}
    .btn-lg{padding:0.75rem 1.25rem}

    /* Grid e Columns */
    .row{margin:0;flex-direction:column}
    .col,.col-6{flex:0 0 100%;max-width:100%;padding:0;margin-bottom:0.75rem}

    /* Tables - Modo cards */
    .table-container{overflow-x:visible}
    .table{font-size:0.8rem}
    .table th,.table td{padding:0.6rem 0.75rem}

    /* Modals */
    .modal-overlay{padding:0.5rem}
    .modal{border-radius:var(--radius-lg);max-height:95vh}
    .modal-header{padding:0.75rem 1rem}
    .modal-title{font-size:1rem}
    .modal-body{padding:1rem;max-height:calc(95vh - 120px)}
    .modal-footer{padding:0.75rem 1rem}

    /* Badges */
    .badge{padding:3px 8px;font-size:0.7rem}
    .status-badge{padding:3px 10px;font-size:0.7rem}

    /* Dropdown */
    .dropdown-menu{min-width:160px}
    .dropdown-item{padding:0.6rem 0.75rem;font-size:0.8rem}

    /* Alerts */
    .alert{padding:0.6rem 0.75rem}
    .alert-message{font-size:0.8rem}
}

/* Mobile pequeno */
@media(max-width:480px){
    .content{padding:0.5rem}

    /* Header ainda mais compacto */
    .header{padding:0 0.5rem}
    .page-title{font-size:0.85rem;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .sidebar-toggle{width:32px;height:32px}
    .control-btn{width:32px;height:32px}
    .user-avatar{width:28px;height:28px}

    /* Stats */
    .stat-card{padding:0.75rem;gap:0.5rem}
    .stat-icon{width:36px;height:36px}
    .stat-value{font-size:1.1rem}
    .stat-label{font-size:0.7rem}

    /* Cards */
    .card-header{padding:0.6rem 0.75rem}
    .card-body{padding:0.75rem}

    /* Buttons */
    .btn{padding:0.5rem 0.75rem;font-size:0.8rem}
    .btn svg{width:16px;height:16px}

    /* Forms */
    .form-control{padding:0.5rem 0.6rem}

    /* Tables */
    .table th,.table td{padding:0.5rem 0.6rem;font-size:0.75rem}

    /* Modals */
    .modal-header{padding:0.6rem 0.75rem}
    .modal-body{padding:0.75rem}
    .modal-footer{padding:0.6rem 0.75rem;flex-direction:column}
    .modal-footer .btn{width:100%}
}

/* Tela muito pequena */
@media(max-width:360px){
    .page-title{max-width:120px;font-size:0.8rem}
    .stat-value{font-size:1rem}
    .btn{padding:0.45rem 0.6rem;font-size:0.75rem}
}

/* Sidebar mobile aprimorada */
@media(max-width:1024px){
    .sidebar{width:280px;box-shadow:4px 0 20px rgba(0,0,0,0.15)}
    .sidebar-header{padding:0.75rem}
    .sidebar-logo{width:36px;height:36px}
    .sidebar-brand-name{font-size:0.9rem}
    .sidebar-content{padding:0.5rem}
    .nav-link{padding:0.7rem 0.75rem;font-size:0.9rem}
    .nav-icon{width:22px;height:22px}
}
