:root{--bg: #0a0e14;--card: #121826;--bg-elevated: #11161f;--border: #1e2738;--text: #e8edf2;--muted: #8b96a5;--accent: #22d3ee;--accent-dim: #0e7490;--danger: #f87171;--ok: #34d399;--warn: #fbbf24;--want: #a78bfa;--radius: 14px;--tabbar-h: 56px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}.page{max-width:640px;margin:0 auto;padding:1rem 1rem calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px) + 1.5rem)}h1{font-size:1.4rem;margin:.5rem 0 1rem}h2{font-size:1.05rem;margin:1.5rem 0 .5rem;color:var(--muted);font-weight:600}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}form{display:flex;flex-direction:column;gap:.75rem}label{display:flex;flex-direction:column;gap:.3rem;font-size:.875rem;color:var(--muted)}input,textarea{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;color:var(--text);font:inherit;padding:.6rem .75rem}input:focus,textarea:focus{outline:2px solid var(--accent-dim);outline-offset:0;border-color:var(--accent-dim)}textarea{resize:vertical;min-height:4.5rem;width:100%}button{background:var(--accent);border:none;border-radius:.5rem;color:#06262c;cursor:pointer;font:inherit;font-weight:600;padding:.65rem 1rem}button:hover{filter:brightness(1.1)}button:disabled{opacity:.5;cursor:default}button.secondary{background:transparent;border:1px solid var(--border);color:var(--muted)}.error{color:var(--danger);font-size:.875rem;margin:0}.muted{color:var(--muted);font-size:.875rem}.tiny{font-size:.7rem}a{color:var(--accent)}.row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.badge{background:var(--accent-dim);border-radius:999px;color:var(--text);font-size:.75rem;padding:.1rem .6rem;white-space:nowrap}.badge-live{background:var(--ok);color:#052e1d;font-weight:700;letter-spacing:.04em}.badge-soon{background:transparent;border:1px solid var(--border);color:var(--muted)}.c-want{color:var(--want)}.c-learning{color:var(--warn)}.c-can{color:var(--ok)}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:50;background:color-mix(in srgb,var(--card) 94%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px)}.tabbar-inner{max-width:640px;margin:0 auto;display:flex;height:var(--tabbar-h)}.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--muted);text-decoration:none;font-size:.62rem;-webkit-tap-highlight-color:transparent}.tabbar a svg{width:23px;height:23px}.tabbar a.active{color:var(--accent)}.toast-host{position:fixed;left:50%;transform:translate(-50%);bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px) + .75rem);z-index:100;display:flex;flex-direction:column;align-items:center;gap:.5rem;width:max-content;max-width:calc(100vw - 2rem);pointer-events:none}.toast{background:var(--card);border:1px solid var(--border);border-radius:999px;padding:.5rem 1.1rem;font-size:.875rem;box-shadow:0 6px 24px #00000073;animation:toast-in .18s ease-out}.toast-error{border-color:var(--danger);color:var(--danger)}.toast-celebration{border-color:var(--ok);color:var(--ok);font-weight:700;font-size:1rem;padding:.7rem 1.4rem}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#04070c99;animation:fade-in .15s ease-out}.sheet{position:fixed;left:50%;transform:translate(-50%);bottom:0;z-index:81;width:100%;max-width:640px;background:var(--card);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;padding:1rem 1.25rem calc(env(safe-area-inset-bottom,0px) + 1.25rem);animation:sheet-up .2s ease-out}.sheet-handle{width:36px;height:4px;border-radius:999px;background:var(--border);margin:0 auto .75rem}.sheet h3{margin:0 0 .4rem;font-size:1.1rem}.sheet-actions{display:flex;gap:.6rem;margin-top:1rem}.sheet-actions button{flex:1}button.voted{background:transparent;border:1px solid var(--ok);color:var(--ok);opacity:1}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-up{0%{transform:translate(-50%,24px);opacity:0}to{transform:translate(-50%);opacity:1}}.card-tap{display:block;width:100%;text-align:left;cursor:pointer;color:inherit;text-decoration:none;font-weight:400;-webkit-tap-highlight-color:transparent}button.card-tap{background:var(--card);font:inherit}.card-tap:hover{filter:none;border-top-color:#2a3650;border-right-color:#2a3650;border-bottom-color:#2a3650}.card-title{font-weight:700;margin:0 0 .15rem}.card-sub{color:var(--muted);font-size:.85rem;margin:0}.club-card{border-left:4px solid var(--accent)}.replay-card{border-color:var(--accent);box-shadow:0 0 26px #22d3ee29;background:linear-gradient(160deg,#102030 0%,var(--card) 70%)}.replay-card:hover{border-color:var(--accent)}.placeholder-card .card-title{color:var(--muted)}.catalog-top{position:sticky;top:0;z-index:20;background:var(--bg);margin:0 -1rem;padding:.5rem 1rem}.catalog-top input[type=search]{width:100%}.chip-row{display:flex;gap:.4rem;overflow-x:auto;padding:.5rem 0 0;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip-row:after{content:"";position:sticky;right:0;flex:0 0 32px;background:linear-gradient(to right,transparent,var(--bg));pointer-events:none}button.chip{display:inline-flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--border);border-radius:999px;color:var(--text);font-size:.8rem;font-weight:500;min-height:40px;padding:.28rem .8rem;white-space:nowrap;flex-shrink:0}button.chip.chip-pos{min-width:44px}button.chip.active{background:var(--accent);border-color:var(--accent);color:#06262c;font-weight:700}.result-count{color:var(--muted);font-size:.75rem;margin:.5rem 0 0}.dive-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;text-align:left;background:var(--card);border:1px solid var(--border);border-left:4px solid transparent;border-radius:var(--radius);color:inherit;font:inherit;font-weight:400;padding:.55rem .8rem;margin-bottom:.45rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.dive-row:hover{filter:none;border-top-color:#2a3650;border-right-color:#2a3650;border-bottom-color:#2a3650}.dive-row.st-want{border-left-color:var(--want)}.dive-row.st-learning{border-left-color:var(--warn)}.dive-row.st-can{border-left-color:var(--ok)}.dive-row-code{font-weight:700;font-size:1rem}.dive-row-name{color:var(--muted);font-size:.8rem}.dive-row-dd{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.dive-code-big{font-size:2.2rem;font-weight:800;letter-spacing:.02em;margin:.25rem 0 0}.anatomy{display:flex;gap:.5rem;flex-wrap:wrap}.anatomy-seg{text-align:center;min-width:3.2rem;flex:0 1 auto}.anatomy-sym{background:var(--card);border:1px solid var(--border);border-radius:10px;font-size:1.4rem;font-weight:700;padding:.35rem .6rem;margin-bottom:.25rem}.anatomy-label{color:var(--muted);font-size:.7rem;line-height:1.25}.dd-table{width:100%;border-collapse:collapse;text-align:center;font-variant-numeric:tabular-nums}.dd-table th{color:var(--muted);font-size:.75rem;font-weight:500;padding:.3rem .2rem;border-bottom:1px solid var(--border)}.dd-table td{padding:.45rem .2rem;font-weight:600}.facts{display:flex;flex-direction:column;gap:.35rem;margin:0}.facts div{display:flex;gap:.5rem;font-size:.875rem}.facts dt{color:var(--muted);flex:0 0 7.5rem}.facts dd{margin:0}.pills{display:flex;flex-wrap:wrap;gap:.45rem}button.pill{display:inline-flex;align-items:center;gap:.4rem;background:var(--card);border:1px solid var(--border);border-radius:999px;color:var(--text);font-weight:600;font-size:.85rem;min-height:44px;padding:.3rem .9rem}a.tap-link{display:inline-flex;align-items:center;min-height:44px}.segmented{display:flex;gap:.5rem;align-items:stretch}button.seg{flex:1;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--muted);font-size:.85rem;padding:.6rem .25rem}button.seg.active-want{background:var(--want);border-color:var(--want);color:#221646;font-weight:700}button.seg.active-learning{background:var(--warn);border-color:var(--warn);color:#3d2c00;font-weight:700}button.seg.active-can{background:var(--ok);border-color:var(--ok);color:#052e1d;font-weight:700}button.seg-clear{flex:0 0 auto;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);padding:.6rem .8rem}.save-indicator{color:var(--muted);font-size:.75rem;min-height:1.1rem;margin:.25rem 0 0}.stats-bar{display:flex;gap:1.25rem;align-items:baseline;flex-wrap:wrap}.stats-num{font-size:1.6rem;font-weight:800}.stats-label{color:var(--muted);font-size:.75rem}.section-count{font-weight:400;color:var(--muted)}.club-stripe{height:6px;border-radius:999px;margin:.5rem 0 .9rem}.member-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.member-row:last-child{border-bottom:none}.member-row .member-date{white-space:nowrap;flex-shrink:0}.code-input{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:1.1rem;letter-spacing:.25em;text-transform:uppercase}.join-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:1.7rem;font-weight:800;letter-spacing:.14em;margin:.1rem 0;overflow-wrap:anywhere}.invite-qr{display:flex;align-items:center;gap:.9rem;margin:.75rem 0 1rem}.qr-img{display:block;border-radius:10px;flex-shrink:0}button.danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}.decoder-row{display:flex;align-items:baseline;gap:.75rem;padding:.3rem 0;font-size:.9rem}.decoder-key{flex:0 0 2rem;text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-weight:700;padding:.1rem 0}.decoder-notes{margin:0;padding-left:1.2rem;font-size:.9rem}.decoder-notes li{margin-bottom:.5rem}.decoder-notes li:last-child{margin-bottom:0}.poster-page{padding-bottom:1.5rem}.poster-actions{display:flex;justify-content:space-between;gap:.6rem;margin-bottom:1rem}.poster-sheet{background:#fff;color:#000;aspect-ratio:210 / 297;border-radius:6px;padding:9% 7%;display:flex;flex-direction:column;align-items:center;text-align:center;overflow:hidden}.poster-club{font-size:clamp(1.5rem,7vw,2.5rem);font-weight:800;line-height:1.12;margin:0}.poster-sub{font-size:clamp(.9rem,3.4vw,1.2rem);color:#333;margin:.3rem 0 6%}.poster-qr{display:block;width:60%;max-width:340px;height:auto}.poster-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:clamp(1.6rem,8vw,2.9rem);font-weight:800;letter-spacing:.13em;margin:4% 0 0}.poster-steps{font-size:clamp(.75rem,2.8vw,1rem);color:#111;text-align:left;margin:5% 0 0;padding-left:1.4em}.poster-steps li{margin-bottom:.25em}.poster-brand{font-size:clamp(.6rem,2.2vw,.8rem);color:#444;margin:auto 0 0;padding-top:4%}@media print{@page{size:A4;margin:12mm}html{background:#fff!important;color-scheme:light}body{background:#fff!important}.tabbar,.toast-host,.poster-actions{display:none!important}.poster-page{max-width:none;margin:0;padding:0}.poster-sheet{aspect-ratio:auto;min-height:270mm;border-radius:0;padding:6mm 4mm}.poster-club{font-size:14mm}.poster-sub{font-size:7mm;margin-bottom:12mm}.poster-qr{width:110mm;max-width:none}.poster-code{font-size:17mm;margin-top:8mm}.poster-steps{font-size:5.5mm;margin-top:10mm}.poster-brand{font-size:4mm}}.version-line{text-align:center;color:var(--muted);font-size:.75rem;margin-top:2.5rem}.stub-card{text-align:center;padding:2rem 1rem}
