:root{--color-brand: #1D9E75;--color-brand-dark: #0F6E56;--color-brand-light: #E1F5EE;--bg-primary: #FFFFFF;--bg-secondary: #F4F4F2;--bg-tertiary: #FAFAFA;--border-color: rgba(0,0,0,.1);--border: .5px solid var(--border-color);--text-primary: #111111;--text-secondary: #555555;--text-tertiary: #888888;--status-ok-bg: #E1F5EE;--status-ok-text: #085041;--status-warn-bg: #FAEEDA;--status-warn-text: #633806;--status-err-bg: #FAECE7;--status-err-text: #4A1B0C;--status-info-bg: #E6F1FB;--status-info-text: #0C447C;--radius-sm: 6px;--radius-md: 7px;--radius-lg: 10px;--radius-pill: 4px;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--sidebar-width: 220px;--topbar-height: 56px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.08);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-weight:400;color:var(--text-primary);background:var(--bg-tertiary);line-height:1.5;overflow:hidden}input,select,textarea,button{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topbar-height) 1fr;grid-template-areas:"sidebar topbar" "sidebar main";height:100vh;width:100vw}.app-layout.sidebar-collapsed{--sidebar-width: 60px}.topbar{grid-area:topbar;display:flex;align-items:center;gap:12px;padding:0 20px;background:var(--bg-primary);border-bottom:var(--border);height:var(--topbar-height);z-index:20}.topbar-logo{display:flex;align-items:center;gap:6px;font-weight:600;font-size:15px;letter-spacing:-.3px;white-space:nowrap}.topbar-logo .dot{width:7px;height:7px;border-radius:50%;background:var(--color-brand);display:inline-block}.topbar-search{flex:1;max-width:380px;position:relative}.topbar-search input{width:100%;height:34px;padding:0 12px 0 34px;background:var(--bg-secondary);border:var(--border);border-radius:var(--radius-md);font-size:12px;color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.topbar-search input:focus{border-color:var(--color-brand)}.topbar-search .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-tertiary)}.topbar-spacer{flex:1}.topbar-notifications{position:relative;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:var(--border);border-radius:var(--radius-md);background:var(--bg-primary);cursor:pointer;transition:background var(--transition-fast)}.topbar-notifications:hover{background:var(--bg-secondary)}.topbar-notifications .badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;border-radius:8px;background:#ef4444;color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px}.topbar-user{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:var(--border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.topbar-user:hover{background:var(--bg-secondary)}.topbar-user .user-name{font-size:12px;font-weight:500;line-height:1.2}.role-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:var(--radius-pill);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.role-badge.super-admin{background:#e6f1fb;color:#0c447c}.role-badge.admin-area{background:#e1f5ee;color:#085041}.role-badge.supervisor{background:#f3e8ff;color:#5b21b6}.role-badge.operario{background:#faeeda;color:#633806}.role-badge.auditor{background:#f4f4f2;color:#555}.avatar{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.avatar.sm{width:24px;height:24px;font-size:9px}.avatar.lg{width:32px;height:32px;font-size:12px}.sidebar{grid-area:sidebar;background:var(--bg-primary);border-right:var(--border);display:flex;flex-direction:column;height:100vh;overflow-y:auto;z-index:30;transition:width var(--transition-slow);width:var(--sidebar-width)}.sidebar-header{display:flex;align-items:center;gap:8px;padding:16px;border-bottom:var(--border);height:var(--topbar-height)}.sidebar-header .logo-text{font-weight:600;font-size:15px;letter-spacing:-.3px}.sidebar-header .logo-dot{width:8px;height:8px;border-radius:50%;background:var(--color-brand)}.sidebar-section{padding:12px 8px 4px}.sidebar-section-label{font-size:10px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;padding:0 8px;margin-bottom:4px}.sidebar-nav{display:flex;flex-direction:column;gap:1px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:400;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative}.sidebar-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-item.active{background:var(--color-brand-light);color:var(--color-brand-dark);font-weight:500}.sidebar-item .icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-item .icon svg{width:16px;height:16px}.sidebar-item .item-badge{margin-left:auto;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:9px;font-size:10px;font-weight:600;background:var(--bg-secondary);color:var(--text-secondary);padding:0 5px}.sidebar-item.active .item-badge{background:#0f6e5626;color:var(--color-brand-dark)}.sidebar-footer{margin-top:auto;padding:12px 16px;border-top:var(--border);display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-tertiary)}.sidebar-footer .status-dot{width:6px;height:6px;border-radius:50%;background:var(--color-brand);animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.main-content{grid-area:main;overflow-y:auto;padding:20px;background:var(--bg-tertiary)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h1{font-size:20px;font-weight:600;letter-spacing:-.3px}.page-header .subtitle{font-size:12px;color:var(--text-tertiary);margin-top:2px}.panel{background:var(--bg-primary);border:var(--border);border-radius:var(--radius-lg);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:var(--border)}.panel-header .panel-title{font-size:13px;font-weight:600;letter-spacing:-.2px}.panel-body{padding:16px}.panel-body.no-pad{padding:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.metric-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:14px 16px;transition:transform var(--transition-fast)}.metric-card:hover{transform:translateY(-1px)}.metric-card .metric-label{font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.metric-card .metric-value{font-size:22px;font-weight:600;letter-spacing:-.5px;color:var(--text-primary);line-height:1.2}.metric-card .metric-change{font-size:11px;font-weight:500;margin-top:4px}.metric-card .metric-change.positive{color:var(--status-ok-text)}.metric-card .metric-change.negative{color:var(--status-err-text)}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{background:var(--bg-secondary);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--text-tertiary);padding:8px 12px;text-align:left;white-space:nowrap;border-bottom:var(--border)}.data-table td{padding:10px 12px;font-size:12px;border-bottom:var(--border);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .mono{font-family:var(--font-mono);font-size:12px}.data-table .row-critical{background:#fef2f2}.data-table .row-warning{background:#fffbeb}.pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:var(--border);font-size:12px;color:var(--text-tertiary)}.pagination-btns{display:flex;gap:4px}.pagination-btns button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);cursor:pointer;font-size:11px;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.pagination-btns button:hover:not(:disabled){background:var(--bg-secondary)}.pagination-btns button.active{background:var(--color-brand);color:#fff;border-color:var(--color-brand)}.pagination-btns button:disabled{opacity:.4;cursor:not-allowed}.status-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:500;white-space:nowrap}.status-pill.ok{background:var(--status-ok-bg);color:var(--status-ok-text)}.status-pill.warn{background:var(--status-warn-bg);color:var(--status-warn-text)}.status-pill.err{background:var(--status-err-bg);color:var(--status-err-text)}.status-pill.info{background:var(--status-info-bg);color:var(--status-info-text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 14px;border:var(--border);border-radius:var(--radius-md);font-size:12px;font-weight:500;cursor:pointer;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-fast);white-space:nowrap}.btn:hover{background:var(--bg-secondary)}.btn-primary{background:var(--color-brand);color:#fff;border-color:var(--color-brand)}.btn-primary:hover{background:var(--color-brand-dark);border-color:var(--color-brand-dark)}.btn-danger{background:var(--status-err-bg);color:var(--status-err-text);border-color:#4a1b0c26}.btn-danger:hover{background:#f5ddd6}.btn-sm{height:26px;padding:0 10px;font-size:11px}.btn-icon{width:32px;padding:0}.btn:disabled{opacity:.5;cursor:not-allowed}.tabs{display:flex;gap:0;border-bottom:var(--border);margin-bottom:16px;overflow-x:auto}.tab{padding:10px 16px;font-size:12px;font-weight:500;color:var(--text-tertiary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);white-space:nowrap}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--color-brand-dark);border-bottom-color:var(--color-brand);font-weight:600}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.form-input,.form-select{width:100%;height:34px;padding:0 10px;border:var(--border);border-radius:var(--radius-md);background:var(--bg-primary);font-size:13px;color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus{border-color:var(--color-brand)}.form-textarea{width:100%;min-height:80px;padding:8px 10px;border:var(--border);border-radius:var(--radius-md);background:var(--bg-primary);font-size:13px;color:var(--text-primary);outline:none;resize:vertical;transition:border-color var(--transition-fast)}.form-textarea:focus{border-color:var(--color-brand)}.form-error{font-size:11px;color:var(--status-err-text);margin-top:3px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-base)}.modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp var(--transition-slow)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:var(--border)}.modal-header h3{font-size:15px;font-weight:600}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:20px}.modal-footer{padding:12px 20px;border-top:var(--border);display:flex;gap:8px;justify-content:flex-end}.slide-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:90;animation:fadeIn var(--transition-base)}.slide-panel{position:fixed;top:0;right:0;width:420px;max-width:90vw;height:100vh;background:var(--bg-primary);box-shadow:var(--shadow-lg);z-index:91;display:flex;flex-direction:column;animation:slideRight var(--transition-slow)}.slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:var(--border)}.slide-panel-body{flex:1;overflow-y:auto;padding:20px}.toast-container{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:12px;font-weight:500;animation:slideUp var(--transition-slow);min-width:280px;max-width:400px}.toast.success{background:var(--status-ok-bg);color:var(--status-ok-text);border:1px solid rgba(8,80,65,.15)}.toast.error{background:var(--status-err-bg);color:var(--status-err-text);border:1px solid rgba(74,27,12,.15)}.toast.info{background:var(--status-info-bg);color:var(--status-info-text);border:1px solid rgba(12,68,124,.15)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.login-card{background:var(--bg-primary);border:var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:380px;box-shadow:var(--shadow-md)}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{font-size:22px;font-weight:600;letter-spacing:-.5px;display:flex;align-items:center;justify-content:center;gap:6px}.login-logo .dot{width:8px;height:8px;border-radius:50%;background:var(--color-brand);display:inline-block}.login-logo p{font-size:12px;color:var(--text-tertiary);margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:16px}.dashboard-main,.dashboard-side{display:flex;flex-direction:column;gap:16px}.area-cards{display:flex;flex-direction:column;gap:8px}.area-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-secondary);transition:all var(--transition-fast);cursor:pointer}.area-card:hover{background:var(--color-brand-light)}.area-card .area-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px}.area-card .area-info{flex:1}.area-card .area-name{font-size:12px;font-weight:500}.area-card .area-progress{height:3px;border-radius:2px;background:#0000000f;margin-top:4px;overflow:hidden}.area-card .area-progress-bar{height:100%;border-radius:2px;transition:width var(--transition-slow)}.activity-feed{display:flex;flex-direction:column;gap:0}.activity-item{display:flex;gap:10px;padding:10px 0;border-bottom:var(--border);font-size:12px}.activity-item:last-child{border-bottom:none}.activity-item .activity-icon{width:26px;height:26px;border-radius:var(--radius-sm);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px}.activity-item .activity-text{flex:1;color:var(--text-secondary);line-height:1.4}.activity-item .activity-text strong{color:var(--text-primary);font-weight:500}.activity-item .activity-time{font-size:10px;color:var(--text-tertiary);white-space:nowrap}.pipeline{display:flex;gap:2px;align-items:center}.pipeline-step{padding:4px 10px;border-radius:var(--radius-pill);font-size:10px;font-weight:500;background:var(--bg-secondary);color:var(--text-tertiary);transition:all var(--transition-fast)}.pipeline-step.active{background:var(--color-brand-light);color:var(--color-brand-dark)}.pipeline-step.completed{background:var(--color-brand);color:#fff}.pipeline-arrow{font-size:10px;color:var(--text-tertiary)}.toggle{position:relative;width:36px;height:20px;cursor:pointer}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000001f;border-radius:10px;transition:background var(--transition-base)}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform var(--transition-base);box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle-slider{background:var(--color-brand)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}.role-hierarchy{display:flex;flex-direction:column;gap:8px}.role-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:12px}.role-card .role-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.role-card .role-name{font-weight:500}.role-card .role-desc{font-size:11px;color:var(--text-tertiary)}.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.report-card{background:var(--bg-primary);border:var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px;transition:all var(--transition-fast)}.report-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.report-card .report-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px}.report-card h3{font-size:14px;font-weight:600}.report-card p{font-size:12px;color:var(--text-tertiary);line-height:1.4}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 1024px){.app-layout{--sidebar-width: 60px}.sidebar .sidebar-item .item-label,.sidebar .sidebar-section-label,.sidebar .sidebar-footer span,.sidebar .sidebar-header .logo-text{display:none}.sidebar .sidebar-item{justify-content:center;padding:10px}.sidebar .sidebar-item .item-badge{display:none}.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}}.module-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:20px}.module-card{background:var(--bg-primary);border:var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center;cursor:pointer;transition:all var(--transition-fast)}.module-card:hover{border-color:var(--color-brand);box-shadow:var(--shadow-sm)}.module-card.active{border-color:var(--color-brand);background:var(--color-brand-light)}.module-card .module-icon{font-size:28px;margin-bottom:8px}.module-card h3{font-size:14px;font-weight:600;margin-bottom:4px}.module-card p{font-size:11px;color:var(--text-tertiary)}.date-filter{display:flex;align-items:center;gap:8px}.date-filter label{font-size:11px;color:var(--text-tertiary);font-weight:500}.date-filter input[type=date]{height:30px;padding:0 8px;border:var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-sans);color:var(--text-primary);outline:none}.date-filter input[type=date]:focus{border-color:var(--color-brand)}.unauthorized-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px}.unauthorized-page h2{font-size:48px;font-weight:600;color:var(--text-tertiary);margin-bottom:8px}.unauthorized-page p{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-tertiary)}.empty-state .empty-icon{font-size:36px;margin-bottom:12px;opacity:.5}.empty-state p{font-size:13px}
