@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.home-container{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:Inter,system-ui,sans-serif;display:flex;position:relative;overflow:hidden}.home-container:before,.home-container:after{content:"";filter:blur(100px);z-index:0;border-radius:50%;position:absolute}.home-container:before{background:#3b82f626;width:500px;height:500px;top:-100px;left:-100px}.home-container:after{background:#10b9811a;width:600px;height:600px;bottom:-150px;right:-100px}.home-content{z-index:1;width:100%;max-width:1100px;position:relative}.home-header{text-align:center;margin-bottom:60px}.logo-wrapper{margin-bottom:30px}.home-logo{object-fit:contain;filter:drop-shadow(0 4px 6px #0000000d);max-width:100%;height:48px}.home-title{color:#0f172a;letter-spacing:-.03em;margin-bottom:12px;font-size:2.5rem;font-weight:800}.home-subtitle{color:#64748b;font-size:1.15rem;font-weight:500}.modules-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;padding:0 20px;display:grid}.module-card{-webkit-backdrop-filter:blur(20px);cursor:pointer;background:#ffffffb3;border:1px solid #fffc;border-radius:28px;flex-direction:column;height:100%;min-height:320px;padding:32px;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden;box-shadow:0 10px 40px #0000000a,0 1px 3px #00000005}.module-card:hover{border-color:#fff;transform:translateY(-8px);box-shadow:0 20px 50px #00000014,0 2px 10px #00000008}.card-bg{opacity:.1;z-index:0;height:140px;transition:opacity .4s,height .4s;position:absolute;top:0;left:0;right:0}.comercial-bg{background:linear-gradient(135deg,#f59e0b,#ef4444)}.proyectos-bg{background:linear-gradient(135deg,#3b82f6,#6366f1)}.financiero-bg{background:linear-gradient(135deg,#10b981,#059669)}.module-card:hover .card-bg{opacity:.15;height:100%}.card-content{z-index:1;flex-direction:column;height:100%;display:flex;position:relative}.icon-wrapper{background:#fff;border-radius:20px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:24px;transition:transform .3s;display:flex;box-shadow:0 8px 20px #0000000f}.module-card:hover .icon-wrapper{transform:scale(1.05)rotate(-3deg)}.comercial-icon{color:#f59e0b}.proyectos-icon{color:#3b82f6}.financiero-icon{color:#10b981}.module-card h3{color:#1e293b;letter-spacing:-.02em;margin-bottom:12px;font-size:1.5rem;font-weight:800}.module-card p{color:#64748b;flex-grow:1;margin-bottom:32px;font-size:.95rem;line-height:1.5}.card-footer{align-items:center;margin-top:auto;display:flex}.action-text{color:#0f172a;align-items:center;gap:6px;font-size:.95rem;font-weight:700;transition:gap .3s,color .3s;display:flex}.module-card:hover .action-text{gap:10px}.module-card:hover .comercial-icon~.card-footer .action-text{color:#f59e0b}.module-card:hover .proyectos-icon~.card-footer .action-text{color:#3b82f6}.module-card:hover .financiero-icon~.card-footer .action-text{color:#10b981}.module-card.disabled{opacity:.6;filter:grayscale(.4);cursor:not-allowed}.module-card.disabled:hover{transform:none;box-shadow:0 10px 40px #0000000a}.module-card.disabled:hover .card-bg{opacity:.1;height:140px}.module-card.disabled:hover .icon-wrapper{transform:none}.badge-locked{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;background:#f1f5f9;border-radius:12px;padding:6px 12px;font-size:.8rem;font-weight:700}.home-loading{color:#64748b;background:#f8fafc;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;font-weight:600;display:flex}@media (width<=768px){.home-title{font-size:2rem}.modules-grid{grid-template-columns:1fr}}:root{--primary-color:#0070f3;--primary-hover:#005bb5;--bg-main:#f8fafc;--bg-sidebar:#fff;--bg-card:#fff;--text-main:#0f172a;--text-muted:#64748b;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:1.5rem;--status-todo-bg:#e2e8f0;--status-todo-text:#475569;--status-doing-bg:#dbeafe;--status-doing-text:#1e40af;--status-done-bg:#dcfce7;--status-done-text:#166534;--status-approved-bg:#f3e8ff;--status-approved-text:#6b21a8;--priority-low:#10b981;--priority-medium:#f59e0b;--priority-high:#ef4444;--priority-urgent:#991b1b}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.app-container{height:100vh;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);flex-direction:column;width:260px;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.sidebar.collapsed{width:70px}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-section,.sidebar.collapsed .sidebar-logo-text,.sidebar.collapsed .btn-logout span{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar-toggle{border:1px solid var(--border-color);cursor:pointer;z-index:40;width:24px;height:24px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute;top:32px;right:-12px}.sidebar-toggle:hover{border-color:var(--primary-color);color:var(--primary-color);background-color:#f8fafc}.sidebar.collapsed .sidebar-toggle{transform:rotate(180deg)}.sidebar-mini-logo{background-color:var(--primary-color);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.sidebar-header{border-bottom:1px solid var(--border-color);align-items:center;display:flex}.sidebar-nav{flex:1;padding:10px}.nav-section{color:#94a3b8;letter-spacing:.05em;margin-top:24px;margin-bottom:8px;padding:0 15px;font-size:.7rem;font-weight:700}.nav-item{border-radius:var(--radius-md);color:#475569;align-items:center;gap:12px;margin-bottom:4px;padding:10px 15px;font-weight:600;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{background-color:var(--bg-main);color:var(--text-main)}.nav-item.active{color:var(--primary-color);background-color:#f1f5f9}.nav-item.active:before{content:"";background-color:var(--primary-color);border-radius:4px;width:4px;position:absolute;top:8px;bottom:8px;left:-10px}.btn-logout{color:#ef4444;cursor:pointer;background-color:#fef2f2;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-weight:600;transition:all .2s;display:flex}.btn-logout:hover{background-color:#fee2e2}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.header{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex}.content-area{flex:1;padding:24px;overflow-y:auto}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.status-project-done{color:#1e40af;background-color:#dbeafe}.status-project-approved{color:#6b21a8;background-color:#f3e8ff}.status-project-ontime{color:#166534;background-color:#dcfce7}.status-project-delayed{color:#991b1b;background-color:#fee2e2}.status-project-pending{color:#475569;background-color:#f1f5f9}.status-chip{border-radius:12px;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.upload-zone{border:2px dashed var(--border-color);text-align:center;cursor:pointer;background-color:#f8fafc;border-radius:12px;padding:32px;transition:all .2s}.upload-zone:hover{border-color:var(--primary-color);background-color:#f0f9ff}.upload-zone-icon{color:var(--text-muted);margin-bottom:12px}.gantt-container{border:1px solid var(--border-color);background:#fff;border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.gantt-header{border-bottom:1px solid var(--border-color);background-color:#f8fafc;display:flex}.gantt-label-col{border-right:1px solid var(--border-color);width:200px;min-width:200px;color:var(--text-muted);text-transform:none;padding:12px 16px;font-size:.75rem;font-weight:700}.gantt-timeline-col{flex:1;display:flex;position:relative;overflow-x:auto}.gantt-week-header{text-align:center;border-right:1px solid var(--border-color);flex:1;min-width:60px;padding:8px}.gantt-row{border-bottom:1px solid #f1f5f9;display:flex}.gantt-row:last-child{border-bottom:none}.gantt-phase-bar{color:#fff;height:32px;box-shadow:var(--shadow-sm);z-index:1;border-radius:20px;align-items:center;padding:0 12px;font-size:.75rem;font-weight:600;display:flex;position:relative}.gantt-today-line{z-index:10;pointer-events:none;background-color:#ef4444;width:2px;position:absolute;top:0;bottom:0}.gantt-today-line:after{content:"HOY";color:#fff;background-color:#ef4444;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.btn-secondary{color:var(--text-main);border:1px solid var(--border-color);background-color:#fff}.btn-secondary:hover{background-color:var(--bg-main)}.auth-container{background-color:var(--bg-main);justify-content:center;align-items:center;height:100vh;display:flex}.auth-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;justify-content:center;width:100%;max-width:420px;min-height:440px;padding:48px 40px;display:flex}.auth-title{text-align:center;margin-bottom:24px;font-size:1.5rem;font-weight:700}.form-group{margin-bottom:16px}.form-group label{color:var(--text-main);margin-bottom:8px;font-size:.875rem;font-weight:500;display:block}.form-input{background-color:#f8fafc;border:1px solid #0000;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-size:.875rem;transition:all .2s}.form-input:focus{border-color:var(--primary-color);background-color:#fff;box-shadow:0 0 0 2px #2563eb1a}.badge{border-radius:9999px;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.board-container{gap:20px;height:100%;padding-bottom:20px;display:flex;overflow-x:auto}.board-column{background-color:var(--bg-sidebar);border-radius:var(--radius-lg);flex-direction:column;width:300px;min-width:300px;max-height:100%;display:flex}.column-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;font-size:.875rem;font-weight:600;display:flex}.task-card{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);cursor:grab;background-color:#fff;padding:16px;transition:box-shadow .2s}.task-card:hover{box-shadow:var(--shadow-md)}.task-card:active{cursor:grabbing}.task-title{margin-bottom:8px;font-size:.875rem;font-weight:500}.task-meta{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border-color);background-color:#fff;overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{background-color:var(--bg-main);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--border-color);padding:16px;font-size:.875rem}.table tr:last-child td{border-bottom:none}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title{font-size:1.5rem;font-weight:700}.modal-overlay{z-index:50;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:24px;width:100%;max-width:500px;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000026}.modal-header{border-bottom:1px solid var(--border-color);background-color:#fcfdfe;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.modal-content.wide{flex-direction:column;width:95vw;max-width:1400px;height:90vh;max-height:90vh;padding:0;display:flex;overflow:hidden}.modal-body{flex:1;padding:32px;overflow-y:auto}.form-card{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:20px;padding:24px;transition:all .2s}.form-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color)}.card-title{color:var(--text-main);text-transform:none;letter-spacing:normal;align-items:center;gap:10px;margin-bottom:24px;font-size:.8125rem;font-weight:800;display:flex}.card-title-icon{color:var(--primary-color);background:#f0f7ff;border-radius:10px;padding:8px}.board-header{border-bottom:1px solid var(--border-color);background:#fff;margin-bottom:24px;padding:24px 32px}.avatar-stack{align-items:center;display:flex}.avatar{color:#475569;width:32px;height:32px;box-shadow:var(--shadow-sm);background:#f1f5f9;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;margin-left:-10px;font-size:.75rem;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar.more{background:var(--bg-main);color:var(--text-muted);cursor:pointer}.task-card{border:1px solid var(--border-color);cursor:pointer;background:#fff;border-radius:16px;flex-direction:column;gap:12px;padding:16px;transition:all .2s;display:flex}.task-desc-preview{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8125rem;line-height:1.5;display:-webkit-box;overflow:hidden}.board-menu-top{gap:32px;margin-bottom:16px;display:flex}.board-menu-item{color:var(--text-muted);cursor:pointer;border-bottom:2px solid #0000;padding-bottom:8px;font-size:.875rem;font-weight:700}.board-container{align-items:flex-start;gap:24px;height:100%;padding:0 32px 32px;display:flex;overflow-x:auto}.board-column{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;flex-direction:column;width:320px;min-width:320px;max-height:100%;display:flex}.column-content{flex-direction:column;flex:1;gap:12px;padding:0 12px 12px;display:flex;overflow-y:auto}.btn-add-card{color:#64748b;cursor:pointer;background:0 0;border:2px dashed #cbd5e1;border-radius:12px;align-items:center;gap:8px;width:100%;margin-top:8px;padding:12px;font-size:.8125rem;font-weight:600;transition:all .2s;display:flex}.btn-add-card:hover{border-color:var(--primary-color);color:var(--primary-color);box-shadow:var(--shadow-sm);background:#fff}.task-card{border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;flex-direction:column;gap:12px;padding:16px;transition:all .2s;display:flex}.task-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}
