@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap";:root{--ink: #f5f4f1;--muted: rgba(245, 244, 241, .72);--glass: rgba(12, 16, 20, .64);--glass-strong: rgba(10, 13, 16, .78);--stroke: rgba(255, 255, 255, .14);--accent: #f4b26f;--accent-strong: #dd8e4a;--shadow: 0 30px 70px rgba(9, 10, 12, .45)}*{box-sizing:border-box}body{margin:0;font-family:Roboto,system-ui,sans-serif;color:var(--ink);background-color:#14181c;background-image:url(/background_image.webp);background-size:cover;background-position:center;background-repeat:no-repeat;min-height:100vh}#root{min-height:100vh}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page{min-height:100vh;padding:10vh 10vw 12vh;display:flex;align-items:center;justify-content:center;position:relative;isolation:isolate}.page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,#080a0cbf,#080a0c59);z-index:-2}.page:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(244,178,111,.12),transparent 55%),radial-gradient(circle at 80% 10%,rgba(180,120,70,.2),transparent 60%);z-index:-1}.glass-card{width:min(1200px,100%);min-height:clamp(520px,72vh,760px);background:var(--glass);border-radius:32px;border:1px solid var(--stroke);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:clamp(24px,4vw,48px);display:grid;grid-template-columns:minmax(260px,.9fr) minmax(320px,1.1fr);gap:clamp(24px,4vw,40px)}.page.app-view{padding:16px;align-items:stretch;height:100dvh;max-width:100vw;max-height:100dvh;overflow:hidden}.page.viewer-view{padding:1.5vh 1.5vw;align-items:stretch}.app-shell{width:100%;display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:stretch;height:100%;max-width:100%;max-height:100%}.app-main{position:relative;display:flex;gap:20px;align-items:stretch;height:100%;min-width:0;min-height:0;max-width:100%;max-height:100%}.app-main .canvas-panel{flex:1;min-width:0;min-height:0}.sidebar{height:100%;width:min(230px,28vw);min-width:0;max-width:100%;max-height:100%;background:#0a0d10bf;border-radius:24px;border:1px solid rgba(255,255,255,.12);padding:16px;display:grid;grid-template-rows:auto 1fr;gap:16px;transition:none}.sidebar.collapsed{width:44px;max-width:44px;padding:4px;gap:0;grid-template-rows:1fr;justify-items:stretch;align-items:stretch}.sidebar-header{display:flex;align-items:center;justify-content:space-between;min-width:0;width:100%;font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .sidebar-header p{opacity:0;width:0;height:0;overflow:hidden}.sidebar-header p{margin:0}.sidebar-actions{display:inline-flex;align-items:center;gap:8px}.sidebar-toggle{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);border-radius:12px;width:36px;height:36px;cursor:pointer;display:grid;place-items:center}.sidebar.collapsed .sidebar-toggle{width:32px;height:32px;border-radius:10px}.sidebar-collapsed-button{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;border-radius:18px;width:100%;height:100%;display:grid;place-items:center;color:var(--ink);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.sidebar-collapsed-button svg{width:20px;height:20px}.sidebar-collapsed-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.sidebar-toggle svg{width:18px;height:18px}.sidebar-expand{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);border-radius:10px;width:36px;height:36px;padding:0;display:grid;place-items:center;cursor:pointer;text-transform:uppercase}.sidebar-expand svg{width:16px;height:16px}.sidebar-content{display:grid;gap:12px;align-content:start;min-width:0;width:100%}.sidebar.collapsed .sidebar-content{justify-items:center}.sidebar.collapsed .tools-sidebar-body,.sidebar.collapsed .media-sidebar-body{display:none}.media-sidebar{width:320px;display:grid;grid-template-rows:auto 1fr}.media-sidebar-header{padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}.media-sidebar-body{display:grid;grid-template-columns:190px 1fr;gap:12px;overflow:hidden;min-height:0;padding-top:10px;height:100%}.media-sidebar.compact .media-sidebar-body{grid-template-columns:1fr;gap:0}.media-tree-panel{display:grid;grid-template-rows:auto 1fr;gap:8px;min-height:0;padding-right:6px;border-right:1px solid rgba(255,255,255,.08)}.media-tree-controls{display:flex;gap:6px;align-items:center}.media-tree-action{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);border-radius:8px;width:28px;height:28px;padding:0;display:grid;place-items:center;cursor:pointer}.media-tree-action svg{width:16px;height:16px}.media-tree-action:disabled{opacity:.4;cursor:not-allowed}.media-tree-action.danger{border-color:#f46f6f66;color:#f4a0a0e6}.media-tree{display:grid;gap:14px;min-height:0;overflow:auto;min-width:0;align-content:start}.media-tree-section{display:grid;gap:6px;align-content:start}.media-tree-title{margin:0;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.media-tree-list{display:grid;gap:2px;align-content:start}.media-tree-item{display:grid}.media-tree-row{border:none;background:transparent;color:var(--ink);display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:8px;cursor:pointer;text-align:left;padding-left:calc(6px + var(--level, 0) * 12px)}.media-tree-row:hover{background:#ffffff0f}.media-tree-row.active{background:#f4b26f2e}.media-tree-row.drag-over{background:#f4b26f47;border:1px dashed rgba(244,178,111,.6)}.media-tree-caret{width:14px;height:14px;display:grid;place-items:center;color:var(--muted);transform:translateY(-1px)}.media-tree-caret svg{width:12px;height:12px}.media-tree-caret.open{transform:rotate(90deg)}.media-tree-spacer{width:14px;height:14px}.media-tree-label{font-size:.72rem;color:var(--ink);flex:1}.media-tree-status{font-size:.55rem;text-transform:uppercase;letter-spacing:.12em;padding:2px 6px;border-radius:999px;background:#ffffff1a;color:var(--muted)}.media-tree-count{font-size:.6rem;padding:2px 6px;border-radius:999px;background:#ffffff14;color:var(--muted)}.media-tree-children{display:grid;gap:2px}.media-sidebar-panel{min-height:0;display:flex;min-width:0;height:100%}.media-sidebar.expanded{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:10;border-radius:28px;padding:20px;background:#06080aeb;box-shadow:0 24px 60px #05070966;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.media-sidebar.expanded .media-sidebar-body{height:100%;grid-template-columns:230px 1fr}.media-browser{display:grid;grid-template-rows:auto auto 1fr;gap:8px;height:100%;min-height:0;flex:1}.media-browser.compact-controls{grid-template-rows:auto 1fr}.media-toolbar{display:flex;justify-content:space-between;gap:8px;align-items:center}.media-toolbar-left,.media-toolbar-right{display:inline-flex;align-items:center;gap:6px}.media-sort{display:inline-flex;align-items:center;gap:4px}.media-sort-label select{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;color:var(--ink);border-radius:8px;padding:4px 8px;font-size:.65rem;font-family:inherit}.media-sort-dir{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;color:var(--ink);border-radius:8px;width:24px;height:24px;display:grid;place-items:center;cursor:pointer;font-size:.65rem}.media-sort-dir svg{width:14px;height:14px}.media-toolbar-left{min-width:0;overflow:hidden}.media-tool{width:26px;height:26px;border-radius:6px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);font-size:.7rem;display:grid;place-items:center;cursor:pointer}.media-tool:disabled{opacity:.45;cursor:not-allowed}.media-tool svg{width:14px;height:14px}.media-tool-accent{border-color:#f4b26f80;background:#f4b26f33}.media-breadcrumbs{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.media-crumb{display:inline-flex;align-items:center;gap:4px}.media-crumb-link{border:none;background:transparent;color:var(--muted);font:inherit;letter-spacing:inherit;text-transform:inherit;padding:0;cursor:pointer}.media-crumb-link:hover,.media-crumb-current{color:var(--ink)}.media-crumb-sep{opacity:.4}.media-search{display:inline-flex}.media-search input{width:150px;border:1px solid rgba(255,255,255,.14);background:#090c0fb3;color:var(--ink);border-radius:10px;padding:5px 8px;font-size:.7rem;font-family:inherit}.media-filters,.media-quick-filters{display:flex;flex-wrap:wrap;gap:6px}.media-quick-filter{border:1px solid rgba(255,255,255,.14);background:#090c0fa6;color:var(--muted);border-radius:10px;padding:6px 10px;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.media-quick-label{font-size:.6rem}.media-quick-filter.active{color:var(--ink);border-color:#f4b26f99;background:#f4b26f2e}.media-quick-count{font-size:.6rem;padding:2px 6px;border-radius:999px;background:#ffffff14;color:var(--muted)}.media-filter{border:1px solid rgba(255,255,255,.14);background:#090c0f99;color:var(--muted);border-radius:6px;padding:4px 8px;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.media-filter.active{color:var(--ink);border-color:#f4b26f99;background:#f4b26f2e}.media-browser-body{display:grid;grid-template-columns:1fr;gap:12px;min-height:0;min-width:0}.media-browser.with-preview .media-browser-body{grid-template-columns:minmax(0,1fr) 240px}.media-file-list{display:grid;grid-template-rows:auto 1fr;min-height:0;border:1px solid rgba(255,255,255,.12);border-radius:12px;overflow:hidden;background:#090c0fb3}.media-file-list.compact .media-file-header,.media-file-list.compact .media-row{grid-template-columns:1fr;min-height:30px;height:30px;padding:4px 8px}.media-file-list.compact .media-file-header button:nth-child(n+2),.media-file-list.compact .media-row-type,.media-file-list.compact .media-row-size,.media-file-list.compact .media-row-updated{display:none}.media-file-list.compact .media-file-body{gap:1px}.media-file-list.compact .media-row-thumb{width:28px;height:18px}.media-file-list.compact .media-row-tags{display:none}.media-file-header{display:grid;grid-template-columns:1.6fr .7fr .6fr .8fr;gap:8px;padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.08)}.media-file-sort{border:none;background:transparent;color:var(--muted);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;padding:0;display:inline-flex;align-items:center;gap:6px;cursor:pointer;text-align:left}.media-file-sort.active{color:var(--ink)}.media-file-sort-icon{font-size:.65rem;opacity:.7}.media-file-sort-icon svg{width:12px;height:12px}.media-file-body{overflow:auto;display:grid;gap:2px;padding:2px;align-content:start}.media-row{border:none;background:transparent;color:var(--ink);text-align:left;display:grid;grid-template-columns:1.6fr .7fr .6fr .8fr;gap:8px;align-items:center;padding:6px 8px;font-size:.75rem;border-radius:8px;cursor:pointer}.media-row:hover{background:#ffffff0f}.media-row.selected{background:#f4b26f29}.media-row-name{display:flex;align-items:center;gap:8px;min-width:0}.media-row-thumb{width:34px;height:24px;border-radius:6px;background:#ffffff14;overflow:hidden;flex-shrink:0}.media-row-thumb img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.media-row-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-row-tags{display:inline-flex;gap:4px;margin-left:8px}.media-row-tag{border:1px solid rgba(255,255,255,.18);background:#090c0fb3;color:var(--muted);border-radius:999px;padding:2px 6px;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase}.media-row-type,.media-row-size,.media-row-updated{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.media-preview{border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#090c0fb3;padding:10px;display:grid;gap:10px;min-height:0}.media-preview-thumb{height:160px;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.media-preview-thumb img{width:100%;height:100%;object-fit:cover}.media-preview-meta{display:grid;gap:8px}.media-preview-tags{display:inline-flex;gap:6px}.media-preview-tag{border:1px solid rgba(255,255,255,.18);background:#090c0fb3;color:var(--muted);border-radius:999px;padding:3px 8px;display:inline-flex;align-items:center;justify-content:center;gap:4px;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;font:inherit;cursor:pointer}.media-preview-tag svg{width:16px;height:16px}.media-preview-tag.active{color:var(--ink);border-color:#f4b26f99;background:#f4b26f33}.media-preview-tag:disabled{opacity:.4;cursor:not-allowed}.media-preview-actions{display:flex;gap:8px;margin-top:8px}.media-preview-action{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);border-radius:10px;padding:6px 10px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer}.media-preview-action svg{width:16px;height:16px}.media-preview-action:disabled{opacity:.4;cursor:not-allowed}.media-preview-action.danger{border-color:#f46f6f73;color:#f4a0a0f2}.media-preview-title{margin:0;font-size:.85rem}.media-preview-grid{display:grid;gap:6px}.media-preview-label{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.media-preview-value{font-size:.75rem;color:var(--ink)}.media-preview-empty{margin:0;font-size:.75rem;color:var(--muted)}.tools-sidebar-body{display:grid;gap:12px;align-content:start}.visuals-sidebar-body,.soundscape-sidebar-body{display:grid;grid-template-rows:1fr auto;gap:16px;min-height:0;align-content:start;min-width:0;width:100%}.sidebar-section{display:grid;gap:10px;min-height:0;align-content:start;min-width:0;width:100%}.sidebar-section-title{margin:0;font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;width:100%}.scope-toggle{display:inline-flex;align-items:center;gap:4px;padding:3px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#090c0fa6;max-width:100%;min-width:0}.scope-toggle-button{border:none;border-radius:999px;width:30px;height:26px;padding:0;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:background .2s ease,color .2s ease;min-width:0}.scope-toggle-button svg{width:14px;height:14px}.scope-toggle-button.active{background:#f4b26f2e;color:#f4b26f}.tool-icon-button{width:100%;height:48px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#090c0fa6;color:var(--ink);font-size:.85rem;font-weight:600;letter-spacing:.08em;display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform .2s ease,border-color .2s ease;padding:0 14px}.tool-icon-button:hover{transform:translateY(-1px);border-color:#f4b26f66}.tool-icon-button.active{border-color:#f4b26f80;background:#14100cb3}.tool-icon{width:34px;height:34px;border-radius:10px;background:#ffffff0f;display:grid;place-items:center}.tool-icon svg{width:18px;height:18px}.tool-icon-label{text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--muted)}.sidebar.collapsed .tool-icon-button{width:48px;padding:0;justify-content:center}.sidebar.collapsed .tool-icon-label{display:none}.sidebar.collapsed .tools-sidebar-body{justify-items:center}.scene-panel{display:grid;gap:10px;padding:4px 2px 0}.scene-toolbar{display:flex;align-items:center;gap:8px}.scene-toolbar-button{width:32px;height:32px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#090c0fa6;color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.scene-toolbar-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.scene-toolbar-button.danger{color:#f07d7d;border-color:#f07d7d59}.scene-toolbar-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.scene-toolbar-button svg{width:16px;height:16px}.scene-list{display:grid;gap:8px;min-width:0;width:100%}.scene-item,.playlist-item{width:100%;max-width:100%;display:grid;grid-template-columns:52px 1fr;align-items:center;gap:10px;padding:8px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#080a0cb3;color:var(--ink);cursor:pointer;text-align:left;transition:border-color .2s ease,background .2s ease}.scene-item.selected,.playlist-item.active,.scene-item.drag-over,.playlist-item.drag-over{background:#2c2218cc;border-color:#f4b26f66}.scene-preview,.playlist-preview{width:52px;height:36px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.scene-preview img,.playlist-preview img{width:100%;height:100%;object-fit:cover;display:block}.scene-text,.playlist-text{display:grid;gap:2px;min-width:0}.scene-title,.playlist-title{font-size:.82rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-subtitle,.playlist-subtitle{font-size:.65rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-panel{display:grid;gap:10px;padding:4px 2px 0}.token-grid,.soundboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-content:start;min-width:0;width:100%}.token-button,.soundboard-button{position:relative;width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#090c0fa6;color:var(--ink);padding:0;display:block;cursor:pointer;overflow:hidden;transform:translateZ(0);transition:border-color .2s ease,box-shadow .2s ease;will-change:transform}.token-button:before,.soundboard-button:before{content:"";display:block;padding-top:100%}.token-button .token-image,.soundboard-button .token-image,.token-button .token-placeholder,.soundboard-button .token-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.token-button:hover,.soundboard-button:hover{border-color:#f4b26f66;box-shadow:0 6px 16px #00000059}.token-button.drag-over,.soundboard-button.drag-over{border-color:#f4b26fb3}.soundboard-button.active{border-color:#f4b26f8c;background:#14100cb8}.soundboard-loop{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#f4b26fe6;pointer-events:none;z-index:2}.soundboard-loop svg{width:22px;height:22px}.token-image{width:100%;height:100%;object-fit:cover;display:block}.token-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--muted)}.token-placeholder svg{width:22px;height:22px}.token-shape-circle .token-image,.token-shape-circle{border-radius:999px}.token-shape-hex .token-image,.token-shape-hex,.token-shape-hex-point .token-image,.token-shape-hex-point{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}.token-shape-hex-flat .token-image,.token-shape-hex-flat{clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%)}.token-shape-free .token-image{object-fit:contain;background:#090c0f66}.token-menu{position:fixed;z-index:1000;background:#090c0ff2;border-radius:12px;border:1px solid rgba(255,255,255,.12);padding:10px;display:grid;gap:8px;min-width:220px}.token-menu-compact{padding:8px;gap:6px;min-width:180px}.token-menu-title{margin:0;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.token-menu-group{display:grid;gap:6px}.token-menu-compact .token-menu-group{grid-template-columns:repeat(4,32px);gap:6px}.token-menu-option{border:1px solid rgba(255,255,255,.12);background:#090c0fb3;color:var(--ink);border-radius:10px;padding:6px 8px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer}.token-menu-compact .token-menu-option{width:32px;height:32px;padding:0;font-size:.95rem;text-transform:none;letter-spacing:0;display:grid;place-items:center}.token-menu-compact .token-menu-option svg{width:18px;height:18px}.token-menu-option.active{border-color:#f4b26f8c;background:#14100cb3}.token-menu-action{border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#090c0fb3;color:var(--ink);padding:6px 8px;display:inline-flex;align-items:center;gap:8px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer}.token-menu-action svg{width:16px;height:16px}.token-menu-action.danger{border-color:#f07d7d59;color:#f07d7d}.token-menu-field{display:grid;gap:6px;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.token-menu-field input[type=number]{border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#090c0fbf;color:var(--ink);padding:6px 8px;font-family:inherit}.token-menu-field input[type=range]{height:4px;border-radius:999px;background:#ffffff2e;accent-color:var(--accent)}.token-menu-controls{display:grid;gap:8px}.token-menu-compact .token-menu-controls{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.token-menu-toggle{display:inline-flex;align-items:center;gap:8px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.canvas-token-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3}.canvas-map-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none}.canvas-map-layer.interactive{pointer-events:auto}.canvas-map-stage{width:100%;height:100%}.token-menu-compact .token-menu-field{grid-template-columns:18px 1fr;align-items:center;gap:6px;font-size:0}.token-menu-compact .token-menu-field svg{width:16px;height:16px}.token-menu-compact .token-menu-field input[type=number]{padding:4px 6px;font-size:.65rem}.token-menu-compact .token-menu-actions{display:grid;grid-template-columns:repeat(2,32px);gap:6px;justify-content:start}.token-menu-compact .token-menu-action{width:32px;height:32px;padding:0;justify-content:center;gap:0;text-transform:none;letter-spacing:0}.canvas-token-layer.interactive{pointer-events:auto}.canvas-token-layer.readonly{pointer-events:none}.canvas-token{position:absolute;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#06080a80;padding:0;cursor:grab;overflow:hidden;pointer-events:auto}.canvas-token:active{cursor:grabbing}.canvas-token .token-placeholder{background:#090c0f80}.token-editor-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:36;padding:10px;background:#06080ac7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.token-editor-window{width:100%;height:100%;display:flex;flex-direction:column;gap:12px;padding:16px 18px;background:#0a0c10f0;border-radius:18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 50px #0006}.token-editor-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.token-editor-header h2{margin:4px 0 0;font-size:1.2rem}.token-editor-kicker{margin:0;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.token-editor-actions{display:inline-flex;gap:8px}.token-editor-action{width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:#090c0fcc;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.token-editor-action svg{width:18px;height:18px}.token-editor-action:hover{border-color:#f4b26f80;transform:translateY(-1px)}.token-editor-action:disabled{opacity:.5;cursor:not-allowed;transform:none}.token-editor-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.token-editor-shapes{display:inline-flex;flex-wrap:wrap;gap:6px}.token-editor-shape{width:32px;height:32px;border-radius:9px;border:1px solid rgba(255,255,255,.16);background:#080a0dcc;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.token-editor-shape svg{width:18px;height:18px}.token-editor-shape:hover{border-color:#f4b26f73;transform:translateY(-1px)}.token-editor-shape.active{border-color:#f4b26f99;background:#14100cb3}.token-editor-meta{font-size:.7rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.token-editor-stage{flex:1;min-height:0;position:relative;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#06080a8c;overflow:hidden}.token-editor-canvas{width:100%;height:100%}.token-editor-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center;font-size:.75rem;color:var(--muted);padding:0 24px;pointer-events:none}.playlist-list{display:grid;gap:8px;min-width:0;width:100%}.playlist-list.drop-active{outline:1px dashed rgba(244,178,111,.4);border-radius:12px;padding:4px}.playlist-empty{margin:0;padding:12px 8px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.canvas-panel{background:#0a0d10bf;border-radius:28px;border:1px solid rgba(255,255,255,.14);padding:20px;display:grid;grid-template-rows:auto 1fr;gap:16px;height:100%;max-width:100%;max-height:100%}.canvas-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem}.canvas-header p{margin:0}.layout-picker{position:relative;display:inline-flex;align-items:center;gap:8px}.layout-icons{position:absolute;left:0;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px;padding:6px 6px 6px 66px;border-radius:14px;background:#090c0feb;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 36px #00000059;opacity:0;visibility:hidden;pointer-events:auto;transition:opacity .5s ease 1s,visibility 0s linear 1.5s;z-index:6}.layout-picker:hover .layout-icons,.layout-picker:focus-within .layout-icons,.layout-icons:hover,.layout-icons:focus-within{opacity:1;visibility:visible;pointer-events:auto;transition-delay:0s}.layout-toolbar{display:flex;align-items:center;gap:10px}.canvas-header-left{justify-self:start}.canvas-header-center{display:flex;justify-content:center;gap:10px}.canvas-header-controls{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap;justify-self:end}.settings-button{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;border-radius:12px;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.settings-button svg{width:18px;height:18px}.settings-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.settings-button.active{border-color:#f4b26f8c}.audio-controls{display:flex;align-items:center;justify-content:flex-end}.audio-hover{position:relative;display:inline-flex;align-items:center;gap:8px}.audio-extra{position:absolute;right:0;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:8px;padding:6px 52px 6px 6px;border-radius:14px;background:#090c0feb;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 36px #00000059;opacity:0;visibility:hidden;pointer-events:auto;transition:opacity .5s ease 1s,visibility 0s linear 1.5s;z-index:6}.audio-volume-group{display:inline-flex;align-items:center;gap:6px}.audio-hover:hover .audio-extra,.audio-hover:focus-within .audio-extra,.audio-extra:hover,.audio-extra:focus-within{opacity:1;visibility:visible;pointer-events:auto;transition-delay:0s}.audio-button{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;border-radius:12px;min-width:38px;height:38px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;gap:6px;color:var(--ink);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;font-family:inherit;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.audio-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.audio-button.active{border-color:#f4b26f8c}.audio-button svg{width:16px;height:16px;fill:currentColor}.audio-button.audio-mode{min-width:38px}.audio-volume{height:4px;border-radius:999px;background:#ffffff2e;accent-color:var(--accent)}.audio-volume{width:84px}.layout-button{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;border-radius:12px;width:58px;height:38px;padding:0;display:grid;place-items:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.layout-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.layout-button.layout-current{border-color:#ffffff47;position:relative;z-index:7}.audio-trigger{position:relative;z-index:7}.viewer-button{border:1px solid rgba(255,255,255,.16);background:#090c0fbf;border-radius:12px;width:44px;height:38px;display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:border-color .2s ease,transform .2s ease}.viewer-button:hover{border-color:#f4b26f80;transform:translateY(-1px)}.viewer-button svg{width:20px;height:20px;fill:currentColor}.layout-button.active{border-color:#f4b26f80}.layout-visual{width:40px;height:24px;display:grid;gap:3px}.layout-cell{background:#fff3;border-radius:3px}.session-toggle{display:flex;align-items:center}.toggle{border:1px solid rgba(255,255,255,.16);background:#090c0fb3;border-radius:999px;padding:4px 10px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .2s ease}.toggle.on{border-color:#f4b26f80}.toggle-knob{width:20px;height:20px;border-radius:50%;background:#fff3;position:relative}.toggle.on .toggle-knob{background:#f4b26fd9}.toggle-label{display:inline-flex;align-items:center;justify-content:center;color:var(--ink)}.toggle-label svg{width:16px;height:16px}.session-status{justify-self:end}.session-status label{display:grid;gap:6px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.session-status select{border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:6px 10px;font-size:.8rem;font-family:inherit}.canvas-surface{position:relative;width:100%;height:100%;box-sizing:border-box;border-radius:22px;background:#06080abf;border:1px dashed rgba(255,255,255,.2);padding:4px;overflow:hidden}.settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#040608b3;display:grid;align-items:stretch;justify-items:stretch;z-index:5}.settings-window{width:100%;height:100%;max-height:100%;background:#090c0fe6;border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 60px #00000080;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.settings-window-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--muted)}.settings-window-header p{margin:0}.settings-close{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;border-radius:10px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer}.settings-close svg{width:16px;height:16px}.settings-window-body{padding:16px;overflow:hidden;min-height:0}.settings-columns{display:grid;grid-template-columns:minmax(180px,220px) minmax(0,1fr);gap:16px;width:100%;height:100%;min-height:0}.settings-nav{display:grid;gap:12px;align-content:start;padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#080a0c99}.settings-nav-title{margin:0;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.settings-tabs{display:grid;gap:10px}.settings-tab{border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#090c0fa6;color:var(--ink);padding:10px 12px;text-align:left;font-family:inherit;cursor:pointer;display:grid;gap:4px;transition:border-color .2s ease,background .2s ease}.settings-tab:hover{border-color:#ffffff4d;background:#0c0f12b3}.settings-tab.active{border-color:#f4b26f8c;background:#f4b26f1f}.settings-tab.active .settings-tab-label{color:#f4b26f}.settings-tab-label{font-size:.8rem;font-weight:600;color:var(--ink)}.settings-tab-desc{font-size:.65rem;color:var(--muted)}.settings-content{min-width:0;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#080a0c99;padding:14px;display:grid;align-content:start;overflow:auto;min-height:0}.settings-placeholder{margin:0;font-size:.8rem;color:var(--muted)}.settings-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.settings-stat{border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#0a0c0ebf;padding:12px 14px;display:grid;gap:6px}.settings-stat-label{margin:0;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.settings-stat-value{margin:0;font-size:1.2rem;color:var(--ink)}.settings-stat-meta{margin:0;font-size:.7rem;color:var(--muted)}.settings-section{display:grid;gap:14px}.settings-section-title{margin:0;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.settings-actions{display:grid;gap:12px}.settings-block{display:grid;gap:12px;padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#080a0cb3}.settings-block-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-block-title{margin:0;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.settings-form{display:grid;gap:10px}.settings-field{display:grid;gap:6px;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.settings-field input,.settings-field textarea,.settings-field select{border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fbf;color:var(--ink);padding:8px 10px;font-size:.8rem;font-family:inherit;text-transform:none;letter-spacing:.02em}.settings-field textarea{resize:vertical;min-height:80px}.settings-form-actions{display:flex;gap:10px;justify-content:flex-end}.settings-form-button{border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:8px 12px;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.settings-form-button:disabled{opacity:.6;cursor:not-allowed}.settings-form-button.primary{border-color:#f4b26f8c;color:#f4b26f}.settings-form-button.danger{border-color:#f07d7d66;color:#f07d7d}.settings-image-row{display:flex;align-items:center;gap:12px}.settings-image-preview{width:140px;height:84px;border-radius:12px;border:1px dashed rgba(255,255,255,.25);display:grid;place-items:center;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;background-size:cover;background-position:center}.settings-error{margin:0;font-size:.72rem;color:#f07d7d}.settings-action{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;padding:14px 16px;border-radius:14px;background:#080a0cb3;border:1px solid rgba(255,255,255,.08)}.settings-action-text{display:grid;gap:4px}.settings-action-title{margin:0;font-size:.95rem;color:var(--ink)}.settings-action-desc{margin:0;font-size:.78rem;color:var(--muted)}.settings-action-button{border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:8px 12px;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.settings-action-button:hover{border-color:#f4b26f8c;color:#f4b26f}.settings-action-button svg{width:16px;height:16px}.settings-transfer-actions{display:grid;gap:12px}.settings-file-input{display:none}.cell-editor-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:7;background:#040608b8}.cell-editor-toolbar{position:absolute;top:10px;left:12px;right:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:14px;background:#090c0fe6;border:1px solid rgba(255,255,255,.12);z-index:1}.cell-editor-tools,.cell-editor-actions{display:flex;gap:6px}.cell-editor-tool,.cell-editor-action{width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#07090ccc;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.cell-editor-tool svg,.cell-editor-action svg{width:16px;height:16px}.cell-editor-tool.active{border-color:#f4b26f99;color:#f4b26f}.cell-editor-controls{display:flex;gap:10px;align-items:center}.cell-editor-field{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:6px;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.cell-editor-field input[type=color]{width:32px;height:24px;padding:0;border:none;background:transparent}.cell-editor-field input[type=number]{width:52px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:4px 6px;font-size:.7rem;font-family:inherit}.cell-editor-stage{position:absolute;border-radius:18px;border:1px solid rgba(255,255,255,.16);overflow:hidden;box-shadow:0 20px 50px #00000073}.media-explorer-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#040608c7;display:grid;place-items:center;z-index:6;border-radius:22px;transition:opacity .18s ease}.media-explorer-overlay.drag-hidden{opacity:0;pointer-events:none}.media-explorer-window{width:100%;height:100%;background:#090c0feb;border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:0 26px 70px #0000008c;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.media-explorer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--muted)}.media-explorer-header p{margin:0}.media-explorer-close{border:1px solid rgba(255,255,255,.14);background:#090c0fb3;border-radius:10px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer}.media-explorer-close svg{width:16px;height:16px}.media-explorer-body{grid-template-columns:240px 1fr;padding:12px}.viewer-shell{width:100%;min-height:96vh;background:#0a0d10cc;border-radius:24px;border:1px solid rgba(255,255,255,.12);padding:8px;display:flex;flex-direction:column}.viewer-surface{height:100%;flex:1}.canvas-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:36px 36px;opacity:.3}.media-grid{position:relative;display:grid;gap:4px;width:100%;height:100%}.media-cell{position:relative;border-radius:14px;background:#090c0fcc;border:1px solid rgba(255,255,255,.1);overflow:hidden}.media-cell.drag-over{border-color:#f4b26f99}.media-content{width:100%;height:100%;object-fit:cover;display:block}.cell-index{position:absolute;top:6px;left:6px;background:#090c0fb3;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:2px 6px;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);z-index:2}.cell-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.cell-canvas-stage{display:block}.drop-hint{width:100%;height:100%;position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:grid;place-items:center;font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.2em}.context-menu{position:fixed;z-index:1000;background:#090c0ff2;border-radius:12px;border:1px solid rgba(255,255,255,.12);padding:6px;display:grid;gap:8px;min-width:200px}.context-menu button{border:none;background:transparent;color:var(--ink);text-align:left;padding:8px 10px;border-radius:8px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:8px}.context-menu button svg{width:16px;height:16px}.context-menu button:hover{background:#ffffff14}.context-menu-section{display:grid;gap:6px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}.context-menu-section:last-child{border-bottom:none;padding-bottom:0}.context-menu-item.active{background:#f4b26f26;color:#f4b26f}.context-menu-item.danger{color:#f39b9b}.context-menu-item:disabled{opacity:.4;cursor:not-allowed}.context-menu-item:disabled:hover{background:transparent}.context-menu-row{display:flex;gap:6px}.context-menu-icon{width:34px;height:34px;padding:0;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#080a0cb3;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.context-menu-icon.active{border-color:#f4b26f99;color:#f4b26f}.context-menu-pill{border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#080a0cb3;color:var(--ink);font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;padding:4px 10px;cursor:pointer}.context-menu-pill.active{border-color:#f4b26f99;color:#f4b26f}.context-menu-field{display:grid;grid-template-columns:18px 1fr;align-items:center;gap:6px;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.context-menu-field input[type=color]{width:100%;height:26px;padding:0;border:none;background:transparent}.context-menu-field input[type=range]{width:100%}.context-menu-field input[type=number]{border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:4px 6px;font-size:.65rem;font-family:inherit}.playlist-menu{position:fixed;z-index:1000;background:#090c0ff2;border-radius:12px;border:1px solid rgba(255,255,255,.12);padding:10px;display:grid;gap:8px;min-width:210px}.playlist-menu-title{margin:0;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.playlist-menu-field{display:grid;gap:6px;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.playlist-menu-field input[type=number]{border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#090c0fbf;color:var(--ink);padding:6px 8px;font-family:inherit}.playlist-menu-field input[type=range]{height:4px;border-radius:999px;background:#ffffff2e;accent-color:var(--accent)}.playlist-menu-delete{border-radius:10px;border:1px solid rgba(240,125,125,.35);background:#090c0fb3;color:#f07d7d;padding:6px 8px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.transition-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#050607}.transition-video{width:100%;height:100%;object-fit:cover}.transition-fade{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 40% 40%,#0000001a,#000000a6)}.column{display:flex;flex-direction:column;gap:24px}.kicker{text-transform:uppercase;letter-spacing:.3em;font-size:.7rem;color:var(--muted);margin:0 0 12px}h1,h2{font-family:Roboto,system-ui,sans-serif;margin:0;font-weight:600;line-height:1.15}h1,h2{font-size:clamp(1.6rem,2.4vw,2.4rem)}.tagline{margin:10px 0 0;color:var(--muted);font-size:1.05rem;max-width:420px}.auth-panel{background:var(--glass-strong);border-radius:24px;padding:24px;border:1px solid rgba(255,255,255,.12);display:grid;gap:18px}.auth-tabs{display:inline-flex;background:#ffffff14;border-radius:999px;padding:4px;width:fit-content}.auth-tabs button{border:none;background:transparent;color:var(--muted);font-family:inherit;font-size:.95rem;padding:8px 16px;border-radius:999px;cursor:pointer;transition:all .2s ease}.auth-tabs button.active{background:#f4b26f3d;color:var(--ink)}.auth-form{display:grid;gap:14px}.auth-error{margin:0;font-size:.85rem;color:#f2b1a1}.auth-form label{display:grid;gap:6px;font-size:.85rem;color:var(--muted)}.auth-form input{border-radius:14px;border:1px solid rgba(255,255,255,.16);background:#090c0fa6;padding:12px 14px;color:var(--ink);font-size:.95rem;font-family:inherit}.auth-form input:focus{outline:none;border-color:#f4b26f99;box-shadow:0 0 0 2px #f4b26f26}.primary{margin-top:6px;border:none;border-radius:14px;padding:12px 16px;font-size:1rem;font-family:inherit;color:#1c1207;background:linear-gradient(135deg,var(--accent),var(--accent-strong));cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.primary:hover{transform:translateY(-1px);box-shadow:0 12px 24px #f4b26f47}.sessions-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.sessions-info{display:grid;gap:4px}.sessions-create{display:flex;align-items:center;gap:8px}.sessions-input{border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:8px 10px;font-size:.75rem;font-family:inherit;width:180px}.sessions-input:disabled{opacity:.5;cursor:not-allowed}.sessions-button{width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:#090c0fbf;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.sessions-button svg{width:18px;height:18px}.sessions-button:hover{border-color:#f4b26f66;transform:translateY(-1px)}.sessions-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.sessions-list{display:grid;gap:14px}.sessions-empty{margin:0;font-size:.85rem;color:var(--muted)}.session-card{display:flex;align-items:center;gap:16px;padding:14px 16px;border-radius:18px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);position:relative;transition:transform .2s ease,border-color .2s ease;cursor:pointer}.session-link{text-decoration:none;color:inherit}.session-card:hover{transform:translateY(-2px);border-color:#f4b26f73}.session-card:after{content:attr(data-tooltip);position:absolute;right:16px;top:calc(100% + 10px);background:#0c1014f2;color:var(--ink);padding:10px 14px;border-radius:12px;font-size:.85rem;opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .2s ease,transform .2s ease;border:1px solid rgba(255,255,255,.12);width:max-content;max-width:240px}.session-card:hover:after{opacity:1;transform:translateY(0)}.session-thumb{width:74px;height:56px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.18);flex-shrink:0}.session-content{flex:1;min-width:0}.session-action{margin-left:auto;width:32px;height:32px;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:#090c0fbf;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.session-action svg{width:18px;height:18px}.session-action:hover{border-color:#f4b26f66;transform:translateY(-1px)}.session-action.danger{border-color:#f07d7d59;color:#f07d7d}.session-adventure{margin:0;font-weight:600;font-size:1rem}.session-title{margin:4px 0 0;font-size:.85rem;color:var(--muted)}.adventure-details{display:flex;flex-direction:column;gap:18px}.adventure-details-header{display:grid;gap:6px}.adventure-details-card{display:grid;gap:16px;padding:16px;border-radius:20px;background:#ffffff14;border:1px solid rgba(255,255,255,.12)}.adventure-details-cover{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.16);aspect-ratio:16/9}.adventure-details-cover img{width:100%;height:100%;object-fit:cover;display:block}.adventure-details-badge{position:absolute;top:12px;right:12px;border-radius:999px;border:1px solid rgba(255,255,255,.3);padding:4px 10px;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;background:#080a0cbf;color:var(--ink)}.adventure-details-body{display:grid;gap:10px}.adventure-details-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.adventure-details-title{margin:0;font-size:1.05rem;font-weight:600}.adventure-details-description{margin:0;font-size:.85rem;color:var(--muted);line-height:1.4}.adventure-details-meta{display:grid;gap:8px}.adventure-details-meta-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:12px;padding:8px 10px;background:#090c0fa6;border:1px solid rgba(255,255,255,.12)}.adventure-details-meta-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.adventure-details-meta-value{font-size:.8rem;color:var(--ink)}.adventure-details-empty{margin:0;font-size:.85rem;color:var(--muted)}.adventure-panel{display:flex;flex-direction:column;gap:24px}.adventure-header{display:flex;align-items:center;justify-content:space-between;gap:18px}.adventure-count{border-radius:999px;border:1px solid rgba(255,255,255,.18);padding:6px 12px;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.adventure-create{display:flex;align-items:center;gap:10px}.adventure-input{flex:1;border-radius:14px;border:1px solid rgba(255,255,255,.16);background:#090c0fb3;color:var(--ink);padding:10px 12px;font-size:.85rem;font-family:inherit}.adventure-icon{width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#090c0fbf;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:border-color .2s ease,transform .2s ease}.adventure-icon svg{width:20px;height:20px}.adventure-icon:hover{border-color:#f4b26f66;transform:translateY(-1px)}.adventure-icon.danger{border-color:#f07d7d59;color:#f07d7d}.adventure-list{display:grid;gap:12px}.adventure-card{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);transition:border-color .2s ease,background .2s ease}.adventure-card.active{border-color:#f4b26f8c;background:#f4b26f1f}.adventure-select{flex:1;background:transparent;border:none;text-align:left;color:inherit;cursor:pointer;display:grid;gap:4px;font-family:inherit}.adventure-title{margin:0;font-size:1rem;font-weight:600}.adventure-meta{margin:0;font-size:.8rem;color:var(--muted)}.adventure-actions{display:inline-flex;align-items:center;gap:8px}.adventure-badge{border-radius:999px;border:1px solid rgba(255,255,255,.2);padding:4px 10px;font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.adventure-empty{margin:0;font-size:.85rem;color:var(--muted)}.adventure-start{border-radius:16px;border:1px solid rgba(244,178,111,.6);background:#f4b26f26;color:#f4b26f;padding:12px 18px;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:transform .2s ease,border-color .2s ease}.adventure-start svg{width:18px;height:18px}.adventure-start:hover{border-color:#f4b26fcc;transform:translateY(-1px)}.adventure-start:disabled{opacity:.5;cursor:not-allowed;border-color:#fff3;color:var(--muted)}.legal-footer{position:fixed;bottom:18px;left:0;right:0;display:flex;justify-content:center;gap:24px;font-size:.85rem;z-index:2}.legal-footer a{color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:999px;background:#0a0d1066;border:1px solid rgba(255,255,255,.08);transition:color .2s ease,background .2s ease}.legal-footer a:hover{color:var(--ink);background:#0a0d10b3}.legal-card{max-width:720px;grid-template-columns:1fr;text-align:left;gap:16px}.legal-kicker{letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-size:.7rem;margin:0}.legal-line{margin:0;color:var(--muted)}.legal-back{margin-top:10px;color:var(--accent);text-decoration:none;font-weight:600}.legal-back:hover{color:var(--accent-strong)}.notebook-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:35;padding:8px;background:#06080ac7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notebook-window{width:100%;height:100%;display:flex;flex-direction:column;gap:12px;padding:18px 20px;background:#0a0c10eb;border-radius:18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 50px #0006}.notebook-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.notebook-header h2{margin:4px 0 0;font-size:1.3rem}.notebook-kicker{margin:0;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.notebook-actions{display:inline-flex;gap:8px}.notebook-action{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:#090c0fcc;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.notebook-action svg{width:18px;height:18px}.notebook-action:hover{border-color:#f4b26f80;transform:translateY(-1px)}.notebook-toolbar{display:inline-flex;gap:8px;padding:8px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#080a0dcc;width:fit-content}.notebook-tool{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#0c1014cc;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.notebook-tool svg{width:18px;height:18px}.notebook-tool:hover{border-color:#f4b26f73;transform:translateY(-1px)}.notebook-editor{flex:1;min-height:0;padding:16px 18px;border-radius:16px;border:1px solid rgba(255,255,255,.16);background:#050709bf;color:var(--ink);font-size:.95rem;line-height:1.6;overflow-y:auto;outline:none}.notebook-editor h1,.notebook-editor h2,.notebook-editor h3,.notebook-editor p{margin:0 0 10px}@media (max-width: 980px){.glass-card{grid-template-columns:1fr}.session-card:after{right:12px;left:12px;width:auto}.app-shell{grid-template-columns:1fr;height:auto}.app-main{flex-direction:column;height:auto}.sidebar{width:100%;height:auto}.sidebar.collapsed{width:100%}}@media (max-width: 720px){.page{padding:8vh 6vw 14vh}.glass-card{padding:20px}.legal-footer{flex-wrap:wrap;gap:12px;padding:0 12px}.page.app-view{padding:12px}.page.viewer-view{padding:1.5vh 2vw 4vh}.settings-columns{grid-template-columns:1fr}.settings-nav{padding:10px}}
