:root{--color-primary: #ff8c42;--color-primary-hover: #ffa66b;--color-primary-alpha: rgba(255, 140, 66, .2);--bg-main: #2a2a2a;--bg-surface: #1a1a1a;--bg-element: #333333;--bg-element-hover: #444444;--border-subtle: #333333;--border-medium: #555555;--color-danger: #d9534f;--color-danger-hover: #c9302c;--color-success: #5cb85c;--color-info: #5bc0de;--color-warning: #f0ad4e;--color-team-a: #007bff;--color-team-b: #dc3545;--color-ball: #ffff00;--color-equipment: #ffc107;--text-main: rgba(255, 255, 255, .87);--text-muted: #888888;--text-dim: #666666;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 20px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 50px;--radius-standard: 10px;--spacing-panel-bottom: calc(var(--spacing-lg) + 24px);--surface-low: #121212;--surface-mid: #1e1e1e;--surface-high: #2a2a2a;--shadow-soft: 0 4px 12px rgba(0, 0, 0, .25);--shadow-heavy: 0 12px 48px rgba(0, 0, 0, .5);--stroke-subtle: rgba(255, 255, 255, .06);--stroke-medium: rgba(255, 255, 255, .12);--transition-fast: .15s ease;--transition-standard: .25s cubic-bezier(.4, 0, .2, 1);--z-ui: 50}.dashboard-sidebar-header{padding:16px;border-bottom:1px solid var(--border-subtle);font-weight:700;color:var(--text-dim);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.dashboard-folders-list{flex:1;overflow-y:auto;padding:8px}.dashboard-folders-add-row{margin-top:16px;padding:0 12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}.dashboard-folders-label{font-weight:700}.dashboard-folders-footer{padding:12px 16px;border-top:1px solid var(--border-subtle);font-size:11px;color:var(--text-dim);text-align:center;display:flex;align-items:center;justify-content:center;gap:6px}.dashboard-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-dim)}.dashboard-empty-icon{margin-bottom:16px;opacity:.2}.sidebar-btn-content{display:flex;align-items:center;gap:10px}.folder-icon{color:var(--text-dim)}.sidebar-btn.active .folder-icon,.folder-icon.selected{color:var(--color-primary)}.project-thumb-icon{color:var(--text-dim)}.dashboard-title-box{display:flex;align-items:center;gap:10px}.dashboard-title-text{font-weight:700;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-title-text.mobile{max-width:120px}.dashboard-actions-row{display:flex;align-items:center;gap:16px}.dashboard-actions-row.mobile{gap:8px}.dashboard-back-link{background:none;border:none;color:var(--color-primary);font-size:12px;font-weight:700;cursor:pointer;padding-right:0;min-width:unset}.btn-add-folder{border:none;background:transparent;height:auto;width:auto;padding:4px}.btn-close-dashboard{color:var(--text-muted);font-size:24px;background:none;border:none;cursor:pointer;min-width:unset;min-height:unset;margin-left:16px}.btn-close-dashboard.mobile{margin-left:4px}.dashboard-content-scrollbox{flex:1;overflow-y:auto}.dashboard-error-banner{margin:24px;padding:12px;background-color:#d9534f1a;border:1px solid var(--color-danger);color:var(--color-danger);border-radius:var(--radius-md);text-align:center}.folder-create-form{padding:0 8px 8px}.folder-create-input{border-color:var(--color-primary)!important}.project-item-actions{margin-left:auto}.project-item-actions-grid{padding:0 var(--spacing-md) var(--spacing-md)}.overflow-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:none;border:none;color:var(--text-main);font-size:13px;border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%}.overflow-item:hover:not(:disabled){background-color:var(--bg-element-hover);color:#fff}.overflow-item:disabled{opacity:.4;cursor:not-allowed}.overflow-item.danger{color:var(--color-danger)}.overflow-item.danger:hover:not(:disabled){background-color:#d9534f1a}.overflow-divider{height:1px;background:var(--border-subtle);margin:4px 6px}.overflow-section-label{padding:4px 8px;font-size:11px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.header-btn.compact{padding:0 6px;min-width:28px;gap:4px}.header-mobile-controls{display:flex;align-items:center;gap:6px}.header-mobile-save{transition:opacity .2s}.header-mobile-save.disabled{opacity:.5}.header-mobile-user-menu{margin-left:var(--spacing-xs)}.header-desktop-save{transition:opacity .2s,cursor .2s}.header-desktop-save.disabled{opacity:.5;cursor:not-allowed}.header-export-controls{display:flex;gap:6px;margin-left:0}.header-speed-select-icon{margin-left:var(--spacing-xs);font-size:10px;color:var(--color-warning)}#header-controls{min-width:0}.header-overflow-menu .header-speed-selector{width:100%;margin:0}.header-overflow-menu .header-speed-selector select{width:100%;padding:6px}.tutorial-prompt-text{margin:0 0 var(--spacing-md) 0;color:var(--text-main);line-height:1.5}.tutorial-prompt-checkbox{margin:0;color:var(--text-muted)}.header-project-container{display:flex;align-items:center;gap:var(--spacing-lg)}.header-project-container.compact{gap:var(--spacing-sm)}.header-project-info{font-weight:700;font-size:18px;color:var(--color-primary);display:flex;align-items:center;gap:12px}.header-sport-select{background-color:var(--bg-element);color:#fff;border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:4px 8px;font-size:14px;cursor:pointer;width:clamp(100px,15vw,180px);transition:width .2s ease}@media(max-width:1024px){.header-project-info{font-size:16px}.header-sport-select{width:clamp(80px,20vw,150px);margin-left:0}}.header-project-name{color:#fff;font-size:14px;display:flex;align-items:center;margin-left:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.header-project-label{color:var(--border-subtle);margin-right:var(--spacing-sm)}.header-project-tag{color:var(--color-primary);opacity:.8}.header-project-value{margin-left:var(--spacing-xs)}.header-ghost-container{position:absolute;visibility:hidden;pointer-events:none;top:0;left:0;display:flex;gap:8px;white-space:nowrap}.header-ghost-container.compact{gap:4px}.header-overflow-trigger-wrap{position:relative}.header-overflow-menu{position:absolute;top:calc(100% + 8px);right:0;background-color:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:0 8px 16px #00000080;min-width:200px;z-index:2000;padding:6px;display:flex;flex-direction:column;gap:4px}.header-overflow-item-row{display:flex;gap:4px;padding:4px}.header-overflow-speed-container{padding:0 8px 8px}.header-neon-group{display:flex;gap:2px;align-items:center}.neon-lite-btn{font-size:10px;padding:2px 4px;width:auto;min-width:32px}.header-btn.active-primary{color:var(--color-primary)!important}.header-btn.active-neon{color:#00f3ff!important}.header-btn.inactive{color:var(--text-muted)!important}.header-logo-tag{font-size:10px;color:var(--text-dim);margin-left:var(--spacing-xs)}.header-logo-compact{margin-right:4px}.header-readonly-badge{margin-left:var(--spacing-sm);font-size:10px;background-color:var(--bg-element);padding:2px 6px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:var(--spacing-xs)}.header-save-status{margin-left:15px;font-size:12px;color:var(--text-muted);font-weight:400}.view-mode-selector{display:flex;gap:2px}.view-mode-btn{padding:6px 8px;font-size:12px;background-color:var(--bg-element);color:#fff;border:1px solid var(--border-medium);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;transition:all .2s}.view-mode-btn:hover{background-color:var(--bg-element-hover);border-color:var(--color-primary)}.view-mode-btn.active{background-color:var(--color-primary)}.header-export-group{display:flex;gap:8px;align-items:center}.export-btn-recording{background-color:var(--color-danger)!important;border-color:#0003!important}.prop-input-label-row{min-width:72px;width:88px;flex:1 1 88px}.prop-input-color-row{width:fit-content;max-width:100%;flex:0 1 auto;padding:4px;border:1px solid var(--stroke-subtle);border-radius:var(--radius-standard);background-color:var(--surface-high);gap:var(--spacing-sm);overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;-ms-overflow-style:auto}.selected-objects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.selected-objects-title{margin:0}.selected-count-badge{font-size:11px;background-color:var(--bg-element);padding:2px 6px;border-radius:10px;color:var(--text-muted)}.color-picker-container{position:relative}.arrow-style-group,.arrow-head-group{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.view-mode-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.view-mode-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.arrow-style-group{grid-template-columns:repeat(3,minmax(0,1fr))}.arrow-preview-btn{height:40px;padding:0;display:flex;align-items:center;justify-content:center}.arrow-preview-btn.active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.arrow-style-line{width:26px;height:0;border-top:3px solid #fff}.arrow-style-line.dashed{border-top-style:dashed}.arrow-style-line.dotted{border-top-style:dotted}.arrow-head-preview{position:relative;display:block;width:26px;height:2px;background:#fff}.arrow-head-preview.start:before,.arrow-head-preview.end:after{content:"";position:absolute;width:0;height:0}.arrow-head-preview.start.head-none:before,.arrow-head-preview.end.head-none:after{display:none}.arrow-head-preview.start.head-arrow:before{left:-8px;top:-4px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:8px solid #fff}.arrow-head-preview.end.head-arrow:after{right:-8px;top:-4px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:8px solid #fff}.arrow-head-preview.start.head-t-shape:before{left:-2px;top:-4px;width:2px;height:10px;background:#fff}.arrow-head-preview.end.head-t-shape:after{right:-2px;top:-4px;width:2px;height:10px;background:#fff}.arrow-head-preview.start.head-dot:before{left:-6px;top:-3px;width:8px;height:8px;border-radius:50%;background:#fff}.arrow-head-preview.end.head-dot:after{right:-6px;top:-3px;width:8px;height:8px;border-radius:50%;background:#fff}.reset-btn{margin-top:auto;background-color:var(--bg-element);border-color:var(--border-medium)}.delete-btn{background-color:var(--color-danger);border-color:var(--color-danger)}.delete-btn:hover{background-color:var(--color-danger-hover);border-color:var(--color-danger-hover)}.reset-btn:hover{background-color:var(--bg-element-hover);border-color:var(--color-primary)}.properties-panel>.btn-action.reset-btn,.properties-panel>.btn-action.delete-btn{flex:0 0 44px;width:100%}.panel-section-primary{margin-bottom:calc(var(--spacing-lg) * 1.5)}.panel-section-secondary{margin-top:var(--spacing-lg);padding:var(--spacing-md);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background-color:#ffffff05}.panel-helper-note{margin-top:auto;color:var(--text-dim);font-size:10px;line-height:1.4;text-align:center;padding:var(--spacing-lg);max-width:220px;margin-left:auto;margin-right:auto;opacity:.6;font-style:italic}.properties-panel{display:flex;flex-direction:column;height:100%;min-height:0;overflow-y:auto;padding:var(--spacing-lg);padding-bottom:var(--spacing-panel-bottom);scrollbar-width:thin}.step-settings-section{display:flex;flex-direction:column;gap:16px;padding:20px;border:1px solid var(--stroke-subtle);border-radius:var(--radius-standard);background-color:var(--surface-low)}.step-settings-section .prop-header{margin:0}.step-color-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.step-color-input{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border-medium);background:var(--bg-element);padding:2px;cursor:pointer}.properties-panel .color-btn{width:32px;height:32px;border-radius:var(--radius-standard);cursor:pointer;border:1px solid var(--stroke-subtle);transition:var(--transition-fast);padding:0;--swatch-color: #ffffff;background-color:var(--swatch-color)}.color-btn:hover{transform:scale(1.05);border-color:var(--color-primary)}.color-btn.active{border:2px solid white;box-shadow:0 0 0 1px var(--bg-surface)}@media(max-width:1024px){.prop-row{flex-wrap:wrap}.prop-input-label-row{flex:1 1 100%;width:100%;min-width:0}.prop-input-color-row{justify-content:flex-start}}.tutorial-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:var(--z-overlay-max)}.tutorial-bubble-container{position:fixed;z-index:var(--z-overlay-max);transition:all .3s ease}.tutorial-skip-btn{border:none;color:var(--text-muted);background:transparent;flex:none;height:auto;font-size:13px;cursor:pointer}.tutorial-skip-btn:hover{text-decoration:underline;color:var(--text-main)}.tutorial-nav-btn{height:36px;padding:0 16px}.tutorial-next-btn{height:36px;background-color:var(--color-primary);font-weight:700;color:#fff}.tutorial-next-btn:hover{background-color:var(--color-primary-hover)}#timeline-container{grid-area:timeline;height:var(--timeline-h);overflow-x:hidden;overflow-y:hidden;background-color:#121212d1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--stroke-subtle);display:flex;flex-direction:column;padding:4px var(--spacing-md);z-index:var(--z-timeline);box-sizing:border-box}.timeline-controls{display:flex;justify-content:space-between;gap:calc(var(--spacing-md) * var(--ui-scale, 1));margin-bottom:4px;align-items:center}.timeline-controls-main{display:flex;gap:calc(var(--spacing-sm) * var(--ui-scale, 1));align-items:center;flex-wrap:nowrap}.timeline-btn{border:none;color:#fff;padding:0 calc(12px * var(--ui-scale, 1));height:calc(44px * var(--ui-scale, 1));cursor:pointer;border-radius:var(--radius-standard);flex-shrink:0;display:flex;justify-content:center;align-items:center;gap:calc(8px * var(--ui-scale, 1));font-weight:600;font-size:13px;transition:var(--transition-standard)}.timeline-btn:disabled{opacity:.5;cursor:not-allowed}.timeline-btn-play{width:calc(40px * var(--ui-scale, 1));background-color:var(--color-success)}.timeline-btn-play.playing{background-color:var(--color-danger)}.timeline-btn-add{background-color:var(--color-success)}.timeline-btn-delete{background-color:var(--color-danger)}.timeline-btn-ghost,.timeline-btn-dynamic{background:transparent;border:1px solid var(--border-medium);color:var(--text-muted)}.timeline-btn-ghost.active{color:var(--color-danger)}.timeline-btn-dynamic.active{color:var(--color-team-a)}.timeline-btn-dynamic:disabled{color:#444}.timeline-label{font-size:14px;color:var(--text-muted);min-width:calc(80px * var(--ui-scale, 1));text-align:center;flex-shrink:0}.timeline-frames{display:flex;overflow-x:auto;gap:6px;flex:1;min-height:0;align-items:center;padding-bottom:1px}.frame-box{width:96px;height:46px;min-width:96px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface-high),#fff 3%),var(--surface-mid));border:1px solid var(--stroke-subtle);border-radius:var(--radius-standard);cursor:pointer;color:color-mix(in srgb,var(--text-main),#fff 8%);display:flex;flex-direction:column;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:var(--transition-standard),transform .15s ease,box-shadow .2s ease,border-color .2s ease;flex-shrink:0;overflow:hidden;box-shadow:inset 0 1px #ffffff0d}.frame-box span{pointer-events:none;text-align:center}.frame-box:hover{border-color:color-mix(in srgb,var(--stroke-medium),#fff 18%);transform:translateY(-1px);box-shadow:0 4px 10px #00000040,inset 0 1px #ffffff0d}.frame-box.active{background:linear-gradient(180deg,color-mix(in srgb,var(--frame-color),#fff 12%),var(--frame-color))!important;border-color:color-mix(in srgb,#fff,var(--frame-color) 20%);box-shadow:0 0 0 1px color-mix(in srgb,var(--frame-color),#fff 35%),0 6px 14px #00000047}.timeline-frames::-webkit-scrollbar{height:4px}.timeline-frames::-webkit-scrollbar-track{background:#0000001a}.timeline-frames::-webkit-scrollbar-thumb{background:var(--stroke-medium);border-radius:2px}.frame-label-wrapper{pointer-events:none;text-align:center;line-height:1.1;display:flex;align-items:center;justify-content:center}.frame-box span:first-child{font-weight:700;display:block;font-size:14px;letter-spacing:.01em;text-shadow:0 1px 1px rgba(0,0,0,.35);color:color-mix(in srgb,var(--text-main),#fff 14%);font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}.frame-box span:nth-child(2){font-size:10px;color:var(--text-muted)}.frame-box.active span:first-child{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.45)}@media(min-width:768px)and (max-width:1280px){#timeline-container{padding:3px var(--spacing-md);height:var(--timeline-h)}.timeline-controls{margin-bottom:2px;gap:8px}.timeline-btn{min-height:30px;height:30px;padding:0 10px;font-size:11px}.timeline-label{font-size:11px;min-width:50px}.frame-box{width:72px;min-width:72px;height:30px}.frame-box span:first-child{font-size:11px}.frame-box span:nth-child(2){display:none}}@media(min-width:1025px)and (max-width:1280px){.frame-box{width:80px;min-width:80px;height:32px}}@media(max-height:500px)and (min-width:768px){#timeline-container{padding-top:3px;padding-right:8px;padding-bottom:3px}.timeline-controls{margin-bottom:2px;gap:6px}.timeline-btn{height:28px;min-height:28px;padding:0 8px;font-size:10px}.timeline-label{font-size:11px;min-width:52px}.frame-box{min-width:62px;width:62px;height:30px}}.frame-box.drop-before{border-left:4px solid #00ff88}.frame-box.drop-after{border-right:4px solid #00ff88}:root{--board-bg: #2a2a2a;--header-h: 56px;--timeline-h: 120px;--footer-h: 0px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--board-h: calc(100dvh - var(--header-h) - var(--timeline-h));--content-safe-h: var(--board-h);--toolbar-footprint: 80px;--z-board: 1;--z-toolbar: 10;--z-timeline: 20;--z-header: 100;--z-drawer-overlay: 150;--z-drawer: 200;--z-modal-overlay: 1000;--z-modal: 1001;--z-toast: 2000;--z-max: 99999;--area-header: header;--area-toolbar: toolbar;--area-board: board;--area-panel: panel;--area-timeline: timeline;--area-footer: footer;--toolbar-w: 80px;--panel-w: 250px;--toolbar-mobile-h: 60px}.app-container{--ui-scale: 1;height:100dvh;max-height:100dvh;display:grid;grid-template-areas:"header" "main" "timeline";grid-template-rows:auto 1fr auto;overflow:hidden}@media(max-width:767px){:root{--header-h: 50px;--toolbar-footprint: 0px;--timeline-h: 70px;--footer-h: 0px;--toolbar-w: 0px;--panel-w: 0px}.app-container{grid-template-areas:"header" "board" "toolbar" "timeline";grid-template-rows:auto 1fr auto auto}.main-content-wrapper{display:contents!important}}@media(min-width:768px)and (max-width:1024px){:root{--header-h: 48px;--timeline-h: 72px;--footer-h: 0px;--toolbar-footprint: 64px;--panel-w: 200px;--toolbar-w: 64px}.app-container.vp-tablet{--ui-scale: .92}}@media(min-width:1025px)and (max-width:1280px){:root{--header-h: 48px;--timeline-h: 80px;--toolbar-footprint: 72px;--toolbar-w: 72px;--panel-w: 220px}.app-container.vp-narrow{--ui-scale: .94}}.main-content-wrapper{grid-area:main;display:grid;grid-template-areas:"toolbar board panel";grid-template-columns:var(--toolbar-w) 1fr auto;min-height:0;min-width:0;overflow:hidden}.board-container-base{grid-area:board;position:relative;min-height:0;min-width:0;background-color:var(--board-bg)}.legal-footer-wrapper{height:var(--footer-h);position:relative;padding:2px 10px;font-size:11px;color:var(--text-muted);font-family:sans-serif;display:flex;justify-content:flex-end;background-color:transparent;border-top:1px solid var(--stroke-subtle);z-index:calc(var(--z-ui) + 1)}.legal-footer-content{pointer-events:auto;background-color:#00000040;padding:2px 8px;border-radius:4px}.btn-legal-link{background:none;border:none;color:#aaa;cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.props-sidebar-desktop{width:calc(250px * var(--ui-scale, 1));min-width:calc(250px * var(--ui-scale, 1));flex-shrink:0;height:100%;min-height:0;overflow:hidden;display:flex;position:relative;background-color:var(--surface-mid);border-left:1px solid var(--stroke-subtle);box-shadow:-8px 0 20px #00000047}@media(min-width:1025px)and (max-width:1280px){.props-sidebar-desktop{width:220px;min-width:220px}}.btn-toggle-properties{position:absolute;top:10px;right:10px;z-index:var(--z-toolbar);background-color:#333;color:#fff;border:1px solid #555;border-radius:4px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px #0000004d;pointer-events:auto}.btn-toggle-properties svg{font-size:14px}@media(min-width:1025px)and (max-width:1280px){.btn-toggle-properties{top:8px;right:8px;padding:7px}}.btn-restore-ui{position:absolute;top:10px;right:10px;z-index:var(--z-toast);background-color:#00000080;color:#fff;border:1px solid #666;border-radius:4px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-restore-ui svg{font-size:20px}.legal-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;z-index:var(--z-modal-overlay);display:flex;justify-content:center;align-items:center}.legal-modal-container{background-color:#1e1e1e;padding:0;border-radius:12px;width:min(700px,95vw);height:min(500px,90vh);display:flex;flex-direction:column;color:#fff;border:1px solid #333;box-shadow:0 8px 32px #00000080;overflow:hidden;z-index:var(--z-modal)}.legal-modal-header{display:flex;justify-content:space-between;padding:20px;border-bottom:1px solid #333;align-items:center}.legal-modal-title{margin:0;font-size:18px;display:flex;align-items:center;gap:10px}.btn-legal-close{background:none;border:none;color:#888;cursor:pointer;font-size:20px}.legal-modal-body{display:flex;flex:1;overflow:hidden}.legal-sidebar{background-color:#151515;display:flex;overflow-x:auto}.legal-sidebar-desktop{width:200px;border-right:1px solid #333;flex-direction:column;overflow-x:hidden}.legal-sidebar-mobile{width:100%;border-bottom:1px solid #333;flex-direction:row}.btn-legal-tab{padding:15px;border:none;cursor:pointer;white-space:nowrap;background:transparent;color:#888;font-weight:400}.btn-legal-tab-active{background:#222;color:#ff8c42;font-weight:700}.btn-legal-tab-desktop{width:100%;text-align:left}.btn-legal-tab-mobile{width:auto;text-align:center}.legal-content-panel{flex:1;padding:30px;overflow-y:auto;line-height:1.6;font-size:14px;color:#ccc;overscroll-behavior:contain}.legal-accent-link{color:#ff8c42}.save-modal-btn{border-radius:var(--radius-sm);padding:8px 16px;color:#fff}.save-modal-btn-secondary{background:transparent;border:1px solid var(--border-medium)}.save-modal-btn-primary{background:var(--color-primary);border:none;font-weight:700}.save-modal-save-btn{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.save-modal-save-btn.disabled{background:var(--bg-element);cursor:not-allowed}.save-modal-center{text-align:center}.save-modal-lock-icon{margin-bottom:var(--spacing-lg)}.save-modal-text-main{color:var(--text-main);line-height:1.6;margin:0 0 var(--spacing-md)}.save-modal-text-muted{color:var(--text-muted)}.save-modal-description{color:var(--text-muted);font-size:.9rem;margin-bottom:var(--spacing-lg)}.save-modal-field{margin-bottom:var(--spacing-lg)}.save-modal-label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-muted);font-size:13px}.save-modal-input{width:100%;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border-medium);background-color:var(--bg-element);color:#fff;font-size:16px;outline:none}.save-modal-error{color:var(--color-danger);margin-bottom:var(--spacing-md);font-size:14px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{font-family:Inter,Outfit,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-main);background-color:var(--bg-main);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 18px;--font-size-title: 22px}h1,h2,h3{font-family:Outfit,sans-serif;letter-spacing:-.02em}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;min-height:100dvh;width:100vw}#root{width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;overscroll-behavior:none}#board-canvas{touch-action:none}button{border-radius:var(--radius-md);border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-element);color:#fff;cursor:pointer;transition:all .25s}button:hover{border-color:var(--color-primary);background-color:var(--bg-element-hover)}button:disabled{cursor:not-allowed;opacity:.5}input,select{background-color:var(--bg-element);color:#fff;border:1px solid var(--border-medium);padding:5px;border-radius:var(--radius-sm)}#header-bar{grid-area:header;height:var(--header-h);min-height:var(--header-h);background-color:var(--bg-surface);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;flex-wrap:nowrap;padding:0 calc(var(--spacing-lg) * var(--ui-scale, 1));padding-left:calc(calc(var(--spacing-lg) * var(--ui-scale, 1)) + var(--safe-left));padding-right:calc(calc(var(--spacing-lg) * var(--ui-scale, 1)) + var(--safe-right));justify-content:space-between;gap:var(--spacing-sm);z-index:var(--z-header);box-sizing:border-box}.header-section{display:flex;align-items:center;gap:var(--spacing-lg)}.header-section.mobile{gap:var(--spacing-sm)}#header-controls{display:flex;gap:8px;align-items:center;flex:1 1 auto;min-width:0;justify-content:flex-end;container-type:inline-size;container-name:header-controls}#header-controls>*{flex-shrink:0}@container header-controls (max-width: 600px){.vertical-divider:not(.mobile){display:none}.header-speed-selector{display:none}}.header-section,.main-content-wrapper,.board-container-base,#header-controls{min-width:0}#dev-responsive-badge{position:fixed;bottom:4px;left:4px;background:#000c;color:#0f0;font-family:monospace;font-size:10px;padding:2px 6px;border-radius:4px;z-index:9999;pointer-events:none;border:1px solid #060;display:flex;gap:8px}#dev-responsive-badge span:after{content:attr(data-val)}#header-controls.mobile{gap:var(--spacing-xs)}#header-controls::-webkit-scrollbar{display:none}.header-btn{padding:0 calc(10px * var(--ui-scale, 1));display:flex;align-items:center;justify-content:center;min-width:calc(34px * var(--ui-scale, 1));height:calc(34px * var(--ui-scale, 1));background-color:var(--bg-element);border:1px solid var(--border-medium);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.header-btn svg{width:calc(14px * var(--ui-scale, 1));height:calc(14px * var(--ui-scale, 1))}.header-btn:hover{background-color:var(--bg-element-hover);border-color:var(--color-primary)}.header-login-btn{background-color:transparent;border:1px solid var(--color-primary);color:var(--color-primary);padding:0 16px;height:calc(34px * var(--ui-scale, 1));border-radius:var(--radius-sm);font-weight:700;font-size:13px;transition:all .2s;display:flex;align-items:center;justify-content:center}.header-login-btn:hover{background-color:var(--color-primary-alpha);color:var(--color-primary-hover)}.header-btn.small{padding:4px 8px;height:28px;font-size:11px}.header-btn.danger{background-color:var(--color-danger);border-color:#0003}.header-btn.danger:hover{background-color:var(--color-danger-hover)}.header-btn.accent{background-color:var(--color-primary);border-color:#0003}.header-btn.accent:hover{background-color:var(--color-primary-hover)}.header-speed-selector{display:flex;align-items:center;margin-right:var(--spacing-xs);font-size:12px;color:var(--text-muted)}.header-speed-selector select{background:var(--bg-element);border:1px solid var(--border-medium);font-size:11px;padding:2px 4px}.header-zoom-wrap{display:flex;align-items:center;gap:var(--spacing-xs)}.header-zoom-input{width:calc(45px * var(--ui-scale, 1));padding:calc(4px * var(--ui-scale, 1)) calc(6px * var(--ui-scale, 1));background-color:var(--bg-element);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:#fff;font-size:12px;text-align:center}.header-zoom-range{width:calc(60px * var(--ui-scale, 1));accent-color:var(--color-primary)}.vertical-divider{width:1px;background-color:var(--border-subtle);height:24px;margin:0 2px}.vertical-divider.mobile{height:18px;background-color:var(--border-medium);margin:0 4px}#toolbar-container{grid-area:toolbar;display:flex;flex-direction:column;gap:calc(var(--spacing-sm) * var(--ui-scale, 1));background-color:var(--bg-surface);padding:calc(var(--spacing-md) * var(--ui-scale, 1));border-right:1px solid var(--border-subtle);z-index:var(--z-toolbar);overflow-y:auto;scrollbar-width:thin}@media(max-width:767px){#header-bar{padding:0 10px}#toolbar-container{grid-area:toolbar;display:flex;flex-direction:row;justify-content:flex-start;align-items:center;width:100%;height:var(--toolbar-mobile-h);padding:8px 10px;background-color:var(--bg-surface);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);border-right:none;overflow-x:auto;overflow-y:hidden;white-space:nowrap;z-index:var(--z-toolbar)}.hide-on-mobile{display:none}}#toolbar-container::-webkit-scrollbar{display:none}#toolbar-container>button,#toolbar-container>div:not(.toolbar-divider){flex-shrink:0;min-width:44px;min-height:44px}#toolbar-container>.toolbar-divider{height:1px;flex-shrink:0;align-self:center}.props-sidebar-desktop{grid-area:panel;width:var(--panel-w);min-width:var(--panel-w);display:flex;border-left:1px solid var(--border-subtle)}.legal-footer-wrapper{grid-area:footer}@media(max-width:767px)and (max-height:500px){#toolbar-container{position:fixed;left:calc(8px + var(--safe-left));right:calc(8px + var(--safe-right));top:auto;bottom:calc(var(--timeline-h) + var(--footer-h) + var(--safe-bottom) + 6px);flex-direction:row;align-items:center;justify-content:flex-start;max-height:64px;padding:4px 8px;gap:6px;overflow-x:auto;overflow-y:hidden;white-space:nowrap;background-color:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}#toolbar-container>button,#toolbar-container>div{flex-shrink:0}}@media(min-width:768px)and (max-width:1024px){.props-sidebar-desktop{display:flex!important}.properties-panel{padding:var(--spacing-md)}.properties-panel-mobile,.drawer-overlay{display:none!important}}@media(pointer:coarse){button,input[type=checkbox],input[type=color]{min-width:44px;min-height:44px}}.ui-hidden #header-bar,.ui-hidden #toolbar-container,.ui-hidden .properties-panel-mobile,.ui-hidden .drawer-overlay,.ui-hidden button.btn-toggle-properties{display:none}.ui-hidden{scrollbar-width:none;-ms-overflow-style:none;overflow-y:hidden}.app-main-layout{width:100%}.ui-hidden::-webkit-scrollbar{display:none}.properties-panel{width:100%;height:100%;background-color:var(--bg-surface);color:var(--text-main);padding:var(--spacing-lg);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:var(--spacing-md);overflow-y:auto;box-sizing:border-box;overscroll-behavior:contain}.prop-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.prop-header{margin:0;font-size:18px;font-weight:700}.prop-sub-label{font-size:12px;color:var(--text-muted);text-transform:capitalize}.checkbox-row{display:flex;align-items:center;gap:var(--spacing-sm);font-size:14px;cursor:pointer;padding:var(--spacing-xs) 0;-webkit-user-select:none;user-select:none}.checkbox-row input{width:18px;height:18px;cursor:pointer}.prop-label{font-size:14px;color:var(--text-muted)}.prop-input{padding:var(--spacing-sm);background-color:var(--bg-element);border:1px solid var(--border-medium);color:#fff;border-radius:var(--radius-sm);min-height:36px;width:100%;box-sizing:border-box;outline:none}.prop-input:focus{border-color:var(--color-primary)}.prop-row{display:flex;align-items:center;gap:var(--spacing-sm)}.prop-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.btn-group{display:flex;gap:var(--spacing-sm)}button.btn-action{flex:1;height:44px;background-color:var(--bg-element);border:1px solid var(--border-medium);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);padding:0}button.btn-action:hover{background-color:var(--bg-element-hover);border-color:var(--color-primary)}button.btn-action.destructive{background-color:var(--color-danger)}button.btn-action.destructive:hover{background-color:var(--color-danger-hover)}button.btn-action.accent{background-color:var(--color-primary);color:#fff}button.btn-action.accent:hover{background-color:var(--color-primary-hover)}button.btn-action.padded{padding:0 var(--spacing-md)}.project-item{display:flex;background-color:var(--bg-element);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:all .2s;-webkit-user-select:none;user-select:none}.project-item:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.project-item.grid{flex-direction:column}.project-item.list{flex-direction:row;align-items:center;padding:var(--spacing-md)}.project-thumb-box{background:var(--bg-surface);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.grid .project-thumb-box{height:120px;width:100%;border-bottom:1px solid var(--border-subtle)}.list .project-thumb-box{width:48px;height:48px;border-radius:var(--radius-sm);margin-right:var(--spacing-md)}.project-thumb-box img{width:100%;height:100%;object-fit:cover}.project-info-box{flex:1;min-width:0}.grid .project-info-box{padding:var(--spacing-md)}.project-title{color:#fff;font-weight:500;font-size:14px;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-date{color:var(--text-muted);font-size:12px;margin:0}.project-del-btn{color:var(--color-danger);background:#d9534f1a;padding:6px;border-radius:var(--radius-sm);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.project-del-btn:hover{background:var(--color-danger);color:#fff}.dashboard-search-wrap{position:relative;display:flex;align-items:center}.dashboard-search-wrap svg{position:absolute;left:12px;color:var(--text-dim);pointer-events:none}.dashboard-search-input{border-radius:20px;padding:8px 16px 8px 36px;font-size:14px;width:250px;background-color:var(--bg-surface);border:1px solid var(--border-subtle);color:#fff}@media(max-width:768px){.dashboard-search-input{width:130px;padding:6px 12px 6px 30px}}@media(max-width:768px)and (max-height:620px){#toolbar-container{max-height:66px;padding:4px 8px calc(4px + env(safe-area-inset-bottom)) 8px}#toolbar-container>button,#toolbar-container>div{min-width:40px;min-height:40px;margin:0 4px}}.view-toggle{display:flex;background:var(--bg-surface);border-radius:8px;padding:4px;border:1px solid var(--border-subtle);gap:4px}.view-toggle-btn{padding:6px;border-radius:4px;background:transparent;color:var(--text-dim);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.view-toggle-btn.active{background:var(--bg-element);color:#fff}.divider{border:none;border-top:1px solid var(--border-subtle);width:100%;margin:var(--spacing-md) 0}.color-btn{width:40px;height:40px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border-medium);transition:transform .1s;padding:0}.color-btn:hover{transform:scale(1.05)}.color-btn.active{border:2px solid white}.modal-overlay-blur{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background-color:#000000d1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal-overlay)}.dashboard-container{background-color:var(--bg-surface);width:90vw;height:85vh;display:flex;overflow:hidden;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000080;z-index:var(--z-modal)}.dashboard-container.mobile{width:100vw;height:100dvh;border-radius:0;flex-direction:column}.dashboard-sidebar{width:250px;background-color:#121212;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0}.dashboard-sidebar.mobile{width:100%}.dashboard-main{flex:1;display:flex;flex-direction:column;background-color:var(--bg-surface);overscroll-behavior:contain}.dashboard-header{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);border-bottom:1px solid var(--border-subtle)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg);padding:var(--spacing-lg)}.dashboard-list{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg)}.clickable-item{background-color:var(--bg-element);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all .2s;cursor:pointer}.clickable-item:hover{border-color:var(--color-primary);background-color:var(--bg-element-hover);transform:translateY(-2px)}.clickable-item.active{background-color:var(--color-primary-alpha);border-color:var(--color-primary)}.sidebar-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;background:transparent;border:none;color:var(--text-muted);transition:all .2s;text-align:left}.sidebar-btn:hover{background-color:var(--bg-element);color:#fff}.sidebar-btn.active{background-color:var(--color-primary-alpha);color:var(--color-primary)}.tutorial-dimmer{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:calc(var(--z-overlay-hint) - 1);pointer-events:none}.tutorial-spotlight{position:fixed;border:2px solid var(--color-primary);box-shadow:0 0 0 9999px #00000080;z-index:calc(var(--z-overlay-hint) - 2);border-radius:var(--radius-sm);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.tutorial-bubble{background-color:var(--bg-surface);color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-md);box-shadow:0 10px 25px #00000080;width:280px;z-index:var(--z-overlay-hint);border:1px solid var(--border-medium)}.tutorial-title{margin:0 0 var(--spacing-sm) 0;color:var(--color-primary);font-size:18px}.tutorial-text{margin:0 0 var(--spacing-lg) 0;font-size:14px;color:var(--text-main);line-height:1.5}.tutorial-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.tutorial-nav{display:flex;gap:var(--spacing-sm)}@media(max-width:768px){.tutorial-bubble{width:calc(100vw - 40px);max-width:320px}}
