:root{--frame-verb:#e23a32;--frame-noun:#d8a313;--frame-adj:#2b8fd8;--frame-prep:#38a350;--frame-adverb:#ec8a2c;--frame-neutral:#6b6f7a;--bg:#14182a;--bg-2:#1c2238;--bg-3:#262d49;--panel:#fff;--panel-2:#f3f5fb;--ink:#f4f6ff;--ink-muted:#b8c0d9;--ink-dark:#1a1d2e;--line:#2a3050;--accent:#f6c545;--danger:#e23a32;--ok:#38a350;--radius-sm:6px;--radius:12px;--radius-lg:20px;--shadow-1:0 1px 2px #00000014, 0 4px 12px #0000000f;--shadow-2:0 4px 16px #0000002e, 0 16px 48px #0003;--font:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;--font-display:"Inter", var(--font)}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font);color:var(--ink);background:radial-gradient(1200px 600px at 20% -10%, #2a335a 0%, transparent 60%), radial-gradient(1000px 500px at 90% 110%, #3a2858 0%, transparent 60%), var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.5}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}input,textarea,select{font:inherit;color:inherit}.app-shell{grid-template-rows:auto 1fr auto;min-height:100%;display:grid}.topbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#14182ab3;align-items:center;gap:24px;padding:14px 24px;display:flex;position:sticky;top:0}.brand{letter-spacing:.06em;align-items:center;gap:10px;font-weight:800;display:flex}.brand-mark{border-radius:8px;width:32px;height:32px;display:block}.brand-name{font-family:var(--font-display);font-size:16px}.nav{gap:12px;margin-left:16px;display:flex}.nav a{color:var(--ink-muted);border-radius:999px;padding:6px 12px;font-size:14px;font-weight:600;transition:background .15s,color .15s}.nav a:hover{color:var(--ink);background:#ffffff0d}.nav a.active{color:var(--ink-dark);background:var(--accent)}.topbar .lang-switcher{margin-left:auto}.main{width:100%;max-width:1400px;margin:0 auto;padding:24px}.footer{text-align:center;color:var(--ink-muted);border-top:1px solid var(--line);padding:14px 24px;font-size:12px}.btn{background:var(--panel);color:var(--ink-dark);border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 16px;font-weight:600;transition:transform 40ms,box-shadow .15s,background .15s;display:inline-flex}.btn:hover{box-shadow:var(--shadow-1)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:var(--ink-dark)}.btn.ghost{color:inherit;background:0 0;border-color:#7f7f7f59}.btn.ghost:hover{background:#7f7f7f14}.btn.danger{background:var(--danger);color:#fff}.card{background:var(--panel);color:var(--ink-dark);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);padding:24px}.card.dark{background:var(--bg-2);color:var(--ink)}.hero{grid-template-columns:1.2fr 1fr;align-items:center;gap:40px;padding:40px 0;display:grid}@media (max-width:880px){.hero{grid-template-columns:1fr}}.hero h1{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 16px;font-size:clamp(36px,6vw,64px);line-height:1.05}.hero p.lede{color:var(--ink-muted);max-width:56ch;margin:0 0 24px;font-size:18px}.hero .cta-row{flex-wrap:wrap;gap:12px;display:flex}.lang-switcher{border:1px solid var(--line);background:#ffffff0d;border-radius:999px;padding:2px;display:inline-flex}.lang-switcher button{color:var(--ink-muted);letter-spacing:.04em;background:0 0;border:0;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.lang-switcher button.active{background:var(--accent);color:var(--ink-dark)}.board-grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}@media (max-width:1100px){.board-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.board-grid{grid-template-columns:1fr}}.board{aspect-ratio:1/1.06;background:#57c3e0;border-radius:14px;grid-template-rows:22px 1fr 22px;grid-template-columns:22px 1fr 18px;gap:2px;padding:4px;display:grid;position:relative}.board__inner{background:#fff;border-radius:4px;grid-area:2/2;grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr);gap:4px;padding:5px;display:grid}.board__id{color:#fff;place-items:center;font-size:14px;font-weight:900;display:grid}.board__id--tl{grid-area:1/3}.board__id--br{grid-area:3/1}.board__theme{color:#fff;letter-spacing:.06em;writing-mode:vertical-rl;text-transform:uppercase;text-align:center;grid-area:2/3;place-items:center;font-size:11px;font-weight:700;display:grid}.board__row-labels{color:#fff;grid-area:2/1;grid-template-rows:repeat(4,1fr);font-size:14px;font-weight:900;display:grid}.board__row-labels span{place-items:center;display:grid}.board__col-labels{color:#fff;grid-area:3/2;grid-template-columns:repeat(4,1fr);font-size:14px;font-weight:900;display:grid}.board__col-labels span{place-items:center;display:grid}.icon-cell{-webkit-user-select:none;user-select:none;cursor:pointer;background:#fff;border:1.5px solid #1a1d2e;border-radius:2px;place-items:center;transition:transform 60ms,box-shadow .15s;display:grid;position:relative;overflow:hidden}.icon-cell img{object-fit:contain;pointer-events:none;width:100%;height:100%}.icon-cell:hover{box-shadow:0 0 0 2px var(--accent) inset;z-index:2}.icon-cell.disabled{cursor:default}.frame,.frame *{pointer-events:none}.frame{--frame-color:var(--frame-noun);border:5px solid var(--frame-color);border-radius:4px;position:absolute;inset:-3px;box-shadow:0 0 0 1px #0003}.frame.plural{box-shadow:inset 0 0 0 3px white, inset 0 0 0 7px var(--frame-color), 0 0 0 1px #0003;border-width:4px}.frame.verb{--frame-color:var(--frame-verb)}.frame.noun{--frame-color:var(--frame-noun)}.frame.adj{--frame-color:var(--frame-adj)}.frame.prep{--frame-color:var(--frame-prep)}.frame.adverb{--frame-color:var(--frame-adverb)}.frame.neutral{--frame-color:var(--frame-neutral)}.frame__order{background:var(--frame-color);color:#fff;border-radius:10px;place-items:center;min-width:20px;height:20px;padding:0 5px;font-size:13px;font-weight:900;display:grid;position:absolute;bottom:-4px;right:-4px;box-shadow:0 0 0 2px #fff,0 1px 2px #00000040}.frame__sash{color:#fff;background:#14182ad6;border-top-left-radius:4px;border-top-right-radius:4px;align-items:center;gap:6px;height:16px;padding:2px 6px;display:flex;position:absolute;bottom:0;left:4px;right:26px}.frame__pin{font-size:11px;font-weight:800;line-height:1}.frame__pin--neg{color:#ff7670}.tense-bar{align-items:center;gap:1px;display:inline-flex}.tense-bar__dot{background:#ffffff4d;border:1px solid #ffffffb3;border-radius:50%;width:4px;height:4px}.tense-bar__dot.active{background:#fff;border-color:#fff;box-shadow:0 0 0 1px #f6c545}.tense-bar__line{background:#ffffff8c;width:5px;height:1px}.composer{grid-template-columns:1fr 340px;gap:24px;display:grid}@media (max-width:1100px){.composer{grid-template-columns:1fr}}.panel{background:var(--panel);color:var(--ink-dark);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:16px}.panel h3{margin:0 0 12px;font-size:16px}.sentence-track{background:var(--panel-2);border:1px dashed #c5cde0;border-radius:10px;flex-wrap:wrap;gap:8px;min-height:56px;padding:8px;display:flex}.sentence-token{color:var(--ink-dark);border:2px solid var(--frame-noun);cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-family:inherit;font-size:13px;font-weight:700;transition:transform 60ms,box-shadow .15s;display:inline-flex}.sentence-token:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.sentence-token:active{transform:translateY(0)}.sentence-token .pos{color:var(--ink-muted);font-size:11px;font-weight:600}.sentence-token.verb{border-color:var(--frame-verb)}.sentence-token.noun{border-color:var(--frame-noun)}.sentence-token.adj{border-color:var(--frame-adj)}.sentence-token.prep{border-color:var(--frame-prep)}.sentence-token.adverb{border-color:var(--frame-adverb)}.sentence-token.neutral{border-color:var(--frame-neutral)}label.field{color:var(--ink-dark);margin:10px 0;font-size:13px;font-weight:600;display:block}label.field input,label.field select,label.field textarea{width:100%;color:var(--ink-dark);background:#fff;border:1px solid #d6dbed;border-radius:10px;margin-top:4px;padding:10px 12px;display:block}textarea{resize:vertical}.timer{background:var(--bg-3);color:var(--ink);font-variant-numeric:tabular-nums;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-weight:800;display:inline-flex}.timer.warning{background:var(--frame-adverb);color:#fff}.timer.danger{background:var(--danger);color:#fff}.feedback-fab{z-index:60;background:var(--accent);color:var(--ink-dark);letter-spacing:.02em;cursor:pointer;border:0;border-radius:999px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:800;transition:transform .1s,box-shadow .15s;display:inline-flex;position:fixed;bottom:18px;left:18px;box-shadow:0 6px 18px #00000059,0 2px 6px #0003}.feedback-fab:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0006,0 2px 6px #0003}.feedback-fab:active{transform:translateY(0)}.feedback-card{gap:12px;width:100%;max-width:540px;max-height:calc(100vh - 32px);display:grid;overflow-y:auto}.feedback-contact summary{cursor:pointer;background:var(--panel-2);color:var(--ink-dark);border-radius:6px;padding:6px 8px;font-size:13px;font-weight:600;list-style:none}.feedback-contact summary::-webkit-details-marker{display:none}.feedback-contact summary:before{content:"▸";margin-right:6px;transition:transform .15s;display:inline-block}.feedback-contact[open] summary:before{transform:rotate(90deg)}.feedback-contact .optional{color:var(--ink-muted);font-weight:400}.feedback-contact__note{border-left:3px solid var(--accent);color:var(--ink-dark);background:#fff8e3;border-radius:0 6px 6px 0;margin:8px 0;padding:8px 10px;font-size:12px}.feedback-dropzone{background:var(--panel-2);cursor:pointer;text-align:center;border:2px dashed #c5cde0;border-radius:10px;gap:4px;padding:14px;transition:border-color .15s,background .15s;display:grid}.feedback-dropzone:hover{border-color:var(--accent);background:#faf6ea}.feedback-files{gap:6px;max-height:200px;margin:0;padding:0;list-style:none;display:grid;overflow-y:auto}.feedback-files li{background:var(--panel-2);border-radius:6px;grid-template-columns:40px 1fr auto auto;align-items:center;gap:8px;padding:4px 8px;font-size:13px;display:grid}.feedback-files img{object-fit:cover;border-radius:4px;width:40px;height:40px}.feedback-files__icon{text-align:center;font-size:24px}.feedback-files__name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.feedback-files__size{color:var(--ink-muted);font-variant-numeric:tabular-nums;font-size:11px}.codes-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:16px;display:grid}.legend{background:var(--panel);color:var(--ink-dark);border-radius:var(--radius);box-shadow:var(--shadow-1);gap:14px;padding:14px 16px;display:grid}.legend__title{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-bottom:6px;font-size:12px;font-weight:800}.legend__chips{flex-wrap:wrap;gap:6px;display:flex}.legend__chip{border:2px solid var(--frame-noun);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.legend__swatch{border-radius:2px;width:10px;height:10px;display:inline-block}.legend__rows{gap:4px;font-size:12px;display:grid}.legend__rows>div{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.legend__sample{background:#fff;border-radius:3px;width:18px;height:18px;display:inline-block}.legend__bar{background:var(--panel-2);border-radius:4px;padding:0 4px;font-family:monospace;display:inline-block}.howto{max-width:1100px;margin:0 auto}.howto__head{margin-bottom:24px}.howto__head h1{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 8px;font-size:clamp(28px,5vw,44px)}.howto__tagline{color:var(--accent);letter-spacing:.02em;margin:0 0 16px;font-weight:700}.howto__note{color:var(--ink-muted);max-width:70ch;margin:0 0 8px;font-size:14px}.howto__note--muted{opacity:.85;font-style:italic}.howto__grid{grid-template-columns:repeat(2,1fr);align-items:start;gap:16px;display:grid}@media (max-width:760px){.howto__grid{grid-template-columns:1fr}}.howto__section{padding:20px 22px}.howto__section h2{font-family:var(--font-display);color:var(--ink-dark);margin:0 0 10px;font-size:18px}.howto__section p{margin:0 0 10px}.howto__section p:last-child{margin-bottom:0}.howto__section ul,.howto__section ol{margin:4px 0 0;padding-left:20px}.howto__section li{margin:0 0 6px}.howto__section li:last-child{margin-bottom:0}.howto__section ol{list-style:decimal}.howto__section ul{list-style:outside}.howto__legend-heading{font-family:var(--font-display);color:var(--ink);margin:28px 0 12px;font-size:18px}.howto__closing{border-left:3px solid var(--accent);background:var(--bg-2);color:var(--ink-muted);border-radius:0 8px 8px 0;margin:20px 0 8px;padding:14px 16px;font-size:14px}.zoom-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#080a16c7;place-items:center;padding:16px;animation:.12s ease-out zoomFade;display:grid;position:fixed;inset:0}@keyframes zoomFade{0%{opacity:0}to{opacity:1}}.zoom-card{color:var(--ink-dark);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);background:#fff;gap:14px;width:100%;max-width:min(560px,92vw);padding:18px;animation:.16s cubic-bezier(.2,.9,.3,1.3) zoomPop;display:grid;position:relative}@keyframes zoomPop{0%{opacity:.4;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.zoom-close{background:var(--panel-2);width:32px;height:32px;color:var(--ink-dark);border:0;border-radius:50%;font-size:22px;line-height:1;position:absolute;top:8px;right:8px}.zoom-close:hover{background:var(--frame-verb);color:#fff}.zoom-meta{flex-wrap:wrap;gap:6px;display:flex}.zoom-image{border:1.5px solid var(--ink-dark);aspect-ratio:1;background:#fff;border-radius:6px;place-items:center;margin:6px;display:grid;position:relative;overflow:visible}.zoom-image img{object-fit:contain;width:100%;height:100%}.zoom-image .frame{border-width:7px;inset:-5px}.zoom-image .frame.plural{box-shadow:inset 0 0 0 4px white, inset 0 0 0 10px var(--frame-color), 0 0 0 1px #00000040}.zoom-image .frame__order{border-radius:16px;min-width:32px;height:32px;font-size:20px;bottom:-8px;right:-8px}.zoom-image .frame__sash{gap:12px;height:28px;padding:4px 10px;font-size:16px;left:6px;right:40px}.zoom-image .tense-bar__dot{width:7px;height:7px}.zoom-image .tense-bar__line{width:10px;height:2px}.zoom-image .frame__pin{font-size:18px}.zoom-markers{gap:6px;display:grid}.zoom-marker{background:var(--panel-2);border-radius:8px;grid-template-columns:130px 1fr;align-items:center;gap:10px;padding:6px 8px;font-size:14px;display:grid}.zoom-marker__label{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:700}.zoom-marker__value{color:var(--ink-dark)}.zoom-marker__pill{border:2px solid var(--frame-noun);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:13px;font-weight:800;display:inline-flex}.zoom-marker__pill.verb{border-color:var(--frame-verb);color:var(--frame-verb)}.zoom-marker__pill.noun{border-color:var(--frame-noun);color:var(--frame-noun)}.zoom-marker__pill.adj{border-color:var(--frame-adj);color:var(--frame-adj)}.zoom-marker__pill.prep{border-color:var(--frame-prep);color:var(--frame-prep)}.zoom-marker__pill.adverb{border-color:var(--frame-adverb);color:var(--frame-adverb)}.zoom-marker__pill.neutral{border-color:var(--frame-neutral);color:var(--frame-neutral)}.zoom-glosses{gap:4px;display:grid}.zoom-gloss-row{border-top:1px solid #eef0f6;grid-template-columns:36px 1fr;gap:8px;padding:4px 0;font-size:14px;display:grid}.zoom-gloss-row:first-child{border-top:0}.zoom-gloss-lang{color:var(--ink-muted);font-family:monospace;font-weight:800}.pill{color:var(--ink-muted);letter-spacing:.04em;text-transform:uppercase;background:#ffffff14;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.pill.ok{background:var(--ok);color:#fff}.pill.danger{background:var(--danger);color:#fff}.pill.accent{background:var(--accent);color:var(--ink-dark)}
