:root,:root[data-theme=light]{--purple-50: #f5f0ff;--purple-100: #ece2ff;--purple-200: #d6c0ff;--purple-300: #b894ff;--purple-400: #9a6bff;--purple-500: #7c4dff;--purple-600: #6b3fa0;--purple-700: #4f2d80;--purple-800: #371f5c;--purple-900: #20133a;--amber-300: #ffd28a;--amber-400: #ffb755;--amber-500: #f59e2c;--bg: #faf6ff;--bg-elev-1: #ffffff;--bg-elev-2: #f3ebff;--bg-overlay: rgba(32, 19, 58, .55);--fg: #1c1430;--fg-muted: #4a3a66;--fg-faint: #7b6a99;--fg-on-purple:#f8f4ff;--border: rgba(108, 63, 160, .18);--border-soft: rgba(108, 63, 160, .1);--status-online: #5fcf80;--status-idle: #f5b740;--status-dnd: #e25656;--status-offline:#7b6a99;--radius-sm: 6px;--radius: 12px;--radius-lg: 22px;--shadow-1: 0 1px 2px rgba(32,19,58,.06), 0 2px 8px rgba(32,19,58,.08);--shadow-2: 0 8px 24px rgba(32,19,58,.18);--shadow-glow: 0 0 0 1px rgba(124,77,255,.22), 0 8px 28px rgba(124,77,255,.28);--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-serif: "Source Serif 4", Georgia, "Times New Roman", serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace}:root[data-theme=dark]{--bg: #110a22;--bg-elev-1: #1a1133;--bg-elev-2: #241647;--bg-overlay: rgba(0, 0, 0, .55);--fg: #f1ebff;--fg-muted: #c9b9ee;--fg-faint: #8b7bb4;--fg-on-purple:#f8f4ff;--border: rgba(184, 148, 255, .18);--border-soft: rgba(184, 148, 255, .08);--shadow-1: 0 1px 2px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.45);--shadow-2: 0 12px 40px rgba(0,0,0,.55);--shadow-glow: 0 0 0 1px rgba(184,148,255,.28), 0 8px 28px rgba(124,77,255,.32)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}button,[role=button],.input,select{min-height:44px}.btn[style*="padding: 0.25"],.editor__elem-toolbar button{min-height:auto}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}a{color:var(--purple-500);text-decoration:none}a:hover{color:var(--purple-400)}button{font:inherit;cursor:pointer}:focus-visible{outline:2px solid var(--purple-400);outline-offset:2px;border-radius:var(--radius-sm)}.skip-link{position:absolute;left:-9999px;top:0;background:var(--purple-600);color:var(--fg-on-purple);padding:.5rem 1rem;border-radius:0 0 var(--radius) 0;z-index:999}.skip-link:focus{left:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius);border:1px solid transparent;background:var(--purple-600);color:var(--fg-on-purple);font-weight:600;letter-spacing:.01em;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.btn:hover{background:var(--purple-500);box-shadow:var(--shadow-glow)}.btn:active{transform:translateY(1px)}.btn--ghost{background:transparent;color:var(--fg);border-color:var(--border)}.btn--ghost:hover{background:var(--bg-elev-2);box-shadow:none}.card{background:var(--bg-elev-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);padding:1.5rem}.input{width:100%;padding:.7rem .9rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev-1);color:var(--fg);font:inherit;transition:border-color .12s ease,box-shadow .12s ease}.input:focus{border-color:var(--purple-400);box-shadow:0 0 0 3px #7c4dff2e;outline:none}.muted{color:var(--fg-muted)}.faint{color:var(--fg-faint)}.landing{min-height:100dvh;position:relative;display:flex;flex-direction:column;color:var(--fg-on-purple);isolation:isolate}.landing:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/backgrounds/01-night-sky-beach.png);background-size:cover;background-position:center;z-index:-2}.landing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#20133a6b,#371f5c59 38%,#20133ab8);z-index:-1}.landing__nav{display:flex;align-items:center;justify-content:space-between;padding:1.5rem clamp(1rem,4vw,3rem)}.landing__brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-serif);font-size:1.4rem;font-weight:700;letter-spacing:.02em}.landing__brand-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--purple-400),var(--purple-700));box-shadow:var(--shadow-glow);color:var(--fg-on-purple);font-family:var(--font-serif);font-weight:700}.landing__nav-actions{display:flex;gap:.6rem}.landing__hero{flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:2rem clamp(1rem,6vw,5rem);max-width:60rem}.landing__eyebrow{display:inline-block;padding:.25rem .75rem;border:1px solid rgba(255,255,255,.25);border-radius:999px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--purple-100);margin-bottom:1.5rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.landing__title{font-family:var(--font-serif);font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.05;margin:0 0 1rem;text-shadow:0 4px 28px rgba(0,0,0,.45)}.landing__title em{font-style:italic;background:linear-gradient(120deg,var(--amber-300),var(--purple-200));-webkit-background-clip:text;background-clip:text;color:transparent}.landing__subtitle{font-size:1.15rem;max-width:38rem;color:var(--purple-100);margin:0 0 2rem;text-shadow:0 2px 12px rgba(0,0,0,.4)}.landing__cta{display:flex;gap:.75rem;flex-wrap:wrap}.landing__cta .btn{padding:.9rem 1.6rem;font-size:1rem}.landing__cta .btn--ghost{color:var(--fg-on-purple);border-color:#ffffff59;background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.landing__cta .btn--ghost:hover{background:#ffffff1f}.landing__footer{padding:1rem clamp(1rem,4vw,3rem);font-size:.82rem;color:#fff9;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.editor{position:relative;min-height:100dvh;background:var(--bg);color:var(--fg)}.editor__bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background-size:cover;background-position:center}.editor__bg-veil{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1}.editor__topbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-elev-1) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.editor__topbar h1{margin:0;font-family:var(--font-serif);font-size:1.1rem;letter-spacing:.01em}.editor__chip{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-elev-1);font-size:.85rem}.editor__chip--active{background:var(--purple-600);color:var(--fg-on-purple);border-color:transparent}.editor__canvas-wrap{position:relative;width:100%;min-height:calc(100dvh - 56px);overflow:auto}.editor__canvas{position:relative;margin:1.5rem auto;background:var(--canvas-bg, transparent);border-radius:var(--radius-lg);outline:1px dashed var(--border);outline-offset:-1px}.editor__canvas--editing{background-image:linear-gradient(to right,rgba(124,77,255,.06) 1px,transparent 1px),linear-gradient(to bottom,rgba(124,77,255,.06) 1px,transparent 1px);background-size:200px 200px}.editor__plus{position:absolute;top:50%;left:50%;width:96px;height:96px;transform:translate(-50%,-50%);border-radius:50%;border:2px dashed var(--purple-300);background:color-mix(in srgb,var(--purple-50) 70%,transparent);font-size:3rem;color:var(--purple-600);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-glow);transition:transform .12s ease,box-shadow .12s ease}.editor__plus:hover{transform:translate(-50%,-50%) scale(1.04)}.editor__plus-hint{position:absolute;top:calc(50% + 64px);left:50%;transform:translate(-50%);color:var(--fg-muted);font-size:.9rem;text-align:center;width:max-content}.editor__element{position:absolute;box-sizing:border-box}.editor__element--editing{outline:1.5px solid transparent;cursor:grab}.editor__element--editing:hover{outline-color:var(--purple-300)}.editor__element--selected{outline:2px solid var(--purple-500)!important}.editor__handle{position:absolute;width:12px;height:12px;background:var(--purple-500);border:2px solid var(--bg-elev-1);border-radius:50%;z-index:2;touch-action:none}.editor__handle:after{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px}@media (pointer: coarse){.editor__handle{width:18px;height:18px}.editor__handle:after{top:-8px;right:-8px;bottom:-8px;left:-8px}}.editor__handle--nw{top:-7px;left:-7px;cursor:nwse-resize}.editor__handle--ne{top:-7px;right:-7px;cursor:nesw-resize}.editor__handle--sw{bottom:-7px;left:-7px;cursor:nesw-resize}.editor__handle--se{bottom:-7px;right:-7px;cursor:nwse-resize}.editor__elem-toolbar{position:absolute;top:-34px;left:0;display:flex;gap:.25rem;background:var(--bg-elev-1);border:1px solid var(--border);border-radius:8px;padding:2px;font-size:.78rem;box-shadow:var(--shadow-1);white-space:nowrap}.editor__elem-toolbar button{padding:.25rem .5rem;background:transparent;border:0;border-radius:6px;color:var(--fg)}.editor__elem-toolbar button:hover{background:var(--bg-elev-2)}.editor__elem-toolbar button[data-danger]:hover{background:#e256562e;color:var(--status-dnd)}.editor__add-menu{position:absolute;z-index:80;min-width:220px;background:var(--bg-elev-1);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-2);padding:.5rem}.editor__add-menu h4{margin:.25rem .5rem .5rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint)}.editor__add-menu button{display:flex;flex-direction:column;align-items:flex-start;width:100%;gap:2px;padding:.5rem .6rem;background:transparent;border:0;border-radius:8px;color:var(--fg);text-align:left}.editor__add-menu button:hover{background:var(--bg-elev-2)}.editor__add-menu button span{font-weight:600}.editor__add-menu button small{color:var(--fg-faint)}.editor__inspector{position:fixed;top:56px;right:0;bottom:0;width:320px;background:var(--bg-elev-1);border-left:1px solid var(--border);padding:1rem;overflow-y:auto;z-index:70}.editor__inspector h3{margin:0 0 .5rem;font-family:var(--font-serif)}.editor__inspector h4{margin:1rem 0 .4rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint)}.editor__inspector .row{display:grid;grid-template-columns:110px 1fr;gap:.5rem;align-items:center;margin:.35rem 0}.editor__inspector .row label{font-size:.85rem;color:var(--fg-muted)}.editor__inspector .row input,.editor__inspector .row select,.editor__inspector .row textarea{width:100%;padding:.4rem .5rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-elev-2);color:var(--fg);font:inherit;font-size:.85rem}.editor__inspector .row textarea{min-height:80px;resize:vertical}.editor__inspector .row input[type=color]{padding:0;height:32px}.voice-lobby{position:fixed;top:56px;right:0;bottom:0;width:min(380px,92vw);background:var(--bg-elev-1);border-left:1px solid var(--border);box-shadow:var(--shadow-2);z-index:90;display:flex;flex-direction:column;transform:translate(0);transition:transform .18s ease}.voice-lobby__head{padding:1rem 1.25rem .5rem;border-bottom:1px solid var(--border-soft)}.voice-lobby__title{font-family:var(--font-serif);font-size:1.2rem;margin:0}.voice-lobby__subtitle{color:var(--fg-muted);font-size:.85rem;margin:.2rem 0 0}.voice-lobby__list{flex:1;overflow-y:auto;padding:.5rem 1rem;display:flex;flex-direction:column;gap:.5rem}.voice-lobby__participant{display:flex;align-items:center;gap:.75rem;padding:.6rem .7rem;border-radius:var(--radius);background:var(--bg-elev-2)}.voice-lobby__avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--purple-300),var(--purple-700));display:grid;place-items:center;color:var(--fg-on-purple);font-weight:700}.voice-lobby__name{font-weight:600}.voice-lobby__flags{color:var(--fg-faint);font-size:.82rem}.voice-lobby__empty{color:var(--fg-faint);padding:1rem;text-align:center}.voice-lobby__foot{padding:.75rem 1rem 1.25rem;border-top:1px solid var(--border-soft);display:flex;gap:.5rem}.voice-lobby__foot .btn{flex:1}
