@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap";:root{--bg-main:#0b1e33;--bg-panel:#0d1f33bf;--bg-card:#0d1f338c;--bg-card-hover:#163559e6;--border-subtle:#d9a05b26;--border-active:#d9a05b;--border-highlight:#f7b538;--text-main:#e0e6ed;--text-muted:#a0b3c6;--text-accent:#d9a05b;--text-success:#00ff9c;--text-error:#ff4d4d;--accent-cyan:#00d2ff;--accent-cyan-glow:#00d2ff4d;--color-vessel:#7ec8e3;--color-vessel-glow:#7ec8e340;--font-sans:"Inter", -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--font-serif:"Cinzel", "Playfair Display", serif;--font-display:"Cinzel", serif;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-tactical:0 20px 50px #000c, 0 0 0 1px #d9a05b1a;--shadow-glow-brass:0 0 15px #d9a05b33;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px}@media (width<=768px){:root{--spacing-md:12px;--spacing-lg:16px;--spacing-xl:24px;--radius-lg:12px;--radius-xl:16px}}*{box-sizing:border-box;margin:0;padding:0}::selection{color:#fff;background:#d9a05b59}body{font-family:var(--font-sans);background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 20% 0,#0d2d47 0%,#0000 55%),radial-gradient(at 80% 0,#06121e 0%,#0000 55%),radial-gradient(circle at 50% 100%,#0b1e33 0%,#040a12 100%);background-attachment:fixed;min-height:100vh;position:relative}body:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(135deg,#0000 0%,#d9a05b05 50%,#0000 100%) 0 0/400% 400%;animation:22s infinite shimmerBg;position:fixed;inset:0}@keyframes shimmerBg{0%{background-position:0 0}50%{background-position:100% 100%}to{background-position:0 0}}h1,h2,h3,h4,h5,h6{color:var(--text-accent);font-weight:700;font-family:var(--font-serif);letter-spacing:.05em}button{cursor:pointer;background:0 0;border:none;font-family:inherit;transition:all .2s}input,select{outline:none;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--border-active)}.glass-panel{background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);box-shadow:var(--shadow-tactical);position:relative;overflow:hidden}.glass-panel:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);height:1px;position:absolute;top:0;left:0;right:0}.text-cyan{color:var(--text-accent)}.text-mono{font-family:var(--font-mono)}.uppercase{text-transform:uppercase;letter-spacing:.05em}.app-container{flex-direction:column;align-items:center;gap:24px;min-height:100vh;padding:24px;display:flex}.app-header{background:var(--bg-panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-subtle);border-top:2px solid var(--border-active);border-radius:var(--radius-lg);width:100%;max-width:1700px;box-shadow:var(--shadow-tactical);justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:relative;overflow:hidden}.app-header:after{content:"";background:linear-gradient(90deg,#0000,#d9a05b0d,#0000);width:50%;height:100%;animation:8s linear infinite headerShimmer;position:absolute;top:0;left:-100%;transform:skew(-25deg)}@keyframes headerShimmer{to{left:200%}}.header-brand{flex-direction:column;display:flex}.app-title{font-family:var(--font-display);letter-spacing:.2em;color:var(--text-accent);text-transform:uppercase;text-shadow:0 0 15px #d9a05b4d;font-size:28px;font-weight:700}.header-subtitle-container{align-items:center;gap:12px;margin-top:4px;display:flex}.app-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;opacity:.7;font-size:11px}.discord-bot-badge{color:#b9c3ffcc;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:#5865f21a;border:1px solid #5865f24d;border-radius:4px;padding:2px 8px;font-size:9px;font-weight:700}.discord-bot-badge:hover{color:#fff;background:#5865f240;border-color:#5865f299}.header-status-area{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.status-row{align-items:center;gap:12px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.connected{background:var(--text-success);box-shadow:0 0 10px var(--text-success);animation:2s ease-in-out infinite pulseGlow}.status-dot.disconnected{background:var(--text-error);box-shadow:0 0 10px var(--text-error)}@keyframes pulseGlow{0%{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}to{opacity:.6;transform:scale(.9)}}.sandbox-badge{background:var(--text-success);color:#000;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:800;box-shadow:0 0 10px #00ff9c4d}.commander-badge{background:var(--text-accent);color:#000;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:800}.lobby-name-container{min-width:180px}.lobby-name-input{border:1px solid var(--border-subtle);color:var(--text-main);border-radius:var(--radius-sm);background:#0006;padding:6px 12px;font-size:14px;font-weight:700;transition:all .3s}.lobby-name-input:focus{border-color:var(--border-active);box-shadow:0 0 10px #d9a05b33}.lobby-name-display{color:var(--text-main);font-size:16px;font-weight:700}.room-id-tag{font-family:var(--font-mono);color:var(--text-muted);opacity:.6;font-size:14px}.battle-time-row{align-items:center;gap:10px;font-size:12px;display:flex}.battle-label{color:var(--text-muted);letter-spacing:.05em}.battle-time-input{border:1px solid var(--border-subtle);color:var(--text-accent);border-radius:var(--radius-sm);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#0000004d;padding:4px 8px;font-size:12px}.tabs-container{gap:16px;width:100%;max-width:1700px;display:flex}.tab-btn{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;flex:1;padding:16px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.tab-btn:before{content:"";background:var(--border-active);width:100%;height:2px;transition:transform .3s;position:absolute;bottom:0;left:0;transform:scaleX(0)}.tab-btn:hover{background:var(--bg-card-hover);color:var(--text-main);border-color:var(--border-active)}.tab-btn.active{background:var(--bg-card-hover);color:var(--text-accent);border-color:var(--border-active);box-shadow:var(--shadow-glow-brass)}.tab-btn.active:before{transform:scaleX(1)}.tactical-main{flex-direction:column;align-items:center;gap:24px;width:100%;display:flex}.main-content{border-radius:var(--radius-xl);flex-direction:column;width:100%;max-width:1700px;min-height:700px;padding:32px;display:flex;overflow:hidden}.tactical-grid-overlay{pointer-events:none;z-index:-1;background-image:linear-gradient(#d9a05b08 1px,#0000 1px),linear-gradient(90deg,#d9a05b08 1px,#0000 1px);background-size:40px 40px;position:fixed;inset:0}.btn-primary{color:#0d1a26;border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.13em;background:linear-gradient(135deg,#c8853a 0%,#d9a05b 40%,#f7b538 100%) 0 0/200%;border:1px solid #ffffff26;padding:14px 30px;font-size:14px;font-weight:800;transition:all .3s;box-shadow:0 0 20px #d9a05b59,0 2px 10px #0006}.btn-primary:hover{color:#000;background-position:100%;transform:translateY(-2px);box-shadow:0 0 30px #f7b5388c,0 4px 18px #00000080}.btn-primary:active{transform:translateY(0)}.btn-ghost{color:var(--text-accent);border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--border-active);background:0 0;padding:12px 24px;font-weight:700;transition:all .2s}.btn-ghost:hover{background:#d9a05b1f;transform:translateY(-1px);box-shadow:0 0 12px #d9a05b33}.input-field{border:1px solid var(--border-subtle);color:var(--text-main);border-radius:var(--radius-md);background:#0f1e3299;padding:14px 20px;font-size:15px;transition:border-color .25s,box-shadow .25s}.input-field:focus{border-color:var(--border-active);box-shadow:0 0 14px #d9a05b47,inset 0 1px #ffffff0d}.lobby-view{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.lobby-card{text-align:center;width:100%;max-width:600px;padding:52px 48px;transition:box-shadow .4s,border-color .4s}.lobby-card:hover{border-color:#d9a05b66;box-shadow:inset 0 1px #ffffff1a,0 20px 60px #000000b3,0 0 0 1px #d9a05b4d,0 0 40px #d9a05b1f}.lobby-title{text-shadow:0 0 32px #d9a05b59;letter-spacing:.08em;margin-bottom:10px;font-family:Cinzel,Playfair Display,serif;font-size:42px}.lobby-input-group{flex-direction:column;gap:16px;margin-top:32px;display:flex}.lobby-divider{background:linear-gradient(90deg, transparent, var(--border-subtle), transparent);height:1px;margin:32px 0;position:relative}.roster-tab{flex-direction:column;flex:1;gap:24px;display:flex}.roster-registration-panel{justify-content:space-between;align-items:flex-start;gap:32px;padding:24px;display:flex}.registration-info{flex:1}.registration-title{letter-spacing:.1em;color:var(--text-accent);text-transform:uppercase;margin-bottom:16px;font-size:14px;font-weight:700}.registration-controls{flex-direction:column;flex:1.5;gap:12px;display:flex}.controls-row{gap:12px;display:flex}.roster-table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex:1;overflow:hidden}.roster-table{border-collapse:collapse;width:100%}.roster-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;text-align:left;border-bottom:1px solid var(--border-active);background:#0006;padding:16px 20px;font-size:11px;font-weight:700}.roster-table td{vertical-align:middle;border-bottom:1px solid #d9a05b1a;padding:14px 20px}.roster-table tr:hover{background:#d9a05b08}.roster-row-selected{box-shadow:inset 4px 0 0 0 var(--border-active);background:#d9a05b0d}.ship-pill{color:var(--text-muted);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);font-size:12px;font-family:var(--font-mono);text-transform:uppercase;background:#0000004d;align-items:center;gap:6px;padding:4px 12px;transition:all .2s;display:inline-flex}.ship-pill-my{border-color:var(--border-active);color:var(--text-accent);background:#d9a05b1a}.discord-pool-container{margin-top:12px}.discord-pool-header{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.applied-vessels-list{flex-wrap:wrap;gap:8px;display:flex}.no-offers-hint{opacity:.5;font-size:11px;font-style:italic}.remove-icon{opacity:.5;margin-left:4px;font-size:10px}.commander-cell{align-items:center;gap:12px;display:flex}.name-stack{flex-direction:column;display:flex}.p-name{font-size:14px;font-weight:700}.p-tag{color:var(--text-muted);letter-spacing:.1em;font-size:10px}.vessel-pool{flex-wrap:wrap;gap:6px;display:flex}.no-offers{opacity:.3;letter-spacing:.1em;font-size:10px}.role-pill{border:none;font-size:10px;font-weight:700}.assigned-ship-cell{align-items:center;gap:10px;display:flex}.ship-icon-small{filter:drop-shadow(0 0 5px #7ec8e366);width:18px;height:18px}.assigned-ship-name{color:var(--text-muted);font-size:13px;font-weight:700}.assigned-ship-name.active{color:var(--accent-cyan);text-shadow:0 0 10px var(--accent-cyan-glow)}.discord-pool-body{padding:0 20px 20px}.applicants-grid{flex-wrap:wrap;gap:12px;display:flex}.applicant-card{background:#5865f20d;border-color:#5865f233;padding:8px 16px}.avatar-small{border-radius:50%;width:20px;height:20px}.applicant-name{font-size:12px;font-weight:700}.applicant-status{opacity:.6;font-size:10px;font-style:italic}.assignment-tab{flex:1;gap:24px;display:flex}.recruit-pool{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;gap:16px;width:300px;padding:20px;display:flex}.recruit-pool-title{color:var(--text-accent);text-transform:uppercase;letter-spacing:.1em;text-align:center;border-bottom:1px solid var(--border-subtle);padding-bottom:12px;font-size:14px;font-weight:700}.recruit-list{flex-direction:column;flex:1;gap:12px;display:flex;overflow-y:auto}.recruit-card{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:grab;justify-content:space-between;align-items:center;padding:12px;transition:all .2s;display:flex}.recruit-card:hover{border-color:var(--border-active);background:#d9a05b0d;transform:translate(4px)}.recruit-info{flex:1;min-width:0}.recruit-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.recruit-vessel{color:var(--text-accent);text-transform:uppercase;align-items:center;gap:6px;margin-top:4px;font-size:10px;display:flex}.squadron-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;padding-bottom:20px;display:grid;overflow-y:auto}.squadron-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;min-height:250px;transition:all .3s;display:flex;overflow:hidden}.squadron-card.active-sq{border-color:var(--border-active);box-shadow:var(--shadow-glow-brass)}.squadron-card.inactive{opacity:.4;filter:grayscale(.5)}.squadron-header{border-bottom:1px solid var(--border-subtle);background:#0000004d;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.squadron-title{color:var(--text-main);text-transform:uppercase;font-size:14px;font-weight:700}.squadron-body{flex-direction:column;flex:1;gap:8px;min-height:100px;padding:16px;display:flex}.assigned-player{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:grab;justify-content:space-between;align-items:center;padding:10px 14px;transition:all .2s;display:flex}.assigned-player:hover{border-color:var(--border-active);background:#d9a05b0d}.player-role-tag{background:var(--text-accent);color:#000;text-transform:uppercase;border-radius:2px;padding:2px 6px;font-size:9px;font-weight:800}.no-recruits-hint{text-align:center;opacity:.5;margin-top:20px;font-size:12px}.ship-icon-mini{vertical-align:middle;width:12px;height:12px}.mini-select{width:70px;padding:4px;font-size:10px}.squadron-title-area{flex:1;align-items:center;gap:8px;display:flex}.squadron-name-input{border:none;border-bottom:1px solid var(--border-subtle);color:var(--text-main);background:#0003;width:100%;max-width:180px;padding:2px 4px;font-size:12px;font-weight:700;transition:all .3s}.squadron-name-input:focus{border-color:var(--border-active);background:#0006;outline:none}.squadron-name-label{letter-spacing:.05em;font-size:12px;font-weight:700}.mini-btn{padding:4px 8px;font-size:9px}.player-meta{flex:1;min-width:0}.player-vessel{color:var(--text-accent);opacity:.8;text-transform:uppercase;align-items:center;gap:4px;font-size:10px;display:flex}.role-select-mini{background:#0006;width:auto;padding:2px 4px;font-size:9px}.drop-zone{border-radius:var(--radius-md);width:100%;min-height:80px;font-family:var(--font-mono);color:var(--text-muted);pointer-events:auto;border:2px dashed #d9a05b4d;justify-content:center;align-items:center;font-size:12px;transition:all .2s;display:flex}.drop-zone:hover{border-color:var(--border-active);color:var(--text-accent);background:#d9a05b0d}.toggle-switch{border-radius:10px;width:40px;height:20px;transition:background .3s;position:relative}.toggle-switch.on{background:var(--text-success)}.toggle-switch.off{background:var(--text-muted)}.toggle-knob{background:#fff;border-radius:50%;width:14px;height:14px;transition:left .3s;position:absolute;top:3px}.toggle-switch.on .toggle-knob{left:23px}.toggle-switch.off .toggle-knob{left:3px}.formation-tab{background:var(--bg-main);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.formation-nav{border-bottom:1px solid var(--border-subtle);z-index:10;background:#0006;flex-wrap:wrap;flex-shrink:0;justify-content:center;gap:10px;padding:16px;display:flex}.formation-nav button{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-radius:var(--radius-md);background:0 0;border:1px solid #d9a05b40;padding:9px 20px;font-size:12px;font-weight:700;transition:all .2s}.formation-nav button:hover{color:var(--text-main);background:#d9a05b1a;border-color:#d9a05b73}.formation-nav button.active{color:#0d1a26;background:linear-gradient(135deg,#c8853a 0%,#d9a05b 40%,#f7b538 100%);border-color:#0000;font-weight:800;box-shadow:0 0 16px #d9a05b66}.formation-content{flex-direction:column;flex:1;display:flex;overflow:auto}.tactical-viewport{flex-direction:column;flex-shrink:0;align-items:center;min-height:100%;display:flex;position:relative}.tactical-header{opacity:.4;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;height:60px;margin-top:20px;display:flex}.forward-arrow{color:var(--text-accent);font-size:32px;line-height:1}.forward-text{color:var(--text-accent);text-transform:uppercase;letter-spacing:.2em;font-size:10px;font-weight:700}.formation-container{background-image:linear-gradient(#d9a05b0d 1px,#0000 1px),linear-gradient(90deg,#d9a05b0d 1px,#0000 1px);background-size:60px 60px;background-attachment:local;flex-direction:column;flex-shrink:0;align-items:center;width:100%;padding:80px 80px 300px;display:flex}.formation-layout{gap:60px;margin:0 auto;display:flex;position:relative}.formation-layout.compact{gap:30px}.formation-slot{transition:transform .5s cubic-bezier(.4,0,.2,1)}.tactical-unit.tiny{width:100px}.unit-icon-wrapper{justify-content:center;align-items:center;width:100px;height:100px;transition:all .3s;display:flex;position:relative}.tactical-unit.tiny .unit-icon-wrapper{width:35px;height:35px}.unit-icon{object-fit:contain;filter:drop-shadow(0 0 10px #d9a05b4d);width:100%;height:100%;transition:transform .3s}.tactical-unit.rate1 .unit-icon,.tactical-unit.rate2 .unit-icon,.tactical-unit.rate3 .unit-icon{transform:scale(1.3)}.tactical-unit.rate7 .unit-icon{transform:scale(.7)}.unit-me-tag{background:var(--text-error);color:#fff;border-radius:4px;padding:2px 6px;font-size:9px;font-style:italic;font-weight:900;position:absolute;top:-10px;box-shadow:0 0 10px #d6282880}.unit-label{text-align:center;background:#0006;border:2px solid #d9a05b66;flex-direction:column;justify-content:center;width:100%;min-height:85px;padding:12px 20px;transition:all .3s;display:flex;box-shadow:0 4px 15px #0000004d}.tactical-unit.compact .unit-label{min-height:70px;padding:8px 14px}.unit-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;transition:all .3s;overflow:hidden}.unit-ship{white-space:nowrap;text-overflow:ellipsis;opacity:.95;color:var(--color-vessel);text-shadow:0 0 8px var(--color-vessel-glow);margin-top:4px;font-size:11px;transition:all .3s;overflow:hidden}.unit-role{font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);opacity:.7;border-top:1px solid #d9a05b26;margin-top:6px;padding-top:4px}.tactical-unit.compact .unit-role{margin-top:4px;font-size:9px}.map-tab{flex-direction:column;flex:1;display:flex;position:relative}.map-controls{z-index:50;justify-content:space-between;align-items:center;display:flex;position:absolute;top:24px;left:24px;right:24px}.map-tools{background:var(--bg-panel);border-radius:var(--radius-md);border:1px solid var(--border-subtle);display:flex;overflow:hidden}.map-tool-btn{text-transform:uppercase;color:var(--text-muted);border-right:1px solid var(--border-subtle);padding:10px 16px;font-size:11px;font-weight:700}.map-tool-btn:last-child{border-right:none}.map-tool-btn:hover{color:var(--text-main);background:#ffffff0d}.map-tool-btn.active{color:var(--text-accent);background:#d9a05b33}@media (width>=1920px){.app-header,.tabs-container,.main-content{max-width:2000px}.app-title{font-size:38px}.tab-btn{padding:20px 38px;font-size:15px}.app-subtitle{font-size:16px}.roster-table th,.roster-table td{padding:16px 24px;font-size:15px}.lobby-card{max-width:780px;padding:60px 56px}.lobby-title{font-size:52px}}@media (width<=1280px){.app-header,.tabs-container,.main-content{max-width:1200px}.tab-btn{padding:16px 24px;font-size:13px}}@media (width<=1024px){.app-header{text-align:center;flex-direction:column;gap:16px;padding:16px 20px}.app-title{font-size:26px}.assignment-tab{flex-direction:column;overflow-y:auto}.recruit-pool{width:100%;max-height:280px}.recruit-list{flex-flow:wrap;max-height:180px}.recruit-card{flex:1;min-width:180px}.squadron-grid{grid-template-columns:1fr 1fr;overflow-y:visible}.main-content{height:auto;min-height:calc(100vh - 220px)}}@media (width<=768px){.app-container{gap:12px;padding:12px}.app-title{letter-spacing:.08em;font-size:20px}.app-subtitle{font-size:12px}.tabs-container{white-space:nowrap;scrollbar-width:none;-ms-overflow-style:none;padding:0 8px;overflow-x:auto}.tabs-container::-webkit-scrollbar{display:none}.tab-btn{flex-shrink:0;padding:11px 16px;font-size:11px}.main-content{height:auto;min-height:calc(100vh - 240px)}.roster-top-panel{flex-direction:column;align-items:stretch;gap:14px}.roster-controls{flex-direction:column;gap:8px}.roster-controls select,.roster-controls .btn-primary{width:100%!important}.roster-table-container{overflow-x:auto}.roster-table th:nth-child(4),.roster-table td:nth-child(4){display:none}.lobby-card{max-width:100%;padding:28px 20px}.lobby-title{font-size:28px}.formation-nav{flex-wrap:wrap;gap:8px;padding:10px}.formation-nav button{flex:1;min-width:80px;padding:8px 12px;font-size:10px}.map-controls{flex-direction:column;align-items:stretch;gap:12px}.map-tools{justify-content:center}.squadron-grid{grid-template-columns:1fr}}@media (width<=480px){.app-header{padding:12px}.app-title{letter-spacing:.06em;font-size:17px}.connection-status{flex-wrap:wrap;justify-content:center;padding:8px 12px;font-size:12px}.sandbox-badge,.commander-badge{padding:3px 7px;font-size:10px}.squadron-header{text-align:center;flex-direction:column;align-items:stretch;gap:10px}.squadron-header input{width:100%!important}.btn-primary{padding:12px 20px;font-size:13px}.input-field{padding:11px 14px;font-size:14px}.roster-table th:nth-child(3),.roster-table td:nth-child(3),.roster-table th:nth-child(4),.roster-table td:nth-child(4){display:none}.lobby-title{font-size:22px}.lobby-card{padding:20px 16px}.lobby-input-group{gap:12px;margin-top:20px}}@media (width<=360px){.app-title{font-size:14px}.tab-btn{padding:9px 10px;font-size:9px}.lobby-title{font-size:18px}}.formation-tab{flex-direction:column;flex:1;gap:20px;display:flex}.formation-nav{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);gap:12px;padding:12px;display:flex}.formation-nav button{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:#0000004d;flex:1;padding:10px;font-size:11px;transition:all .2s}.formation-nav button.active{border-color:var(--border-active);color:var(--text-accent);background:#d9a05b1a;box-shadow:inset 0 0 10px #d9a05b1a}.formation-content{flex-direction:column;flex:1;display:flex}.tactical-viewport{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#0006;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.tactical-header{background:linear-gradient(#d9a05b0d,#0000);flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex}.forward-arrow{color:var(--border-active);filter:drop-shadow(0 0 10px var(--border-active));font-size:18px;animation:2s ease-in-out infinite pulse-gold}.forward-text{text-transform:uppercase;letter-spacing:.3em;color:var(--text-muted);font-size:11px;font-weight:700}.formation-container{flex:1;justify-content:center;padding:40px;display:flex;overflow:auto}.formation-layout{gap:40px;transition:all .5s;display:flex}.formation-line-ahead{flex-direction:column;align-items:center}.formation-line-abreast{flex-direction:row;align-items:center}.formation-echelon-right,.formation-echelon-left{flex-direction:column;align-items:center}.tactical-unit{flex-direction:column;align-items:center;gap:12px;width:180px;transition:all .3s;display:flex}.unit-icon-wrapper{border:1px solid var(--border-subtle);background:#0000004d;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;display:flex;position:relative}.tactical-unit:hover .unit-icon-wrapper{border-color:var(--border-active);transform:scale(1.1);box-shadow:0 0 20px #d9a05b33}.unit-icon{object-fit:contain;filter:drop-shadow(0 0 5px #fff3);width:40px;height:40px}.unit-me-tag{background:var(--accent-cyan);color:#000;box-shadow:0 0 10px var(--accent-cyan-glow);border-radius:2px;padding:2px 4px;font-size:8px;font-weight:800;position:absolute;top:-4px;right:-4px}.unit-label{text-align:center;flex-direction:column;gap:4px;width:100%;padding:10px;display:flex}.unit-name{color:var(--text-main);margin:0;font-size:14px;font-weight:700}.unit-ship{color:var(--text-accent);margin:0;font-size:11px}.unit-role{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:0;font-size:9px}.tactical-unit.compact{gap:8px;width:140px}.tactical-unit.compact .unit-icon-wrapper{width:40px;height:40px}.tactical-unit.compact .unit-icon{width:24px;height:24px}.tactical-unit.compact .unit-label{padding:6px}.tactical-unit.compact .unit-name{font-size:11px}.tactical-unit.compact .unit-ship{font-size:9px}.offline-notice{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.2em;flex:1;place-items:center;font-size:14px;font-style:italic;display:grid}
