:root{color-scheme:dark;--cc-bg: #080c18;--cc-bg-deep: #050810;--cc-bg-card: rgba(8, 12, 28, .92);--cc-bg-panel: rgba(4, 6, 14, .7);--cc-bg-input: rgba(5, 8, 18, .8);--cc-bg-overlay: rgba(2, 4, 12, .8);--cc-bg-sheet: #0a0f22;--cc-primary: #7dd3fc;--cc-primary-fg: #050a10;--cc-secondary: #c4b5fd;--cc-success: #4ade80;--cc-danger: #f87171;--cc-amber: #fbbf24;--cc-text: #e8ecff;--cc-text-muted: #7a87b3;--cc-text-dim: #3a4465;--cc-text-panel: #4a5270;--cc-border: rgba(125, 211, 252, .18);--cc-border-muted: rgba(125, 211, 252, .09);--cc-border-strong: rgba(125, 211, 252, .3);--cc-border-dashed: rgba(255, 255, 255, .07);--cc-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--cc-font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--cc-stars: radial-gradient(1px 1px at 8% 12%, rgba(255,255,255,.85) 0%, transparent 100%), radial-gradient(1px 1px at 23% 7%, rgba(255,255,255,.65) 0%, transparent 100%), radial-gradient(1px 1px at 67% 4%, rgba(255,255,255,.75) 0%, transparent 100%), radial-gradient(.8px .8px at 91% 9%, rgba(255,255,255,.55) 0%, transparent 100%), radial-gradient(1px 1px at 45% 2%, rgba(255,255,255,.7) 0%, transparent 100%), radial-gradient(1px 1px at 78% 18%, rgba(255,255,255,.8) 0%, transparent 100%), radial-gradient(1px 1px at 32% 15%, rgba(255,255,255,.6) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 15% 25%, rgba(255,255,255,.9) 0%, transparent 100%), radial-gradient(.8px .8px at 88% 22%, rgba(255,255,255,.5) 0%, transparent 100%), radial-gradient(1px 1px at 55% 8%, rgba(255,255,255,.7) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 72% 35%, rgba(255,255,255,.85) 0%, transparent 100%), radial-gradient(1px 1px at 12% 42%, rgba(255,255,255,.55) 0%, transparent 100%), radial-gradient(1px 1px at 95% 38%, rgba(255,255,255,.75) 0%, transparent 100%), radial-gradient(.8px .8px at 38% 30%, rgba(255,255,255,.6) 0%, transparent 100%), radial-gradient(1px 1px at 61% 46%, rgba(255,255,255,.8) 0%, transparent 100%), radial-gradient(1px 1px at 5% 55%, rgba(255,255,255,.65) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 80% 50%, rgba(255,255,255,.9) 0%, transparent 100%), radial-gradient(.8px .8px at 28% 58%, rgba(255,255,255,.55) 0%, transparent 100%), radial-gradient(1px 1px at 52% 62%, rgba(255,255,255,.7) 0%, transparent 100%), radial-gradient(1px 1px at 17% 68%, rgba(255,255,255,.75) 0%, transparent 100%), radial-gradient(1px 1px at 93% 65%, rgba(255,255,255,.6) 0%, transparent 100%), radial-gradient(1px 1px at 43% 72%, rgba(255,255,255,.8) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 70% 78%, rgba(255,255,255,.85) 0%, transparent 100%), radial-gradient(.8px .8px at 25% 82%, rgba(255,255,255,.65) 0%, transparent 100%), radial-gradient(1px 1px at 87% 75%, rgba(255,255,255,.55) 0%, transparent 100%), radial-gradient(1px 1px at 60% 88%, rgba(255,255,255,.7) 0%, transparent 100%), radial-gradient(.8px .8px at 35% 92%, rgba(255,255,255,.75) 0%, transparent 100%), radial-gradient(1px 1px at 10% 85%, rgba(255,255,255,.6) 0%, transparent 100%), radial-gradient(1px 1px at 50% 95%, rgba(255,255,255,.8) 0%, transparent 100%), radial-gradient(1px 1px at 75% 90%, rgba(255,255,255,.65) 0%, transparent 100%), radial-gradient(ellipse 50% 40% at 30% 40%, rgba(125,211,252,.06) 0%, transparent 100%), radial-gradient(ellipse 45% 35% at 70% 60%, rgba(196,181,253,.05) 0%, transparent 100%)}@keyframes cc-beacon{0%,to{box-shadow:0 0 16px #7dd3fc4d,0 0 #7dd3fc00}50%{box-shadow:0 0 40px #7dd3fcb3,0 0 80px #7dd3fc33}}@keyframes cc-beacon-text{0%,to{text-shadow:0 0 24px rgba(125,211,252,.45)}50%{text-shadow:0 0 48px rgba(125,211,252,.9),0 0 80px rgba(125,211,252,.3)}}@keyframes cc-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes cc-pulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes cc-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes cc-fade-in{0%{opacity:0}to{opacity:1}}*{box-sizing:border-box}body{margin:0;background:var(--cc-bg);color:var(--cc-text);font-family:var(--cc-font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}code{font-family:var(--cc-font-mono);background:#ffffff1a;padding:.1em .35em;border-radius:4px}.tablet-screen{min-height:100vh;background-color:var(--cc-bg);background-image:var(--cc-stars);display:flex;align-items:center;justify-content:center;text-align:center;padding:40px}.tablet-screen--col{flex-direction:column}.signin-card{width:360px;background:var(--cc-bg-card);border:1px solid var(--cc-border);border-radius:14px;padding:36px 32px;box-shadow:0 24px 64px #0009}.cc-logo{text-align:center;margin-bottom:28px}.cc-logo__icon{font-size:38px;display:inline-block;animation:cc-float 4s ease-in-out infinite}.cc-logo__icon--large{font-size:52px}.cc-logo__title{font-family:var(--cc-font-mono);font-size:21px;font-weight:800;color:var(--cc-text);letter-spacing:.18em;margin-top:8px;animation:cc-beacon-text 4s ease-in-out infinite}.cc-logo__subtitle{font-size:9px;font-weight:700;letter-spacing:.32em;color:var(--cc-primary);margin-top:4px;text-transform:uppercase}.cc-field{margin-bottom:14px;text-align:left}.cc-field:last-of-type{margin-bottom:22px}.cc-label{display:block;font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--cc-primary);text-transform:uppercase;margin-bottom:6px}.cc-input{width:100%;background:var(--cc-bg-input);border:1px solid rgba(125,211,252,.22);border-radius:7px;padding:11px 14px;color:var(--cc-text);font-family:var(--cc-font-mono);font-size:14px;outline:none;transition:border-color .2s}.cc-input:focus{border-color:var(--cc-primary)}.cc-input::placeholder{color:var(--cc-text-panel)}.cc-btn{display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;font-weight:800;letter-spacing:.07em;transition:opacity .2s,transform .1s}.cc-btn:active{transform:scale(.98)}.cc-btn--primary{width:100%;background:var(--cc-primary);color:var(--cc-primary-fg);font-size:14px;border-radius:8px;padding:13px}.cc-btn--primary-large{background:var(--cc-primary);color:var(--cc-primary-fg);font-size:16px;border-radius:10px;padding:18px 52px;animation:cc-beacon 2.5s ease-in-out infinite}.cc-btn--ghost{width:100%;background:transparent;color:var(--cc-primary);border:1px solid rgba(125,211,252,.28);border-radius:8px;padding:11px;font-size:13px;font-weight:600;letter-spacing:.05em}.cc-btn--launch{width:100%;background:#7dd3fc1f;color:var(--cc-primary);border:1px solid var(--cc-border-strong);border-radius:8px;padding:15px;font-size:15px;font-weight:700;letter-spacing:.06em}.cc-btn--launch[disabled]{cursor:not-allowed;opacity:.6}.cc-btn--launch:not([disabled]){animation:cc-beacon 2.5s ease-in-out infinite}.cc-btn[disabled]{cursor:not-allowed;opacity:.5}.cc-divider{display:flex;align-items:center;gap:10px;margin:16px 0}.cc-divider__line{flex:1;height:1px;background:#7dd3fc1a}.cc-divider__text{font-size:11px;color:var(--cc-text-dim)}.cc-error{color:var(--cc-danger);font-size:13px;margin:8px 0}.host-description{color:var(--cc-text-muted);font-size:15px;line-height:1.7;max-width:420px;margin-bottom:40px}.host-section-label{font-family:var(--cc-font-mono);font-size:10px;font-weight:700;letter-spacing:.32em;color:var(--cc-primary);text-transform:uppercase;margin-bottom:8px}.host-title{font-size:30px;font-weight:800;color:var(--cc-text);margin:0 0 12px;text-shadow:0 0 30px rgba(125,211,252,.35)}.cc-crew-req{margin-top:22px;display:flex;align-items:center;gap:8px;justify-content:center}.cc-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cc-dot--green{background:var(--cc-success);box-shadow:0 0 6px #4ade80b3;animation:cc-pulse 2s ease-in-out infinite}.cc-dot--primary{background:var(--cc-primary);box-shadow:0 0 8px #7dd3fcb3}.cc-dot--secondary{background:var(--cc-secondary);box-shadow:0 0 8px #c4b5fd99}.cc-dot--empty{width:10px;height:10px;border:1px dashed rgba(255,255,255,.18)}.cc-crew-req__text{font-family:var(--cc-font-mono);font-size:10px;color:var(--cc-text-dim);letter-spacing:.12em}.lobby{min-height:100vh;background-color:var(--cc-bg);background-image:var(--cc-stars);display:grid;grid-template-columns:1fr 1.15fr;overflow:hidden}.lobby__code-panel{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:52px;border-right:1px solid var(--cc-border-muted)}.lobby__code-label{font-family:var(--cc-font-mono);font-size:10px;font-weight:700;letter-spacing:.34em;color:var(--cc-primary);text-transform:uppercase;margin-bottom:18px}.lobby__code{font-family:var(--cc-font-mono);font-size:clamp(40px,8vw,78px);font-weight:900;color:var(--cc-text);letter-spacing:.28em;padding-left:.28em;animation:cc-beacon-text 3s ease-in-out infinite;line-height:1;margin:0}.lobby__code-hint{color:var(--cc-text-dim);font-size:12px;margin:18px 0 28px;text-align:center;line-height:1.8}.lobby__qr{background:var(--cc-bg-input);border:1px solid var(--cc-border);border-radius:10px;padding:14px;margin-bottom:18px}.lobby__share-link{display:flex;align-items:center;gap:10px;background:var(--cc-bg-input);border:1px solid var(--cc-border);border-radius:8px;padding:9px 14px;max-width:360px;width:100%}.lobby__share-url{flex:1;font-family:var(--cc-font-mono);font-size:11px;color:var(--cc-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby__share-copy{background:none;border:1px solid var(--cc-border);border-radius:6px;color:var(--cc-primary);font-family:var(--cc-font-mono);font-size:10px;font-weight:700;letter-spacing:.06em;padding:4px 10px;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.lobby__share-copy:hover{background:#7dd3fc14;border-color:var(--cc-border-strong)}.lobby__share-copy--copied{color:var(--cc-success);border-color:#4ade804d}.lobby__crew-panel{display:flex;flex-direction:column;padding:44px}.lobby__crew-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.lobby__crew-title{font-family:var(--cc-font-mono);font-size:10px;font-weight:700;letter-spacing:.28em;color:var(--cc-primary);text-transform:uppercase}.lobby__crew-count{font-family:var(--cc-font-mono);font-size:10px;color:var(--cc-text-dim);background:#7dd3fc12;border:1px solid rgba(125,211,252,.14);border-radius:20px;padding:3px 12px}.lobby__crew-list{list-style:none;padding:0;margin:0;flex:1;display:flex;flex-direction:column;gap:8px}.lobby__crew-member{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:8px}.lobby__crew-member--filled{background:#7dd3fc0d;border:1px solid var(--cc-border)}.lobby__crew-member--empty{border:1px dashed var(--cc-border-dashed)}.lobby__crew-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.lobby__crew-name{flex:1;color:var(--cc-text);font-size:14px;font-weight:600}.lobby__crew-empty-text{color:var(--cc-text-dim);font-size:13px}.lobby__host-badge{font-family:var(--cc-font-mono);font-size:9px;color:var(--cc-primary);background:#7dd3fc1a;border:1px solid rgba(125,211,252,.22);border-radius:4px;padding:2px 8px;letter-spacing:.1em}.lobby__cta{margin-top:28px}.lobby__cta-hint{text-align:center;font-size:11px;color:var(--cc-text-dim);letter-spacing:.08em;margin-top:10px}.game-header{display:flex;align-items:center;gap:16px;padding:14px 28px;background:#04060ef2;border-bottom:1px solid var(--cc-border-muted);flex-shrink:0}.game-header__brand{font-family:var(--cc-font-mono);font-size:14px;font-weight:700;color:var(--cc-text);letter-spacing:.12em}.game-header__divider{width:1px;height:16px;background:#ffffff14}.game-header__turn{font-size:12px;color:var(--cc-text-panel);letter-spacing:.06em}.game-header__spacer{flex:1}.game-header__active{display:flex;align-items:center;gap:9px;background:#4ade8012;border:1px solid rgba(74,222,128,.25);border-radius:6px;padding:6px 16px}.game-header__active-dot{width:7px;height:7px;background:var(--cc-success);border-radius:50%;box-shadow:0 0 8px #4ade80cc;animation:cc-pulse 1.5s ease-in-out infinite}.game-header__active-name{font-size:12px;font-weight:700;letter-spacing:.09em;font-family:var(--cc-font-mono)}.game-shell{min-height:100vh;background-color:var(--cc-bg);display:flex;flex-direction:column}.game-content{flex:1;display:flex;overflow:hidden}.game-board-area{flex:2;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.game-board-area:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 42% 48%,rgba(125,211,252,.04) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 68% 32%,rgba(196,181,253,.03) 0%,transparent 55%);pointer-events:none}.board-svg{width:min(620px,100%);height:min(620px,100%);max-width:100%;max-height:100%;position:relative;z-index:1}.board-label{font-size:3px;fill:#a0b4d8;font-family:var(--cc-font-mono)}.board-label--dim{font-size:2.6px;fill:#5a6890}.board-legend{font-size:2.2px;fill:var(--cc-text-dim);font-family:var(--cc-font-mono)}.status-panel{width:320px;flex-shrink:0;background:var(--cc-bg-panel);border-left:1px solid var(--cc-border-muted);padding:24px 22px;overflow-y:auto;display:flex;flex-direction:column;gap:28px}.status-panel__section-title{font-family:var(--cc-font-mono);font-size:9px;font-weight:700;letter-spacing:.3em;color:var(--cc-primary);text-transform:uppercase;margin:0 0 14px}.status-panel__section-title--dim{color:var(--cc-text-dim)}.status-panel__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}.status-panel__row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;transition:background-color .3s ease}.status-panel__row.is-flashing{background-color:#7dd3fc1f}.status-panel__rank{font-family:var(--cc-font-mono);font-size:9px;color:var(--cc-text-dim);width:12px}.status-panel__swatch{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-panel__name{flex:1;color:var(--cc-text);font-size:13px;font-weight:600}.status-panel__score{font-family:var(--cc-font-mono);font-size:12px;font-weight:700}.status-panel__score-label{font-size:10px;color:var(--cc-text-dim)}.market-table{background:#05081299;border:1px solid var(--cc-border-muted);border-radius:8px;overflow:hidden}.market-row{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid rgba(125,211,252,.06)}.market-row:last-child{border-bottom:none}.market-row__icon{font-size:15px;margin-right:10px}.market-row__name{flex:1;color:var(--cc-text);font-size:13px}.market-row__price{font-family:var(--cc-font-mono);color:var(--cc-amber);font-size:13px;font-weight:600}.alignment-placeholder{padding:14px;background:#7dd3fc05;border:1px dashed rgba(125,211,252,.07);border-radius:6px;text-align:center;font-size:11px;color:var(--cc-text-dim)}.status-panel__endgame .is-winner{font-weight:700;color:var(--cc-primary)}.phone-screen{font-family:var(--cc-font-sans);min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background-color:var(--cc-bg);background-image:var(--cc-stars);color:var(--cc-text);position:relative;overflow:hidden}.phone-screen--centered{align-items:center;justify-content:center;text-align:center;padding:2rem 1.25rem}.phone-turn-banner{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background:var(--cc-bg-panel);border-bottom:1px solid var(--cc-border-muted);flex-shrink:0}.phone-turn-banner__status{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.phone-turn-banner__dot{width:8px;height:8px;border-radius:50%;animation:cc-pulse 1.8s ease-in-out infinite}.phone-turn-banner__dot--active{background:var(--cc-success);box-shadow:0 0 8px var(--cc-success)}.phone-turn-banner__dot--waiting{background:var(--cc-text-muted)}.phone-turn-banner__fuel{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--cc-amber);font-weight:600;font-family:var(--cc-font-mono)}.phone-content{flex:1;overflow-y:auto;padding:1rem;-webkit-overflow-scrolling:touch}.phone-tab-bar{display:flex;border-top:1px solid var(--cc-border-muted);background:var(--cc-bg-deep);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0px)}.phone-tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.55rem 0;border:none;background:transparent;color:var(--cc-text-muted);font-size:.7rem;font-weight:500;cursor:pointer;border-top:2px solid transparent;transition:color .2s,border-color .2s;font-family:var(--cc-font-sans)}.phone-tab-btn__icon{font-size:1.25rem;line-height:1}.phone-tab-btn--active{color:var(--cc-primary);border-top-color:var(--cc-primary)}.phone-tab-panel{animation:cc-fade-in .2s ease-out}.phone-section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cc-text-muted);margin:0 0 .75rem;font-weight:600}.phone-fuel-card{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:var(--cc-bg-card);border:1px solid var(--cc-border);border-radius:12px;margin-bottom:1.25rem}.phone-fuel-card__icon{font-size:1.5rem;flex-shrink:0}.phone-fuel-card__bar-container{flex:1;display:flex;flex-direction:column;gap:.3rem}.phone-fuel-card__label{font-size:.75rem;color:var(--cc-text-muted);text-transform:uppercase;letter-spacing:.05em}.phone-fuel-card__bar{height:6px;border-radius:3px;background:var(--cc-text-dim);overflow:hidden}.phone-fuel-card__bar-fill{height:100%;border-radius:3px;background:var(--cc-amber);transition:width .4s ease}.phone-fuel-card__amount{font-size:1.5rem;font-weight:700;color:var(--cc-amber);font-family:var(--cc-font-mono);flex-shrink:0;min-width:2.5rem;text-align:right}.phone-mineral-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.phone-mineral-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.85rem .5rem;background:var(--cc-bg-card);border:1px solid var(--cc-border);border-radius:12px;transition:opacity .2s}.phone-mineral-card--empty{opacity:.5}.phone-mineral-card__icon{font-size:1.5rem}.phone-mineral-card__name{font-size:.75rem;color:var(--cc-text-muted);text-transform:capitalize}.phone-mineral-card__count{font-size:1.25rem;font-weight:700;font-family:var(--cc-font-mono)}.phone-hand-empty{text-align:center;padding:2rem 1rem;color:var(--cc-text-muted);font-size:.9rem}.phone-dest-card{position:relative;display:flex;flex-direction:column;gap:.35rem;padding:.85rem 1rem;margin-bottom:.65rem;border-radius:12px;background:var(--cc-bg-card);border:1px solid var(--cc-border)}.phone-dest-card__name{font-weight:700;font-size:1rem}.phone-dest-card__badge{position:absolute;top:.65rem;right:.75rem;background:var(--cc-primary);color:var(--cc-primary-fg);font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;font-family:var(--cc-font-mono)}.phone-dest-card__route{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;margin-top:.2rem}.phone-dest-card__waypoint{width:8px;height:8px;border-radius:50%;background:var(--cc-secondary);flex-shrink:0}.phone-dest-card__line{width:24px;height:2px;background:var(--cc-border-strong);flex-shrink:0}.phone-dest-card__route-text{color:var(--cc-text-muted);font-size:.85rem;margin-left:.5rem}.phone-action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.phone-action-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem .5rem;border-radius:12px;border:1px solid var(--cc-border);background:var(--cc-bg-card);color:var(--cc-text);cursor:pointer;transition:border-color .2s,background .2s;font-family:var(--cc-font-sans)}.phone-action-card:hover:not(:disabled){border-color:var(--cc-border-strong);background:#7dd3fc0d}.phone-action-card:disabled{opacity:.45;cursor:not-allowed}.phone-action-card__icon{font-size:1.5rem;line-height:1}.phone-action-card__title{font-weight:600;font-size:.85rem;line-height:1.2;text-align:center}.phone-action-card__sub{font-size:.7rem;color:var(--cc-text-muted);text-align:center}.phone-end-turn{margin-top:1rem;width:100%;padding:.85rem 1rem;border-radius:12px;border:1px solid rgba(248,113,113,.35);background:#f871711f;color:var(--cc-danger);font-weight:700;font-size:1rem;cursor:pointer;transition:background .2s;font-family:var(--cc-font-sans)}.phone-end-turn:hover:not(:disabled){background:#f8717138}.phone-end-turn:disabled{opacity:.4;cursor:not-allowed}.phone-hint{color:var(--cc-text-muted);font-size:.9rem}.phone-error{color:var(--cc-danger);font-size:.85rem}.phone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:var(--cc-bg-overlay);display:flex;flex-direction:column;justify-content:flex-end;animation:cc-fade-in .2s ease-out}.phone-sheet{background:var(--cc-bg-sheet);border-top:1px solid var(--cc-border);border-radius:20px 20px 0 0;padding:.75rem 1.25rem 1.5rem;max-height:85vh;overflow-y:auto;animation:cc-slide-up .3s ease-out}.phone-sheet__handle{width:36px;height:4px;border-radius:2px;background:var(--cc-text-dim);margin:0 auto 1rem}.phone-sheet__title{font-size:1.1rem;font-weight:700;margin:0 0 1rem}.phone-sheet select,.phone-sheet input[type=number]{width:100%;padding:.7rem .85rem;border-radius:10px;border:1px solid var(--cc-border);background:var(--cc-bg-input);color:var(--cc-text);font-size:.95rem;font-family:var(--cc-font-sans);margin-bottom:.75rem;-moz-appearance:none;appearance:none;-webkit-appearance:none}.phone-sheet select:focus,.phone-sheet input[type=number]:focus{outline:none;border-color:var(--cc-primary)}.phone-sheet__preview{display:flex;align-items:center;justify-content:center;padding:.65rem 1rem;border-radius:10px;background:#7dd3fc14;border:1px solid var(--cc-border-muted);color:var(--cc-primary);font-weight:600;font-size:.9rem;margin-bottom:.75rem;font-family:var(--cc-font-mono)}.phone-sheet__buttons{display:flex;gap:.6rem}.phone-sheet__btn-cancel{flex:1;padding:.8rem;border-radius:12px;border:1px solid var(--cc-border);background:var(--cc-bg-card);color:var(--cc-text);font-weight:600;font-size:.95rem;cursor:pointer;font-family:var(--cc-font-sans)}.phone-sheet__btn-confirm{flex:1;padding:.8rem;border-radius:12px;border:none;background:var(--cc-primary);color:var(--cc-primary-fg);font-weight:700;font-size:.95rem;cursor:pointer;font-family:var(--cc-font-sans)}.phone-sheet__btn-confirm:disabled{opacity:.4;cursor:not-allowed}.phone-sheet__btn-back{width:100%;padding:.8rem;border-radius:12px;border:1px solid var(--cc-border);background:var(--cc-bg-card);color:var(--cc-text);font-weight:600;font-size:.95rem;cursor:pointer;font-family:var(--cc-font-sans)}.phone-join-logo{font-size:3.5rem;animation:cc-float 3s ease-in-out infinite;margin-bottom:.5rem}.phone-join-title{font-size:1.5rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;margin:0 0 .25rem;animation:cc-beacon-text 4s ease-in-out infinite;font-family:var(--cc-font-mono)}.phone-join-subtitle{color:var(--cc-text-muted);font-size:.9rem;margin:0 0 1.75rem}.phone-join-code-display{display:flex;gap:.4rem;justify-content:center;margin-bottom:1.25rem}.phone-join-cell{width:2.8rem;height:3.4rem;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1.5px solid var(--cc-border);background:var(--cc-bg-input);font-size:1.3rem;font-weight:700;font-family:var(--cc-font-mono);text-transform:uppercase;color:var(--cc-text)}.phone-join-cell--cursor{border-color:var(--cc-primary);box-shadow:0 0 12px #7dd3fc40;animation:cc-beacon 2s ease-in-out infinite}.phone-join-cell--filled{border-color:var(--cc-primary);color:var(--cc-primary)}.phone-join-hidden-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.phone-join-submit{width:100%;max-width:280px;padding:.85rem 1.5rem;border-radius:12px;border:none;background:var(--cc-primary);color:var(--cc-primary-fg);font-weight:700;font-size:1.05rem;cursor:pointer;transition:opacity .2s;font-family:var(--cc-font-sans)}.phone-join-submit:disabled{opacity:.4;cursor:not-allowed}.phone-join-scan{margin-top:1rem;color:var(--cc-text-muted);font-size:.85rem;background:none;border:none;cursor:pointer;font-family:var(--cc-font-sans)}.phone-join-scan:hover{color:var(--cc-primary)}.phone-home-bar{position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:134px;height:5px;border-radius:3px;background:var(--cc-text-dim)}.phone-waiting-hint{color:var(--cc-text-muted);font-size:.9rem;animation:cc-pulse 2s ease-in-out infinite}
