*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f0f2f5;--bg-card:#fff;--text:#1a1a2e;--text-muted:#6c757d;--border:#dee2e6;--border-light:#e2e6ea;--primary:#4361ee;--primary-dark:#3a56d4;--danger:#e63946;--danger-light:#fce4e6;--warning:#f4a261;--warning-light:#fff3cd;--success:#2a9d8f;--success-light:#d4edda;--gray-50:#f8f9fa;--gray-100:#f0f2f5;--gray-200:#e2e6ea;--gray-300:#dee2e6;--gray-400:#adb5bd;--gray-500:#6c757d;--gray-700:#495057;--gray-900:#1a1a2e;--nav-bg:#fff;--nav-shadow:0 1px 4px rgba(0,0,0,.06);--radius:10px;--radius-lg:16px;--shadow:0 2px 12px rgba(0,0,0,.06);--shadow-lg:0 4px 24px rgba(0,0,0,.10);--transition:.2s ease}
body.dark{--bg:#1a1a2e;--bg-card:#16213e;--text:#e0e0e0;--text-muted:#8e99a4;--border:#2a2a4a;--border-light:#2a2a4a;--gray-50:#1e1e3a;--gray-100:#1a1a2e;--gray-200:#2a2a4a;--gray-300:#3a3a5a;--gray-400:#6a6a8a;--gray-500:#8e99a4;--gray-700:#c0c0d0;--gray-900:#e0e0e0;--nav-bg:#16213e;--nav-shadow:0 1px 4px rgba(0,0,0,.3);--danger-light:#3d1f23;--warning-light:#3d3520;--success-light:#1f3d36}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}
.navbar{background:var(--nav-bg);box-shadow:var(--nav-shadow);position:sticky;top:0;z-index:100}
.nav-container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-brand{display:flex;align-items:center;gap:.5rem;font-size:1.15rem;font-weight:700;color:var(--text);text-decoration:none}
.nav-logo{height:32px;width:auto;border-radius:4px}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-link{padding:.5rem .75rem;color:var(--gray-700);font-size:.9rem;font-weight:500;border-radius:var(--radius);transition:background var(--transition);text-decoration:none;background:none;border:none;cursor:pointer;font-family:inherit}
.nav-link:hover{background:var(--gray-50);text-decoration:none}
.nav-dropdown{position:relative}.nav-dropdown-menu{display:none;position:absolute;right:0;top:100%;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;overflow:hidden;z-index:200;border:1px solid var(--border)}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{display:block;padding:.6rem 1rem;color:var(--gray-700);font-size:.9rem;text-decoration:none}.nav-dropdown-menu a:hover{background:var(--gray-50)}
.nav-hamburger{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text)}
.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem}
.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}
.card-title{font-size:1.2rem;font-weight:700}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);text-decoration:none;font-family:inherit;line-height:1.4;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);text-decoration:none}
.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--gray-700)}.btn-outline:hover{border-color:var(--gray-400);background:var(--gray-50)}
.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}
.btn-icon{padding:.35rem;background:none;border:none;cursor:pointer;font-size:1rem;color:var(--gray-500);border-radius:var(--radius);transition:all var(--transition)}.btn-icon:hover{background:var(--gray-200);color:var(--text)}
.form-group{margin-bottom:1rem}.form-group label{display:block;font-weight:600;font-size:.85rem;margin-bottom:.3rem;color:var(--gray-700)}
.form-control{width:100%;padding:.55rem .75rem;font-size:.95rem;border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;background:var(--bg-card);color:var(--text)}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(67,97,238,.1)}
textarea.form-control{min-height:70px;resize:vertical}select.form-control{cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.9rem}
.alert-success{background:var(--success-light);color:#155724}.alert-danger{background:var(--danger-light);color:#c0392b}.alert-warning{background:var(--warning-light);color:#856404}.alert-info{background:#d1ecf1;color:#0c5460}
body.dark .alert-success{color:#8fd4a4}body.dark .alert-danger{color:#f1a0a8}
.checklist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}
.checklist-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem;transition:transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column}
.checklist-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.checklist-card h3{font-size:1.1rem;margin-bottom:.3rem}.checklist-card p{color:var(--text-muted);font-size:.85rem;margin-bottom:1rem;flex:1}
.checklist-card .card-actions{display:flex;gap:.5rem;margin-top:auto}
.checklist-card-logo{height:28px;width:auto;max-width:120px;border-radius:4px;margin-bottom:.5rem;display:block;object-fit:contain}
.checklist-stats{display:flex;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;flex-wrap:wrap}
.stat-badge{padding:.15rem .5rem;border-radius:20px;font-weight:600}
.stat-green{background:var(--success-light);color:#155724}.stat-yellow{background:var(--warning-light);color:#856404}.stat-red{background:var(--danger-light);color:#c0392b}.stat-gray{background:var(--gray-200);color:var(--gray-700)}
body.dark .stat-green{color:#8fd4a4}body.dark .stat-red{color:#f1a0a8}body.dark .stat-yellow{color:#d4b96a}
.checklist-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}
.checklist-header h1{font-size:1.5rem;display:inline}
.checklist-logo{height:50px;border-radius:6px;margin-bottom:.5rem}
.budget-bar{display:flex;gap:0;padding:0!important;overflow:hidden;border-radius:var(--radius-lg)!important;margin-bottom:1rem}
.budget-item{flex:1;padding:.8rem 1.2rem;text-align:center;min-width:100px}
.budget-item .budget-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.8}
.budget-item .budget-value{font-size:1.15rem;font-weight:800;margin-top:.1rem}
.budget-budget{background:#d4edda;color:#155724}.budget-cost{background:#fff3cd;color:#856404}
.budget-saldo-plus{background:#d1ecf1;color:#0a58ca}.budget-saldo-minus{background:#f8d7da;color:#842029}
.budget-notes{background:var(--bg-card);padding:.8rem 1.2rem;font-size:.85rem;color:var(--text-muted);flex:2;display:flex;align-items:center}
body.dark .budget-budget{background:#1f3d36;color:#8fd4a4}body.dark .budget-cost{background:#3d3520;color:#d4b96a}body.dark .budget-saldo-plus{background:#1a3040;color:#7ec8d8}body.dark .budget-saldo-minus{background:#3d1f23;color:#f1a0a8}
.category{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1rem;overflow:hidden;border-left:4px solid var(--gray-300);transition:border-color .3s}
.category.dragging{opacity:.4}.category.all-green{border-left-color:var(--success);background:linear-gradient(135deg,rgba(42,157,143,.05) 0%,var(--bg-card) 50%)}
.category-header{display:flex;align-items:center;padding:.7rem 1rem;cursor:pointer;user-select:none;transition:background var(--transition);gap:.5rem}
.category-header:hover{background:var(--gray-50)}.category.all-green .category-header{background:rgba(42,157,143,.06)}
.category-title{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;font-size:1rem;font-weight:700}.category.all-green .category-title{color:var(--success)}
.category-badge{font-size:.72rem;font-weight:600;padding:.1rem .4rem;border-radius:20px;background:var(--gray-200);color:var(--gray-500)}.category.all-green .category-badge{background:var(--success);color:#fff}
.category-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0;margin-left:auto}
.category-cost{font-size:1rem;font-weight:700;color:var(--primary);white-space:nowrap}
.category-actions{display:flex;gap:.2rem}
.category-short-desc{padding:0 1rem .4rem 2.8rem;font-size:.85rem;color:var(--text-muted)}
.cat-notes-panel{padding:0 1rem .4rem 2.8rem}.cat-notes-panel .notes-box{background:var(--gray-50);border-radius:var(--radius);padding:.5rem;font-size:.85rem;white-space:pre-wrap}
.cat-drag{cursor:grab;color:var(--gray-400);font-size:.85rem;flex-shrink:0}.cat-drag:active{cursor:grabbing}
.category-body{padding:0 1rem .5rem}.category-body.collapsed{display:none}
.collapse-icon{transition:transform .2s;font-size:.7rem}.collapsed-cat .collapse-icon{transform:rotate(-90deg)}
.item{display:flex;align-items:flex-start;gap:.4rem;padding:.4rem 0;border-bottom:1px solid var(--border-light);transition:background var(--transition);border-radius:4px}
.item:last-child{border-bottom:none}.item.expanded{border-bottom:none}.item.dragging{opacity:.4}.item:hover{background:var(--gray-50)}
.item-drag{cursor:grab;color:var(--gray-400);font-size:.8rem;padding:.15rem;flex-shrink:0;touch-action:none;margin-top:3px}.item-drag:active{cursor:grabbing}
.item-content{flex:1;min-width:0}.item-toggle{cursor:pointer}
.item-title-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.item-title{font-size:.9rem;font-weight:500}
.item-short-desc{font-size:.78rem;color:var(--text-muted);margin-top:.05rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.item-right{display:flex;align-items:flex-start;gap:.25rem;flex-shrink:0;margin-top:1px}
.item-cost{font-size:.82rem;font-weight:600;color:var(--primary);white-space:nowrap;padding:.1rem .3rem}
.item-cost-income{color:var(--success)}
.item-actions{display:flex;align-items:flex-start;gap:.1rem}
.item-detail{display:none;padding:.15rem 0 .3rem 1.8rem;font-size:.85rem}.item-detail.open{display:block}
.item-detail .notes-box{background:var(--gray-50);border-radius:var(--radius);padding:.4rem .6rem;margin-bottom:.2rem;white-space:pre-wrap;line-height:1.5}
.attachments-list{margin-bottom:.2rem}
.attachment-indicator{display:inline-flex;align-items:center;gap:.15rem;font-size:.76rem;color:var(--primary);cursor:pointer;padding:.05rem .3rem;border-radius:var(--radius);transition:background var(--transition)}.attachment-indicator:hover{background:rgba(67,97,238,.08)}
.attachment-item{display:flex;align-items:center;justify-content:space-between;padding:.1rem 0;font-size:.85rem}.attachment-item a{word-break:break-all;color:var(--primary)}
.item-detail-actions{display:flex;gap:.75rem;align-items:center;margin-top:.4rem;flex-wrap:wrap;padding:.4rem 0;border-top:1px dashed var(--border-light)}
/* Item toolbar */
.item-toolbar{display:flex;align-items:center;gap:.3rem;margin-top:.5rem;padding:.5rem .6rem;background:var(--gray-50);border-radius:var(--radius);flex-wrap:wrap}
.toolbar-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .7rem;font-size:.82rem;font-weight:500;border:1.5px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--gray-700);cursor:pointer;transition:all var(--transition);font-family:inherit;text-decoration:none}
.toolbar-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(67,97,238,.04);text-decoration:none}
.toolbar-danger{color:var(--danger);border-color:var(--danger-light)}.toolbar-danger:hover{border-color:var(--danger);background:var(--danger-light)}
.toolbar-upload{cursor:pointer}.toolbar-upload input{position:absolute;opacity:0;pointer-events:none}
.tb-icon{font-size:1rem}
.toolbar-drop{display:inline-flex;align-items:center;padding:.35rem .7rem;font-size:.78rem;color:var(--text-muted);border:1.5px dashed var(--border);border-radius:8px;transition:all var(--transition);min-width:0}
.toolbar-drop.drop-active,.toolbar-drop:hover{border-color:var(--primary);color:var(--primary);background:rgba(67,97,238,.04)}
.item-indicator{font-size:.72rem;color:var(--gray-400);margin-left:.15rem}
body.dark .item-toolbar{background:var(--gray-200)}body.dark .toolbar-btn{background:var(--bg-card);border-color:var(--border)}
.inline-cost-edit{display:flex;align-items:center;gap:.3rem}
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:.6rem;text-align:center;font-size:.82rem;color:var(--text-muted);transition:all var(--transition);cursor:pointer;margin-top:.3rem}
.drop-zone:hover,.drop-zone-hover{border-color:var(--primary);background:rgba(67,97,238,.04);color:var(--primary)}
.drop-zone-label{color:var(--primary);cursor:pointer;text-decoration:underline}
.status-btn{width:32px;height:32px;border-radius:8px;border:2px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;flex-shrink:0;transition:all var(--transition);font-weight:700;margin-top:1px}
.status-btn:hover{transform:scale(1.1)}
.status-btn[data-status="none"]{border-color:var(--gray-300);color:transparent}
.status-btn[data-status="red"]{border-color:var(--danger);background:var(--danger-light);color:var(--danger)}
.status-btn[data-status="yellow"]{border-color:var(--warning);background:var(--warning-light);color:#b8860b}
.status-btn[data-status="green"]{border-color:var(--success);background:var(--success-light);color:var(--success)}
.status-picker{display:flex;gap:.5rem;padding:.25rem 0}
.status-option{width:40px;height:40px;border-radius:10px;border:2.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;font-weight:700;transition:all var(--transition)}
.status-option:hover{transform:scale(1.08)}.status-option.selected{box-shadow:0 0 0 3px rgba(67,97,238,.25)}
.status-option[data-status="none"]{background:var(--bg-card)}.status-option[data-status="red"]{border-color:var(--danger);background:var(--danger-light);color:var(--danger)}.status-option[data-status="yellow"]{border-color:var(--warning);background:var(--warning-light);color:#b8860b}.status-option[data-status="green"]{border-color:var(--success);background:var(--success-light);color:var(--success)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;opacity:0;visibility:hidden;transition:all .25s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.5rem;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;transform:translateY(20px);transition:transform .25s}
.modal-overlay.active .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.modal-header h2{font-size:1.1rem}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--gray-500)}.modal-close:hover{color:var(--text)}
.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}
.table-wrapper{overflow-x:auto}table.table{width:100%;border-collapse:collapse}
table.table th,table.table td{padding:.55rem .75rem;text-align:left;border-bottom:1px solid var(--border-light);font-size:.9rem}
table.table th{font-weight:600;color:var(--gray-700);background:var(--gray-50)}table.table tr:hover td{background:var(--gray-50)}
table.table tfoot td{border-top:2px solid var(--border);border-bottom:none}
.auth-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 80px);padding:2rem}
.auth-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem;max-width:440px;width:100%}
.auth-card h1{font-size:1.4rem;margin-bottom:.3rem}.auth-card .subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state .icon{font-size:3rem;margin-bottom:.75rem}.empty-state h3{color:var(--gray-700);margin-bottom:.3rem}
.profile-logo-preview{width:80px;height:80px;border-radius:var(--radius);object-fit:cover;border:2px solid var(--border)}
.tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--border);margin-bottom:1.5rem}
.tab{padding:.6rem 1rem;font-weight:600;font-size:.9rem;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab:hover{color:var(--text)}
.footer{background:var(--nav-bg);border-top:1px solid var(--border);margin-top:auto}
.footer-container{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--text-muted)}
.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--text-muted)}.footer-links a:hover{color:var(--text)}
.text-danger{color:var(--danger)!important}.text-success{color:var(--success)!important}.text-muted{color:var(--text-muted)!important}
.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.5rem!important}.mb-2{margin-bottom:1rem!important}.mt-1{margin-top:.5rem!important}.mt-2{margin-top:1rem!important}
.d-flex{display:flex}.gap-1{gap:.5rem}
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000}
.confirm-box{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;max-width:400px;width:90%;box-shadow:var(--shadow-lg)}
.confirm-box h3{margin-bottom:.5rem}.confirm-box p{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.confirm-actions{display:flex;justify-content:flex-end;gap:.5rem}
.drag-over{border-top:3px solid var(--primary);padding-top:3px}.category.drag-over-cat{outline:2px dashed var(--primary);outline-offset:-2px}
@media(max-width:768px){.nav-links{display:none;position:absolute;top:60px;left:0;right:0;background:var(--nav-bg);flex-direction:column;padding:1rem;box-shadow:var(--shadow-lg)}.nav-links.open{display:flex}.nav-hamburger{display:block}.form-row{grid-template-columns:1fr}.checklist-grid{grid-template-columns:1fr}.checklist-header{flex-direction:column;align-items:flex-start}.footer-container{flex-direction:column;gap:.5rem;text-align:center}.budget-bar{flex-wrap:wrap}}
@media print{.no-print,.navbar,.footer,.btn,.btn-icon,.item-actions,.category-actions,.item-drag,.cat-drag,.status-picker,.modal-overlay,.confirm-overlay,.nav-hamburger,.item-detail-actions,.item-toolbar,.toolbar-btn,.toolbar-drop,.drop-zone{display:none!important}body,body.dark{background:#fff!important;color:#000!important;font-size:11pt}.main-content{padding:0;max-width:100%}.card,.category,.checklist-card{box-shadow:none;border:1px solid #ccc;break-inside:avoid;background:#fff!important}.category{border-left:3px solid #999;margin-bottom:.5rem}.category.all-green{border-left-color:#2a9d8f;background:#f0faf8!important}.category-body.collapsed{display:block!important}.item{padding:.2rem 0}.item-detail{display:block!important;padding-left:1.2rem}.status-btn{width:20px;height:20px;font-size:.7rem;border-width:1.5px;print-color-adjust:exact;-webkit-print-color-adjust:exact}.status-btn[data-status="red"]{background:#fce4e6!important;color:#e63946!important;border-color:#e63946!important}.status-btn[data-status="yellow"]{background:#fff3cd!important;color:#b8860b!important;border-color:#f4a261!important}.status-btn[data-status="green"]{background:#d4edda!important;color:#2a9d8f!important;border-color:#2a9d8f!important}.category-cost,.item-cost{color:#000!important;font-weight:700}.checklist-logo{height:40px}.print-header{display:block!important}.budget-bar{border:1px solid #ccc}.budget-item{border-right:1px solid #ccc;print-color-adjust:exact;-webkit-print-color-adjust:exact}a{color:#000!important;text-decoration:none!important}}
.print-header{display:none}
