:root{--z-chat:900;--z-overlay:1000;--z-modal:2000;--z-toast:3000;--ocean-950:#082f49;--ocean-900:#0c4a6e;--ocean-700:#0369a1;--ocean-500:#0ea5e9;--ocean-300:#7dd3fc;--ocean-100:#e0f2fe;--teal-500:#14b8a6;--teal-300:#5eead4;--gold-500:#f59e0b;--gold-300:#fcd34d;--sand-100:#fef3c7;--coral-500:#f43f5e;--ink:#0f172a;--ink-soft:#475569;--ink-faint:#94a3b8;--glass:#ffffffb8;--glass-strong:#ffffffe0;--glass-border:#ffffffa6;--radius-lg:20px;--radius-md:14px;--radius-sm:10px;--shadow-soft:0 8px 30px #0348761a;--shadow-float:0 16px 44px #03487629;--grad-primary:linear-gradient(135deg, #38bdf8, #0284c7);--grad-success:linear-gradient(135deg, #34d399, #0d9488);--grad-warning:linear-gradient(135deg, #fbbf24, #f97316);--grad-danger:linear-gradient(135deg, #fb7185, #e11d48);--grad-gold:linear-gradient(135deg, #fde68a, #f59e0b);--grad-grey:linear-gradient(135deg, #cbd5e1, #94a3b8);--grad-deep:linear-gradient(120deg, #075985, #0369a1 55%, #0d9488)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:var(--ink);background:linear-gradient(#f0f9ff 0%,#e0f2fe 38%,#ccfbf1 100%) fixed;min-height:100vh;font-family:PingFang SC,Noto Sans SC,Microsoft YaHei,-apple-system,Segoe UI,sans-serif;overflow-x:hidden}.bg-orb{filter:blur(90px);z-index:-1;pointer-events:none;border-radius:50%;animation:26s ease-in-out infinite alternate drift;position:fixed}.orb-1{background:#7dd3fc8c;width:520px;height:520px;top:-140px;left:-120px}.orb-2{background:#5eead480;width:460px;height:460px;animation-delay:-8s;bottom:-160px;right:-100px}.orb-3{background:#fde68a66;width:380px;height:380px;animation-delay:-16s;top:38%;left:58%}@keyframes drift{0%{transform:translate(0,0)scale(1)}to{transform:translate(48px,-36px)scale(1.12)}}a{color:var(--ocean-700)}::selection{background:#38bdf84d}#app{grid-template:"header header header""me main partner"1fr"actions actions actions""log log log"/300px minmax(0,1fr) 300px;gap:12px;max-width:1720px;min-height:100vh;margin:0 auto;padding:14px;display:grid}.panel{background:var(--glass);-webkit-backdrop-filter:blur(18px)saturate(1.35);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.header{background:var(--grad-deep);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-float);flex-wrap:wrap;grid-area:header;justify-content:space-between;align-items:center;gap:12px;padding:14px 22px;display:flex;position:relative;overflow:hidden}.header:after{content:"";pointer-events:none;background:radial-gradient(1100px 130px at 18% -40%,#ffffff38,#0000 60%);position:absolute;inset:0}.brand{align-items:center;gap:14px;display:flex}.brand .logo{filter:drop-shadow(0 2px 6px #00000040);font-size:32px}.brand h1{letter-spacing:.5px;background:linear-gradient(120deg,#fff,#fde68a 70%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px}.brand .gen-badge{vertical-align:3px;letter-spacing:1px;color:#451a03;background:var(--grad-gold);-webkit-text-fill-color:#451a03;border-radius:999px;margin-left:8px;padding:2px 9px;font-size:10px;font-weight:800;display:inline-block;box-shadow:0 2px 6px #f59e0b66}.brand .subtitle{color:#e0f2fee6;margin-top:3px;font-size:12px}.header-actions{z-index:1;flex-wrap:wrap;align-items:center;gap:8px;display:flex}.header-actions .me-chip{background:#ffffff29;border:1px solid #ffffff40;border-radius:999px;padding:5px 14px;font-size:12px;font-weight:600}.side-panel{max-height:calc(100vh - 250px);padding:14px;overflow-y:auto}#status-panel{grid-area:me}#roster-panel{grid-area:partner}.crew-head{border-bottom:1px solid #0ea5e92e;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:10px;display:flex}.crew-head .avatar{background:var(--grad-primary);border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;font-size:20px;display:flex;box-shadow:0 4px 10px #0284c74d}.crew-head.partner .avatar{background:var(--grad-success);box-shadow:0 4px 10px #0d94884d}.crew-head .who{flex:1;min-width:0}.crew-head .who .nm{color:var(--ocean-900);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:800;overflow:hidden}.crew-head .who .role{color:var(--ink-faint);font-size:10.5px}.dot{border-radius:50%;flex:none;width:9px;height:9px;display:inline-block}.dot.on{background:#10b981;box-shadow:0 0 0 4px #10b9812e}.dot.off{background:#94a3b8;box-shadow:0 0 0 4px #94a3b826}.status-section{background:var(--glass-strong);border-radius:var(--radius-md);border:1px solid #0ea5e924;margin-bottom:10px;padding:11px 12px}.status-section h3{color:var(--ocean-700);letter-spacing:.5px;align-items:center;gap:5px;margin-bottom:7px;font-size:12px;font-weight:800;display:flex}.stat-row{color:var(--ink-soft);justify-content:space-between;align-items:center;padding:3px 0;font-size:12px;display:flex}.stat-value{color:var(--ocean-700);font-weight:700}.stat-money{color:#059669;font-size:14px;font-weight:800}.stat-score{color:#b45309;font-weight:800}.inv-item{align-items:center;padding:2.5px 0;font-size:11.5px;display:flex}.inv-item .icon{margin-right:5px}.inv-item .name{flex:1;font-weight:600}.inv-item .count{text-align:right;font-variant-numeric:tabular-nums;min-width:30px;font-weight:800}.inv-section-title{color:var(--ink-faint);letter-spacing:2px;margin-top:4px;padding:5px 0 3px;font-size:10px;font-weight:700}.chip{color:var(--ocean-700);background:linear-gradient(135deg,#38bdf821,#14b8a621);border:1px solid #0ea5e940;border-radius:999px;align-items:center;gap:4px;margin:2px 2px 2px 0;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.chip.amber{color:#92400e;background:linear-gradient(135deg,#fde68a59,#fbbf2433);border-color:#f59e0b66}.chip.green{color:#047857;background:linear-gradient(135deg,#34d3992e,#0d948824);border-color:#10b98159}.roster-widget{border-radius:var(--radius-md);background:#fff9;border:1px solid #0ea5e92e;margin-bottom:10px;overflow:hidden}.roster-widget-head{cursor:pointer;align-items:center;gap:8px;padding:10px 12px;display:flex}.roster-widget-head:hover{background:#0ea5e914}.roster-widget-stats{white-space:nowrap;align-items:center;gap:10px;margin-left:auto;font-size:12px;display:flex}.roster-toggle{color:var(--ink-soft);font-size:13px}.muted{color:var(--ink-faint);font-size:11px}.tip{cursor:help;border-bottom:1px dashed #64748b8c}.tip-bubble{color:#f0f9ff;white-space:normal;overflow-wrap:break-word;opacity:0;pointer-events:none;z-index:4000;background:#0f172af0;border-radius:10px;max-width:min(280px,100vw - 20px);padding:8px 11px;font-size:11px;font-weight:500;line-height:1.55;transition:opacity .16s,transform .16s;position:fixed;top:0;left:0;transform:translateY(4px);box-shadow:0 8px 24px #00000040}.tip-bubble.tip-hidden{display:none}.tip-bubble.tip-show{opacity:1;transform:translateY(0)}.tip-bubble:after{content:"";left:var(--tip-caret,50%);background:#0f172af0;width:10px;height:10px;margin-left:-5px;position:absolute;transform:rotate(45deg)}.tip-bubble[data-placement=above]:after{bottom:-4px}.tip-bubble[data-placement=below]:after{top:-4px}.phase-panel{grid-area:main;max-height:calc(100vh - 250px);padding:18px 20px;position:relative;overflow-y:auto}.phase-view{animation:.35s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stepper{align-items:flex-start;margin:2px 0 16px;padding:4px 0 2px;display:flex;overflow-x:auto}.step{text-align:center;flex-direction:column;flex:1;align-items:center;min-width:60px;display:flex;position:relative}.step:before{content:"";z-index:0;background:#94a3b84d;border-radius:2px;width:100%;height:3px;position:absolute;top:16px;left:-50%}.step:first-child:before{display:none}.step.done:before{background:linear-gradient(90deg,#34d399,#10b981)}.step.current:before{background:linear-gradient(90deg,#10b981,#38bdf8)}.step .bubble{color:#94a3b8;z-index:1;background:#e2e8f0;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:33px;height:33px;font-size:14px;transition:all .25s;display:flex;box-shadow:0 2px 6px #00000014}.step.done .bubble{background:var(--grad-success);color:#fff}.step.current .bubble{background:var(--grad-primary);color:#fff;animation:2.2s ease-in-out infinite pulse;box-shadow:0 0 0 6px #38bdf82e}@keyframes pulse{0%,to{box-shadow:0 0 0 5px #38bdf833}50%{box-shadow:0 0 0 9px #38bdf814}}.step .lbl{color:var(--ink-faint);margin-top:6px;font-size:11px;font-weight:700}.step.current .lbl{color:var(--ocean-700)}.step.done .lbl{color:#0f766e}.phase-brief{border-radius:var(--radius-md);background:linear-gradient(135deg,#38bdf81a,#14b8a61a);border:1px solid #0ea5e938;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-bottom:16px;padding:14px 18px;display:flex}.phase-brief .pb-icon{filter:drop-shadow(0 2px 4px #0284c740);font-size:32px;line-height:1}.phase-brief .pb-text{flex:1;min-width:200px}.phase-brief h2{color:var(--ocean-900);margin-bottom:3px;font-size:18px}.phase-brief p{color:var(--ink-soft);font-size:12.5px;line-height:1.65}.phase-brief .pb-sync{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.btn{--btn-bg:var(--grad-primary);--btn-shadow:#0284c747;background:var(--btn-bg);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:0 3px 10px var(--btn-shadow), inset 0 1px 0 #ffffff47;border:none;border-radius:12px;padding:9px 17px;font-family:inherit;font-size:13px;font-weight:700;transition:transform .16s,box-shadow .16s,filter .16s}.btn:hover:not(:disabled){box-shadow:0 8px 20px var(--btn-shadow), inset 0 1px 0 #ffffff47;filter:saturate(1.12);transform:translateY(-2px)}.btn:active:not(:disabled){transform:translateY(0)scale(.97)}.btn:focus-visible{outline-offset:2px;outline:3px solid #0ea5e973}.btn:disabled{background:var(--grad-grey);cursor:not-allowed;box-shadow:none;opacity:.75;color:#334155}.btn-success{--btn-bg:var(--grad-success);--btn-shadow:#0d94884d}.btn-warning{--btn-bg:var(--grad-warning);--btn-shadow:#f973164d}.btn-danger{--btn-bg:var(--grad-danger);--btn-shadow:#e11d484d}.btn-gold{--btn-bg:var(--grad-gold);--btn-shadow:#f59e0b59;color:#451a03}.btn-grey{--btn-bg:var(--grad-grey);--btn-shadow:#64748b40;color:#334155}.btn-ghost{--btn-bg:#ffffff8c;color:var(--ocean-700);box-shadow:none;background:#ffffff8c;border:1px solid #0ea5e973}.btn-ghost:hover:not(:disabled){filter:none;background:#e0f2fee6}.header .btn-ghost,.control-panel .btn-ghost{color:#fff;background:#ffffff24;border:1px solid #ffffff52}.header .btn-ghost:hover:not(:disabled),.control-panel .btn-ghost:hover:not(:disabled){background:#ffffff42}.btn-lg{border-radius:14px;padding:12px 26px;font-size:14px}.btn-xl{border-radius:16px;padding:15px 34px;font-size:16px}.btn-sub{opacity:.85;margin-top:2px;font-size:10px;font-weight:500;display:block}.btn-shield{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;padding:4px 0;display:grid}.card{background:var(--glass-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);border:1px solid #0ea5e92e;flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden}.card:hover{box-shadow:var(--shadow-float);transform:translateY(-3px)}.golden-order-card{background:radial-gradient(circle at 12% 0,#fde68a61,#0000 34%),linear-gradient(135deg,#fffbebf5,#fef3c7f0 48%,#ffffffeb);border:1px solid #f59e0bbf;position:relative;box-shadow:0 18px 48px #92400e2e}.golden-order-card.final-mandate{grid-column:1/-1}.golden-order-card:before,.golden-order-card:after{content:"";pointer-events:none;background:#f59e0bc7;border-radius:50%;width:7px;height:7px;animation:2.8s ease-in-out infinite mandateSpark;position:absolute;box-shadow:0 0 18px #f59e0be6}.golden-order-card:before{top:12px;right:18px}.golden-order-card:after{animation-delay:-1.4s;bottom:14px;left:20px}.golden-order-card .card-header{color:#fff7ed;letter-spacing:0;background:linear-gradient(135deg,#451a03,#b45309 52%,#f59e0b);border-bottom-color:#f59e0b8c;font-family:Georgia,Times New Roman,Noto Serif SC,serif}.golden-order-card .card-total{color:#78350f;border-top-color:#b4530959}.card-tag.golden{color:#451a03;background:linear-gradient(135deg,#fde68a,#f59e0b);box-shadow:0 2px 8px #f59e0b47}@keyframes mandateSpark{0%,to{opacity:.28;transform:translateY(0)scale(.82)}50%{opacity:1;transform:translateY(-8px)scale(1.16)}}.card-header{color:var(--ocean-900);background:linear-gradient(135deg,#38bdf824,#14b8a61f);border-bottom:1px solid #0ea5e926;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-size:13.5px;font-weight:800;display:flex}.card-tag{color:var(--ocean-700);white-space:nowrap;background:#0ea5e924;border-radius:999px;padding:2px 9px;font-size:10px;font-weight:800}.card-tag.product{color:#92400e;background:#f59e0b29}.card-body{flex:1;padding:12px 14px}.card-footer{border-top:1px solid #94a3b82e;padding:10px 14px}.card-total{color:var(--ocean-900);border-top:1px dashed #94a3b859;justify-content:space-between;margin-top:8px;padding-top:8px;font-size:13px;font-weight:800;display:flex}.resource-row{align-items:center;padding:4px 0;font-size:12.5px;display:flex}.resource-row .icon{margin-right:7px;font-size:16px}.resource-row .name{min-width:64px;font-weight:700}.resource-row .qty{color:var(--ink-soft);margin:0 6px}.resource-row .price{color:var(--ink-faint);margin-left:auto;font-size:11.5px}.price-original{color:var(--ink-faint);text-decoration:line-through}.price-discounted{color:#059669;font-weight:800}.resource-row .inv-status{margin-left:8px;font-size:11px;font-weight:700}.hero-title{text-align:center;background:linear-gradient(120deg,#075985,#0ea5e9 50%,#0d9488);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:18px 0 8px;font-size:30px;font-weight:900}.subtitle-text{color:var(--ink-soft);text-align:center;margin-bottom:18px;font-size:14px}.center-block{max-width:960px;margin:0 auto;padding:10px 6px}.pm-banner{border-radius:var(--radius-md);color:#78350f;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #f59e0b73;align-items:flex-start;gap:12px;margin:14px 0;padding:13px 16px;font-size:12.5px;line-height:1.7;display:flex;box-shadow:0 4px 14px #f59e0b1f}.pm-banner .pm-icon{font-size:24px;line-height:1.2}.pm-banner strong{color:#92400e}.pm-banner a{color:#b45309;font-weight:800;text-decoration-thickness:2px}.pm-banner .pm-close{color:#b45309;cursor:pointer;background:0 0;border:none;flex:none;margin-left:auto;padding:0 2px;font-size:16px}.section-box{background:var(--glass-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);border:1px solid #0ea5e929;margin:14px 0;padding:16px 18px}.section-box h3{color:var(--ocean-900);align-items:center;gap:6px;margin-bottom:8px;font-size:15px;display:flex}.section-hint{color:var(--ink-faint);margin-bottom:10px;font-size:11.5px;line-height:1.6}.environment-banner{border-radius:var(--radius-md);box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#e0f2fed1,#ccfbf1b3);border:1px solid #0ea5e947;align-items:center;gap:12px;margin:0 0 16px;padding:13px 16px;display:flex}.environment-banner .env-icon{font-size:32px;line-height:1}.environment-banner .env-copy{flex:1;min-width:180px}.environment-banner .env-title{color:var(--ocean-900);font-size:14px;font-weight:900}.environment-banner .env-desc{color:var(--ink-soft);margin-top:2px;font-size:12px;line-height:1.55}.environment-banner .env-tags{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.separator{background:linear-gradient(90deg,#0000,#0ea5e966,#0000);border:none;height:1px;margin:16px 0}.profit-positive{color:#059669;font-weight:800}.profit-negative{color:#e11d48;font-weight:800}.boon-card{background:var(--glass-strong);border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-soft);border:1px solid #0ea5e933;padding:18px 14px;transition:transform .2s,box-shadow .2s,border-color .2s}.boon-card:hover{box-shadow:var(--shadow-float);border-color:#f59e0b80;transform:translateY(-5px)}.boon-icon{filter:drop-shadow(0 4px 8px #0284c733);margin:6px 0;font-size:44px}.boon-name{color:var(--ocean-900);margin:6px 0;font-size:15px;font-weight:800}.boon-desc{color:var(--ink-soft);min-height:48px;margin:8px 0 12px;font-size:12px;line-height:1.6}.worker-row{border-radius:var(--radius-sm);background:#ffffffd9;border:1px solid #94a3b840;justify-content:space-between;align-items:center;gap:8px;margin:5px 0;padding:8px 12px;font-size:12px;display:flex}.worker-row .w-state{color:var(--ink-soft)}.worker-row .w-state .busy{color:#b45309;font-weight:700}.worker-row .w-state .idle{color:#059669;font-weight:700}.whisper-panel{border-radius:var(--radius-md);background:linear-gradient(135deg,#fef3c799,#fffbebd9);border:1px solid #f59e0b73;margin:0 0 16px;overflow:hidden;box-shadow:0 4px 14px #f59e0b1f}.whisper-panel summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:#92400e;flex-wrap:wrap;align-items:center;gap:10px;padding:13px 16px;font-size:14px;font-weight:800;list-style:none;transition:background .15s;display:flex}.whisper-panel summary:hover{background:#f59e0b1a}.whisper-panel summary::-webkit-details-marker{display:none}.whisper-panel summary:after{content:"▾";color:#b45309;margin-left:auto;font-size:14px;transition:transform .2s}.whisper-panel:not([open]) summary:after{transform:rotate(-90deg)}.whisper-body{padding:4px 16px 14px}.whisper-clue{border-radius:var(--radius-sm);background:#ffffffeb;border:1px solid #f59e0b4d;align-items:center;gap:8px;margin:6px 0;padding:8px 12px;font-size:12.5px;display:flex}.trade-section{border-radius:var(--radius-md);background:linear-gradient(135deg,#fef3c78c,#fffbebcc);border:1px solid #f59e0b59;margin:14px 0;padding:16px 18px}.trade-section h3{color:#92400e;margin-bottom:4px;font-size:14px}.trade-order{border-radius:var(--radius-sm);background:#ffffffeb;border:1px solid #f59e0b4d;margin:8px 0;padding:12px 14px;font-size:12.5px;line-height:1.7}.trade-order .actions{gap:8px;margin-top:8px;display:flex}.trade-create{font-size:12.5px;line-height:2.1}.trade-create select,.trade-create input{background:#fff;border:1px solid #0ea5e959;border-radius:9px;margin:2px 4px;padding:6px 9px;font-family:inherit;font-size:12px}.trade-create select:focus,.trade-create input:focus{outline:2px solid #0ea5e966}.control-panel{background:var(--grad-deep);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);flex-wrap:wrap;grid-area:actions;align-items:center;gap:10px;padding:10px 16px;display:flex}.sync-chip{color:#fde68a;background:#ffffff26;border:1px solid #ffffff40;border-radius:999px;align-items:center;gap:6px;padding:6px 15px;font-size:12px;font-weight:800;display:inline-flex}.control-spacer{flex:1}.control-hint{color:#e0f2fecc;font-size:11.5px}.log-panel{grid-area:log;height:132px;padding:10px 14px;font-size:11.5px;overflow-y:auto}.log-panel .log-title{letter-spacing:1px;color:var(--ink-faint);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffd9;margin-bottom:4px;padding:3px 0;font-size:11px;font-weight:800;position:sticky;top:-4px}.log-entry{color:var(--ink-soft);border-bottom:1px dotted #94a3b84d;padding:3px 6px}.log-entry:last-child{border-bottom:none}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:var(--z-modal);background:#082f4980;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--glass-strong);-webkit-backdrop-filter:blur(22px)saturate(1.4);backdrop-filter:blur(22px)saturate(1.4);border:1px solid #ffffffb3;border-radius:24px;width:100%;max-width:620px;max-height:90vh;padding:26px 28px;animation:.28s fadeUp;position:relative;overflow-y:auto;box-shadow:0 24px 70px #082f4959}.modal.modal-wide{max-width:780px}.modal h2{color:var(--ocean-900);text-align:center;margin-bottom:14px;font-size:20px}.modal .modal-x{width:30px;height:30px;color:var(--ink-soft);cursor:pointer;background:#94a3b826;border:none;border-radius:50%;font-size:15px;transition:background .15s;position:absolute;top:14px;right:16px}.modal .modal-x:hover{background:#94a3b84d}.diff-options{gap:12px;margin:16px 0 12px;display:flex}.diff-option{border-radius:var(--radius-md);cursor:pointer;background:#f8fafccc;border:2px solid #94a3b859;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 12px;font-family:inherit;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.diff-option:hover{transform:translateY(-2px)}.diff-option.selected{border-color:var(--ocean-500,#0ea5e9);background:#fff;box-shadow:0 6px 18px #0284c72e}.diff-badge{color:#fff;border-radius:999px;padding:3px 14px;font-size:16px;font-weight:800}.diff-badge.diff-easy{background:linear-gradient(135deg,#34d399,#0d9488)}.diff-badge.diff-standard{background:linear-gradient(135deg,#fbbf24,#d97706)}.diff-badge.diff-hard{background:linear-gradient(135deg,#fb7185,#b91c1c)}.diff-tagline{color:var(--ink-soft);text-align:center;font-size:12px;line-height:1.5}.diff-summary{color:#334155;border-radius:var(--radius-md);background:#e0f2fe73;margin-bottom:6px;padding:12px 14px;font-size:13px;line-height:1.85}.chip.diff-easy{color:#0f766e;background:#0d948829}.chip.diff-standard{color:#b45309;background:#d9770629}.chip.diff-hard{color:#b91c1c;background:#b91c1c24}.manual-tabs{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:14px;display:flex}.mtab{color:var(--ink-soft);cursor:pointer;background:#94a3b82e;border:none;border-radius:999px;padding:7px 15px;font-family:inherit;font-size:12px;font-weight:700;transition:all .15s}.mtab:hover{background:#38bdf833}.mtab.active{background:var(--grad-primary);color:#fff;box-shadow:0 3px 10px #0284c74d}.manual-body{color:#334155;max-height:50vh;padding:2px 8px 2px 2px;font-size:13px;line-height:1.85;overflow-y:auto}.manual-body h4{color:var(--ocean-900);margin:14px 0 6px;font-size:14.5px}.manual-body h4:first-child{margin-top:0}.manual-body ul,.manual-body ol{margin:4px 0 10px;padding-left:22px}.manual-body li{margin:3px 0}.manual-body table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;margin:8px 0 12px;font-size:12px;overflow:hidden}.manual-body th,.manual-body td{text-align:left;border:1px solid #94a3b859;padding:6px 9px}.manual-body th{color:var(--ocean-900);background:#e0f2fecc}.kbd{color:#fff;background:#0f172a;border-radius:6px;padding:1px 8px;font-size:11px;font-weight:700}#login-overlay,#lobby-overlay{z-index:var(--z-overlay);background:radial-gradient(900px 500px at 15% 10%,#7dd3fc66,#0000 65%),radial-gradient(800px 500px at 85% 90%,#5eead466,#0000 65%),linear-gradient(#e0f2fe,#ccfbf1);justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.login-box,.lobby-box{background:var(--glass-strong);-webkit-backdrop-filter:blur(24px)saturate(1.4);backdrop-filter:blur(24px)saturate(1.4);text-align:center;border:1px solid #ffffffbf;border-radius:26px;width:100%;max-width:460px;padding:34px 32px;animation:.4s fadeUp;box-shadow:0 24px 70px #082f4938}.login-brand .logo{filter:drop-shadow(0 6px 14px #0284c74d);font-size:50px}.login-brand h2{background:linear-gradient(120deg,#075985,#0ea5e9 50%,#0d9488);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:8px 0 2px;font-size:26px;font-weight:900}.login-brand .tagline{color:var(--ink-soft);margin-bottom:16px;font-size:12.5px}.login-box input{background:#ffffffe6;border:1px solid #0ea5e959;border-radius:13px;width:100%;margin:7px 0;padding:12px 15px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-box input:focus{border-color:var(--ocean-500);outline:none;box-shadow:0 0 0 4px #0ea5e926}.login-box .btn{width:100%;margin:6px 0}.pm-note{color:#92400e;text-align:left;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #f59e0b66;border-radius:13px;margin-top:16px;padding:10px 13px;font-size:11.5px;line-height:1.7}.pm-note a{color:#b45309;font-weight:800}.lobby-box{text-align:left;max-width:680px;max-height:84vh;overflow-y:auto}.lobby-box h2{text-align:center;color:var(--ocean-900)}.lobby-sub{text-align:center;color:var(--ink-soft);margin:6px 0 4px;font-size:12.5px;line-height:1.7}.online-user-item{border-radius:var(--radius-md);background:#ffffffe6;border:1px solid #0ea5e933;justify-content:space-between;align-items:center;margin:8px 0;padding:12px 16px;transition:transform .15s,box-shadow .15s;display:flex}.online-user-item:hover{box-shadow:var(--shadow-soft);transform:translateY(-2px)}.online-user-item .u-name{color:var(--ocean-900);align-items:center;gap:8px;font-weight:700;display:flex}#chat-window{background:var(--glass-strong);-webkit-backdrop-filter:blur(20px)saturate(1.4);backdrop-filter:blur(20px)saturate(1.4);width:350px;height:480px;z-index:var(--z-chat);border:1px solid #ffffffb3;border-radius:20px;flex-direction:column;display:none;position:fixed;bottom:22px;right:22px;overflow:hidden;box-shadow:0 18px 50px #082f4947}#chat-header{background:var(--grad-deep);color:#fff;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;font-weight:700;display:flex}#chat-messages{flex:1;padding:12px;overflow-y:auto}.chat-bubble{word-wrap:break-word;border-radius:15px;max-width:80%;margin:7px 0;padding:8px 13px;font-size:12.5px;line-height:1.55;animation:.2s fadeUp}.chat-bubble.sent{background:var(--grad-primary);color:#fff;border-bottom-right-radius:5px;margin-left:auto;box-shadow:0 3px 8px #0284c740}.chat-bubble.received{background:#fffffff2;border:1px solid #94a3b84d;border-bottom-left-radius:5px}#chat-input-area{border-top:1px solid #94a3b840;gap:8px;padding:10px 12px;display:flex}#chat-input{background:#ffffffe6;border:1px solid #0ea5e959;border-radius:999px;flex:1;padding:9px 13px;font-family:inherit;font-size:12.5px}#chat-input:focus{border-color:var(--ocean-500);outline:none;box-shadow:0 0 0 3px #0ea5e926}#toast-stack{z-index:var(--z-toast);pointer-events:none;flex-direction:column;align-items:flex-end;gap:10px;max-width:380px;display:flex;position:fixed;top:20px;right:20px}.notification{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#f0fdfa;pointer-events:auto;background:#0f172aeb;border-left:4px solid #10b981;border-radius:14px;max-width:360px;padding:13px 20px 13px 16px;font-size:13px;line-height:1.55;animation:.3s cubic-bezier(.2,.8,.3,1.1) slideIn;box-shadow:0 12px 32px #0000004d}.notification.error{border-left-color:#fb7185}.notification.log{border-left-color:#38bdf8}.notification.fading{animation:.4s forwards toastFadeOut}@keyframes slideIn{0%{opacity:0;transform:translate(420px)}to{opacity:1;transform:translate(0)}}@keyframes toastFadeOut{to{opacity:0;transform:translate(420px)}}.spectate-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1500;background:#082f4973;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.spectate-window{background:var(--glass-strong);-webkit-backdrop-filter:blur(22px)saturate(1.4);backdrop-filter:blur(22px)saturate(1.4);border:1px solid #ffffffb3;border-radius:22px;flex-direction:column;width:min(940px,100%);max-height:88vh;animation:.28s fadeUp;display:flex;overflow:hidden;box-shadow:0 24px 70px #082f4966}.spectate-head{background:var(--grad-deep);color:#fff;flex:none;align-items:center;gap:12px;padding:13px 18px;display:flex}.spectate-head .sp-title{flex:1;min-width:0;font-size:15px;font-weight:800}.spectate-head .sp-sub{color:#e0f2fed9;margin-top:2px;font-size:11px;font-weight:500}.sp-live{color:#fecdd3;letter-spacing:1px;background:#f43f5e38;border:1px solid #f43f5e8c;border-radius:999px;flex:none;align-items:center;gap:6px;padding:3px 11px;font-size:11px;font-weight:800;display:inline-flex}.sp-live-dot{background:#fb7185;border-radius:50%;width:7px;height:7px;animation:1.6s ease-in-out infinite livePulse}@keyframes livePulse{0%,to{box-shadow:0 0 #fb71858c}50%{box-shadow:0 0 0 5px #fb718500}}.spectate-head .sp-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex:none;width:30px;height:30px;font-size:16px;transition:background .15s}.spectate-head .sp-close:hover{background:#ffffff4d}.spectate-body{align-items:stretch;gap:16px;min-height:0;padding:14px 18px;display:flex}.sp-names{border-right:1px solid #94a3b840;flex-direction:column;flex:none;gap:5px;width:168px;padding-right:14px;display:flex;overflow-y:auto}.sp-name-item{cursor:pointer;color:var(--ocean-900);background:#ffffff80;border-radius:10px;align-items:center;gap:7px;padding:9px 10px;font-size:12.5px;font-weight:700;transition:background .15s;display:flex}.sp-name-item:hover{background:#0ea5e924}.sp-name-item.active{background:var(--grad-primary);color:#fff;box-shadow:0 3px 10px #0284c74d}.sp-name-item .nm{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sp-detail{flex:1;grid-template-columns:1fr 1fr;align-items:start;gap:0 14px;min-width:0;display:grid;overflow-y:auto}.sp-detail .sp-col{min-width:0}.sp-detail .sp-wide{grid-column:1/-1}.spectate-foot{color:var(--ink-faint);background:#ffffff8c;border-top:1px solid #94a3b840;flex:none;padding:10px 18px;font-size:11.5px}@media (width<=760px){.spectate-body{flex-direction:column}.sp-names{border-bottom:1px solid #94a3b840;border-right:none;flex-direction:row;width:auto;padding-bottom:10px;padding-right:0;overflow-x:auto}.sp-detail{grid-template-columns:1fr}}@media (width<=1280px){#app{grid-template-columns:260px minmax(0,1fr) 260px}}@media (width<=1024px){#app{grid-template-columns:1fr;grid-template-areas:"header""main""me""partner""actions""log"}.side-panel{max-height:340px}.phase-panel{max-height:none}}.btn:active:not(:disabled){filter:brightness(.92)saturate(1.12);box-shadow:0 1px 4px var(--btn-shadow), inset 0 2px 7px #00000038;transform:translateY(1px)scale(.94)}.btn:focus-visible{box-shadow:0 0 0 3px #0ea5e973, 0 3px 10px var(--btn-shadow);outline:none}.notification.clickable{cursor:pointer}.notification.clickable:hover{filter:brightness(1.14);transform:translate(-3px)}
