*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:#faf8f5;color:#1c2b3a;line-height:1.5;min-width:320px;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #d5d0c8;border-top-color:#c0392b;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{background:#1c2b3a;color:#fff;padding:2rem 1.5rem 1.5rem}.header-inner{max-width:1100px;margin:0 auto}.header-subtitle{font-size:.75rem;letter-spacing:3px;text-transform:uppercase;opacity:.7;margin-bottom:.25rem;color:#e74c3c}.header-title{font-size:1.75rem;font-weight:800;margin-bottom:.125rem;line-height:1.2}.header-tagline{font-size:.95rem;opacity:.6;margin-bottom:1.25rem}.stats-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.stat-badge{display:flex;flex-direction:column;align-items:center;background:#ffffff14;border-radius:8px;padding:.5rem 1rem;min-width:80px}.stat-number{font-size:1.5rem;font-weight:700}.stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.stat-completed{background:#2ecc7133}.stat-pioneer{background:#c0392b33}.stat-sarita{background:#3498db33}.stat-unassigned{background:#ffffff0f}.progress-bar-container{margin-top:.25rem}.progress-bar{height:8px;background:#ffffff1f;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#27ae60,#2ecc71);border-radius:4px;transition:width .4s ease}.progress-text{font-size:.8rem;opacity:.6;margin-top:.35rem}.legend{max-width:1100px;margin:1rem auto;padding:.75rem 1.5rem;display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.85rem;color:#555}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-dot{width:12px;height:12px;border-radius:3px}.legend-dot-pioneer{background:#c0392b}.legend-dot-sarita{background:#2980b9}.legend-check:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:#27ae60;color:#fff;border-radius:3px;font-size:.7rem;font-weight:700}.filters{max-width:1100px;margin:0 auto 1rem;padding:0 1.5rem}.filter-group{margin-bottom:.75rem}.filter-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:.35rem;display:block}.filter-pills{display:flex;gap:.35rem;flex-wrap:wrap}.pill{padding:.35rem .75rem;border:1px solid #d5d0c8;border-radius:20px;background:#fff;color:#555;font-size:.8rem;cursor:pointer;transition:all .15s;font-family:inherit}.pill:hover{border-color:#c0392b;color:#c0392b}.pill-active{background:#1c2b3a;color:#fff;border-color:#1c2b3a}.phases{max-width:1100px;margin:0 auto;padding:0 1.5rem 2rem}.phase-section{background:#fff;border-radius:12px;margin-bottom:1rem;box-shadow:0 1px 3px #1c2b3a14;overflow:hidden}.phase-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;background:#f0ede8;cursor:pointer;-webkit-user-select:none;user-select:none;gap:1rem}.phase-header:hover{background:#e8e4de}.phase-header-left{display:flex;align-items:center;gap:.6rem;min-width:0}.phase-chevron{font-size:.65rem;color:#999;transition:transform .2s;flex-shrink:0}.phase-chevron-open{transform:rotate(90deg)}.phase-title{font-size:.95rem;font-weight:700;color:#1c2b3a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.phase-header-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.phase-progress-bar{width:100px;height:6px;background:#d5d0c8;border-radius:3px;overflow:hidden}.phase-progress-fill{height:100%;background:#27ae60;border-radius:3px;transition:width .3s ease}.phase-progress-text{font-size:.8rem;color:#888;font-weight:600;min-width:30px;text-align:right}.phase-body{padding:0}.table-header{display:flex;align-items:center;padding:.5rem 1.25rem;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#aaa;border-bottom:1px solid #f0ede8}.col-action{flex:1;min-width:0}.col-check{width:90px;text-align:center;flex-shrink:0}.col-actions-header{width:80px;text-align:center;flex-shrink:0}.col-actions-btns{width:80px;display:flex;justify-content:center;gap:.35rem;flex-shrink:0}.action-row{display:flex;align-items:center;padding:.65rem 1.25rem;border-bottom:1px solid #f5f2ed;transition:background .1s}.action-row:hover{background:#faf8f5}.action-row:last-of-type{border-bottom:none}.action-done{opacity:.55}.action-done .action-text{text-decoration:line-through}.action-text{font-size:.9rem;color:#1c2b3a;margin-right:.5rem}.category-tag{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.65rem;font-weight:600;color:#fff;white-space:nowrap;vertical-align:middle}.checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1c2b3a}.checkbox-pioneer{accent-color:#c0392b}.checkbox-sarita{accent-color:#2980b9}.checkbox-done{accent-color:#27ae60}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #d5d0c8;border-radius:6px;background:#fff;cursor:pointer;transition:all .15s;color:#999;font-family:inherit}.icon-btn:hover{border-color:#bbb}.icon-btn-edit:hover{color:#1c2b3a;background:#f0ede8;border-color:#1c2b3a}.icon-btn-delete:hover{color:#c0392b;background:#fef2f2;border-color:#c0392b}.edit-form,.add-form{flex:1;padding:.5rem 0}.edit-textarea{width:100%;padding:.5rem .75rem;border:1px solid #d5d0c8;border-radius:6px;font-family:inherit;font-size:.9rem;resize:vertical;min-height:60px;margin-bottom:.5rem}.edit-textarea:focus{outline:none;border-color:#c0392b;box-shadow:0 0 0 2px #c0392b1f}.edit-selects{display:flex;gap:.5rem;margin-bottom:.5rem}.edit-selects select{padding:.4rem .6rem;border:1px solid #d5d0c8;border-radius:6px;font-family:inherit;font-size:.85rem;background:#fff}.edit-buttons{display:flex;gap:.5rem}.btn{padding:.4rem 1rem;border:none;border-radius:6px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.85}.btn-save{background:#c0392b;color:#fff}.btn-cancel{background:#e5e5e5;color:#555}.add-action-btn{display:block;width:100%;padding:.65rem;border:none;border-top:1px solid #f0ede8;border-radius:0;background:#f8f6f2;color:#1c2b3a;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.add-action-btn:hover{background:#eeebe5;color:#0f1a25}.add-form{padding:.75rem 1.25rem;border-top:1px solid #f0ede8}.footer{max-width:1100px;margin:0 auto 2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #1c2b3a14}.footer-title{font-size:.95rem;font-weight:700;color:#1c2b3a;margin-bottom:.75rem}.footer-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.footer-stat{display:flex;flex-direction:column;align-items:center;min-width:80px}.footer-stat-number{font-size:1.75rem;font-weight:700;color:#1c2b3a}.footer-stat-label{font-size:.75rem;color:#888}@media(max-width:768px){.header-title{font-size:1.25rem}.stats-row{gap:.35rem}.stat-badge{padding:.35rem .6rem;min-width:60px}.stat-number{font-size:1.1rem}.col-check{width:55px;font-size:.55rem}.table-header .col-check{font-size:.5rem;letter-spacing:0}.col-actions-header,.col-actions-btns{width:70px}.icon-btn{width:28px;height:28px}.icon-btn svg{width:13px;height:13px}.phase-progress-bar{width:60px}.phase-title{font-size:.85rem}.legend{font-size:.75rem;gap:.75rem}.phases{padding:0 .75rem 2rem}.footer{margin-left:.75rem;margin-right:.75rem}.filters{padding:0 .75rem}}
