:root{--bg-0:#0a1020;--bg-1:#0b1426;--bg-2:#0e1830;--panel:#0d1730;--panel-2:#101c38;--panel-3:#0e1a33;--line:#1f2a44;--line-strong:#2a3a5c;--text:#e7ecf5;--text-dim:#9aa6c0;--text-mute:#6b7894;--accent:#3aa1ff;--accent-2:#7c5cff;--green:#10a37f;--gold:#f5b73d;--shadow: 0 1px 0 rgba(255,255,255,.02) inset, 0 0 0 1px rgba(255,255,255,.02) inset;font-family:Segoe UI,Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;height:100%}body{color:var(--text);background:radial-gradient(1200px 700px at 85% -10%,rgba(80,60,180,.18),transparent 60%),radial-gradient(900px 600px at 0% 110%,rgba(30,60,140,.18),transparent 60%),linear-gradient(180deg,#0a1326,#0a1020);min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased;overflow-x:hidden}button{font-family:inherit}header.topbar{height:64px;display:flex;align-items:center;padding:0 28px;gap:18px}.ms-logo{display:flex;align-items:center;gap:10px}.ms-logo svg{display:block}.ms-logo .ms-word{font-size:20px;font-weight:400;color:#fff;letter-spacing:.2px}.divider-v{width:1px;height:24px;background:#2a3046;margin:0 4px}.app-title{font-size:18px;font-weight:400;color:#e7ecf5;letter-spacing:.2px}.app-title-button{padding:0;border:0;background:transparent;cursor:pointer}.app-title-button:hover{color:#fff}.preview-pill{margin-left:10px;border:1px solid #4a5577;color:#cfd6e6;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:400;background:transparent}.top-right{margin-left:auto;display:flex;align-items:center;gap:22px;color:#cfd6e6;font-size:14px}.top-right .chip{display:flex;align-items:center;gap:8px;cursor:pointer}.top-right .chip svg{display:block}.avatar-picker{position:relative;display:flex;align-items:center}.avatar{width:36px;height:36px;border-radius:50%;background:#0e1a35;border:1px solid rgba(255,255,255,.18);padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;box-shadow:var(--shadow)}.avatar:hover{border-color:#5aa8ff}.avatar img{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.avatar-menu{position:absolute;right:0;top:calc(100% + 12px);z-index:25;width:220px;border:1px solid #2a3a5c;border-radius:8px;background:linear-gradient(180deg,#101c38,#0d1730);box-shadow:0 18px 48px #00000061,var(--shadow);padding:8px;display:flex;flex-direction:column;gap:6px}.avatar-menu:before{content:"";position:absolute;right:12px;top:-6px;width:10px;height:10px;background:#101c38;border-left:1px solid #2a3a5c;border-top:1px solid #2a3a5c;transform:rotate(45deg)}.avatar-option{width:100%;min-height:46px;border:1px solid transparent;border-radius:8px;background:transparent;color:#cfd6e6;display:flex;align-items:center;gap:10px;padding:7px 8px;font-size:13.5px;font-weight:500;text-align:left;cursor:pointer}.avatar-option:hover{background:#121d39;border-color:#26395f;color:#fff}.avatar-option.is-selected{background:#123d35;border-color:#1f9d6a;color:#fff}.avatar-option img{width:32px;height:32px;border-radius:50%;display:block;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.app{display:grid;grid-template-columns:280px 1fr;gap:0;padding:0 22px 22px;align-items:start}aside.sidebar{background:linear-gradient(180deg,#0f1830,#0c1428);border:1px solid #1a2440;border-radius:10px;padding:22px 20px 18px;min-height:calc(100vh - 96px);display:flex;flex-direction:column;box-shadow:var(--shadow)}.puzzle-no{font-size:13px;color:#aab4cc;margin:0 0 6px;font-weight:400}.puzzle-title{font-size:22px;font-weight:600;margin:0 0 12px;color:#fff;letter-spacing:.1px}.puzzle-desc{font-size:13.5px;line-height:1.55;color:#aeb8d0;margin:0 0 14px}.view-inst{display:inline-flex;align-items:center;gap:8px;color:#5aa8ff;font-size:13.5px;text-decoration:none;margin-bottom:22px}.view-inst svg{display:block}.tabs{display:flex;gap:24px;border-bottom:1px solid #1d2742;margin-bottom:16px}.tab{padding:10px 2px;font-size:13px;letter-spacing:.6px;color:#7d8aa6;cursor:pointer;font-weight:600}.tab.active{color:#e7ecf5;border-bottom:2px solid #5aa8ff;margin-bottom:-1px}.hint-text{font-size:13px;color:#9aa6c0;line-height:1.5;margin:6px 0 14px}.cards,.card-group{display:flex;flex-direction:column;gap:10px}.card-group+.card-group{margin-top:6px}.card-group-title{font-size:12px;font-weight:600;letter-spacing:.6px;color:#9aa6c0;text-transform:uppercase;margin:2px 0 -2px}.card{display:flex;align-items:center;gap:12px;background:#121d39;border:1px solid #1f2c4d;border-radius:8px;padding:10px 12px;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:border-color .15s,transform .05s;touch-action:none}.card:hover{border-color:#2d3e6a}.card.highlighted{border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a inset}.card.dragging{opacity:.55}.card.drag-overlay{box-shadow:0 14px 32px #00000059;cursor:grabbing}.card .ic{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card .label{flex:1;min-width:0;font-size:14px;font-weight:600;color:#e7ecf5;line-height:1.2}.card .sub{display:block;font-size:11.5px;color:#7e8aa4;font-weight:400;margin-top:3px}.drag-dots{width:14px;height:18px;opacity:.55;background-image:radial-gradient(circle,#8b95ad 1.2px,transparent 1.3px);background-size:5px 5px;background-position:0 0;flex-shrink:0}.ic.green{background:#10a37f}.ic.purple{background:#6c4ed8}.ic.blue{background:#1f86d9}.ic.purple-soft{background:#7b5cff}.ic.blue-soft{background:linear-gradient(135deg,#3aa1ff,#7c5cff)}.hint-row{margin-top:auto;padding-top:16px;display:flex;align-items:center;gap:14px}.hint-row .need{font-size:13.5px;color:#aeb8d0}.btn-hint{margin-left:auto;display:inline-flex;align-items:center;gap:8px;background:#0e1a35;border:1px solid #2a3a5c;color:#dbe3f4;border-radius:8px;padding:8px 14px;font-size:13.5px;cursor:pointer}.btn-hint svg{color:#5aa8ff}main.content{padding-left:22px;display:flex;flex-direction:column;gap:18px}.top-row{display:grid;grid-template-columns:1fr 200px;gap:18px}.goal{background:linear-gradient(180deg,#0f2348,#0c1c3a);border:1px solid #1f3c70;border-radius:10px;padding:16px 20px;display:flex;gap:14px;align-items:flex-start}.goal .i-ic{width:22px;height:22px;border-radius:50%;border:1.5px solid #5aa8ff;color:#5aa8ff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;margin-top:1px;flex-shrink:0;font-family:Segoe UI,serif}.goal h3{margin:0 0 4px;font-size:15px;font-weight:600;color:#fff}.goal p{margin:0;font-size:13.5px;color:#c4cee2;line-height:1.55}.goal b{color:#dbe3f4;font-weight:600}.points{background:#0d1830;border:1px solid #1f2c4d;border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:14px}.points .trophy{color:#f5b73d}.points .num{font-size:22px;font-weight:600;color:#fff;line-height:1}.points .lbl{font-size:13px;color:#aeb8d0;margin-top:4px}.canvas{background:radial-gradient(800px 400px at 50% 0%,rgba(60,90,180,.05),transparent 60%),#0a1428;border:1px dashed #2b3a5e;border-radius:12px;padding:28px 28px 32px;position:relative;background-image:radial-gradient(circle,#1a2745 1px,transparent 1.2px),linear-gradient(180deg,#0b1530,#0a1224);background-size:22px 22px,100% 100%;background-position:0 0,0 0}.header-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr) 28px) minmax(0,1fr);align-items:center;margin-bottom:14px;position:relative}.head-cell{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.head-num{width:30px;height:30px;border-radius:50%;border:1px solid #3a486a;color:#cfd6e6;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;background:#0c1730}.head-lbl{font-size:13px;color:#aeb8d0}.head-arrow{color:#4a587a;font-size:20px;line-height:1;text-align:center;transform:translateY(-10px)}.diagram-divider{height:1px;margin:0 0 15px;background:linear-gradient(90deg,transparent 0%,rgba(58,72,106,.72) 8%,rgba(58,72,106,.72) 92%,transparent 100%)}.diagram{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:auto auto auto;align-items:center;-moz-column-gap:8px;column-gap:8px;row-gap:18px;padding:10px 0 4px;position:relative}.diagram.sentence-diagram{-moz-column-gap:12px;column-gap:12px;row-gap:24px}.node{width:120px;height:108px;margin:0 auto;border:1.5px dashed #3a486a;border-radius:10px;background:#0c1730;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative}.node.sentence-node{width:min(184px,100%);height:auto;min-height:148px;padding:18px 10px 12px;gap:7px}.node .badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);width:24px;height:24px;border-radius:50%;background:#0c1730;border:1px solid #3a486a;color:#cfd6e6;font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:center}.node .badge.purple{background:#6c4ed8;border-color:#6c4ed8;color:#fff;font-weight:600}.node .nlabel{font-size:13px;color:#cfd6e6;text-align:center;line-height:1.2;max-width:104px}.node.sentence-node .nlabel{max-width:100%;font-size:11.5px;line-height:1.24;overflow-wrap:break-word}.node .placed-label{font-size:12.5px}.node.filled{background:#0e1a33;border-style:solid;border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a}.node.filled .nlabel{color:#fff}.node.drop-placeholder{cursor:copy}.node.drop-placeholder.is-over{border-color:#5aa8ff;box-shadow:0 0 0 1px #5aa8ffa6}.node.drop-placeholder.is-over-valid{border-style:solid;border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a}.node.drop-placeholder.is-over-invalid{border-style:solid;border-color:#e5484d;box-shadow:0 0 0 1px #e5484d}.node.drop-placeholder.is-filled{background:#0e1a33}.node.drop-placeholder.is-correct{border-style:solid;border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a}.node.drop-placeholder.is-incorrect{border-style:solid;border-color:#e5484d;box-shadow:0 0 0 1px #e5484d}.row-top,.row-mid,.row-bot{display:contents}.conns{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.footer{display:flex;align-items:center;justify-content:space-between;margin-top:22px;gap:18px}.note-wrapper{display:flex;justify-content:center;margin-top:26px}.note{flex:1;background:#0d1730;border:1px solid #1f2c4d;border-radius:10px;padding:14px 22px;text-align:center;color:#aeb8d0;font-size:13.5px;line-height:1.55;max-width:760px;margin:0 auto}.actions-left,.actions-right{display:flex;align-items:center;gap:18px}.icon-btn{display:inline-flex;align-items:center;gap:8px;background:#0e1a35;border:1px solid #2a3a5c;color:#dbe3f4;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;padding:10px 18px}.icon-btn:hover{color:#fff;border-color:#3a4d78}.btn{display:inline-flex;align-items:center;gap:10px;background:#0e1a35;border:1px solid #2a3a5c;color:#e7ecf5;border-radius:8px;padding:10px 22px;font-size:14px;font-weight:500;cursor:pointer}.btn:hover{border-color:#3a4d78}.btn-primary{background:#123d35;border-color:#1f9d6a;color:#fff}.btn-primary:hover{border-color:#28c184;background:#16483f}.btn.disabled{color:#6b7894;cursor:not-allowed;opacity:.6}.btn.disabled:hover{border-color:#2a3a5c}.bottom-bar{display:grid;grid-template-columns:1fr 1fr;align-items:center;margin-top:14px}.bottom-bar .actions-right{justify-content:flex-end}.completion-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:28px;background:#040812bd;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.completion-dialog{width:min(420px,100%);border:1px solid #2a3a5c;border-radius:8px;background:linear-gradient(180deg,#101c38,#0d1730);box-shadow:0 24px 60px #0000006b,var(--shadow);padding:28px;text-align:center}.completion-icon{width:66px;height:66px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:#f5b73d;background:#17213d;border:1px solid #33415f}.completion-icon .trophy{width:42px;height:42px}.completion-kicker{margin:0 0 6px;color:#9aa6c0;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.completion-dialog h2{margin:0;color:#fff;font-size:26px;font-weight:600;letter-spacing:0}.completion-copy{margin:10px 0 22px;color:#c4cee2;font-size:14px;line-height:1.5}.completion-cta{width:100%;justify-content:center}.card-info-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:28;display:flex;align-items:center;justify-content:center;padding:28px;background:#040812a3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-info-dialog{width:min(380px,100%);border:1px solid #2a3a5c;border-radius:8px;background:linear-gradient(180deg,#101c38,#0d1730);box-shadow:0 18px 48px #00000061,var(--shadow);padding:24px;position:relative}.card-info-close{position:absolute;top:12px;right:14px;background:transparent;border:0;color:#9aa6c0;font-size:22px;cursor:pointer;padding:0;line-height:1}.card-info-close:hover{color:#fff}.card-info-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.card-info-header .ic{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-info-label{font-size:16px;font-weight:600;color:#fff}.card-info-title{margin:0 0 6px;font-size:14px;font-weight:600;color:#cfd6e6}.card-info-body{margin:0 0 18px;font-size:13.5px;line-height:1.55;color:#aeb8d0}.card-info-cta{display:inline-flex;text-decoration:none;justify-content:center;width:100%}.node-info-btn{position:absolute;top:-10px;right:-10px;z-index:2;width:22px;height:22px;border-radius:50%;border:1.5px solid #5aa8ff;background:#0c1730;color:#5aa8ff;font-size:12px;font-weight:600;font-family:Segoe UI,serif;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.node-info-btn:hover{background:#162a50;color:#fff;border-color:#fff}.match-info-btn{margin-left:auto;width:22px;height:22px;border-radius:50%;border:1.5px solid #5aa8ff;background:#0c1730;color:#5aa8ff;font-size:12px;font-weight:600;font-family:Segoe UI,serif;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0}.match-info-btn:hover{background:#162a50;color:#fff;border-color:#fff}.match-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;padding:10px 0 4px}.match-slot{min-height:184px;border:1.5px dashed #3a486a;border-radius:8px;background:#0c1730;padding:16px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s,box-shadow .15s,background .15s}.match-slot.is-over{border-color:#5aa8ff;box-shadow:0 0 0 1px #5aa8ffa6}.match-slot.is-over-valid{border-style:solid;border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a}.match-slot.is-over-invalid{border-style:solid;border-color:#e5484d;box-shadow:0 0 0 1px #e5484d}.match-slot.is-filled{background:#0e1a33}.match-slot.is-correct{border-style:solid;border-color:#1f9d6a;box-shadow:0 0 0 1px #1f9d6a}.match-slot.is-incorrect{border-style:solid;border-color:#e5484d;box-shadow:0 0 0 1px #e5484d}.match-slot-head{display:flex;align-items:center;gap:10px;color:#9aa6c0;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.match-description{margin:0;color:#cfd6e6;font-size:13.5px;line-height:1.48}.match-placement{margin-top:auto;min-height:46px;border:1px solid #1f2c4d;border-radius:8px;background:#0b1428;color:#7e8aa4;display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:600;text-align:center}.match-placement.is-filled{justify-content:flex-start;color:#fff;background:#121d39;border-color:#1f9d6a;text-align:left}.match-placement .ic{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home{padding:0 22px 34px;max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.home-intro{display:grid;grid-template-columns:1fr auto;align-items:end;gap:28px;padding:34px 0 4px}.home-kicker{margin:0 0 8px;color:#5aa8ff;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.home h1{margin:0;color:#fff;font-size:34px;font-weight:600;letter-spacing:0;line-height:1.12}.home-copy{margin:12px 0 0;color:#aeb8d0;font-size:14px;line-height:1.55;max-width:640px}.home-start{min-height:52px;padding:14px 24px;font-size:16px;white-space:nowrap}.home-puzzle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.home-puzzle-card{min-height:230px;background:#0d1730;border:1px solid #1f2c4d;border-radius:8px;padding:18px;display:flex;flex-direction:column;box-shadow:var(--shadow)}.home-puzzle-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#9aa6c0;font-size:12px;margin-bottom:14px}.home-puzzle-card h2{margin:0;color:#fff;font-size:18px;font-weight:600;letter-spacing:0;line-height:1.25}.home-puzzle-card p{margin:10px 0 18px;color:#aeb8d0;font-size:13.5px;line-height:1.5}.home-puzzle-cta{margin-top:auto;justify-content:center;width:100%}@media (max-width: 760px){.home-intro{grid-template-columns:1fr;align-items:start}.home-start{width:100%;justify-content:center}.home h1{font-size:28px}}.sr{position:absolute;left:-9999px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.fixed{position:fixed}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}
