*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f1a;--surface:#1c1c2e;--border:#2e2e4a;--accent:#6c63ff;--accent-h:#8b85ff;--danger:#e05c5c;--warn:#e09a3a;--success:#4caf7d;--text:#e8e8f0;--muted:#88a;--radius:12px;--radius-sm:8px}html,body{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}.shell{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}.nav-title{font-size:1rem;font-weight:700}.nav-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:.85rem}.main{flex-direction:column;flex:1;gap:20px;padding:20px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-size:.75rem;font-weight:600}label{color:var(--muted);margin-bottom:6px;font-size:.85rem;display:block}select,input[type=text],input[type=email],input[type=password],textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:12px 14px;font-size:1rem;transition:border-color .15s}select:focus,input:focus,textarea:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:80px}.hours-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.hour-btn{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;text-align:center;padding:16px 0;font-size:1.1rem;font-weight:600;transition:all .15s}.hour-btn:hover{border-color:var(--accent);color:var(--accent)}.hour-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.btn{background:var(--accent);border-radius:var(--radius-sm);color:#fff;cursor:pointer;border:none;width:100%;padding:16px;font-size:1rem;font-weight:600;transition:background .15s}.btn:hover{background:var(--accent-h)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{border:1px solid var(--border);color:var(--text);background:0 0}.btn-danger{background:var(--danger)}.badge{border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.badge-warn{color:var(--warn);background:#3a2800}.badge-danger{color:var(--danger);background:#2e0000}.badge-ok{color:var(--success);background:#002e1a}.entry-list{flex-direction:column;gap:10px;display:flex}.entry{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:4px;padding:14px;display:flex}.entry-top{justify-content:space-between;align-items:center;display:flex}.entry-project{font-size:.95rem;font-weight:600}.entry-hours{color:var(--accent);font-size:1.2rem;font-weight:700}.entry-meta{color:var(--muted);font-size:.8rem}.entry-nota{color:var(--muted);margin-top:4px;font-size:.85rem;font-style:italic}.fase-grid{flex-wrap:wrap;gap:8px;display:flex}.fase-btn{background:var(--bg);border:2px solid var(--border);color:var(--text);cursor:pointer;border-radius:99px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .15s}.fase-btn:hover{border-color:var(--accent)}.fase-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.alert{border-radius:var(--radius-sm);padding:12px 16px;font-size:.9rem}.alert-error{border:1px solid var(--danger);color:var(--danger);background:#2e0000}.alert-ok{border:1px solid var(--success);color:var(--success);background:#002e1a}.tabs{background:var(--surface);border-radius:var(--radius-sm);gap:4px;padding:4px;display:flex}.tab-btn{border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;background:0 0;border:none;flex:1;padding:10px;font-size:.85rem;font-weight:600;transition:all .15s}.tab-btn.active{background:var(--accent);color:#fff}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}th{color:var(--muted);text-align:left;border-bottom:1px solid var(--border);padding:8px 12px;font-weight:600}td{border-bottom:1px solid var(--border);padding:10px 12px}tr:last-child td{border-bottom:none}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);display:flex;position:sticky;bottom:0}.bottom-nav a{color:var(--muted);flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 0;font-size:.7rem;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.bottom-nav a.active,.bottom-nav a:hover{color:var(--accent)}.bottom-nav svg{width:22px;height:22px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;margin:40px auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.text-muted{color:var(--muted)}.text-center{text-align:center}.mt-auto{margin-top:auto}.gap-sm{gap:8px}
