:root{color:#26211d;--font-sans:"Styrene B", "Styrene A", Inter, "SF Pro Text", "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei UI", "Microsoft YaHei", ui-sans-serif, system-ui, sans-serif;--font-display:"Styrene A", "Styrene B", Inter, "SF Pro Display", "SF Pro Text", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei UI", "Microsoft YaHei", ui-sans-serif, system-ui, sans-serif;font-family:var(--font-sans);font-synthesis:none;font-feature-settings:"kern" 1, "liga" 1, "calt" 1;text-rendering:geometricprecision;-webkit-font-smoothing:antialiased;--paper:#f7f3ec;--paper-strong:#fbf8f2;--panel:#fffdf8;--panel-soft:#faf6ef;--ink:#26211d;--text:#26211d;--muted:#746b61;--line:#e3d9cc;--line-strong:#d4c5b5;--clay-800:#8e402f;--clay-700:#a84f3b;--clay-600:#c2614a;--clay-100:#f6ded5;--clay-50:#fbede8;--green-800:#28624d;--green-700:#33765d;--green-100:#dfeee5;--green-50:#f1f7f1;--red-600:#bd463c;--red-50:#fbebe8;--shadow:0 22px 70px #533d2a14;background:#f7f3ec}*{box-sizing:border-box}body{min-width:320px;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);background:var(--paper);font-family:var(--font-sans);margin:0;font-weight:400}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app{background:radial-gradient(circle at 18% -8%, #c2614a1c, transparent 330px), linear-gradient(180deg, #fbf8f2 0, var(--paper) 280px);flex-direction:column;min-height:100dvh;display:flex}.topbar{min-height:82px;color:var(--ink);border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffdf8e0;grid-template-columns:minmax(260px,.75fr) minmax(520px,1.35fr) auto;align-items:center;gap:22px;padding:14px 24px;display:grid;box-shadow:inset 0 1px #ffffffb3}.brand{align-items:center;gap:14px;display:flex}.brand-mark{color:#fff9f1;background:linear-gradient(135deg, var(--clay-600), var(--clay-800));border-radius:8px;place-items:center;width:44px;height:44px;display:grid;box-shadow:0 10px 24px #8e402f38}.brand h1{font-family:var(--font-display);letter-spacing:0;margin:0;font-size:28px;font-weight:720;line-height:1.08}.brand p,.panel-title p,.result-summary p,.footer-note,.validation span{color:var(--muted);margin:0}.brand p{color:var(--muted);margin-top:4px;font-size:13px;font-weight:430}.session-fields{grid-template-columns:minmax(150px,.8fr) minmax(230px,1fr);gap:12px;display:grid}.session-fields label,.unit-control{gap:8px;display:grid}.session-fields span,.control-label{color:var(--muted);font-size:13px;font-weight:620}.session-fields input{width:100%;height:40px;color:var(--ink);border:1px solid var(--line);background:#fffaf3;border-radius:7px;outline:none;padding:0 12px}.live-time{width:100%;height:40px;color:var(--ink);border:1px solid var(--line);white-space:nowrap;background:#fffaf3;border-radius:7px;align-items:center;padding:0 12px;font-size:15px;font-weight:560;display:flex}.room-control{grid-template-columns:1fr 40px 40px 40px minmax(104px,auto);gap:8px;display:grid}.room-control .icon-button,.room-control .button{height:40px}.room-control .icon-button{width:40px;color:var(--clay-800);border:1px solid var(--line);background:#fffaf3;border-radius:7px}.room-control .button{color:var(--clay-800);border-color:#c2614a47;padding:0 12px}.room-control .button:disabled,.room-control .icon-button:disabled{color:#b7aa9d;cursor:not-allowed;background:var(--panel-soft)}.session-fields input:focus{border-color:var(--clay-600)}input:disabled{color:#7f756b;-webkit-text-fill-color:#7f756b;background:#f4efe7}.top-actions,.quick-actions,.result-actions{align-items:center;gap:10px;display:flex}.collab-pill,.readonly-pill{height:42px;color:var(--muted);border:1px solid var(--line);white-space:nowrap;background:#fffaf3;border-radius:7px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:620;display:inline-flex}.readonly-pill{color:var(--clay-800);background:var(--clay-50);border-color:#c2614a3d}.collab-pill.connected{color:var(--green-800);background:var(--green-50);border-color:#33765d47}.collab-pill.connecting{color:var(--clay-800);background:var(--clay-50);border-color:#c2614a3d}.button{border:1px solid var(--line);height:42px;color:var(--ink);white-space:nowrap;background:#fffaf3;border-radius:7px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:14px;font-weight:620;display:inline-flex}.button:hover{border-color:var(--line-strong);background:#fffdf8}.button:disabled:hover{border-color:var(--line);background:#fffaf3}.button.accent{color:var(--clay-800);background:var(--clay-50);border-color:#c2614a47}.button.accent.strong{color:#fffdf8;background:linear-gradient(180deg, var(--clay-600), var(--clay-700));border-color:var(--clay-700);box-shadow:0 10px 24px #a84f3b2e}.button.danger-ghost{color:var(--red-600);background:#fff8f5;border-color:#bd463c52}.workspace{flex:1;grid-template-columns:minmax(720px,1fr) minmax(360px,430px);gap:16px;width:100%;max-width:1500px;margin:0 auto;padding:24px 20px 16px;display:grid}.ledger-panel,.result-panel{background:var(--panel);border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);border-radius:8px}.ledger-panel{padding:16px}.result-panel{flex-direction:column;padding:18px;display:flex}.controls-band{justify-content:space-between;align-items:end;gap:16px;padding-bottom:16px;display:flex}.unit-control .control-label{color:var(--muted)}.stepper{border:1px solid var(--line);background:#fffaf3;border-radius:7px;grid-template-columns:42px minmax(64px,1fr) 42px;height:42px;display:inline-grid;overflow:hidden}.stepper.wide{grid-template-columns:48px 1fr 48px;width:250px;height:48px}.stepper.compact{width:164px}.stepper input,.amount-input,.name-input{border:1px solid var(--line);width:100%;color:var(--text);background:#fffaf3;border-radius:7px;outline:none}.stepper input{text-align:center;border-width:0 1px;border-radius:0;min-width:0;font-size:17px;font-weight:660}.stepper.wide input{font-size:24px}.amount-input,.name-input{height:40px;padding:0 10px;font-weight:540}.amount-input{text-align:right;max-width:132px}.name-input{max-width:150px}input:focus{border-color:var(--clay-600);box-shadow:0 0 0 3px #c2614a1f}.remote-editing{box-shadow:0 0 0 3px #33765d1a;border-color:#33765d7a!important}.remote-edit-hint{width:max-content;max-width:100%;color:var(--green-800);background:var(--green-50);white-space:nowrap;border:1px solid #33765d38;border-radius:999px;margin-top:6px;padding:3px 7px;font-size:11px;font-weight:650;line-height:1.2;display:block}.editing-strip{min-height:42px;color:var(--green-800);background:var(--green-50);border:1px solid #33765d47;border-radius:8px;align-items:center;gap:9px;margin:0 0 12px;padding:9px 12px;font-size:13px;font-weight:620;display:flex}.editing-strip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.icon-button{width:42px;height:42px;color:var(--text);background:0 0;border:0;place-items:center;display:inline-grid}.icon-button:hover{color:var(--clay-700);background:var(--clay-50)}.icon-button:disabled:hover{color:var(--text);background:0 0}.icon-button.delete{color:var(--red-600);border-radius:7px}.table-shell{border:1px solid var(--line);border-radius:8px;overflow-x:auto}.mobile-player-list{display:none}table{border-collapse:collapse;width:100%;min-width:820px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:11px 14px}th{color:#746b61;background:var(--panel-soft);height:48px;font-size:13px;font-weight:620}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:#fffaf3}.seat{color:#fffaf3;background:var(--clay-700);border-radius:999px;place-items:center;width:28px;height:28px;font-size:14px;font-weight:650;display:inline-grid}.money-cell{color:#4e453e;font-weight:620}.net{text-align:right;white-space:nowrap;font-weight:680}.positive,.tone-positive{color:#0b8758}.negative,.tone-negative{color:var(--red-600)}.add-row{height:38px;color:var(--clay-800);background:#fffaf3;border:1px solid #c2614a57;border-radius:7px;align-items:center;gap:8px;margin-top:12px;padding:0 14px;font-weight:620;display:inline-flex}.undo-banner{min-height:42px;color:var(--clay-800);background:var(--clay-50);border:1px solid #c2614a3d;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin:0 0 12px;padding:9px 12px;font-size:13px;font-weight:620;display:flex}.undo-banner button{color:#fffdf8;background:var(--clay-700);border:1px solid var(--clay-700);border-radius:7px;justify-content:center;align-items:center;gap:6px;height:32px;padding:0 10px;font-weight:650;display:inline-flex}.history-strip{grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;margin:0 0 12px;display:grid}.history-strip>span,.history-strip button{border:1px solid var(--line);background:#fffaf3;border-radius:8px;min-height:50px}.history-strip>span{color:var(--muted);grid-column:1/-1;align-items:center;padding:0 12px;font-size:13px;font-weight:580;display:flex}.history-strip button{color:var(--ink);text-align:left;justify-items:start;gap:4px;padding:8px 10px;display:grid}.history-strip button:hover{border-color:var(--line-strong);background:#fffdf8}.history-strip button strong{font-size:13px;line-height:1.1}.history-strip button span{color:var(--muted);font-size:12px;line-height:1.2}.stats-grid{border:1px solid var(--line);background:var(--panel-soft);border-radius:8px;grid-template-columns:repeat(5,1fr);margin-top:16px;display:grid;overflow:hidden}.stat{border-right:1px solid var(--line);gap:7px;padding:14px 18px;display:grid}.stat:last-child{border-right:0}.stat span{color:var(--muted);font-size:13px;font-weight:560}.stat strong{color:var(--text);font-size:24px;font-weight:680;line-height:1}.stat strong small{color:var(--muted);margin-left:4px;font-size:13px;font-weight:520}.validation{border-radius:8px;align-items:center;gap:12px;min-height:62px;margin-top:12px;padding:12px 16px;display:flex}.validation.ok{color:var(--green-700);background:var(--green-50);border:1px solid #33765d47}.validation.warn{color:var(--red-600);background:var(--red-50);border:1px solid #bd463c47}.validation div{gap:3px;display:grid}.validation strong{font-size:15px;font-weight:650}.validation span{font-size:13px}.panel-title{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.panel-title h2{margin:0 0 5px;font-size:24px;font-weight:700;line-height:1.1}.panel-title p{font-size:13px}.result-panel .icon-button{color:var(--clay-800);border:1px solid var(--line);border-radius:7px}.result-summary{border:1px solid var(--line);background:linear-gradient(#fffaf3,#fbf5ed);border-radius:8px;gap:8px;padding:16px;display:grid}.result-summary div{align-items:baseline;gap:8px;display:flex}.result-summary span{color:#4e453e;font-weight:620}.result-summary strong{color:var(--clay-700);font-size:32px;font-weight:690;line-height:1}.result-summary small{color:var(--muted);font-weight:560}.result-summary p{font-size:13px}.imbalance-card{color:var(--red-600);background:var(--red-50);border:1px solid #bd463c47;border-radius:8px;align-items:center;gap:9px;margin-top:12px;padding:11px 12px;font-size:13px;font-weight:560;display:flex}.transfer-list{gap:12px;margin-top:14px;padding-right:2px;display:grid;overflow:auto}.recipient-card{border:1px solid var(--line);background:#fffdf8;border-radius:8px;overflow:hidden}.recipient-card header{color:var(--clay-800);background:linear-gradient(180deg, var(--clay-50), #fffdf8);border-bottom:1px solid var(--line);padding:13px 14px}.recipient-card header div{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.recipient-card header strong{font-size:18px}.recipient-card header span{font-size:13px;font-weight:580}.recipient-lines{display:grid}.transfer-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:14px;min-height:46px;padding:0 14px;display:flex}.transfer-row:last-child{border-bottom:0}.transfer-row span{color:#4e453e;font-weight:520}.transfer-row strong{color:var(--clay-700);white-space:nowrap;font-weight:650}.empty-state{min-height:220px;color:var(--muted);border:1px dashed var(--line-strong);text-align:center;border-radius:8px;align-content:center;place-items:center;gap:9px;padding:24px;display:grid}.empty-state strong{color:var(--text)}.empty-state span{max-width:260px;font-size:13px;line-height:1.6}.footer-note{align-items:center;gap:8px;margin-top:auto;padding-top:16px;font-size:13px;line-height:1.5;display:flex}.modal-backdrop{z-index:40;padding:max(16px, env(safe-area-inset-top,0)) max(16px, env(safe-area-inset-right,0)) max(16px, env(safe-area-inset-bottom,0)) max(16px, env(safe-area-inset-left,0));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#26211d47;place-items:center;display:grid;position:fixed;inset:0}.qr-modal{width:min(100%,380px);color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:8px;gap:14px;padding:16px;display:grid;box-shadow:0 24px 90px #26211d38}.qr-modal header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.qr-modal h2{margin:0;font-size:22px;font-weight:700;line-height:1.15}.qr-modal p{color:var(--muted);margin:4px 0 0;font-size:13px;font-weight:620}.modal-close{border:1px solid var(--line);width:38px;height:38px;color:var(--muted);background:#fffaf3;border-radius:7px;flex:none}.qr-switch{border:1px solid var(--line);background:#fffaf3;border-radius:8px;grid-template-columns:1fr 1fr;padding:3px;display:grid}.qr-switch button{height:36px;color:var(--muted);background:0 0;border:0;border-radius:6px;font-weight:650}.qr-switch button.active{color:#fffdf8;background:var(--clay-700);box-shadow:0 6px 18px #a84f3b2e}.qr-frame{aspect-ratio:1;border:1px solid var(--line);background:#fffdf8;border-radius:8px;place-items:center;padding:16px;display:grid}.qr-frame img{width:100%;max-width:280px;height:auto;display:block}.qr-frame span{color:var(--muted);font-size:14px;font-weight:620}.qr-link-input{width:100%;height:40px;color:var(--muted);border:1px solid var(--line);text-overflow:ellipsis;background:#fffaf3;border-radius:7px;outline:none;padding:0 10px;font-size:12px;font-weight:520}.qr-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.statusbar{width:100%;max-width:1500px;color:var(--muted);justify-content:space-between;gap:16px;margin:0 auto;padding:0 20px 16px;font-size:13px;display:flex}@media (width<=920px){.topbar{grid-template-columns:1fr}.session-fields{grid-template-columns:1fr 1fr}.top-actions{justify-content:flex-start}.workspace{grid-template-columns:1fr}}@media (width<=1180px){.topbar{grid-template-columns:1fr}.top-actions{justify-content:flex-start}.workspace{grid-template-columns:1fr}}@media (width<=760px){body{min-width:0}.topbar{gap:14px;padding:14px}.brand h1{font-size:25px}.brand-mark{width:42px;height:42px}.session-fields,.controls-band,.panel-title{grid-template-columns:1fr;display:grid}.top-actions,.quick-actions,.result-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.collab-pill,.readonly-pill{grid-column:1/-1}.button{width:100%}.room-control{grid-template-columns:1fr 40px 40px 40px}.room-control .button,.top-actions>.button:last-child,.result-actions>.button{grid-column:1/-1}.result-actions{grid-template-columns:repeat(3,1fr)}.result-actions .icon-button{width:100%}.workspace{gap:12px;padding:14px 10px}.history-strip{padding-bottom:2px;display:flex;overflow-x:auto}.history-strip>span,.history-strip button{min-width:148px}.undo-banner{align-items:stretch}.modal-backdrop{place-items:end center;padding:12px}.qr-modal{width:100%}.ledger-panel,.result-panel{padding:10px}.unit-control,.stepper.wide{width:100%}.table-shell{display:none}.mobile-player-list{gap:10px;display:grid}.mobile-player-card{border:1px solid var(--line);background:#fffdf8;border-radius:8px;overflow:hidden}.mobile-player-header{border-bottom:1px solid var(--line);background:var(--panel-soft);justify-content:space-between;align-items:center;gap:10px;min-height:58px;padding:10px;display:flex}.mobile-seat-name{flex:1;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;min-width:0;display:grid}.mobile-seat-name .seat{width:30px;height:30px}.mobile-seat-name .name-input{min-width:0;max-width:none}.mobile-seat-name .remote-edit-hint{grid-column:2;margin-top:-4px}.mobile-player-body{grid-template-columns:1fr 1fr;gap:10px;padding:10px;display:grid}.mobile-field{gap:7px;min-width:0;display:grid}.mobile-field span{color:var(--muted);font-size:12px;font-weight:580}.mobile-field strong{align-items:center;min-height:40px;font-size:18px;font-weight:650;line-height:1;display:flex}.mobile-field .amount-input,.mobile-field .stepper.compact{width:100%;max-width:none}.mobile-field .remote-edit-hint{text-align:center;width:100%}.mobile-field .amount-input{text-align:left}.buyins-field{grid-column:1/-1}.stats-grid{grid-template-columns:1fr 1fr;margin-top:12px}.stat{border-right:0;border-bottom:1px solid var(--line);min-width:0;padding:12px}.stat:nth-child(odd){border-right:1px solid var(--line)}.stat:last-child{border-bottom:0;border-right:0;grid-column:1/-1}.stat strong{font-size:22px}.validation{align-items:flex-start;padding:12px}.panel-title{gap:12px}.result-summary strong{font-size:28px}.transfer-row,.recipient-card header div{align-items:flex-start}.transfer-row{min-height:48px;padding:10px 12px}.transfer-row span{line-height:1.35}.statusbar{flex-direction:column;padding:0 12px 14px}}
