:root{--background: 240 10% 3.9%;--foreground: 0 0% 98%;--card: 240 6% 10%;--card-foreground: 0 0% 98%;--primary: 0 0% 98%;--primary-foreground: 240 5.9% 10%;--secondary: 240 3.7% 15.9%;--secondary-foreground: 0 0% 98%;--muted: 240 3.7% 15.9%;--muted-foreground: 240 5% 64.9%;--accent: 240 3.7% 15.9%;--border: 240 3.7% 15.9%;--input: 240 3.7% 18%;--ring: 240 4.9% 83.9%;--destructive: 0 72% 51%;--radius: .5rem;--green: 142 71% 55%;--red: 0 84% 67%;--amber: 38 95% 62%;--blue: 217 91% 68%}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:hsl(var(--background));color:hsl(var(--foreground));font-size:14px;-webkit-font-smoothing:antialiased}a{color:hsl(var(--foreground));text-decoration:none}a:hover{text-decoration:underline}.center{min-height:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.page{min-height:100%;background:hsl(var(--background))}main{max-width:1400px;margin:0 auto;padding:.75rem 1rem 2rem}.topbar{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid hsl(var(--border))}.topbar h1{margin:0;font-size:1.15rem;font-weight:600;letter-spacing:-.01em}.nav{display:flex;align-items:center;gap:1.1rem;font-size:.9rem}.nav a{color:hsl(var(--muted-foreground))}.nav a:hover{color:hsl(var(--foreground));text-decoration:none}.refresh-btn{display:inline-flex;align-items:center;gap:.3rem;background:hsl(var(--secondary));color:hsl(var(--secondary-foreground));border:1px solid hsl(var(--border));padding:.35rem .7rem;font-size:.85rem}.spin{display:inline-block;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tabs{gap:.15rem;flex-wrap:wrap}.tabs a{padding:.35rem .7rem;border-radius:calc(var(--radius) - 2px);color:hsl(var(--muted-foreground))}.tabs a:hover{color:hsl(var(--foreground));background:hsl(var(--secondary) / .6);text-decoration:none}.tabs a.active{color:hsl(var(--foreground));background:hsl(var(--secondary))}.page-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-bottom:.5rem}.avatar-menu{position:relative;display:inline-flex}.avatar-btn{width:34px;height:34px;border-radius:50%;background:hsl(var(--secondary));border:1px solid hsl(var(--border));display:flex;align-items:center;justify-content:center;font-size:1.05rem;padding:0}.avatar-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:150px;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:var(--radius);box-shadow:0 8px 24px #00000080;padding:.3rem;display:flex;flex-direction:column;z-index:60}.dropdown-item{display:block;width:100%;text-align:left;padding:.5rem .7rem;border-radius:calc(var(--radius) - 2px);background:none;border:none;color:hsl(var(--foreground));font-size:.9rem}.dropdown-item:hover{background:hsl(var(--secondary));text-decoration:none;opacity:1}a.status-chip{color:inherit;text-decoration:none;cursor:pointer}a.status-chip:hover{opacity:.8}a.team-name{color:inherit}.fab-refresh{position:fixed;right:1.25rem;bottom:1.25rem;z-index:50;width:52px;height:52px;border-radius:50%;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;background:hsl(var(--primary));color:hsl(var(--primary-foreground));box-shadow:0 6px 18px #00000073;padding:0}.fab-refresh:disabled{opacity:.8}.card{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.6rem}.center .card{width:100%;max-width:380px}.page .card{margin:0 auto 1rem;max-width:1400px}h1,h2,h3{letter-spacing:-.01em}.card h1{margin:0;font-size:1.4rem}.card h2{margin:0;font-size:1.1rem;font-weight:600}.card h3{margin:0;font-size:1rem;font-weight:600}.muted{color:hsl(var(--muted-foreground));font-size:.9rem}.small{font-size:.78rem}.error{color:hsl(var(--red));font-size:.9rem;margin:0}hr{border:none;border-top:1px solid hsl(var(--border));margin:.5rem 0}input,select{background:hsl(var(--input));border:1px solid hsl(var(--border));border-radius:calc(var(--radius) - 2px);color:hsl(var(--foreground));font-size:.9rem;padding:.5rem .7rem}input::placeholder{color:hsl(var(--muted-foreground))}input:focus,select:focus{outline:none;border-color:hsl(var(--ring));box-shadow:0 0 0 2px hsl(var(--ring) / .25)}button{font-family:inherit;font-size:.88rem;font-weight:500;padding:.5rem .9rem;border:1px solid transparent;border-radius:calc(var(--radius) - 2px);background:hsl(var(--primary));color:hsl(var(--primary-foreground));cursor:pointer;transition:opacity .12s ease,background .12s ease}button:hover{opacity:.9}button:disabled{opacity:.5;cursor:default}button.link{background:none;border:none;color:hsl(var(--muted-foreground));padding:0}button.link:hover{color:hsl(var(--foreground));opacity:1}button.danger,.danger{background:hsl(var(--destructive));color:#fff}.danger-link{color:hsl(var(--red))}.btn{display:inline-block;padding:.5rem .9rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-radius:calc(var(--radius) - 2px);font-weight:500;font-size:.88rem}.btn:hover{text-decoration:none;opacity:.9}.toggle{display:inline-flex;align-items:center;gap:.4rem}.row-form{display:flex;gap:.5rem;flex-wrap:wrap}.row-form input{flex:1;min-width:120px}.row-form button{width:auto}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{text-align:left;padding:.5rem .6rem;border-bottom:1px solid hsl(var(--border))}th{color:hsl(var(--muted-foreground));font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}td.num,th:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}td.strong{font-weight:600}td.num.in{color:hsl(var(--green));font-weight:600}td.num.out{color:hsl(var(--muted-foreground))}.delta{color:hsl(var(--green));font-size:.8rem;margin-left:.25rem}.card-head,.profile-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.status{background:hsl(var(--secondary));color:hsl(var(--secondary-foreground));padding:.25rem .6rem;border-radius:999px;font-size:.78rem;white-space:nowrap}.travel{background:hsl(var(--amber) / .12);border:1px solid hsl(var(--amber) / .3);color:hsl(var(--amber));border-radius:calc(var(--radius) - 2px);padding:.5rem .75rem;font-size:.88rem}.bars{display:flex;flex-direction:column;gap:.6rem;margin-top:.5rem}.bar-head{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:.2rem;color:hsl(var(--muted-foreground))}.bar-track{height:8px;background:hsl(var(--secondary));border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:hsl(var(--primary))}.bar-fill.energy{background:hsl(var(--green))}.bar-fill.nerve{background:hsl(var(--red))}.bar-fill.happy{background:hsl(var(--amber))}.bar-fill.life{background:hsl(var(--blue))}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem;margin-top:.25rem}.stat{background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:calc(var(--radius) - 2px);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.2rem}.stat.total{border-color:hsl(var(--ring) / .4)}.stat-label{font-size:.72rem;color:hsl(var(--muted-foreground));text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.1rem;font-weight:600;font-variant-numeric:tabular-nums}.planner-controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.green{color:hsl(var(--green))}.plan-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.75rem}.pstat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:hsl(var(--muted-foreground))}.pstat-val{font-size:1.3rem;font-weight:700;font-variant-numeric:tabular-nums}.tl-wrap{overflow-x:auto;padding:.5rem 0 .25rem}.stock-low{color:hsl(var(--red))}.wait-tag{color:hsl(var(--blue));font-weight:600}.depart-tag{color:hsl(var(--green));font-weight:600}.next-flight{background:hsl(var(--green) / .12);border:1px solid hsl(var(--green) / .3);color:hsl(var(--foreground));border-radius:var(--radius);padding:.5rem .75rem;margin-top:.25rem;font-size:1rem}.next-flight strong{color:hsl(var(--green))}.tl2{position:relative;display:flex;min-width:100%}.tl2-line{position:absolute;top:18px;left:48px;right:48px;height:3px;border-radius:3px;background:hsl(var(--blue))}.tl2-stop{flex:1 0 96px;min-width:96px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.12rem;position:relative;z-index:1}.tl-node-row{height:36px;display:flex;align-items:center;justify-content:center}.tl-flag{width:34px;height:34px;border-radius:50%;background:hsl(var(--card));border:2px solid hsl(var(--blue));display:flex;align-items:center;justify-content:center;overflow:hidden}.tl-flag img{width:30px;height:30px;object-fit:cover;border-radius:50%}.tl-dot{width:12px;height:12px;border-radius:50%;background:hsl(var(--muted-foreground))}.tl-dot.start{background:hsl(var(--green))}.tl-dot.end{background:hsl(var(--red))}.tl-time{font-size:.78rem;font-weight:600;font-variant-numeric:tabular-nums}.tl-meta{margin-top:.2rem}.tl-itemimg{width:26px;height:26px;object-fit:contain}.spark{display:block;margin:.1rem auto}.seg{display:inline-flex;border:1px solid hsl(var(--border));border-radius:calc(var(--radius) - 2px);overflow:hidden}.seg button{background:none;color:hsl(var(--muted-foreground));border:none;border-radius:0;padding:.4rem .7rem;font-size:.85rem}.seg button.on{background:hsl(var(--secondary));color:hsl(var(--foreground))}.filter-block{margin-top:.75rem}.chip-row{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.3rem}.fchip{background:none;border:1px solid hsl(var(--border));color:hsl(var(--muted-foreground));padding:.3rem .6rem;font-size:.82rem;border-radius:999px;opacity:.5}.fchip.on{opacity:1;border-color:hsl(var(--ring) / .6);color:hsl(var(--foreground));background:hsl(var(--secondary) / .6)}.flag-chip{padding:.3rem .5rem}.flag-chip .flag{height:24px}.plan-result{margin-top:.5rem;padding-top:.5rem;border-top:1px solid hsl(var(--border))}.plan-total{font-size:1.05rem}.plan-legs{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.plan-leg{background:hsl(var(--secondary));border-radius:999px;padding:.2rem .6rem;font-size:.85rem}.profit-row{cursor:pointer}.profit-row:hover{background:hsl(var(--secondary) / .4)}.profit-sub td{border-bottom:1px solid hsl(var(--border));padding-top:.2rem;padding-bottom:.2rem}.country-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.5rem;margin-top:.25rem}.country{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;text-align:left;background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:calc(var(--radius) - 2px);padding:.55rem .65rem;font-size:.76rem;cursor:pointer;color:hsl(var(--foreground))}.country:hover{border-color:hsl(var(--ring) / .5);opacity:1}.country.active{border-color:hsl(var(--ring));background:hsl(var(--secondary))}.country-name{font-weight:600;font-size:.9rem}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.78rem;font-weight:500;background:hsl(var(--secondary));color:hsl(var(--secondary-foreground));white-space:nowrap}.badge.okay{background:hsl(var(--green) / .15);color:hsl(var(--green))}.badge.hosp{background:hsl(var(--red) / .15);color:hsl(var(--red))}.badge.jail{background:hsl(var(--muted));color:hsl(var(--muted-foreground))}.badge.travel{background:hsl(var(--amber) / .15);color:hsl(var(--amber))}.flag{height:.95em;width:auto;vertical-align:-.12em;border-radius:2px;display:inline-block}.badge.abroad{background:hsl(var(--blue) / .15);color:hsl(var(--blue))}.score-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem}.team{display:flex;align-items:center;gap:.6rem}.team.right{justify-content:flex-end;text-align:right}.ftag{height:28px;width:auto;image-rendering:pixelated;border-radius:3px}.team-name{font-weight:600;font-size:.95rem}.team-score{font-size:1.8rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.1}.team.winning .team-score{color:hsl(var(--green))}.vs{white-space:nowrap}.tug-caption{text-align:center}.tug-wrap{position:relative;margin:.7rem 0 .3rem}.tug-track{position:relative;height:14px;background:hsl(var(--secondary));border-radius:999px;overflow:hidden}.tug-fill{position:absolute;top:0;bottom:0}.tug-center{position:absolute;left:50%;top:0;bottom:0;width:2px;background:hsl(var(--card));transform:translate(-50%)}.tug-marker{position:absolute;top:7px;width:16px;height:16px;border-radius:50%;background:hsl(var(--foreground));border:3px solid;transform:translate(-50%,-50%)}.status-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.status-chip{display:flex;align-items:center;gap:.5rem}.status-chip.alert .chip-val{color:hsl(var(--red))}.chip-ico{font-size:1.3rem;line-height:1}.chip-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:hsl(var(--muted-foreground))}.chip-val{font-size:1.05rem;font-weight:600;font-variant-numeric:tabular-nums}.controls-bar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.war-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.75rem}@media (max-width: 720px){.war-grid{grid-template-columns:minmax(0,1fr)}}.side{margin:0;min-width:0}.side-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.25rem}.side-head h3{font-size:1rem}.side-meta{display:flex;align-items:center;gap:.6rem}select.mini{padding:.2rem .4rem;font-size:.76rem}.mini-label{display:inline-flex;align-items:center;gap:.35rem}.chain-mini{font-size:.82rem;font-weight:600;margin-top:.15rem;color:hsl(var(--muted-foreground))}.chain-mini.active{color:hsl(var(--amber))}.chain-mini.cd{color:hsl(var(--blue))}.chain-timer{font-variant-numeric:tabular-nums}.side table{font-size:.84rem;table-layout:fixed;width:100%}.side td{padding:.4rem;border-bottom:1px solid hsl(var(--border));white-space:nowrap}.side td:first-child{overflow:hidden;text-overflow:ellipsis}.side th{text-align:left}.side th:nth-child(2),.side td:nth-child(2){width:38px}.side th:nth-child(3),.side td:nth-child(3){width:92px}.side th:nth-child(4),.side td:nth-child(4){width:58px}.side th:nth-child(5),.side td:nth-child(5){width:108px}.side th:nth-child(6),.side td:nth-child(6){width:44px}@media (max-width: 640px){.side th:nth-child(3),.side td:nth-child(3){display:none}}.side th.num{text-align:right}.nowrap{white-space:nowrap}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:hsl(var(--muted-foreground));vertical-align:middle}.dot.online{background:hsl(var(--green))}.dot.idle{background:hsl(var(--amber))}.dot.offline{background:#52525b}.ff{display:inline-flex;flex-direction:column;align-items:flex-end;line-height:1.1;font-weight:600;font-variant-numeric:tabular-nums}.ff-bs{font-size:.68rem;font-weight:400;color:hsl(var(--muted-foreground))}.ff-great{color:hsl(var(--green))}.ff-good{color:#85e0a6}.ff-mid{color:hsl(var(--amber))}.ff-low{color:hsl(var(--red))}.ff-unknown{color:hsl(var(--muted-foreground))}.attack{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:hsl(var(--destructive) / .15);border:1px solid hsl(var(--destructive) / .4);border-radius:calc(var(--radius) - 3px);font-size:.95rem;line-height:1}.attack:hover{text-decoration:none;opacity:.9}
