:root{--bg: #1c1c1e;--bg-elevated: #242426;--bg-secondary: #2c2c2e;--bg-tertiary: #3a3a3c;--border: #38383a;--text: #f5f5f7;--text-secondary: #a1a1a6;--text-tertiary: #8e8e93;--accent: #d4a76a;--green: #30d158;--red: #ff453a;--blue: #64d2ff;--font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-mono: "SF Mono", "Fira Code", "Menlo", monospace;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-sheet: 12px;--r-pill: 999px;--sheet-header-h: 44px;--shell-header-h: 48px;--shell-nav-h: 56px;--shell-nav-bump: 14px;--shell-chrome-min-pad: var(--sp-2);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}html,body{overflow:hidden;overscroll-behavior:none}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}input,textarea{font:inherit;font-size:16px}a{color:inherit;text-decoration:none}.shell{display:flex;flex-direction:column;height:100dvh;width:100%;background:var(--bg);color:var(--text)}.header{flex:0 0 auto;padding-top:max(var(--safe-top),var(--shell-chrome-min-pad));background:var(--bg-elevated);border-bottom:1px solid var(--border)}.header__row{height:var(--shell-header-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-4);gap:var(--sp-2)}.header__title{font-size:17px;font-weight:700;letter-spacing:-.2px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto;min-width:0}.header__actions{flex:0 0 auto;display:flex;align-items:center;gap:var(--sp-2)}.iconbtn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-secondary);border:1px solid var(--border);font-size:14px;font-weight:700;line-height:1}.iconbtn:active{background:var(--bg-tertiary)}.scope-chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:5px 10px;border-radius:var(--r-md);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:600;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scope-chip__caret{color:var(--text-tertiary);font-size:11px}.main{flex:1 1 auto;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;padding-bottom:calc(var(--shell-nav-bump) + var(--sp-2))}.tabbar{flex:0 0 auto;padding-bottom:max(var(--safe-bottom),var(--shell-chrome-min-pad));background:var(--bg-elevated);border-top:1px solid var(--border)}.tabbar__row{height:var(--shell-nav-h);display:flex;align-items:stretch}.tab{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-tertiary)}.tab__glyph{font-size:19px;line-height:1}.tab__label{font-size:10px;font-weight:600;letter-spacing:.2px}.tab.is-active .tab__glyph,.tab.is-active .tab__label{color:var(--accent)}.tab.add{position:relative}.add__btn{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:44px;height:44px;border-radius:50%;background:var(--accent);color:#1c1c1e;border:3px solid var(--bg-elevated);font-size:24px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.add__label{margin-top:auto;font-size:10px;font-weight:600;letter-spacing:.2px;color:var(--accent);padding-bottom:6px}.placeholder{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-6);gap:var(--sp-2)}.placeholder__title{font-size:22px;font-weight:700}.placeholder__sub{font-size:14px;color:var(--text-tertiary);max-width:280px;line-height:1.5}.sheet-backdrop{position:fixed;inset:0;z-index:1000;background:#00000080;opacity:0;transition:opacity .18s ease-out}.sheet-backdrop.is-open{opacity:1}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:1001;max-height:80dvh;display:flex;flex-direction:column;background:var(--bg-elevated);border-top:1px solid var(--border);border-radius:var(--r-sheet) var(--r-sheet) 0 0;transform:translateY(100%);transition:transform .22s ease-out;overscroll-behavior:contain}.sheet.is-open{transform:translateY(0)}.sheet[data-size=half]{max-height:50dvh}.sheet[data-size=full]{max-height:90dvh}.sheet__header{flex:0 0 auto;height:var(--sheet-header-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-4);border-bottom:1px solid var(--border)}.sheet__title{font-size:15px;font-weight:700;color:var(--text)}.sheet__header-right{display:flex;align-items:center;gap:var(--sp-2)}.sheet__close{width:28px;height:28px;border-radius:50%;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1}.sheet__close:active{background:var(--bg-tertiary)}.sheet__pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-sm);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--accent);font-size:12px;font-weight:700;font-family:var(--font-mono);line-height:1}.sheet__pill:active{background:#d4a76a26}.sheet__pill:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sheet__body{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--sp-2) var(--sp-3) calc(var(--safe-bottom) + var(--sp-3))}.sheet__footer{position:sticky;bottom:calc(-1 * var(--sp-3));margin:var(--sp-2) calc(-1 * var(--sp-3)) calc(-1 * (var(--safe-bottom) + var(--sp-3)));padding:var(--sp-3) var(--sp-3) calc(var(--safe-bottom) + var(--sp-3));background:var(--bg-elevated);border-top:1px solid var(--border);display:flex;gap:var(--sp-2);justify-content:flex-end}.sheet-list{display:flex;flex-direction:column;gap:2px}.sheet-row{display:flex;align-items:center;justify-content:space-between;min-height:44px;padding:0 var(--sp-3);border-radius:var(--r-md);color:var(--text);font-size:16px;font-weight:500;text-align:left}.sheet-row:active{background:var(--bg-tertiary)}.sheet-row.is-active{background:#d4a76a1f;color:var(--accent);font-weight:700}.sheet-row__check{color:var(--accent);font-size:16px}.sheet-row__sub{color:var(--text-tertiary);font-size:12px}.sheet__cta{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);width:100%;height:52px;margin-bottom:var(--sp-3);background:transparent;border:1.5px dashed rgba(212,167,106,.5);border-radius:var(--r-md);color:var(--accent);font-size:15px;font-weight:600;font-family:inherit}.sheet__cta:active{background:#d4a76a14}.sheet__cta__plus{font-size:20px;line-height:1}.set-row{display:flex;align-items:center;min-height:48px;padding:0 var(--sp-2) 0 var(--sp-3);border-radius:var(--r-md);gap:var(--sp-2)}.set-row:active{background:var(--bg-tertiary)}.set-row.is-active{background:#d4a76a1a}.set-row__name{flex:1 1 auto;min-width:0;font-size:16px;font-weight:500;color:var(--text);text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.set-row.is-active .set-row__name{color:var(--text);font-weight:600}.set-row__count{flex:0 0 auto;font-size:14px;color:var(--text-tertiary);font-variant-numeric:tabular-nums;min-width:24px;text-align:right}.set-row__actions{flex:0 0 auto;display:flex;align-items:center;gap:0}.set-row__icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-tertiary);border-radius:50%}.set-row__icon:active{background:var(--bg-tertiary);color:var(--text)}.set-row__icon:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.board-frame{flex:1 1 auto;min-height:0;min-width:0;display:flex;align-items:center;justify-content:center;padding:var(--sp-3)}.board-square{position:relative;border-radius:var(--r-sm);overflow:hidden}.promotion-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-2);padding:var(--sp-2) 0}.promotion-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;aspect-ratio:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text)}.promotion-tile:active{background:#d4a76a26;border-color:var(--accent)}.promotion-tile__glyph{font-size:40px;line-height:1;color:var(--accent)}.promotion-tile__label{font-size:11px;font-weight:600;color:var(--text-secondary);letter-spacing:.2px}:root{--sq-selected: rgba(212, 167, 106, .55);--sq-legal-dot: rgba(212, 167, 106, .45);--sq-legal-capture-ring: rgba(212, 167, 106, .55);--sq-last-move: rgba(212, 167, 106, .18)}.board-layout{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.board-layout__status{flex:0 0 auto;padding:var(--sp-3) var(--sp-3) 0;text-align:center;font-size:13px;font-weight:600;color:var(--text-secondary);letter-spacing:.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-layout__board{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.board-layout__context{flex:0 0 auto;padding:0 var(--sp-3)}.board-layout__actions{flex:0 0 auto;display:flex;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3) 0}.board-action{padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.2px}.board-action:active{background:#d4a76a26;color:var(--accent);border-color:var(--accent)}.board-action[disabled]{opacity:.4;color:var(--text-tertiary)}.board-action.is-primary{background:var(--accent);border-color:var(--accent);color:#1c1c1e}.board-action.is-primary:active{background:#d4a76ae6}.login{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(var(--safe-top),var(--sp-6)) var(--sp-6) max(var(--safe-bottom),var(--sp-6));background:var(--bg);color:var(--text)}.login__card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--sp-4)}.login__brand{text-align:center;margin-bottom:var(--sp-4)}.login__brand-mark{font-size:28px;font-weight:800;letter-spacing:-.5px;color:var(--text)}.login__brand-mark:after{content:".";color:var(--accent)}.login__brand-sub{margin-top:var(--sp-2);font-size:14px;color:var(--text-tertiary);line-height:1.4}.login__tabs{display:flex;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;gap:2px}.login__tab{flex:1;padding:8px 12px;border-radius:var(--r-sm);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600}.login__tab.is-active{background:var(--bg-tertiary);color:var(--text)}.login__field{display:flex;flex-direction:column;gap:var(--sp-1)}.login__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.login__input{height:44px;padding:0 var(--sp-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:16px;font-family:inherit;outline:none}.login__input:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px #d4a76a40}.login__submit{height:48px;background:var(--accent);border:none;border-radius:var(--r-md);color:#1c1c1e;font-size:15px;font-weight:700;letter-spacing:.2px}.login__submit:active{opacity:.85}.login__submit[disabled]{opacity:.4}.login__error{padding:var(--sp-2) var(--sp-3);background:#ff453a1a;border:1px solid rgba(255,69,58,.35);border-radius:var(--r-md);color:var(--red);font-size:13px;line-height:1.4}.login__note{text-align:center;font-size:12px;color:var(--text-tertiary);line-height:1.5;padding-top:var(--sp-2)}
