:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--ink: #17202a;--muted: #52606f;--panel: rgba(250, 252, 252, .9);--panel-strong: rgba(255, 255, 255, .96);--line: rgba(24, 34, 44, .14);--green: #327a5f;--red: #d94b5f;--yellow: #f0b441;--blue: #276fbf;--shadow: 0 18px 46px rgba(20, 34, 44, .18)}*{box-sizing:border-box}html,body{width:100%;height:100%;margin:0;overflow:hidden;background:#9fd7ee;color:var(--ink)}body{min-width:320px}.webgl{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw!important;height:100dvh!important;display:block;outline:none;touch-action:none;-webkit-user-select:none;user-select:none}#ui{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100dvh;z-index:2;pointer-events:none}#ui button,#ui input,#ui a{pointer-events:auto}button,.button-link{min-height:44px;border:1px solid var(--line);border-radius:8px;padding:0 16px;background:var(--panel-strong);color:var(--ink);font:inherit;font-weight:750;letter-spacing:0;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .16s ease,border-color .16s ease,background .16s ease}button:hover,.button-link:hover{transform:translateY(-1px);border-color:#17202a47}button:disabled{cursor:not-allowed;opacity:.48;transform:none}.primary-button{background:var(--red);border-color:#62121e2e;color:#fff}.ghost-button,.icon-button{background:#ffffffad}input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:#ffffffe0;color:var(--ink);font:inherit;letter-spacing:0}label{display:grid;gap:6px}label span,.eyebrow,dt{color:var(--muted);font-size:.73rem;font-weight:850;letter-spacing:.08em;text-transform:uppercase}h1,h2,h3,p{margin:0}h1{max-width:760px;font-size:clamp(2.35rem,6vw,5.8rem);line-height:.95;letter-spacing:0}h2{font-size:clamp(1.15rem,2.4vw,1.75rem);line-height:1.05;letter-spacing:0}h3{font-size:1.08rem;line-height:1.14;letter-spacing:0}.home-panel,.modal-layer,.gallery-panel,.result-panel{pointer-events:auto}.home-panel{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;align-content:center;gap:30px;padding:clamp(18px,5vw,64px);max-width:980px}.brand-stack{display:grid;gap:14px}.lede{max-width:620px;color:#263544;font-size:clamp(1rem,2vw,1.24rem);line-height:1.5}.role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,260px));gap:14px}.role-card{min-height:150px;padding:18px;align-items:flex-start;justify-content:space-between;flex-direction:column;text-align:left;background:#ffffffe6}.role-card span{font-size:1.5rem}.role-card small{max-width:210px;color:var(--muted);font-weight:650;line-height:1.35}.destroyer-card{background:#fff6daeb}.leaderboard-card{background:#eef9f4eb}.storage-note{width:fit-content;max-width:min(620px,calc(100vw - 36px));border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#ffffffbd;color:var(--muted);font-weight:750}.game-shell{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.top-bar{position:absolute;top:18px;left:18px;right:18px;min-height:64px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;border:1px solid var(--line);border-radius:8px;padding:10px;background:#ffffffd1;box-shadow:var(--shadow);pointer-events:auto}.top-bar.unframed{position:static;box-shadow:none}.top-bar h2{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-topbar{position:absolute;top:18px;left:18px;min-height:62px;width:min(430px,calc(100vw - 36px));display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;border:1px solid rgba(255,255,255,.42);border-radius:8px;padding:9px;background:#141b21b8;color:#fff;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto}.builder-topbar .eyebrow{color:#ffffffa8}.builder-topbar h2{color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-profile-popover{position:absolute;top:18px;right:18px;width:min(310px,calc(100vw - 36px));display:grid;gap:8px;pointer-events:auto}.profile-toggle{justify-content:space-between;width:100%;background:#ffffffe6;box-shadow:0 12px 30px #14222c24}.profile-toggle b{min-height:26px;border-radius:999px;padding:4px 9px;background:#17202a14;color:var(--muted);font-size:.78rem}.profile-fields{display:none;gap:10px;border:1px solid var(--line);border-radius:8px;padding:12px;background:#fffffff0;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.builder-profile-popover.is-open .profile-fields{display:grid}.builder-hotbar{position:absolute;left:50%;bottom:16px;width:min(1120px,calc(100vw - 32px));transform:translate(-50%);display:grid;grid-template-columns:170px minmax(420px,1fr) 260px;grid-template-areas:"budget bank actions" "bombs bank actions";gap:10px;border:2px solid rgba(255,255,255,.22);border-radius:8px;padding:10px;background:linear-gradient(180deg,#191e23d1,#0b0e11c7);box-shadow:0 20px 44px #0c141a57;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto}.budget-hud{grid-area:budget;min-width:0;display:grid;grid-template-columns:auto 1fr;align-content:center;gap:4px 8px;border:1px solid rgba(255,255,255,.16);border-radius:8px;padding:10px;background:#ffffff1a;color:#fff}.budget-hud strong{font-size:1.35rem}.budget-hud span{align-self:center;color:#ffffffb3;font-size:.74rem;font-weight:850;text-transform:uppercase}.budget-hud .meter{grid-column:1 / -1;background:#ffffff2e}.budget-hud em{grid-column:1 / -1;color:#ffffffb8;font-size:.72rem;font-style:normal;font-weight:800;line-height:1.25}.budget-hud em.ok{color:#bce8cd}.hotbar-bank{grid-area:bank;display:grid;gap:8px;min-width:0}.hotbar-slots{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.hotbar-slot{position:relative;min-width:0;min-height:76px;display:grid;grid-template-columns:34px minmax(0,1fr) auto;grid-template-rows:auto auto;align-content:center;gap:2px 8px;border:2px solid rgba(255,255,255,.18);border-radius:6px;padding:8px;background:#f7f8f0e0;text-align:left}.hotbar-slot:hover{transform:translateY(-2px)}.hotbar-slot.is-selected{border-color:#f4d96b;background:#fffef3;box-shadow:inset 0 0 0 2px #17202a29,0 0 0 2px #f4d96b61}.slot-swatch,.hotbar-slot .shape-preview{grid-row:1 / span 2;grid-column:1}.slot-swatch{width:30px;height:30px;align-self:center;border:2px solid rgba(23,32,42,.46);border-radius:4px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent),#17202a 28%));box-shadow:inset 0 2px #fff6}.hotbar-slot span:not(.slot-swatch):not(.shape-preview){min-width:0;overflow:hidden;color:var(--ink);font-size:.88rem;font-weight:900;line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.hotbar-slot small{min-width:0;overflow:hidden;color:var(--muted);font-size:.68rem;font-weight:850;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.hotbar-slot b{grid-row:1 / span 2;grid-column:3;min-width:28px;min-height:28px;display:grid;place-items:center;border-radius:50%;background:#17202a14;color:var(--ink);font-size:.9rem}.shape-slot{grid-template-columns:42px minmax(0,1fr)}.shape-slot .shape-preview{width:34px;min-height:34px;align-items:center;justify-content:center}.shape-slot .shape-preview:before{width:min(34px,calc(var(--shape-w) * 6px));height:max(5px,min(30px,calc(var(--shape-h) * 10px)));background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent),#17202a 32%))}.shape-slot.material-stone .shape-preview:before{background:linear-gradient(135deg,rgba(255,255,255,.28),transparent 46%),linear-gradient(90deg,rgba(55,62,72,.22) 0 18%,transparent 18% 48%,rgba(55,62,72,.18) 48% 54%,transparent 54%),linear-gradient(135deg,#c5cdd6,#7f8893)}.shape-slot.material-wood .shape-preview:before{background:linear-gradient(0deg,transparent 42%,rgba(95,48,19,.28) 43% 48%,transparent 49%),linear-gradient(135deg,#f1bc76,#9b5d2c)}.shape-slot.material-glass .shape-preview:before{background:linear-gradient(135deg,rgba(255,255,255,.65) 0 18%,transparent 19% 48%,rgba(255,255,255,.36) 49% 58%,transparent 59%),linear-gradient(135deg,#b9f2ffeb,#3f9fb4a8);box-shadow:inset 0 1px #ffffffbf,0 0 10px #7ed8ee3d}.builder-actions{grid-area:actions;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.builder-actions button{min-width:0;min-height:42px;padding:0 10px}.builder-actions .primary-button{grid-column:1 / -1}.builder-bombs{grid-area:bombs;display:flex;flex-wrap:wrap;align-content:start;gap:6px}.builder-bombs .bomb-pill{min-height:25px;padding:0 8px;background:#ffffffe0;font-size:.68rem}.builder-shell .toast{bottom:174px}.hud{position:absolute;top:100px;z-index:3;width:280px;display:grid;gap:12px;border:1px solid var(--line);border-radius:8px;padding:14px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto}.left-hud{left:18px}.right-hud{right:18px}.builder-shell .right-hud{right:auto;left:318px;top:100px;max-height:calc(100vh - 118px);overflow:auto}.hud.compact{width:248px}.budget-row{display:flex;align-items:baseline;justify-content:space-between}.budget-row strong{font-size:1.55rem}.budget-row span,.mini-status{color:var(--muted);font-size:.88rem;font-weight:700;line-height:1.35}.mini-status.ok{color:var(--green)}.meter{height:10px;overflow:hidden;border-radius:999px;background:#17202a1f}.meter span{display:block;height:100%;border-radius:inherit;background:var(--green)}.palette,.shape-grid,.bomb-select{display:grid;gap:8px}.shape-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.material-card,.shape-card,.bomb-button{min-height:74px;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto auto;align-items:center;padding:10px 12px;border-left:6px solid var(--accent);text-align:left}.material-card span,.shape-card span,.bomb-button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-card small,.shape-card small{color:var(--muted);font-weight:700}.shape-card{--accent: var(--blue);min-height:84px;grid-template-columns:1fr;grid-template-rows:34px auto auto;justify-items:start;padding:10px}.shape-preview{width:100%;min-height:30px;display:flex;align-items:center;overflow:visible}.shape-preview:before{content:"";width:calc(var(--shape-w) * 7px);height:max(5px,calc(var(--shape-h) * 7px));border:2px solid rgba(23,32,42,.58);border-radius:4px;background:linear-gradient(135deg,#f0b441f2,#d94b5fb8);box-shadow:inset 0 1px #ffffff80}.shape-card span:not(.shape-preview){white-space:normal;line-height:1.05;overflow:visible;font-size:.8rem}.material-card em{display:flex;flex-wrap:wrap;gap:6px;color:var(--muted);font-size:.72rem;font-style:normal;font-weight:800}.material-card em span{min-height:22px;display:inline-flex;align-items:center;border-radius:999px;padding:0 8px;background:#17202a12}.material-card b,.bomb-button b{grid-row:1 / span 3;grid-column:2;min-width:34px;min-height:34px;display:grid;place-items:center;border-radius:50%;background:#17202a14}.launcher-drag-zone{position:absolute;left:0;bottom:0;z-index:1;width:min(44vw,390px);height:min(58vh,460px);cursor:grab;pointer-events:auto;touch-action:none}.launcher-drag-zone:active{cursor:grabbing}.is-selected{border-color:var(--ink);background:#fff}.bomb-preview{display:flex;flex-wrap:wrap;gap:8px}.bomb-pill{display:inline-flex;align-items:center;gap:6px;min-height:30px;border-radius:999px;padding:0 10px;background:#ffffffbd;border:1px solid color-mix(in srgb,var(--accent),#17202a 15%);color:var(--ink);font-size:.78rem;font-weight:800}.tool-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.tool-row button{min-width:0;padding:0 10px}.stat-list,.card-stats{display:grid;gap:8px;margin:0}.stat-list div,.card-stats div{display:flex;align-items:baseline;justify-content:space-between;gap:12px}dd{margin:0;font-weight:850}.toast{position:absolute;left:50%;bottom:18px;transform:translate(-50%);width:fit-content;max-width:calc(100vw - 36px);border:1px solid var(--line);border-radius:8px;padding:11px 14px;background:#ffffffeb;box-shadow:var(--shadow);color:var(--ink);font-weight:800;pointer-events:auto}.toast.inline{position:static;transform:none}.gallery-panel{min-height:100%;overflow:auto;padding:18px;display:grid;align-content:start;gap:16px;background:linear-gradient(180deg,#9fd7eedb,#5f8f555c)}.filter-row{display:flex;flex-wrap:wrap;gap:8px}.filter-row button{text-transform:capitalize}.build-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;max-width:1120px}.build-card{min-height:220px;display:grid;gap:16px;align-content:space-between;border:1px solid var(--line);border-radius:8px;padding:16px;background:var(--panel-strong);box-shadow:0 12px 28px #14222c21}.build-card p{margin-top:6px;color:var(--muted);font-weight:700}.leaderboard-panel{gap:18px}.leaderboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;max-width:1180px}.leaderboard-board{display:grid;align-content:start;gap:12px;border:1px solid var(--line);border-radius:8px;padding:16px;background:var(--panel-strong);box-shadow:0 12px 28px #14222c21}.leaderboard-heading{display:grid;gap:3px}.leader-list{display:grid;gap:8px}.leader-row{display:grid;grid-template-columns:30px 46px minmax(0,1fr) minmax(180px,auto);align-items:center;gap:10px;min-height:68px;border:1px solid rgba(24,34,44,.1);border-radius:8px;padding:10px;background:#f7fafac7}.leader-rank{color:var(--muted);font-size:.95rem}.leader-avatar{width:46px;height:46px;display:grid;place-items:center;overflow:hidden;border:2px solid rgba(255,255,255,.9);border-radius:50%;background:#17202a;box-shadow:0 6px 14px #14222c29;color:#fff;font-size:.88rem;font-weight:900}.leader-avatar img{width:100%;height:100%;object-fit:cover}.leader-avatar.fallback{background:linear-gradient(135deg,var(--blue),var(--green))}.leader-name{min-width:0;display:grid;gap:3px}.leader-name strong{overflow:hidden;font-size:.98rem;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.leader-name span,.leader-empty{color:var(--muted);font-size:.82rem;font-weight:750}.leader-stats{display:grid;grid-template-columns:repeat(3,minmax(54px,1fr));gap:6px;margin:0}.leader-stats div{display:grid;gap:2px;min-width:0;border-radius:6px;padding:6px 8px;background:#17202a0f}.leader-stats dt{font-size:.62rem}.leader-stats dd{font-size:1rem}.leader-empty{border:1px dashed rgba(24,34,44,.18);border-radius:8px;padding:16px}.modal-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;background:#17202a2e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.result-panel{position:absolute;left:50%;top:50%;width:min(620px,calc(100vw - 36px));max-height:calc(100dvh - 36px);overflow:auto;transform:translate(-50%,-50%);display:grid;gap:16px;border:1px solid var(--line);border-radius:8px;padding:clamp(18px,4vw,28px);background:var(--panel-strong);box-shadow:var(--shadow)}.modal-layer .result-panel{position:static;transform:none}.publish-panel{width:min(700px,calc(100vw - 36px))}.result-panel h1{font-size:clamp(2rem,5vw,4.2rem)}.result-panel p{color:var(--muted);font-weight:750}.result-actions{display:flex;flex-wrap:wrap;gap:10px}.identity-form{display:grid;gap:12px}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.recap-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:0}.recap-grid div{min-width:0;border:1px solid rgba(24,34,44,.1);border-radius:8px;padding:10px;background:#f7fafad1}.recap-grid dd{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-input{font-size:.92rem}@media(max-width:700px){.home-panel{align-content:end;padding-bottom:24px}.role-grid{grid-template-columns:1fr;max-width:420px}.top-bar{top:10px;left:10px;right:10px;grid-template-columns:auto minmax(0,1fr)}.top-bar .primary-button,.top-bar .ghost-button{grid-column:1 / -1;width:100%}.hud{top:auto;bottom:10px;width:calc(50vw - 15px);max-height:42vh;overflow:auto;padding:10px}.left-hud{left:10px}.right-hud{right:10px}.builder-shell .right-hud{top:auto;left:auto;right:10px;max-height:42vh}.hud.compact{width:calc(50vw - 15px)}.tool-row,.leaderboard-grid{grid-template-columns:1fr}.leader-row{grid-template-columns:28px 42px minmax(0,1fr)}.leader-stats{grid-column:1 / -1}.material-card,.shape-card,.bomb-button{min-height:52px}.toast{bottom:calc(42vh + 20px)}.builder-topbar{top:10px;left:10px;width:calc(100vw - 20px)}.builder-profile-popover{top:82px;right:10px;width:min(300px,calc(100vw - 20px))}.builder-hotbar{bottom:10px;width:calc(100vw - 20px);grid-template-columns:1fr;grid-template-areas:"budget" "bank" "actions" "bombs";max-height:46vh;overflow:auto}.hotbar-slot{min-height:64px;padding:7px}.builder-actions{grid-template-columns:repeat(5,minmax(0,1fr))}.builder-actions .primary-button{grid-column:auto}.builder-shell .toast{bottom:calc(46vh + 20px)}}@media(max-width:500px){.hud,.hud.compact{width:calc(100vw - 20px);max-height:27vh}.left-hud{bottom:calc(27vh + 18px)}.right-hud{bottom:10px}.palette,.shape-grid,.bomb-select{grid-template-columns:repeat(3,minmax(0,1fr))}.material-card,.shape-card,.bomb-button{min-height:72px;grid-template-columns:1fr;grid-template-rows:auto auto auto;justify-items:start;align-content:center}.material-card b,.bomb-button b{grid-row:auto;grid-column:auto;min-width:28px;min-height:28px}.home-panel{gap:18px}.lede,.role-card small{font-size:.95rem}.result-actions{display:grid;grid-template-columns:1fr}.field-grid,.recap-grid{grid-template-columns:1fr}.builder-profile-popover{width:calc(100vw - 20px)}.hotbar-slots{grid-template-columns:repeat(3,minmax(0,1fr))}.hotbar-slot{min-height:68px;grid-template-columns:1fr;grid-template-rows:28px auto auto;justify-items:center;text-align:center}.slot-swatch,.hotbar-slot .shape-preview{grid-row:1;grid-column:1}.hotbar-slot b{position:absolute;top:5px;right:5px;min-width:22px;min-height:22px;font-size:.76rem}.hotbar-slot span:not(.slot-swatch):not(.shape-preview),.hotbar-slot small{max-width:100%;font-size:.68rem}.builder-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.builder-actions .primary-button{grid-column:1 / -1}}@media(min-width:701px)and (max-width:1040px){.builder-hotbar{grid-template-columns:160px minmax(0,1fr);grid-template-areas:"budget actions" "bank bank" "bombs bombs"}.builder-actions{grid-template-columns:repeat(5,minmax(0,1fr))}.builder-actions .primary-button{grid-column:auto}}
