:root{--bg:#f4f4f6;--card:#ffffff;--ink:#1a1a1a;--navy:#1a1a2e;--muted:#6b7280;--line:#e5e7eb;--accent:#ff6b35;--accent-ink:#ffffff;--green:#16a34a;--yellow:#d97706;--red:#ef4444}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.container{max-width:1100px;margin:0 auto;padding:16px 16px 104px}.topbar{display:flex;align-items:center;gap:16px;margin-bottom:16px}.topbar h1{font-size:22px;margin:0;flex:1 1}.back{font-weight:600}.back,.logout{color:var(--muted)}.logout{background:none;border:1px solid var(--line);border-radius:8px;padding:6px 12px}.year{display:flex;align-items:center;gap:10px}.year button{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--card);font-size:18px}.year span{font-weight:700;min-width:48px;text-align:center}.tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.tab{padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--muted);font-weight:600}.tab.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.actions{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.actions button{padding:8px 14px;border-radius:8px;border:1px solid var(--line);background:var(--card);font-weight:600}.actions .pdf{display:inline-flex;gap:6px;align-items:center}.actions select,.editor input,.editor select{padding:7px 10px;border-radius:8px;border:1px solid var(--line);background:var(--card)}.error{color:var(--red);font-weight:600}table.pnl{width:100%;border-collapse:collapse;background:var(--card);border-radius:12px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04)}table.pnl td,table.pnl th{padding:9px 12px;text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;border-bottom:1px solid var(--line);white-space:nowrap}table.pnl th{background:#fafafa;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}table.pnl td.concept,table.pnl th.concept{text-align:left}table.pnl td.sub{padding-left:26px;color:#374151}tr.section td{font-weight:700;background:#fcfcfd}tr.row.auto td.concept:after{content:" (auto)";color:var(--muted);font-weight:400;font-size:11px}tr.resultado td{font-weight:800;border-top:2px solid var(--ink);background:#fff7f2}.editor{margin-top:26px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}.editor h2{font-size:15px;margin:0 0 12px}.editor .form{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.editor label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);font-weight:600}.editor .form>button{padding:9px 18px;border-radius:8px;border:none;background:var(--accent);color:var(--accent-ink);font-weight:700}.editor .form>button:disabled{opacity:.6}.hello{color:var(--muted);margin:0 0 18px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:14px;gap:14px}.card{display:block;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}.card h3{margin:0 0 6px;font-size:16px}.card p{margin:0;color:var(--muted);font-size:13px}.card.soon{opacity:.55}a.card:hover{border-color:var(--accent)}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:340px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:12px}.login-card h1{margin:0 0 8px;font-size:22px}.login-card input{padding:11px 13px;border-radius:9px;border:1px solid var(--line);font-size:15px}.login-card button{padding:11px;border-radius:9px;border:none;background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:15px}.muted{color:var(--muted)}.ok{color:var(--green);font-weight:600}.section-title{font-size:15px;margin:22px 0 10px}.list{display:flex;flex-direction:column;gap:8px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px}a.list-row:hover{border-color:var(--accent)}.frac-edit{display:inline-flex;align-items:center;gap:6px}.mini{width:70px;padding:6px 8px;text-align:right}.chip,.mini{border-radius:7px;border:1px solid var(--line);background:var(--card)}.chip{padding:5px 10px;font-size:12px;font-weight:600}.chip:hover{border-color:var(--accent)}.chip.ghost{color:var(--muted)}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:30;background:rgba(244,244,246,.9);backdrop-filter:saturate(1.5) blur(8px);-webkit-backdrop-filter:saturate(1.5) blur(8px);border-bottom:1px solid var(--line)}.app-header-inner{max-width:1100px;margin:0 auto;padding:9px 16px;gap:12px}.app-header-inner,.brand{display:flex;align-items:center}.brand{gap:10px;min-width:0}.brand-badge{width:34px;height:34px;border-radius:9px;background:var(--navy);color:var(--accent);font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;flex:none}.brand-name{font-weight:700;font-size:17px;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header .gear{margin-left:auto;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--muted);flex:none}.app-header .gear.on,.app-header .gear:hover{color:var(--accent);background:#fff}.app-header .gear svg{width:22px;height:22px}.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:40;background:#fff;border-top:1px solid var(--line);box-shadow:0 -2px 14px rgba(0,0,0,.05);padding-bottom:env(safe-area-inset-bottom)}.bottomnav-inner{max-width:560px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);align-items:end}.navitem{flex-direction:column;justify-content:flex-end;gap:3px;color:var(--muted);height:60px;padding-bottom:7px;font-size:11px;font-weight:600}.navitem,.navitem .ico{display:flex;align-items:center}.navitem .ico{width:24px;height:24px;justify-content:center}.navitem .ico svg{width:23px;height:23px}.navitem.on{color:var(--accent)}.navitem.center{color:var(--navy)}.navitem.center.on{color:var(--accent)}.navitem.center .ico{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;box-shadow:0 5px 14px rgba(255,107,53,.45);margin-top:-24px;border:4px solid var(--bg)}.navitem.center .ico svg{width:26px;height:26px}.screen-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:4px 0 14px}.screen-title{font-size:24px;margin:0;font-weight:800;color:var(--navy)}.link-accent{color:var(--accent);font-weight:700;font-size:14px}.tally{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.pill{font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px}.pill.green{background:#e9f9ef;color:#16a34a}.pill.yellow{background:#fef3e2;color:#d97706}.pill.red{background:#fdecec;color:#dc2626}.dishgroup{margin-bottom:18px}.group-label{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0 0 8px 2px}.dishlist{display:flex;flex-direction:column;gap:8px}.dish{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 14px;box-shadow:0 1px 2px rgba(0,0,0,.04)}a.dish:hover{border-color:var(--accent)}.dish .dot{width:12px;height:12px;border-radius:50%;flex:none}.dish .dot.green{background:#22c55e}.dish .dot.yellow{background:#f59e0b}.dish .dot.red{background:#ef4444}.dish .info{display:flex;flex-direction:column;gap:2px;flex:1 1;min-width:0}.dish .name{font-weight:600;color:var(--navy);font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dish .sub{font-size:12px;color:var(--muted)}.dish .ratio{font-weight:800;font-size:16px;flex:none}.dish .ratio.green{color:#16a34a}.dish .ratio.yellow{color:#d97706}.dish .ratio.red{color:#dc2626}.dish .ratio.none{color:var(--accent);font-size:12px;font-weight:700}.row-strong{font-weight:600;color:var(--navy)}.row-meta{font-size:12px;color:var(--muted);margin-top:2px}.row-right{text-align:right;flex:none}.row-amount{font-weight:700;color:var(--navy)}.sdot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle}.sdot.green{background:#22c55e}.sdot.yellow{background:#f59e0b}.sdot.red{background:#ef4444}.tag-paid{color:var(--green);font-weight:700}.tag-pending{color:var(--yellow);font-weight:700}.empty{text-align:center;color:var(--muted);padding:40px 16px}.danger{background:none;border:1px solid #f1c4c4;color:var(--red);border-radius:10px;padding:11px 16px;font-weight:700}.danger:hover{background:#fdf2f2}