@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root,[data-theme=light]{--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-input: #F1F5F9;--bg-hover: #E2E8F0;--bg-base: #FFFFFF;--border: #E2E8F0;--border-light: #CBD5E1;--divider: #F1F5F9;--text-primary: #111827;--text-secondary:#374151;--text-muted: #6B7280;--accent: #2563EB;--accent-soft: rgba(37,99,235,.08);--accent-hover: #1D4ED8;--green: #10B981;--green-soft: rgba(16,185,129,.1);--red: #EF4444;--red-soft: rgba(239,68,68,.1);--yellow: #F59E0B;--yellow-soft: rgba(245,158,11,.1);--orange: #F97316;--purple: #7C3AED;--cyan: #0891B2;--blue-light: #60A5FA;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Mono", monospace;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--nav-height: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--header-height: 56px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05)}[data-theme=dark]{--bg-primary: #0f1117;--bg-secondary: #141820;--bg-card: #191e2a;--bg-input: #1e2534;--bg-hover: #232b3a;--bg-base: #141820;--border: #262e40;--border-light: #2e3850;--divider: #1f2736;--text-primary: #F1F5F9;--text-secondary:#94A3B8;--text-muted: #64748B;--accent: #3B82F6;--accent-soft: rgba(59,130,246,.15);--accent-hover: #2563EB;--green: #22c55e;--green-soft: rgba(34,197,94,.12);--red: #ef4444;--red-soft: rgba(239,68,68,.12);--yellow: #f59e0b;--yellow-soft: rgba(245,158,11,.12);--orange: #f97316;--purple: #a78bfa;--cyan: #06b6d4;--blue-light: #60A5FA;--shadow: 0 2px 12px rgba(0,0,0,.3);--shadow-md: 0 4px 20px rgba(0,0,0,.35);--shadow-lg: 0 8px 32px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}html{font-size:16px;-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;overscroll-behavior:none;height:100%}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;overflow-y:auto;height:100%;height:-webkit-fill-available;min-height:100dvh;position:relative;width:100%;max-width:100%;top:0;left:0}input,textarea,select,button{font-family:inherit}a{color:inherit;text-decoration:none}#root{height:100%;height:-webkit-fill-available;min-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-layout{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.app-pages{flex:1;overflow-y:scroll;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 20px);scroll-behavior:smooth;width:100%;max-width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100;box-shadow:0 -1px 3px #0000000f,0 -4px 16px #0000000f;overflow:hidden;width:100%;max-width:100%}.nav-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;padding:6px 2px;color:var(--text-muted);transition:color .15s;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.nav-item.active{color:var(--accent)}.nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--accent);border-radius:0 0 4px 4px}.nav-icon{font-size:20px;line-height:1}.nav-label{font-size:9px;font-weight:600;letter-spacing:.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;text-align:center;padding:0 2px}.page-header{position:sticky;top:0;z-index:50;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:10px 16px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;min-height:var(--header-height);width:100%;max-width:100%;overflow-x:hidden;box-shadow:0 1px 0 var(--border)}.page-header>*{min-width:0}.page-title{font-size:16px;font-weight:700;letter-spacing:-.01em;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-primary)}.page-content{flex:1}.action-buttons{display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0}.project-status{flex:1;text-align:center;min-width:0;overflow:hidden}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-light)}.card-sm{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px;transition:background .12s,box-shadow .12s,border-color .12s;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.card-sm:hover{background:var(--bg-hover);border-color:var(--border-light);box-shadow:var(--shadow)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;overflow:hidden;min-width:0;box-shadow:var(--shadow);transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-label{font-size:11px;color:var(--text-muted);font-weight:600;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:20px;font-weight:700;font-family:var(--font-mono)}.list-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;min-width:0;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box}.list-item:hover,.list-item:active{background:var(--bg-hover);border-color:var(--accent);box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius);border:none;font-weight:600;font-size:14px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap;font-family:var(--font-body);flex-shrink:0;letter-spacing:.01em}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn:hover:not(:disabled){filter:brightness(.95)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 3px #2563eb4d}.btn-primary:hover:not(:disabled){background:var(--accent-hover);filter:none;box-shadow:0 4px 12px #2563eb66}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);filter:none}.btn-danger{background:var(--red-soft);color:var(--red);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:#ef444426;filter:none}.btn-sm{padding:7px 12px;font-size:12px;border-radius:7px}.btn-lg{padding:14px 20px;font-size:15px;border-radius:var(--radius-lg);width:100%;justify-content:center;letter-spacing:.02em}.btn-block{width:100%;justify-content:center}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:11px 14px;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:16px;font-family:var(--font-body);font-weight:400;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;max-width:100%;box-sizing:border-box}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--bg-card)}.form-input::placeholder{color:var(--text-muted);font-weight:400}textarea.form-input{resize:vertical;min-height:88px;line-height:1.5}select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8z' fill='%234f5b72'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.tabs{display:flex;gap:6px;padding:8px 14px 10px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:0;width:100%;max-width:100%;box-sizing:border-box}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0;padding:8px 14px;border-radius:99px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;font-family:var(--font-body)}.tab:hover:not(.active){background:var(--bg-hover);color:var(--text-primary)}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.section-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:18px 0 10px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;overflow:hidden}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;overflow:hidden}@media (max-width: 360px){.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}}@media screen and (orientation: landscape) and (max-height: 500px){.grid-3{grid-template-columns:1fr 1fr}}table{width:100%;border-collapse:collapse;min-width:0}.table-wrapper{overflow-x:auto;width:100%;max-width:100%;-webkit-overflow-scrolling:touch;display:block}.page-content,.tab-content,.scroll-area{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;width:100%;max-width:100%}.page-scroll{padding:12px 16px;padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 24px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;flex:1;min-height:0;width:100%;max-width:100%}.project-details{width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.alert{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:var(--radius);font-size:13px;border-left:3px solid;line-height:1.4;width:100%;max-width:100%;box-sizing:border-box}.alert-warning{background:var(--yellow-soft);border-color:var(--yellow);color:var(--yellow)}.alert-danger{background:var(--red-soft);border-color:var(--red);color:var(--red)}.alert-info{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.02em}.empty-state{display:flex;flex-direction:column;align-items:center;padding:48px 24px;gap:12px;text-align:center}.empty-icon{font-size:48px;opacity:.4}.empty-text{color:var(--text-muted);font-size:15px}.divider{height:1px;background:var(--divider);margin:16px 0}.section-separator{height:1px;background:var(--border);margin:20px 0;opacity:.5}.mono{font-family:var(--font-mono)}.c-green{color:var(--green)}.c-red{color:var(--red)}.c-yellow{color:var(--yellow)}.c-accent{color:var(--accent)}.c-muted{color:var(--text-muted)}.fuente-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700;border:1px solid}.fuente-proyecto{background:#22c55e26;color:var(--green);border-color:#22c55e4d}.fuente-deuda{background:#f59e0b26;color:var(--yellow);border-color:#f59e0b4d}.fuente-propio{background:#6b728026;color:var(--text-muted);border-color:#6b72804d}.fuente-caja{background:#06b6d426;color:var(--cyan);border-color:#06b6d44d}.badge-auto{font-size:10px;font-weight:800;padding:1px 6px;border-radius:99px;background:#f59e0b33;color:var(--yellow);border:1px solid rgba(245,158,11,.4);letter-spacing:.04em}.balance-positive{background:linear-gradient(135deg,#22c55e2e,#22c55e0f);border:1px solid rgba(34,197,94,.35)}.balance-negative{background:linear-gradient(135deg,#ef44442e,#ef44440f);border:1px solid rgba(239,68,68,.35)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;overflow:hidden}@media (min-width: 380px){.stats-grid{grid-template-columns:repeat(3,1fr)}}.progress-bar{width:100%;height:6px;background:var(--bg-input);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;transition:width .3s ease}.skeleton{background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-hover) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pin-shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.slide-down{animation:slideDown .2s ease forwards}@keyframes pulseBorder{0%,to{border-color:#f59e0b4d}50%{border-color:#f59e0bb3}}.pulse-border{animation:pulseBorder 2s ease-in-out infinite}.toast-container{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:calc(100% - 32px);max-width:420px}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}select optgroup{font-weight:700;color:var(--text-muted);font-size:12px}select option{font-weight:400;color:var(--text-primary);background:var(--bg-input)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media print{.bottom-nav,.page-header .btn,.btn-danger{display:none!important}body{background:#fff!important;color:#000!important;position:static!important}.card{border:1px solid #ccc!important}}@media (max-width: 360px){.page-title{font-size:15px}.btn-sm{padding:6px 10px;font-size:11px}.btn-lg{padding:12px 14px;font-size:14px}.stat-value,.form-input{font-size:15px}.hide-xs{display:none!important}}@media (max-width: 479px){.page-header{padding:8px 12px}.page-title{font-size:16px}.hide-sm{display:none!important}}@media (min-width: 768px){.app-pages{max-width:600px;margin:0 auto}.bottom-nav{max-width:600px;left:50%;transform:translate(-50%)}}@media (min-width: 1024px){.app-pages,.bottom-nav{max-width:820px}}@media (min-width: 1280px){html,body,#root{height:100vh;min-height:100vh}.app-layout{display:flex;flex-direction:row;height:100vh;overflow:hidden}.bottom-nav{position:fixed;left:0;top:0;width:200px;height:100vh;max-width:200px;flex-direction:column;justify-content:flex-start;align-items:stretch;padding:24px 0 16px;gap:4px;transform:none;border-top:none;border-right:1px solid var(--border);border-radius:0;overflow-y:auto;overflow-x:hidden;z-index:100}.nav-item{flex-direction:row;justify-content:flex-start;gap:10px;padding:10px 20px;border-radius:10px;margin:0 8px;font-size:13px}.nav-label{font-size:13px}.app-pages{margin-left:200px;max-width:100%;width:calc(100vw - 200px);height:100vh;overflow-y:auto;overflow-x:hidden;padding-bottom:24px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.stats-grid{grid-template-columns:repeat(4,1fr)}}@media screen and (orientation: landscape) and (max-height: 500px){.page-header{padding:6px 14px;min-height:46px;flex-wrap:wrap}.action-buttons{flex-wrap:wrap;gap:4px}.project-details{width:100%;max-width:100%;overflow-x:hidden}.page-title{font-size:15px}.form-group{margin-bottom:10px}.form-input{padding:9px 12px}.btn-lg{padding:11px 18px}.stat-card{padding:10px 12px}.stat-value{font-size:16px}.tabs{padding:6px 12px 8px}.empty-state{padding:24px 16px}.empty-icon{font-size:36px}.grid-3,.stats-grid{grid-template-columns:1fr 1fr}}@media screen and (orientation: landscape) and (max-height: 400px){.grid-2,.grid-3{grid-template-columns:1fr}}@media (orientation: landscape) and (max-height: 500px){.modal{max-height:96dvh;max-height:96vh}.modal-body{padding:12px 16px}.modal-header{padding:10px 16px 8px}.modal-title{font-size:15px}}.page-header *,.page-content *,.tab-content *,.card *,.card-sm *,.list-item *{max-width:100%;min-width:0}img{max-width:100%;height:auto;display:block}.app-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.app-logo img{height:32px;width:auto;object-fit:contain}.dashboard-logo{width:100%;display:flex;justify-content:center;padding:20px 16px 12px}.dashboard-logo img{max-width:200px;height:auto;object-fit:contain;border-radius:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);width:100%;max-width:100%;overflow:hidden}.modal{background:var(--bg-card);border-top:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:600px;max-height:92dvh;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -8px 40px #00000080;animation:slideUp .25s cubic-bezier(.16,1,.3,1);box-sizing:border-box}@keyframes slideUp{0%{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border);flex-shrink:0;min-width:0;overflow:hidden}.modal-header:before{content:"";display:none}.modal-title{font-size:16px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.modal-close{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:18px;line-height:1;padding:4px 10px;flex-shrink:0;margin-left:10px;transition:background .15s}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:16px 18px;width:100%;max-width:100%;box-sizing:border-box}.modal-footer{padding:12px 18px;padding-bottom:calc(12px + var(--safe-bottom));border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:10px;flex-direction:column}@media (min-width: 600px){.modal-overlay{align-items:center;padding:20px}.modal{border-radius:var(--radius-xl);max-height:85vh;border:1px solid var(--border)}}
