: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;height:100vh;display:flex;flex-direction:column;background:#efefef;color:#333;overflow:hidden}.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-right{display:flex;align-items:center;gap:8px}.header-left h1{font-size:18px;font-weight:600;color:#294741}.user-badge{font-size:13px;font-weight:700;color:#294741;background:#efefef;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;display:flex;align-items:center;gap:6px}.tab-btn:hover{color:#294741;background:#f8f9fa}.tab-btn.active{color:#294741;border-bottom-color:#294741}.app-content{padding:24px;max-width:1400px;margin:0 auto;flex:1;overflow:hidden;width:100%;display:flex;flex-direction:column}.dashboard,.proyectos,.section,.flyer,.log-correos,.cuentas-compartidas{display:flex;flex-direction:column;flex:1;min-height:0}.section-scrollable{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.section-scrollable .table-container{flex:none;min-height:400px}.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:#294741;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.suplantacion-bar{margin-bottom:16px;padding:10px 16px;background:#f0f4ff;border:1px solid #c5d4f0;border-radius:8px;flex-shrink:0}.suplantacion-activa{display:flex;align-items:center;gap:12px;background:#fff3e0;border:1px solid #ffb74d;border-radius:6px;padding:8px 14px}.suplantacion-activa .suplantacion-label{flex:1;font-size:13px;color:#e65100}.suplantacion-btn-salir{padding:5px 14px;font-size:12px;font-weight:600;background:#e65100;color:#fff;border:none;border-radius:4px;cursor:pointer}.suplantacion-btn-salir:hover{background:#bf360c}.suplantacion-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.suplantacion-form .suplantacion-label{font-size:13px;font-weight:500;color:#555}.suplantacion-input{padding:6px 10px;font-size:13px;border:1px solid #ccc;border-radius:4px;width:260px}.suplantacion-input:focus{outline:none;border-color:#5b7adb;box-shadow:0 0 0 2px #5b7adb26}.suplantacion-btn{padding:6px 16px;font-size:12px;font-weight:600;background:#5b7adb;color:#fff;border:none;border-radius:4px;cursor:pointer}.suplantacion-btn:hover{background:#4a67c4}.suplantacion-btn:disabled{opacity:.5;cursor:default}.suplantacion-msg{font-size:12px;color:#d32f2f;font-weight:500}.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:#294741;color:#294741}.toggle-btn.active{background:#294741;color:#fff;border-color:#294741}.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:#294741;flex-shrink:0}.summary-count{font-size:36px;font-weight:700;color:#294741;line-height:1}.summary-label{font-size:14px;color:#555;line-height:1.3}.filters{display:flex;gap:6px;margin-bottom:20px;flex-shrink:0}.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:#294741;color:#294741}.filter-btn.active{background:#e0ebe8;color:#294741;border-color:#294741}.chart-container{background:#fff;border-radius:10px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000000f;flex-shrink:0}.chart-container h3{font-size:15px;font-weight:600;color:#444;margin-bottom:16px}.table-container{background:#fff;border-radius:10px;overflow:auto;box-shadow:0 1px 3px #0000000f;flex:1;min-height:0}table{width:100%;border-collapse:collapse;font-size:11px}thead{background:#fafafa;position:sticky;top:0;z-index:10}th{text-align:left;padding:10px;font-weight:600;color:#555;border-bottom:1px solid #eee;white-space:nowrap;background:#fafafa;font-size:12px}.filter-row th{padding:4px 6px;background:#f5f5f5;border-bottom:2px solid #e0e0e0}.filter-row input{width:100%;padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:12px;color:#444;background:#fff;outline:none;box-sizing:border-box}.filter-row input:focus{border-color:#294741;box-shadow:0 0 0 2px #0696d726}.filter-row input::placeholder{color:#bbb;font-style:italic}td{padding:8px 10px;border-bottom:1px solid #f0f0f0;color:#444;vertical-align:top}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:#294741;white-space:nowrap}.nowrap{white-space:nowrap}.descripcion-cell{min-width:300px;max-width:500px;vertical-align:top}.descripcion-content{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;font-size:10px;line-height:1.4;white-space:normal;word-break:break-word;min-height:calc(10px * 1.4 * 3)}.destinatarios-cell{max-width:150px;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-cancelado{background:#f8c4c0;color:#8b1a10}.badge-inactivo{background:#dcdcdc;color:#666}.estado-select{padding:3px 8px;font-size:12px;font-weight:600;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;outline:none}.estado-select:focus{border-color:#294741}.vencida{color:#ec4a41;font-weight:600}tr.informe-revisado td{opacity:.5}tr.informe-revisado:hover td{opacity:.75}.link-btn{color:#294741;text-decoration:none;font-weight:500;font-size:13px}.link-btn:hover{text-decoration:underline}.titulo-link{color:#294741;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:4px}.titulo-link:hover{text-decoration:underline}.titulo-link svg{width:14px;height:14px;flex-shrink:0}.gear-btn{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;color:#666;border-radius:4px}.gear-btn:hover{background:#e0e0e0;color:#294741}.text-muted{color:#999}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-shrink:0}.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:#294741}.btn-primary{padding:8px 18px;font-size:14px;font-weight:500;background:#294741;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#1d332e}.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;flex-shrink:0}.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:#294741}.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}.observadores-badges{display:flex;flex-wrap:wrap;gap:4px}.observador-badge{display:inline-block;background:#e8f0fe;color:#1a73e8;padding:2px 8px;border-radius:12px;font-size:11px;white-space:nowrap;cursor:default}.usuarios-list{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.usuario-tag{display:inline-flex;align-items:center;gap:4px;background:#e8f0fe;color:#1a73e8;padding:3px 8px;border-radius:12px;font-size:12px}.btn-tag-remove{background:none;border:none;color:#999;cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.btn-tag-remove:hover{color:#e53e3e}.inline-form{display:flex;gap:6px;align-items:center;margin-top:6px;flex-wrap:wrap}.inline-form input{padding:4px 8px;border:1px solid #ccc;border-radius:4px;font-size:12px;width:140px}.btn-small{padding:4px 10px;font-size:12px;border-radius:4px;border:none;cursor:pointer}.btn-small.btn-primary{background:#294741;color:#fff}.btn-small.btn-primary:hover{background:#1d332e}.btn-small.btn-secondary{background:#e0e0e0;color:#333}.btn-small.btn-secondary:hover{background:#d0d0d0}.log-correos{padding:0}.log-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.log-header h2{font-size:18px;font-weight:600}.log-count{font-size:13px;color:#888;background:#f0f0f0;padding:2px 10px;border-radius:12px}.log-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase;white-space:nowrap}.log-subject{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.log-error{color:#d32f2f;font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-row-error{background:#fff5f5}.tab-count{display:none;background:#ec4a41;color:#fff;border-radius:10px;font-size:10px;font-weight:700;padding:1px 5px;line-height:1.4;min-width:16px;text-align:center}@media(max-width:768px){.app{height:auto;min-height:100dvh;overflow:visible}.app-content{padding:12px;overflow:visible;flex:none}.dashboard,.proyectos,.section,.flyer,.log-correos,.cuentas-compartidas{flex:none;min-height:auto}.section-scrollable{overflow:visible;flex:none}.table-container{flex:none;overflow-x:auto;overflow-y:auto;max-height:65vh;border-radius:8px}.section-scrollable .table-container{min-height:auto}.app-header{height:auto;min-height:44px;padding:0 8px 0 4px;flex-wrap:wrap;align-items:center}.tab-nav{order:2;width:100%;overflow-x:auto;padding:2px 0 0;gap:0;scrollbar-width:none}.tab-nav::-webkit-scrollbar{display:none}.tab-label{display:none}.tab-count{display:inline-block}.tab-btn{padding:10px 14px;gap:4px;flex-shrink:0}.tab-btn svg{width:20px;height:20px}.header-right{order:1;gap:4px}.user-badge{font-size:11px;padding:3px 8px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filters{flex-wrap:wrap;gap:4px;margin-bottom:12px}.filter-btn{padding:5px 10px;font-size:12px}table{font-size:13px}th{font-size:12px;padding:8px}td{padding:7px 8px;font-size:12px}.descripcion-cell{min-width:0;max-width:180px}.destinatarios-cell{max-width:100px}.chart-container{padding:12px;margin-bottom:12px}.form-grid{grid-template-columns:1fr}.section-header{flex-wrap:wrap;gap:8px;margin-bottom:12px}.header-actions{width:100%;flex-wrap:wrap}.search-input{min-width:0;flex:1}.suplantacion-input{width:100%;min-width:0;flex:1}.suplantacion-activa{flex-wrap:wrap}.summary-count{font-size:28px}.summary-card-body{padding:16px}.log-header{flex-wrap:wrap}.log-subject{max-width:160px}.log-error{max-width:120px}}@media(max-width:480px){.app-content{padding:8px}.tab-btn{padding:10px 12px}.user-badge{display:none}th{padding:7px 6px;font-size:11px}td{padding:6px;font-size:12px}.filter-btn{padding:4px 8px;font-size:11px}.chart-container{padding:8px}}
