:root{font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}.app{font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100vh;background:#f5f5f5;color:#333}.app-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;box-shadow:0 1px 3px #00000014}.header-left{display:flex;align-items:center;gap:16px}.header-left h1{font-size:18px;font-weight:600;color:#0696d7}.user-badge{font-size:13px;color:#666;background:#f0f0f0;padding:4px 10px;border-radius:12px}.tab-nav{display:flex;gap:4px}.tab-btn{background:none;border:none;padding:16px 20px;font-size:14px;font-weight:500;color:#666;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{color:#0696d7;background:#f8f9fa}.tab-btn.active{color:#0696d7;border-bottom-color:#0696d7}.app-content{padding:24px;max-width:1400px;margin:0 auto}.loading-screen,.error-screen,.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:12px;color:#666}.error-screen h2{color:#ec4a41}.spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#0696d7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.section-toggle{display:flex;gap:8px;margin-bottom:20px}.toggle-btn{padding:10px 20px;font-size:14px;font-weight:500;border:1px solid #ddd;background:#fff;color:#666;border-radius:8px;cursor:pointer;transition:all .2s}.toggle-btn:hover{border-color:#0696d7;color:#0696d7}.toggle-btn.active{background:#0696d7;color:#fff;border-color:#0696d7}.summary-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e0e0e0;overflow:hidden;margin-bottom:20px}.summary-card-body{display:flex;align-items:center;justify-content:center;gap:12px;padding:28px 20px}.summary-body-icon{width:32px;height:32px;color:#0696d7;flex-shrink:0}.summary-count{font-size:36px;font-weight:700;color:#0696d7;line-height:1}.summary-label{font-size:14px;color:#555;line-height:1.3}.filters{display:flex;gap:6px;margin-bottom:20px}.filter-btn{padding:6px 14px;font-size:13px;border:1px solid #ddd;background:#fff;color:#555;border-radius:16px;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:#0696d7;color:#0696d7}.filter-btn.active{background:#e8f4fd;color:#0696d7;border-color:#0696d7}.chart-container{background:#fff;border-radius:10px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000000f}.chart-container h3{font-size:15px;font-weight:600;color:#444;margin-bottom:16px}.table-container{background:#fff;border-radius:10px;overflow-x:auto;box-shadow:0 1px 3px #0000000f}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:#fafafa}th{text-align:left;padding:12px 14px;font-weight:600;color:#555;border-bottom:1px solid #eee;white-space:nowrap}td{padding:10px 14px;border-bottom:1px solid #f0f0f0;color:#444}tr:hover td{background:#f9fbfd}td.center{text-align:center}td.empty{text-align:center;padding:40px;color:#999}.proyecto-cell{font-weight:600;color:#0696d7;white-space:nowrap}.nowrap{white-space:nowrap}.descripcion-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.badge-activo{background:#b7d78c;color:#333}.badge-inactivo{background:#dcdcdc;color:#666}.vencida{color:#ec4a41;font-weight:600}.link-btn{color:#0696d7;text-decoration:none;font-weight:500;font-size:13px}.link-btn:hover{text-decoration:underline}.text-muted{color:#999}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-header h2{font-size:18px;font-weight:600;color:#333}.header-actions{display:flex;align-items:center;gap:12px}.search-input{padding:8px 14px;font-size:14px;border:1px solid #ddd;border-radius:8px;outline:none;min-width:220px;transition:border-color .2s}.search-input:focus{border-color:#0696d7}.btn-primary{padding:8px 18px;font-size:14px;font-weight:500;background:#0696d7;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#0580b8}.btn-secondary{padding:8px 18px;font-size:14px;background:#fff;color:#666;border:1px solid #ddd;border-radius:8px;cursor:pointer}.btn-secondary:hover{background:#f5f5f5}.btn-icon{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;color:#666}.btn-icon:hover{background:#f0f0f0}.btn-icon.btn-danger:hover{background:#fde8e8;color:#ec4a41}.actions{white-space:nowrap}.form-card{background:#fff;border-radius:10px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000000f}.form-card h3{font-size:16px;margin-bottom:16px;color:#333}.form-error{background:#fde8e8;color:#ec4a41;padding:8px 14px;border-radius:6px;font-size:13px;margin-bottom:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.form-field.full{grid-column:1 / -1}.form-field label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:4px}.form-field input{width:100%;padding:8px 12px;font-size:14px;border:1px solid #ddd;border-radius:6px;outline:none;transition:border-color .2s}.form-field input:focus{border-color:#0696d7}.form-actions{display:flex;gap:8px}.flyer-header{margin-bottom:16px}.flyer-header h2{font-size:18px;font-weight:600;color:#333}.flyer-content{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #0000000f}
