:root{--paper:#fbf4df;--ink:#202022;--muted:#6f6759;--line:#d6cbb5;--green:#22b2a6;--yellow:#f8c136;--red:#ef6f55;--blue:#5fa8d3;--display:Georgia, "Times New Roman", serif;--body:"Avenir Next", "Trebuchet MS", Verdana, sans-serif;color:var(--ink);background:linear-gradient(90deg, #2020220d 1px, transparent 1px), linear-gradient(#2020220a 1px, transparent 1px), var(--paper);font-family:var(--body);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-size:28px 28px;font-size:16px;line-height:1.45}*{box-sizing:border-box}html{min-width:320px}body{min-width:320px;min-height:100svh;margin:0}button,input,textarea{letter-spacing:0}button{font-family:inherit}p,h1,h2{overflow-wrap:anywhere}.app-shell{width:min(1180px,100% - 32px);min-height:100svh;margin:0 auto;padding:24px 0 48px}.home-shell{flex-direction:column;gap:18px;display:flex}.hero-band{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) 260px;align-items:center;gap:22px;min-height:236px;display:grid}.hero-band h1,.group-header h1,.state-shell h1{max-width:780px;color:var(--ink);font-family:var(--display);letter-spacing:0;margin:10px 0 0;font-size:clamp(2.4rem,7vw,5.7rem);line-height:.92}.hero-band h1{text-wrap:balance}.eyebrow{color:var(--green);text-transform:uppercase;align-items:center;gap:7px;font-size:.84rem;font-weight:800;display:inline-flex}.hero-orbit{min-height:210px;position:relative}.orbit-token{border:2px solid var(--ink);background:var(--paper);box-shadow:9px 9px 0 var(--ink);color:var(--ink);font-family:var(--display);border-radius:999px;place-items:center;display:grid;position:absolute}.token-a{background:var(--yellow);width:104px;height:104px;font-size:2.2rem;top:14px;right:92px}.token-b{background:var(--red);width:86px;height:86px;top:92px;right:16px}.token-c{background:var(--blue);width:72px;height:72px;top:128px;right:156px}.tab-switch{border:2px solid var(--ink);background:var(--ink);border-radius:999px;grid-template-columns:repeat(2,minmax(110px,1fr));align-self:flex-start;padding:3px;display:inline-grid}.tab-switch button{color:var(--paper);cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:11px 18px;font-weight:800;display:inline-flex}.tab-switch button.active{background:var(--paper);color:var(--ink)}.work-surface,.group-grid{gap:18px;display:grid}.roll-layout{grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr)}.arisan-layout,.group-grid{grid-template-columns:minmax(0,1fr) 360px;align-items:start}.group-grid{grid-template-columns:minmax(240px,.68fr) minmax(0,1.65fr) minmax(320px,.82fr)}.panel{border:2px solid var(--ink);background:var(--paper);min-width:0;box-shadow:6px 6px 0 var(--ink);border-radius:8px;padding:18px}.panel-heading{align-items:flex-start;gap:11px;margin-bottom:16px;display:flex}.panel-heading h2,.period-header h2,.winner-panel h2,.completion-band h2{color:var(--ink);font-family:var(--display);letter-spacing:0;margin:0;font-size:1.55rem;line-height:1}.panel-heading p,.period-header p,.winner-panel p,.completion-band p,.group-header p,.muted{color:var(--muted);margin:4px 0 0}label{color:var(--ink);gap:7px;font-size:.9rem;font-weight:800;display:grid}input,textarea{box-sizing:border-box;border:2px solid var(--ink);width:100%;min-width:0;color:var(--ink);font:inherit;background:#fffdf7;border-radius:6px;padding:11px 12px}textarea{resize:vertical}input:disabled,textarea:disabled{color:#6f6759;background:#eee9de}input:focus-visible,textarea:focus-visible,button:focus-visible{outline:3px solid var(--blue);outline-offset:2px}.setup-panel{gap:14px;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.side-stack{gap:18px;min-width:0;display:grid}.paste-row{grid-template-columns:minmax(0,1fr) 48px;gap:8px;display:grid}.inline-meta,.ledger-summary{color:var(--muted);justify-content:space-between;align-items:center;gap:10px;font-size:.9rem;font-weight:800;display:flex}.roll-stage{border:2px solid var(--ink);background:radial-gradient(circle at 30% 20%, #f8c136d1, transparent 26%), radial-gradient(circle at 80% 74%, #22b2a68c, transparent 28%), var(--red);min-height:440px;box-shadow:8px 8px 0 var(--ink);color:var(--ink);text-align:center;border-radius:8px;align-content:center;place-items:center;gap:18px;padding:24px;display:grid;position:relative;overflow:hidden}.roll-stage>:not(.confetti-field){z-index:2;position:relative}.roll-stage.celebrating{animation:.7s both stage-celebrate}.dice-core,.trophy-mark,.state-icon{border:2px solid var(--ink);background:var(--paper);width:128px;height:128px;box-shadow:8px 8px 0 var(--ink);border-radius:50%;place-items:center;display:grid}.dice-core.rolling{animation:.62s steps(7,end) infinite shake}.stage-label{color:var(--ink);text-transform:uppercase;margin:0;font-weight:900}.roll-stage h2{font-family:var(--display);margin:0;font-size:clamp(2rem,6vw,4.4rem);line-height:.95}.wheel-frame{aspect-ratio:1;place-items:center;width:min(340px,84vw);margin:0 auto;display:grid;position:relative}.wheel-frame.compact{width:min(220px,100%)}.wheel-pointer{z-index:4;border-left:16px solid #0000;border-right:16px solid #0000;border-top:28px solid var(--ink);filter:drop-shadow(0 3px #0000002e);width:0;height:0;position:absolute;top:-5px;left:50%;transform:translate(-50%)}.name-wheel{border:4px solid var(--ink);background:var(--paper);border-radius:50%;width:100%;height:100%;display:block;position:relative;overflow:hidden;box-shadow:inset 0 0 0 8px #fbf4dfe6}.wheel-frame.compact .name-wheel{box-shadow:inset 0 0 0 7px #fbf4dfe6}.wheel-rotor{will-change:transform;width:100%;height:100%;display:block;position:absolute;inset:0}.wheel-rotor.spinning{transition:transform 4.2s cubic-bezier(.08,.78,.12,1)}.wheel-rotor path{stroke:#20202280;stroke-width:.35px}.wheel-svg-label{fill:var(--ink);font-family:var(--body);paint-order:stroke;pointer-events:none;stroke:#fbf4dfb8;stroke-linejoin:round;stroke-width:2.8px;text-anchor:middle;dominant-baseline:middle;font-size:6px;font-weight:900}.wheel-center{z-index:3;border:3px solid var(--ink);background:var(--paper);width:58px;height:58px;color:var(--ink);box-shadow:3px 3px 0 var(--ink);border-radius:50%;place-items:center;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.wheel-frame.compact .wheel-center{width:46px;height:46px}.primary-button,.secondary-button,.danger-button,.ghost-button,.icon-button{border:2px solid var(--ink);cursor:pointer;min-height:44px;color:var(--ink);font:inherit;border-radius:6px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-weight:900;text-decoration:none;display:inline-flex}.primary-button{background:var(--green);box-shadow:4px 4px 0 var(--ink)}.secondary-button{background:var(--blue)}.danger-button{background:var(--red)}.ghost-button,.icon-button{background:var(--paper)}.icon-button{width:44px;padding:0}.big-action{min-width:210px}button:disabled{cursor:not-allowed;opacity:.58}.recent-list,.period-list,.ledger-list,.owner-tools{gap:10px;display:grid}.recent-item,.period-item{border:2px solid var(--line);width:100%;color:var(--ink);cursor:pointer;text-align:left;background:#fffdf7;border-radius:6px;gap:2px;padding:11px;display:grid}.period-item{grid-template-columns:42px minmax(0,1fr);align-items:center}.period-item small{grid-column:2}.period-item.active,.recent-item:hover{border-color:var(--ink);background:var(--yellow)}.recent-item span,.period-item strong{font-weight:900}.recent-item small,.period-item small{color:var(--muted)}.group-shell{gap:18px;width:min(1840px,100% - 64px);display:grid}.group-header{border-bottom:1px solid var(--line);grid-template-columns:92px minmax(0,1fr) auto;align-items:start;gap:18px;padding-bottom:18px;display:grid}.group-header h1{font-size:clamp(2.3rem,6vw,4.8rem)}.status-pill,.amount-pill{border:2px solid var(--ink);color:var(--ink);border-radius:999px;padding:8px 12px;font-size:.86rem;font-weight:900}.status-pill.active{background:var(--green)}.status-pill.completed{background:var(--yellow)}.status-pill.archived{background:var(--red)}.amount-pill{background:var(--yellow)}.link-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.copy-link{border:2px solid var(--line);background:#fffdf7;border-radius:8px;grid-template-columns:22px minmax(0,1fr) 44px;align-items:center;gap:10px;min-width:0;padding:10px;display:grid}.copy-link small{color:var(--muted);font-weight:900;display:block}.copy-link span{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.completion-band{border:2px solid var(--ink);background:var(--yellow);border-radius:8px;grid-template-columns:36px minmax(0,1fr) auto;align-items:center;gap:14px;padding:16px;display:grid}.period-header{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding-bottom:16px;display:grid}.period-actions{flex-wrap:wrap;justify-content:flex-end;align-items:end;gap:8px;min-width:0;display:flex}.compact-label{flex:220px;min-width:180px}.ledger-summary{flex-wrap:wrap;padding:8px 0 2px}.ledger-row{border:2px solid var(--line);background:#fffdf7;border-radius:8px;align-items:center;gap:8px;min-width:0;padding:10px;display:grid}.ledger-row.editable{grid-template-columns:minmax(128px,1fr) minmax(112px,150px) minmax(136px,1fr) 44px;grid-template-areas:"member amount paidto save""member note note save"}.ledger-row.editable .check-line{grid-area:member}.ledger-row.editable>input:first-of-type{grid-area:amount}.ledger-row.editable>input:nth-of-type(2){grid-area:paidto}.ledger-row.editable>input:nth-of-type(3){grid-area:note}.ledger-row.editable>.icon-button{grid-area:save;align-self:stretch;height:100%}.ledger-row.readonly{grid-template-columns:minmax(0,1fr) 34px}.ledger-row.paid{border-color:var(--green)}.ledger-row:not(.paid){border-color:var(--red)}.check-line{grid-template-columns:none;align-items:center;gap:10px;display:flex}.check-line input{width:20px;height:20px}.ledger-row small{color:var(--muted);display:block}.status-dot{background:var(--green);border-radius:50%;place-items:center;width:28px;height:28px;display:grid}.ledger-row:not(.paid) .status-dot{background:var(--red)}.winner-panel{text-align:center}.winner-panel .trophy-mark{background:var(--yellow);width:98px;height:98px;margin:0 auto 16px}.winner-panel h2{margin-bottom:10px;font-size:2.2rem}.roll-modal-backdrop{z-index:40;background:linear-gradient(135deg, #f8c136e0, #ef6f55e6), var(--paper);place-items:center;padding:24px;display:grid;position:fixed;inset:0;overflow:auto}.roll-modal-stage{border:3px solid var(--ink);background:var(--paper);width:min(980px,100%);min-height:min(820px,100svh - 48px);box-shadow:10px 10px 0 var(--ink);text-align:center;border-radius:10px;grid-template-rows:auto minmax(280px,1fr) auto;place-items:center;gap:18px;padding:28px;display:grid;position:relative;overflow:hidden}.modal-close{z-index:42;border:3px solid var(--ink);background:var(--paper);width:48px;height:48px;color:var(--ink);cursor:pointer;box-shadow:4px 4px 0 var(--ink);border-radius:50%;place-items:center;display:grid;position:fixed;top:24px;right:24px}.modal-title-block{z-index:2;position:relative}.modal-title-block h2{color:var(--ink);font-family:var(--display);margin:8px 0 0;font-size:clamp(2rem,5vw,4.5rem);line-height:.95}.modal-title-block p:last-child,.modal-result-block p{color:var(--muted);margin:8px 0 0}.roll-modal-stage .wheel-frame{width:min(560px,76vw,58svh)}.modal-result-block{z-index:2;align-content:center;place-items:center;gap:10px;min-height:154px;display:grid;position:relative}.modal-result-block h3{color:var(--ink);font-family:var(--display);margin:0;font-size:clamp(4rem,13vw,8.5rem);line-height:.88}.party-row{color:var(--red);justify-content:center;align-items:center;gap:18px;animation:.8s both party-pop;display:flex}.public-party{margin-top:-8px}.roll-modal-error{border:3px solid var(--ink);background:#ffd6cb;border-radius:8px;place-items:center;gap:16px;max-width:620px;padding:24px;display:grid}.confetti-field{z-index:1;pointer-events:none;position:absolute;inset:0;overflow:hidden}.confetti-field span{top:-20px;left:var(--x);border:2px solid var(--ink);background:var(--yellow);width:10px;height:18px;transform:rotate(var(--r));animation:2.2s ease-in forwards confetti-fall;animation-delay:var(--delay);position:absolute}.confetti-field span:nth-child(3n){background:var(--green)}.confetti-field span:nth-child(4n){background:var(--blue)}.confetti-field span:nth-child(5n){background:var(--red)}.owner-tools textarea{min-height:128px}.error-text{border:2px solid var(--ink);color:var(--ink);background:#ffd6cb;border-radius:6px;margin:0;padding:10px 12px;font-weight:800}.error-text.wide{width:fit-content}.state-shell{text-align:center;align-content:center;place-items:center;gap:16px;display:grid}.state-icon{color:var(--ink);background:var(--yellow)}.spin{animation:.8s linear infinite spin}@keyframes shake{0%{transform:rotate(0)translate(0)}25%{transform:rotate(8deg)translate(4px,-3px)}50%{transform:rotate(-7deg)translate(-3px,5px)}75%{transform:rotate(11deg)translate(3px,2px)}to{transform:rotate(0)translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes confetti-fall{0%{opacity:0;transform:translateY(-30px) rotate(var(--r))}12%{opacity:1}to{opacity:0;transform:translateY(100svh) rotate(calc(var(--r) + 620deg))}}@keyframes party-pop{0%{opacity:0;transform:scale(.7)}70%{opacity:1;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}@keyframes stage-celebrate{0%{background-color:var(--red)}45%{background-color:var(--yellow)}to{background-color:#0000}}@media (width<=980px){.group-shell{width:min(100% - 32px,1180px)}.hero-band,.roll-layout,.arisan-layout,.group-grid,.group-header,.link-strip,.completion-band,.period-header{grid-template-columns:1fr}.hero-orbit{display:none}.tab-switch{width:100%}.ledger-row.editable{grid-template-columns:1fr;grid-template-areas:none}.ledger-row.editable .check-line,.ledger-row.editable>input:first-of-type,.ledger-row.editable>input:nth-of-type(2),.ledger-row.editable>input:nth-of-type(3),.ledger-row.editable>.icon-button{grid-area:auto}.period-actions{justify-content:stretch}.period-actions>*{width:100%}}@media (width<=620px){.app-shell{width:min(100% - 20px,1180px);padding-top:14px}.hero-band{min-height:auto;padding:18px 0}.form-grid{grid-template-columns:1fr}.panel,.roll-stage{box-shadow:4px 4px 0 var(--ink);padding:14px}.roll-modal-backdrop{padding:12px}.roll-modal-stage{min-height:calc(100svh - 24px);padding:18px}.modal-close{top:14px;right:14px}}
