:root{color-scheme:light;font-family:Inter,Noto Sans JP,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;background-color:#f1f5f9;color:#0f172a}body{margin:0;background:linear-gradient(160deg,#0f172a,#1e293b 45%,#334155);min-height:100vh}.layout{max-width:1440px;margin:0 auto;padding:24px}.app-header{background:#0f172af2;border-radius:16px;padding:12px 24px;margin-bottom:24px;box-shadow:0 4px 12px #0000004d}.header-content{display:flex;align-items:center;justify-content:space-between;gap:24px}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:12px}.logo svg{flex-shrink:0}.app-header h1{margin:0;font-size:1.25rem;font-weight:600;color:#f8fafc;white-space:nowrap}.header-nav{display:flex;align-items:center;gap:8px}.nav-link{color:#cbd5e1;text-decoration:none;padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .2s}.nav-link:hover{background:#94a3b81a;color:#f8fafc}.nav-link.active{background:#3b82f633;color:#60a5fa}.header-right{display:flex;align-items:center;gap:12px}.icon-button{background:transparent;border:none;color:#cbd5e1;padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-button:hover{background:#94a3b81a;color:#f8fafc}.user-menu{position:relative}.user-button{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#f8fafc;padding:6px 12px;border-radius:999px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;font-size:.9rem}.user-button:hover{background:#94a3b833;border-color:#94a3b84d}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff}.user-name{font-weight:500}.app-main{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:24px;align-items:start}.app-main--split{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.editor-column{display:flex;flex-direction:column;gap:24px}.preview-column{position:sticky;top:24px}.preview-panel{background:#0f172af2;border-radius:18px;padding:16px;box-shadow:0 18px 32px #0f172a66;display:flex;flex-direction:column;gap:12px;min-height:340px}.preview-panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.preview-panel__meta{display:flex;align-items:center;gap:12px}.preview-badge{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;letter-spacing:.02em;padding:6px 14px;border-radius:999px;color:#0f172a}.preview-badge--initial{background:linear-gradient(135deg,#38bdf8,#0ea5e9)}.preview-badge--op_edit{background:linear-gradient(135deg,#cbd5f5,#94a3b8)}.preview-badge--confirm{background:linear-gradient(135deg,#4ade80,#22c55e)}.preview-status{font-size:.8rem;color:#e2e8f0;font-weight:600}.preview-angles{font-size:.85rem;font-weight:700;color:#f8fafc;letter-spacing:.03em}.preview-canvas{border-radius:16px;overflow:hidden;border:1px solid rgba(226,232,240,.2)}.preview-helper{color:#e2e8f0d9;font-size:.8rem;line-height:1.5}.preview-mode-indicator{font-size:.9rem;font-weight:700;color:#f8fafc;padding:8px 16px;background:#3b82f633;border-radius:999px;border:1px solid rgba(59,130,246,.3)}.preview-camera-angle{font-size:.85rem;font-weight:700;color:#f8fafc;letter-spacing:.03em}.preview-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.preview-playback{display:flex;align-items:center;gap:12px}.preview-playback__status{font-size:.8rem;color:#475569}.card{background:#fffffff2;border-radius:16px;padding:20px;box-shadow:0 18px 32px #0f172a33;border:2px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}.card h2{margin:0 0 16px;font-size:1.2rem;color:#0f172a}.card--active{border-color:#1d4ed8;box-shadow:0 0 0 3px #3b82f640,0 24px 44px #2563eb47}.card--active h2{color:#1d4ed8}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header h2{margin:0}.card-body{display:flex;flex-direction:column;gap:16px}.three-preview{width:100%;height:300px;border-radius:14px;overflow:hidden;border:none;background:#0f172a}.selected-coord{font-weight:600;color:#1e293b}.preset-list{display:flex;flex-direction:column;gap:12px}.preset-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:#e2e8f099}.preset-option input[type=radio]{width:16px;height:16px}.preset-label{font-weight:600;color:#1e293b}.cubie-detail{display:flex;flex-direction:column;gap:12px;padding:12px 0}.cubie-detail h3{margin:0;font-size:1rem;color:#0f172a}.cubie-detail--empty{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;padding:24px;background:#3b82f61a;border:2px dashed rgba(59,130,246,.3);border-radius:12px;color:#1e40af}.empty-state-prompt{font-size:.9rem;font-weight:600;color:#1e3a8a}.empty-state-icon{font-size:2rem;animation:pointRight 1.5s ease-in-out infinite}@keyframes pointRight{0%,to{transform:translate(0)}50%{transform:translate(10px)}}.empty-state-content{flex-basis:100%;text-align:center}.empty-state-content h3{margin:0 0 4px;font-size:1rem;color:#1e3a8a}.empty-state-content p{margin:0;font-size:.85rem;color:#1e40af;line-height:1.4}.form-group{display:flex;flex-direction:column;gap:6px}.form-group-inline{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.form-row{display:flex;gap:16px;align-items:flex-end}.form-row .form-group{flex:1;min-width:0}.highlight-actions{display:flex;justify-content:flex-end;margin:8px 0}.chip--readonly{padding-right:12px}.mode-tabs--sub{display:flex;gap:8px;margin:0 0 8px}.arrow-form,.arrow-panel{display:flex;flex-direction:column;gap:16px}.arrow-selection{display:flex;align-items:center;justify-content:space-between;gap:12px}.arrow-actions{display:flex;gap:8px}label{font-size:.85rem;font-weight:600;color:#475569}input,select,textarea{border-radius:10px;border:1px solid #cbd5f5;padding:8px 12px;font-size:.95rem;background:#fff;color:#0f172a}textarea.json-preview{width:100%;min-height:220px;resize:vertical;font-family:Fira Code,Source Code Pro,monospace;font-size:.85rem;background:#0f172a;color:#f8fafc}.helper-text{font-size:.8rem;color:#64748b;margin:0}.grid-colors{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.grid-colors__item{display:flex;flex-direction:column;gap:6px}.grid-colors__item--disabled{opacity:.4}.palette-select{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;border:1px solid rgba(148,163,184,.4);background:#ffffffeb}.palette-select select{flex:1;border:none;background:transparent;padding:0;font-size:.95rem;font-weight:600;color:#0f172a}.palette-select select:focus{outline:none}.palette-select--disabled{opacity:.65}.palette-select .color-chip{display:inline-block}.override-form{border:1px solid rgba(148,163,184,.3);border-radius:12px;padding:12px;background:#f1f5f980}.override-list{display:flex;flex-direction:column;gap:10px}.override-list__header{display:flex;justify-content:space-between;align-items:center}.override-entry{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:#e2e8f099}.color-chip{display:inline-block;width:18px;height:18px;border-radius:50%;border:1px solid rgba(15,23,42,.25)}.btn{border:none;border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.btn.primary{background:linear-gradient(135deg,#2563eb,#60a5fa);color:#fff;box-shadow:0 10px 24px #2563eb4d}.btn.secondary{background:linear-gradient(135deg,#0ea5e9,#14b8a6);color:#fff;box-shadow:0 10px 24px #0ea5e940}.btn.ghost{background:#94a3b833;color:#0f172a}.btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.btn:not(:disabled):hover{transform:translateY(-1px)}.mode-tabs{display:inline-flex;background:#e2e8f099;border-radius:999px;padding:4px;gap:4px}.mode-tab{border:none;background:transparent;padding:8px 16px;border-radius:999px;cursor:pointer;font-weight:600;color:#475569}.mode-tab.active{background:#2563eb;color:#fff;box-shadow:0 10px 24px #2563eb40}.fieldset-reset{border:none;padding:0;margin:0;min-width:0}.camera-controls{display:flex;flex-direction:column;align-items:stretch;gap:16px;padding:12px 16px;border-radius:14px;background:#0f172a14}.camera-axis{display:flex;flex-direction:column;gap:8px;flex:1 1 220px}.camera-axis__header{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:#475569}.camera-axis input[type=range]{width:100%}.camera-axis input[type=number]{width:80px;border-radius:8px;border:1px solid rgba(148,163,184,.6);padding:6px 10px;font-size:.85rem}.camera-controls__row{display:flex;gap:16px;flex-wrap:wrap}.camera-controls__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.camera-form{display:flex;flex-direction:column;gap:16px}.camera-controls__preview{font-size:.8rem;font-weight:600;color:#475569}.highlight-targets{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;background:#60a5fa40;color:#1d4ed8;font-size:.8rem}.operation-actions{display:flex;gap:12px}.queue-list{display:flex;flex-direction:column;gap:12px}.queue-item{display:flex;align-items:stretch;gap:12px;border-radius:12px;padding:12px;background:#f1f5f9cc;border:1px solid rgba(148,163,184,.3)}.drag-handle{border:none;background:transparent;cursor:grab;font-size:1.2rem;color:#475569}.queue-item__content{flex:1;display:flex;flex-direction:column;gap:4px}.queue-item__actions{display:flex;gap:8px;align-items:center}.playback{gap:12px}.playback-actions{display:flex;gap:12px}.playback-message{padding:10px 12px;border-radius:10px;background:#4ade802e;color:#0f172a;font-size:.85rem}.app-footer{margin-top:32px;text-align:center;color:#ffffffb3;font-size:.75rem}@media (max-width: 1100px){.app-main{grid-template-columns:1fr}.column--secondary{min-width:auto}}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172acc;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog-content{background:#fff;padding:24px;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;display:flex;flex-direction:column;gap:16px}.dialog-header{display:flex;justify-content:space-between;align-items:center}.dialog-header h2{margin:0;font-size:1.25rem}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#94a3b8}.dialog-body{display:flex;flex-direction:column;gap:20px}.dialog-actions{gap:12px;margin-top:8px}.preview-note{font-size:.75rem;color:#fff;margin:8px 0 0;text-align:right}.tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#000000e6;color:#fff;padding:8px 12px;border-radius:6px;font-size:.75rem;white-space:nowrap;z-index:100;margin-bottom:8px;pointer-events:none;box-shadow:0 4px 6px #0000001a}.tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:rgba(0,0,0,.9) transparent transparent transparent}.timeline-area{margin-top:24px;margin-bottom:24px}.timeline-card{background:#0f172af2;border-radius:16px;padding:16px;box-shadow:0 4px 12px #0000004d;border:2px solid transparent;transition:all .2s}.timeline-card--active{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;color:#f8fafc}.timeline-header h2{margin:0;font-size:1.1rem}.timeline-actions{display:flex;align-items:center;gap:12px}.timeline-count{font-size:.85rem;color:#94a3b8}.timeline-body{position:relative;min-height:160px}.timeline-new-tooltip{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);background:#3b82f6e6;color:#f8fafc;padding:8px 16px;border-radius:8px;font-size:.85rem;white-space:nowrap;pointer-events:none;box-shadow:0 4px 12px #0003}.timeline-new-tooltip:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid rgba(59,130,246,.9)}.timeline-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.9rem;border:2px dashed #334155;border-radius:8px}.timeline-track{display:flex;gap:8px;overflow-x:auto;padding:16px 8px 50px;min-height:80px;scrollbar-width:thin;scrollbar-color:#475569 #1e293b}.timeline-track::-webkit-scrollbar{height:8px}.timeline-track::-webkit-scrollbar-track{background:#1e293b;border-radius:4px}.timeline-track::-webkit-scrollbar-thumb{background-color:#475569;border-radius:4px}.timeline-item{flex:0 0 120px;background:#fef3c7;border-radius:4px;padding:24px 8px 8px;display:flex;flex-direction:column;gap:4px;cursor:pointer;position:relative;border:none;box-shadow:2px 3px 8px #00000026,0 1px 3px #0000001a;transition:all .2s ease;-webkit-user-select:none;user-select:none}.timeline-item:not(.timeline-item--editing):hover{transform:scale(1.02);box-shadow:3px 5px 12px #00000040,0 2px 6px #00000026;z-index:5}.timeline-item--editing{box-shadow:4px 6px 16px #00000059;transform:translateY(-6px) scale(1.12);z-index:15}.timeline-item__content{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;color:#000}.timeline-item__handle{position:absolute;top:4px;left:6px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:grab;color:#dc2626;font-size:18px;z-index:10;background:radial-gradient(circle at 50% 40%,#ef4444,#dc2626);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 4px #0000004d,inset 0 1px 2px #ffffff4d}.timeline-item__handle:active{cursor:grabbing;transform:rotate(-45deg) scale(1.1)}.timeline-item__handle:before{content:"";position:absolute;width:6px;height:6px;background:#fff6;border-radius:50%;top:3px;left:3px}.timeline-item__content{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.timeline-item__icon-wrapper{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin-bottom:4px;background:transparent}.timeline-item__icon{width:100%;height:100%;object-fit:contain;background:transparent}.timeline-item__type-text{font-size:1rem;font-weight:600;color:#000}.timeline-item__type{font-size:.9rem;color:#000;margin-bottom:2px;display:none}.timeline-item__detail{font-size:.95rem;color:#000;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.timeline-item__delete{position:absolute;top:2px;right:2px;background:transparent;border:none;color:#64748b;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;font-size:14px;opacity:0;transition:all .2s}.timeline-item:hover .timeline-item__delete{opacity:1}.timeline-item__delete:hover{background:#ef444433;color:#ef4444}.timeline-item--rotation{background:#fff;border-top:none}.timeline-item--highlight{background:#d1fae5;border-top:none}.timeline-item--arrow_add,.timeline-item--arrow_remove{background:#fef08a;border-top:none}.timeline-item--wait{background:#fbcfe8;border-top:none}.timeline-item--camera_move{background:#e9d5ff;border-top:none}.timeline-item--initial{background:#fff;border-top:none}.timeline-item--initial .timeline-item__content{display:flex;align-items:center;justify-content:center;height:100%;margin-top:0}.timeline-item--initial .timeline-item__detail{font-size:1rem;font-weight:600}.timeline-item--new{border:2px dashed rgba(148,163,184,.4);background:#1e293b4d}.timeline-item--new:hover{background:#1e293b80;border-color:#94a3b899}.timeline-item--new .timeline-item__detail{font-size:1.5rem;color:#94a3b8;font-weight:300}.timeline-item--new .timeline-item__content{margin-top:8px}.pricing-container{width:100%;max-width:1000px;margin:0 auto;text-align:center}.pricing-container h2{font-size:2rem;margin-bottom:40px;color:#f8fafc}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;align-items:stretch}.pricing-card{background:#1e293bcc;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:32px 24px;display:flex;flex-direction:column;gap:24px;color:#f8fafc;transition:transform .2s}.pricing-card:hover{transform:translateY(-4px)}.pricing-card.featured{background:linear-gradient(145deg,#1e293be6,#0f172af2);border:1px solid rgba(59,130,246,.5);box-shadow:0 20px 40px #0003;position:relative}.pricing-card.annual{border-color:#f59e0b}.discount-badge{position:absolute;top:-12px;right:24px;background:#f59e0b;color:#0f172a;font-weight:800;font-size:.9rem;padding:4px 12px;border-radius:999px;box-shadow:0 4px 12px #f59e0b66;transform:rotate(3deg)}.pricing-card h3{margin:0;font-size:1.5rem;color:#e2e8f0}.pricing-card .price{font-size:2.5rem;font-weight:700;margin:0;color:#f8fafc}.pricing-card .price span{font-size:1rem;font-weight:400;color:#94a3b8}.pricing-card .price-note{margin:-16px 0 0;font-size:.9rem;color:#4ade80;font-weight:600}.pricing-card ul{list-style:none;padding:0;margin:0;text-align:left;display:flex;flex-direction:column;gap:12px;flex:1}.pricing-card ul li{display:flex;align-items:center;gap:8px;color:#cbd5e1}.pricing-card ul li:before{content:"✓";color:#3b82f6;font-weight:700}.pricing-card button{width:100%;padding:12px;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s}.pricing-card .btn-secondary{background:#94a3b81a;color:#94a3b8}.pricing-card .btn-primary{background:#3b82f6;color:#fff}.pricing-card .btn-primary:hover{background:#2563eb}.auth-status{display:flex;align-items:center;gap:12px}.user-email{color:#cbd5e1;font-size:.9rem}.btn-sm{padding:6px 12px;font-size:.85rem}
