.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-5);font-size:var(--text-sm);font-weight:var(--fw-semibold);line-height:var(--leading-tight);border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled,.btn.btn-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary-500);color:var(--color-white);border-color:var(--color-primary-500)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-700);border-color:var(--color-primary-700)}.btn-secondary{background-color:var(--color-secondary-500);color:var(--color-white);border-color:var(--color-secondary-500)}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-600);border-color:var(--color-secondary-600)}.btn-secondary:active:not(:disabled){background-color:var(--color-secondary-700);border-color:var(--color-secondary-700)}.btn-ghost{background-color:transparent;color:var(--color-gray-700);border-color:var(--color-border)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);border-color:var(--color-gray-300);color:var(--color-gray-900)}.btn-ghost:active:not(:disabled){background-color:var(--color-gray-200)}.btn-danger{background-color:var(--color-error-500);color:var(--color-white);border-color:var(--color-error-500)}.btn-danger:hover:not(:disabled){background-color:var(--color-error-600);border-color:var(--color-error-600)}.btn-danger:active:not(:disabled){background-color:var(--color-error-700);border-color:var(--color-error-700)}.btn-sm{padding:var(--space-1-5) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-icon{padding:var(--space-2);gap:0}.btn-icon.btn-sm{padding:var(--space-1-5)}.btn-icon.btn-lg{padding:var(--space-3)}.btn .spinner{width:16px;height:16px;border-width:2px;border-color:currentColor;border-top-color:transparent}.input,.textarea,.select{display:block;width:100%;padding:var(--space-2-5) var(--space-3);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.input::placeholder,.textarea::placeholder{color:var(--color-text-muted)}.input:hover:not(:disabled),.textarea:hover:not(:disabled),.select:hover:not(:disabled){border-color:var(--color-gray-300)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary-400);box-shadow:0 0 0 3px var(--color-focus-ring)}.input:disabled,.textarea:disabled,.select:disabled{background-color:var(--color-gray-100);color:var(--color-text-muted);cursor:not-allowed}.input-error,.input.error,.textarea.error,.select.error{border-color:var(--color-error-500)}.input-error:focus,.input.error:focus,.textarea.error:focus,.select.error:focus{box-shadow:0 0 0 3px #ef44444d}.input-error-message{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-error-600)}.label{display:block;margin-bottom:var(--space-1-5);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-gray-700)}.label-required:after{content:" *";color:var(--color-error-500)}.form-group{margin-bottom:var(--space-4)}.form-hint{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-text-secondary)}.textarea{min-height:80px;resize:vertical}.select{padding-right:var(--space-10);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:16px}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}.card-interactive:active{box-shadow:var(--shadow-sm)}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.card-header h3,.card-header h4{margin:0}.card-body{padding:var(--space-5)}.card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);background-color:var(--color-gray-50)}.card-image{width:100%;aspect-ratio:16 / 10;object-fit:cover}.card-selected{border-color:var(--color-primary-400);box-shadow:0 0 0 2px var(--color-primary-200)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#1c191780;display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal);animation:fadeIn .2s ease forwards}.modal-content{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;animation:scaleIn .2s ease forwards;overflow:hidden}.modal-content.modal-sm{max-width:380px}.modal-content.modal-lg{max-width:720px}.modal-content.modal-xl{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-header h2,.modal-header h3{margin:0;font-size:var(--text-lg)}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-secondary);background:none;border:none;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-text)}.modal-body{padding:var(--space-5);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);background-color:var(--color-gray-50);flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-0-5) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--fw-medium);line-height:var(--leading-normal);border-radius:var(--radius-full);white-space:nowrap;background-color:var(--color-gray-100);color:var(--color-gray-700)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-secondary{background-color:var(--color-secondary-100);color:var(--color-secondary-700)}.badge-accent{background-color:var(--color-accent-100);color:var(--color-accent-700)}.badge-success{background-color:var(--color-success-100);color:var(--color-success-700)}.badge-warning{background-color:var(--color-warning-100);color:var(--color-warning-700)}.badge-error{background-color:var(--color-error-100);color:var(--color-error-700)}.badge-dot{width:6px;height:6px;border-radius:var(--radius-full);background-color:currentColor}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:400px;width:100%;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideInRight .3s ease forwards;pointer-events:auto}.toast-icon{flex-shrink:0;width:20px;height:20px;margin-top:var(--space-0-5)}.toast-body{flex:1;min-width:0}.toast-title{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text)}.toast-message{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-0-5)}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;background:none;border:none;transition:color var(--transition-fast),background-color var(--transition-fast)}.toast-close:hover{background-color:var(--color-gray-100);color:var(--color-text-secondary)}.toast-success{border-left:4px solid var(--color-success-500)}.toast-success .toast-icon{color:var(--color-success-500)}.toast-error{border-left:4px solid var(--color-error-500)}.toast-error .toast-icon{color:var(--color-error-500)}.toast-warning{border-left:4px solid var(--color-warning-500)}.toast-warning .toast-icon{color:var(--color-warning-500)}.toast-info{border-left:4px solid var(--color-primary-500)}.toast-info .toast-icon{color:var(--color-primary-500)}.toast-exit{animation:slideOutRight .2s ease forwards}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:calc(100% + var(--space-1));left:0;z-index:var(--z-dropdown);min-width:180px;padding:var(--space-1);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:scaleIn .15s ease forwards;transform-origin:top left}.dropdown-menu-right{left:auto;right:0;transform-origin:top right}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background-color var(--transition-fast),color var(--transition-fast)}.dropdown-item:hover{background-color:var(--color-gray-100)}.dropdown-item:active{background-color:var(--color-gray-200)}.dropdown-item-icon{flex-shrink:0;width:16px;height:16px;color:var(--color-text-secondary)}.dropdown-item-danger{color:var(--color-error-600)}.dropdown-item-danger:hover{background-color:var(--color-error-50)}.dropdown-divider{height:1px;margin:var(--space-1) 0;background-color:var(--color-border)}.dropdown-label{padding:var(--space-2) var(--space-3) var(--space-1);font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.tabs{display:flex;align-items:center;gap:var(--space-1);border-bottom:1px solid var(--color-border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;margin-bottom:-1px;transition:color var(--transition-fast),border-color var(--transition-fast)}.tab:hover{color:var(--color-text)}.tab-active,.tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-500);font-weight:var(--fw-semibold)}.tab:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:-2px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1-5);font-size:var(--text-xs);font-weight:var(--fw-medium);background-color:var(--color-gray-100);color:var(--color-text-secondary);border-radius:var(--radius-full)}.tab-active .tab-count,.tab.active .tab-count{background-color:var(--color-primary-100);color:var(--color-primary-700)}.tab-panels{padding-top:var(--space-4)}.tab-panel{display:none;animation:fadeIn .2s ease}.tab-panel.active,.tab-panel-active{display:block}.tooltip{position:relative;display:inline-block}.tooltip-content{position:absolute;bottom:calc(100% + var(--space-2));left:50%;transform:translate(-50%);padding:var(--space-1-5) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--fw-medium);color:var(--color-white);background-color:var(--color-gray-800);border-radius:var(--radius-md);white-space:nowrap;pointer-events:none;z-index:var(--z-tooltip);opacity:0;transition:opacity var(--transition-fast)}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--color-gray-800)}.tooltip:hover .tooltip-content,.tooltip:focus-within .tooltip-content{opacity:1}.tooltip-top .tooltip-content{bottom:calc(100% + var(--space-2));top:auto}.tooltip-bottom .tooltip-content{top:calc(100% + var(--space-2));bottom:auto}.tooltip-bottom .tooltip-content:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--color-gray-800)}.avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-primary-100);color:var(--color-primary-700);font-size:var(--text-sm);font-weight:var(--fw-semibold);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:28px;height:28px;font-size:var(--text-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.avatar-xl{width:72px;height:72px;font-size:var(--text-xl)}.avatar-group{display:flex;align-items:center}.avatar-group .avatar{border:2px solid var(--color-white);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:16px;border-radius:var(--radius-sm)}.skeleton-text+.skeleton-text{margin-top:var(--space-2)}.skeleton-heading{height:24px;width:60%;border-radius:var(--radius-sm)}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-image{width:100%;aspect-ratio:16 / 10;border-radius:var(--radius-md)}.skeleton-card{height:200px;border-radius:var(--radius-lg)}.skeleton-btn{height:38px;width:100px;border-radius:var(--radius-md)}.progress{width:100%;height:8px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background-color:var(--color-primary-500);border-radius:var(--radius-full);transition:width var(--transition-normal);min-width:0}.progress-bar-animated{background-image:linear-gradient(45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%,transparent);background-size:16px 16px;animation:progressStripe .6s linear infinite}@keyframes progressStripe{0%{background-position:16px 0}to{background-position:0 0}}.progress-sm{height:4px}.progress-lg{height:12px}.progress-labeled{display:flex;align-items:center;gap:var(--space-3)}.progress-labeled .progress{flex:1}.progress-label{font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);white-space:nowrap}.progress-success .progress-bar{background-color:var(--color-success-500)}.progress-warning .progress-bar{background-color:var(--color-warning-500)}.progress-error .progress-bar{background-color:var(--color-error-500)}.progress-accent .progress-bar{background-color:var(--color-accent-500)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-gray-700);background-color:var(--color-gray-100);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.tag:hover{background-color:var(--color-gray-200);border-color:var(--color-gray-300)}.tag-selected,.tag.active{background-color:var(--color-primary-100);border-color:var(--color-primary-300);color:var(--color-primary-700)}.tag-selected:hover,.tag.active:hover{background-color:var(--color-primary-200);border-color:var(--color-primary-400)}.tag:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.tag-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:var(--radius-full);background:none;border:none;color:inherit;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}.tag-remove:hover{opacity:1}.tag-group{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag-primary{background-color:var(--color-primary-50);border-color:var(--color-primary-200);color:var(--color-primary-700)}.tag-secondary{background-color:var(--color-secondary-50);border-color:var(--color-secondary-200);color:var(--color-secondary-700)}.tag-accent{background-color:var(--color-accent-50);border-color:var(--color-accent-200);color:var(--color-accent-700)}.file-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8) var(--space-6);border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);background-color:var(--color-gray-50);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.file-upload:hover{border-color:var(--color-primary-300);background-color:var(--color-primary-50)}.file-upload-active,.file-upload.dragover{border-color:var(--color-primary-400);background-color:var(--color-primary-50);border-style:solid}.file-upload-icon{width:48px;height:48px;color:var(--color-text-muted);transition:color var(--transition-fast)}.file-upload:hover .file-upload-icon{color:var(--color-primary-400)}.file-upload-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.file-upload-text strong{color:var(--color-primary-600);font-weight:var(--fw-semibold)}.file-upload-hint{font-size:var(--text-xs);color:var(--color-text-muted)}.file-upload-input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.file-upload:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}.file-preview{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--color-gray-50);border:1px solid var(--color-border);border-radius:var(--radius-md)}.file-preview-icon{flex-shrink:0;width:32px;height:32px;color:var(--color-primary-500)}.file-preview-info{flex:1;min-width:0}.file-preview-name{font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{font-size:var(--text-xs);color:var(--color-text-muted)}.file-preview-remove{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);color:var(--color-text-muted);background:none;border:none;cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.file-preview-remove:hover{background-color:var(--color-error-50);color:var(--color-error-500)}.toggle{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-input{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:relative;width:44px;height:24px;background-color:var(--color-gray-300);border-radius:var(--radius-full);transition:background-color var(--transition-fast);flex-shrink:0}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:var(--color-white);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.toggle-input:checked+.toggle-track{background-color:var(--color-primary-500)}.toggle-input:checked+.toggle-track .toggle-thumb{transform:translate(20px)}.toggle-input:focus-visible+.toggle-track{outline:2px solid var(--color-focus-ring);outline-offset:2px}.toggle-input:disabled+.toggle-track{opacity:.5;cursor:not-allowed}.toggle-label{font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text)}.toggle-sm .toggle-track{width:36px;height:20px}.toggle-sm .toggle-thumb{width:16px;height:16px}.toggle-sm .toggle-input:checked+.toggle-track .toggle-thumb{transform:translate(16px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{width:64px;height:64px;color:var(--color-text-muted);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--color-text-secondary);max-width:360px;margin-bottom:var(--space-6)}.divider{display:flex;align-items:center;gap:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm)}.divider:before,.divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);border:1px solid}.alert-icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.alert-info{background-color:var(--color-primary-50);border-color:var(--color-primary-200);color:var(--color-primary-700)}.alert-success{background-color:var(--color-success-50);border-color:var(--color-success-500);color:var(--color-success-700)}.alert-warning{background-color:var(--color-warning-50);border-color:var(--color-warning-500);color:var(--color-warning-700)}.alert-error{background-color:var(--color-error-50);border-color:var(--color-error-500);color:var(--color-error-700)}.app-layout{display:flex;min-height:100vh;background-color:var(--color-bg-subtle)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);display:flex;flex-direction:column;background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:var(--z-sticky);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.sidebar-logo{width:36px;height:36px;flex-shrink:0}.sidebar-title{font-size:var(--text-lg);font-weight:var(--fw-bold);color:var(--color-primary-600);letter-spacing:-.01em}.sidebar-subtitle{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-0-5)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-4)}.sidebar-steps{position:relative;display:flex;flex-direction:column;gap:0}.sidebar-steps:before{content:"";position:absolute;top:20px;left:19px;bottom:20px;width:2px;background-color:var(--color-gray-200);z-index:0}.sidebar-step{position:relative;display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-2);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast);z-index:1;text-decoration:none}.sidebar-step:hover{background-color:var(--color-gray-50)}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--fw-semibold);flex-shrink:0;background-color:var(--color-gray-100);color:var(--color-text-muted);border:2px solid var(--color-gray-200);transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);position:relative;z-index:2}.step-info{flex:1;min-width:0;padding-top:var(--space-0-5)}.step-label{font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);line-height:var(--leading-tight);transition:color var(--transition-fast)}.step-description{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-0-5);line-height:var(--leading-normal)}.step-active,.step-active:hover{background-color:var(--color-primary-50)}.step-active .step-number{background-color:var(--color-primary-500);border-color:var(--color-primary-500);color:var(--color-white)}.step-active .step-label{color:var(--color-primary-700);font-weight:var(--fw-semibold)}.step-completed .step-number{background-color:var(--color-success-500);border-color:var(--color-success-500);color:var(--color-white)}.step-completed .step-label{color:var(--color-text)}.step-completed .step-number:after{content:"";display:block;width:10px;height:6px;border-left:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg) translateY(-1px)}.step-completed .step-number-text{display:none}.step-locked{cursor:not-allowed;opacity:.6}.step-locked:hover{background-color:transparent}.step-locked .step-number{background-color:var(--color-gray-100);border-color:var(--color-gray-200);color:var(--color-text-muted)}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);flex-shrink:0}.sidebar-project{padding:var(--space-3) var(--space-4);margin:var(--space-3) var(--space-4) 0;background-color:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-border)}.sidebar-project-name{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-project-status{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-0-5)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-6) var(--space-8);max-width:calc(100vw - var(--sidebar-width));min-height:100vh}.main-content-full{margin-left:0;max-width:100%}.content-container{max-width:var(--content-max-width);margin:0 auto;width:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.page-header-text{flex:1;min-width:0}.page-title{font-size:var(--text-2xl);font-weight:var(--fw-bold);color:var(--color-text);line-height:var(--leading-tight)}.page-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1);max-width:600px}.page-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.toolbar-group{display:flex;align-items:center;gap:var(--space-1)}.toolbar-separator{width:1px;height:24px;background-color:var(--color-border);margin:0 var(--space-1)}.toolbar-spacer{flex:1}.storyboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}@media(min-width:1200px){.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}.page-preview{display:flex;flex-direction:column;gap:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.page-preview-image{width:100%;aspect-ratio:4 / 3;background-color:var(--color-gray-100);display:flex;align-items:center;justify-content:center;overflow:hidden}.page-preview-image img{width:100%;height:100%;object-fit:cover}.page-preview-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:var(--text-sm)}.page-preview-image-placeholder svg{width:40px;height:40px;opacity:.5}.page-preview-text{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text)}.page-preview-number{font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}@media(min-width:769px){.page-preview-horizontal{flex-direction:row}.page-preview-horizontal .page-preview-image{width:50%;aspect-ratio:auto;min-height:300px}.page-preview-horizontal .page-preview-text{width:50%;display:flex;flex-direction:column;justify-content:center}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.dashboard-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);cursor:pointer}.dashboard-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300);transform:translateY(-2px)}.dashboard-card-cover{width:100%;aspect-ratio:16 / 9;background-color:var(--color-gray-100);overflow:hidden;position:relative}.dashboard-card-cover img{width:100%;height:100%;object-fit:cover}.dashboard-card-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-100) 0%,var(--color-secondary-100) 100%)}.dashboard-card-cover-placeholder svg{width:48px;height:48px;color:var(--color-primary-300)}.dashboard-card-body{padding:var(--space-4)}.dashboard-card-title{font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted)}.dashboard-card-meta-item{display:flex;align-items:center;gap:var(--space-1)}.dashboard-card-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.dashboard-card-new{border:2px dashed var(--color-gray-300);display:flex;align-items:center;justify-content:center;min-height:200px;background-color:transparent;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.dashboard-card-new:hover{border-color:var(--color-primary-300);background-color:var(--color-primary-50);transform:none;box-shadow:none}.dashboard-card-new-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--color-text-muted)}.dashboard-card-new-content svg{width:40px;height:40px}.dashboard-card-new-content span{font-size:var(--text-sm);font-weight:var(--fw-medium)}.dashboard-card-new:hover .dashboard-card-new-content{color:var(--color-primary-500)}.auth-layout{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4);background-color:var(--color-bg-subtle)}.auth-container{width:100%;max-width:420px}.auth-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-logo{width:56px;height:56px;margin:0 auto var(--space-4)}.auth-title{font-size:var(--text-2xl);font-weight:var(--fw-bold);color:var(--color-text);margin-bottom:var(--space-1)}.auth-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-footer a{color:var(--color-primary-600);font-weight:var(--fw-medium)}.auth-footer a:hover{color:var(--color-primary-700);text-decoration:underline}.auth-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-5) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}@media(max-width:1024px){.sidebar{width:240px}.main-content{margin-left:240px;padding:var(--space-5) var(--space-6);max-width:calc(100vw - 240px)}.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}@media(max-width:768px){.app-layout{flex-direction:column}.sidebar{position:relative;width:100%;border-right:none;border-bottom:1px solid var(--color-border);overflow-y:visible}.sidebar-nav{padding:var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch}.sidebar-steps{flex-direction:row;gap:var(--space-1)}.sidebar-steps:before{display:none}.sidebar-step{flex-direction:column;align-items:center;min-width:auto;padding:var(--space-2);text-align:center}.step-description{display:none}.step-label{font-size:var(--text-xs)}.main-content{margin-left:0;padding:var(--space-4);max-width:100%}.page-header{flex-direction:column;gap:var(--space-3)}.page-actions{width:100%}.page-actions .btn{flex:1}.storyboard-grid,.dashboard-grid{grid-template-columns:1fr}.page-preview-horizontal{flex-direction:column}.page-preview-horizontal .page-preview-image,.page-preview-horizontal .page-preview-text{width:100%}.toolbar{flex-wrap:wrap}.auth-card{padding:var(--space-6)}}.sidebar-toggle{display:none;position:fixed;bottom:var(--space-4);right:var(--space-4);z-index:var(--z-overlay);width:48px;height:48px;border-radius:var(--radius-full);background-color:var(--color-primary-500);color:var(--color-white);box-shadow:var(--shadow-lg);align-items:center;justify-content:center;border:none;cursor:pointer}@media(max-width:768px){.sidebar-toggle{display:flex}}.wizard-stage{animation:fadeIn .3s ease forwards}.stage-section{margin-bottom:var(--space-6)}.stage-section-title{font-size:var(--text-lg);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-3)}.stage-section-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);max-width:600px}.capture-stage{max-width:800px}.capture-textarea{width:100%;min-height:280px;padding:var(--space-5);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);resize:vertical;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:var(--font-sans)}.capture-textarea::placeholder{color:var(--color-text-muted);font-style:italic}.capture-textarea:focus{outline:none;border-color:var(--color-primary-400);box-shadow:0 0 0 3px var(--color-focus-ring)}.capture-char-count{display:flex;justify-content:flex-end;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted)}.capture-char-count.near-limit{color:var(--color-warning-600)}.capture-char-count.at-limit{color:var(--color-error-600)}.capture-upload{margin-top:var(--space-4)}.capture-upload .file-upload{min-height:120px;padding:var(--space-6)}.capture-mic-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-muted);background-color:var(--color-gray-100);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:not-allowed;opacity:.6;position:relative}.capture-mic-btn svg{width:18px;height:18px}.capture-mic-btn .coming-soon-badge{position:absolute;top:-8px;right:-8px;padding:var(--space-0-5) var(--space-1-5);font-size:10px;font-weight:var(--fw-semibold);color:var(--color-secondary-700);background-color:var(--color-secondary-100);border-radius:var(--radius-full);line-height:1}.capture-methods{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.capture-method{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);background-color:var(--color-gray-50);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.capture-method:hover{background-color:var(--color-gray-100);border-color:var(--color-gray-300)}.capture-method.active{background-color:var(--color-primary-50);border-color:var(--color-primary-300);color:var(--color-primary-700)}.capture-method svg{width:18px;height:18px}.capture-method.disabled{opacity:.5;cursor:not-allowed}.define-stage{max-width:900px}.character-cards,.place-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.character-card,.place-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.character-card:hover,.place-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}.character-card-header,.place-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.character-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-200) 0%,var(--color-accent-200) 100%);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);flex-shrink:0}.character-name,.place-name{font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.character-role,.place-type{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--fw-medium)}.character-description,.place-description{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin-top:var(--space-2)}.character-traits{display:flex;flex-wrap:wrap;gap:var(--space-1-5);margin-top:var(--space-3)}.character-card-actions,.place-card-actions{display:flex;gap:var(--space-1)}.add-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);min-height:180px;border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);background-color:transparent;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.add-card:hover{border-color:var(--color-primary-300);background-color:var(--color-primary-50);color:var(--color-primary-500)}.add-card svg{width:32px;height:32px}.add-card span{font-size:var(--text-sm);font-weight:var(--fw-medium)}.style-presets{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-3)}.style-preset{position:relative;border:2px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.style-preset:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md)}.style-preset-selected,.style-preset.active{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-200)}.style-preset-image{width:100%;aspect-ratio:4 / 3;background-color:var(--color-gray-100);object-fit:cover}.style-preset-info{padding:var(--space-3)}.style-preset-name{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text)}.style-preset-description{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-0-5)}.style-preset-selected .style-preset-check,.style-preset.active .style-preset-check{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;background-color:var(--color-primary-500);color:var(--color-white);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.style-preset-check{display:none}.storyboard-stage{max-width:1100px}.storyboard-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast),border-color var(--transition-fast);position:relative}.storyboard-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}.storyboard-drag-handle{position:absolute;top:var(--space-2);left:var(--space-2);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-muted);background-color:#ffffffe6;cursor:grab;z-index:2;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast)}.storyboard-card:hover .storyboard-drag-handle{opacity:1}.storyboard-drag-handle:hover{color:var(--color-text-secondary);background-color:var(--color-white);box-shadow:var(--shadow-sm)}.storyboard-drag-handle:active{cursor:grabbing}.storyboard-card.dragging{opacity:.5;border-color:var(--color-primary-300)}.storyboard-card.drag-over{border-color:var(--color-primary-400);box-shadow:0 0 0 2px var(--color-primary-200)}.storyboard-page-number{position:absolute;top:var(--space-2);right:var(--space-2);display:flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:#ffffffe6;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--fw-bold);color:var(--color-text-secondary);z-index:2}.storyboard-image{width:100%;aspect-ratio:4 / 3;background-color:var(--color-gray-100);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.storyboard-image img{width:100%;height:100%;object-fit:cover}.storyboard-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);color:var(--color-text-muted);font-size:var(--text-xs)}.storyboard-image-placeholder svg{width:32px;height:32px;opacity:.4}.storyboard-text{padding:var(--space-3);font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.storyboard-text-empty{color:var(--color-text-muted);font-style:italic}.storyboard-card-actions{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border)}.storyboard-add-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);min-height:250px;border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);background-color:transparent;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.storyboard-add-page:hover{border-color:var(--color-primary-300);background-color:var(--color-primary-50);color:var(--color-primary-500)}.storyboard-add-page svg{width:36px;height:36px}.storyboard-add-page span{font-size:var(--text-sm);font-weight:var(--fw-medium)}.illustrate-stage{max-width:1100px}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.image-gallery-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.image-gallery-item:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md)}.image-gallery-item.selected{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-200)}.image-gallery-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.image-gallery-item-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%);display:flex;align-items:flex-end;padding:var(--space-3);opacity:0;transition:opacity var(--transition-fast)}.image-gallery-item:hover .image-gallery-item-overlay{opacity:1}.image-gallery-item-actions{display:flex;gap:var(--space-2)}.image-gallery-item.selected:after{content:"";position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;background-color:var(--color-primary-500);border-radius:var(--radius-full);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-position:center;background-repeat:no-repeat}.generation-controls{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}.generation-controls-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.generation-controls-title{font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--color-text)}.generation-controls-body{display:flex;flex-direction:column;gap:var(--space-4)}.generation-controls-row{display:flex;align-items:flex-end;gap:var(--space-3)}.generation-controls-row .form-group{flex:1;margin-bottom:0}.generate-btn{min-width:140px}.generate-btn.generating{position:relative}.generate-btn.generating .spinner{border-color:#ffffff4d;border-top-color:var(--color-white)}.variant-picker{display:flex;gap:var(--space-3);padding:var(--space-3);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.variant-option{flex:1;border-radius:var(--radius-md);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.variant-option:hover{border-color:var(--color-gray-300)}.variant-option.selected{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-200)}.variant-option img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.variant-option-label{padding:var(--space-1-5);font-size:var(--text-xs);font-weight:var(--fw-medium);text-align:center;color:var(--color-text-secondary)}.variant-option.selected .variant-option-label{color:var(--color-primary-600);font-weight:var(--fw-semibold)}.image-generating{aspect-ratio:1;background-color:var(--color-gray-100);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);border:1px solid var(--color-border)}.image-generating .spinner{width:32px;height:32px;border-width:3px}.image-generating-text{font-size:var(--text-sm);color:var(--color-text-muted)}.illustrate-stage__ref-pages{margin-top:var(--space-3)}.illustrate-stage__ref-pages h5{font-size:var(--text-sm);font-weight:var(--fw-semibold);margin-bottom:var(--space-1)}.illustrate-stage__ref-pages-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-2)}.illustrate-stage__ref-pages-empty{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.illustrate-stage__ref-pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2)}.illustrate-stage__ref-page-thumb{position:relative;display:flex;flex-direction:column;align-items:stretch;padding:0;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font:inherit}.illustrate-stage__ref-page-thumb:hover:not(:disabled){border-color:var(--color-primary-300, var(--color-gray-300))}.illustrate-stage__ref-page-thumb--selected{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-200)}.illustrate-stage__ref-page-thumb--disabled{opacity:.45;cursor:not-allowed}.illustrate-stage__ref-page-thumb-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.illustrate-stage__ref-page-thumb-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-weight:var(--fw-semibold);font-size:var(--text-lg);color:var(--color-text-muted);background:var(--color-gray-100)}.illustrate-stage__ref-page-thumb-label{padding:var(--space-1);font-size:var(--text-xs);text-align:center;color:var(--color-text-secondary);background:var(--color-gray-50)}.illustrate-stage__ref-page-thumb-check{position:absolute;top:var(--space-1);right:var(--space-1);width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-500);color:#fff;border-radius:var(--radius-full);font-size:11px;font-weight:var(--fw-bold)}.polish-stage{max-width:1000px}.polish-page{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-5)}.polish-page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background-color:var(--color-gray-50)}.polish-page-label{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text-secondary)}.polish-page-actions{display:flex;gap:var(--space-2)}.polish-page-content{display:flex;gap:0;min-height:320px}.polish-page-image{width:50%;background-color:var(--color-gray-100);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.polish-page-image img{width:100%;height:100%;object-fit:cover}.polish-page-image-actions{position:absolute;bottom:var(--space-3);right:var(--space-3);display:flex;gap:var(--space-2);opacity:0;transition:opacity var(--transition-fast)}.polish-page:hover .polish-page-image-actions{opacity:1}.polish-page-text{width:50%;padding:var(--space-5);display:flex;flex-direction:column}.polish-page-text textarea{flex:1;width:100%;border:none;resize:none;font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text);padding:0;font-family:var(--font-sans)}.polish-page-text textarea:focus{outline:none}.polish-page-text textarea::placeholder{color:var(--color-text-muted)}@media(max-width:768px){.polish-page-content{flex-direction:column}.polish-page-image,.polish-page-text{width:100%}.polish-page-image{aspect-ratio:4 / 3}}.polish-navigation{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4) 0}.polish-page-indicator{font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary)}.export-stage{max-width:900px}.export-formats{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.export-format-card{background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;text-align:center;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.export-format-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md)}.export-format-card.selected{border-color:var(--color-primary-500);background-color:var(--color-primary-50);box-shadow:0 0 0 2px var(--color-primary-200)}.export-format-icon{width:48px;height:48px;margin:0 auto var(--space-3);color:var(--color-text-muted);transition:color var(--transition-fast)}.export-format-card.selected .export-format-icon{color:var(--color-primary-500)}.export-format-name{font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.export-format-description{font-size:var(--text-sm);color:var(--color-text-secondary)}.pdf-preview{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-5)}.pdf-preview-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background-color:var(--color-gray-50)}.pdf-preview-title{font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text-secondary)}.pdf-preview-body{padding:var(--space-6);background-color:var(--color-gray-100);display:flex;align-items:center;justify-content:center;min-height:400px}.pdf-preview-page{background-color:var(--color-white);box-shadow:var(--shadow-lg);border-radius:var(--radius-sm);width:100%;max-width:500px;aspect-ratio:8.5 / 11;padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4)}.export-download{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center}.export-download-icon{width:56px;height:56px;margin:0 auto var(--space-3);color:var(--color-accent-500)}.export-download-title{font-size:var(--text-lg);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.export-download-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-5)}.export-download-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.export-progress{margin-top:var(--space-4)}.export-progress-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.ai-suggestion{background-color:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-lg);padding:var(--space-4);animation:slideInUp .3s ease forwards}.ai-suggestion__badge{display:inline-flex;align-items:center;padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-weight:var(--fw-semibold);line-height:1;color:var(--color-white);background-color:var(--color-primary-500);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.ai-suggestion-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.ai-suggestion-icon{width:20px;height:20px;color:var(--color-primary-500);flex-shrink:0}.ai-suggestion-label{font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--color-primary-600);text-transform:uppercase;letter-spacing:.05em}.ai-suggestion-content{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.ai-suggestion-actions{display:flex;gap:var(--space-2)}.ai-suggestion-accept{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-white);background-color:var(--color-success-500);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.ai-suggestion-accept:hover{background-color:var(--color-success-600)}.ai-suggestion-edit{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-primary-700);background-color:var(--color-primary-100);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.ai-suggestion-edit:hover{background-color:var(--color-primary-200)}.ai-suggestion-reject{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.ai-suggestion-reject:hover{background-color:var(--color-gray-100);color:var(--color-text)}.ai-suggestions-list{display:flex;flex-direction:column;gap:var(--space-3)}.prompt-editor{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.prompt-editor-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary);background:none;border:none;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.prompt-editor-toggle:hover{background-color:var(--color-gray-50);color:var(--color-text)}.prompt-editor-toggle-icon{width:16px;height:16px;transition:transform var(--transition-fast)}.prompt-editor.expanded .prompt-editor-toggle-icon{transform:rotate(180deg)}.prompt-editor-body{display:none;padding:0 var(--space-4) var(--space-4)}.prompt-editor.expanded .prompt-editor-body{display:block;animation:slideInDown .2s ease}.prompt-editor-textarea{width:100%;min-height:120px;padding:var(--space-3);font-size:var(--text-sm);font-family:var(--font-mono);line-height:var(--leading-relaxed);color:var(--color-text);background-color:var(--color-gray-50);border:1px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.prompt-editor-textarea:focus{outline:none;border-color:var(--color-primary-400);box-shadow:0 0 0 3px var(--color-focus-ring)}.prompt-editor-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-2)}.prompt-editor-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-3)}.prompt-tokens{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-2)}.prompt-token{display:inline-flex;align-items:center;padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-primary-600);background-color:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.prompt-token:hover{background-color:var(--color-primary-100)}.wizard-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) 0;margin-top:var(--space-8);border-top:1px solid var(--color-border)}.wizard-footer-left,.wizard-footer-right{display:flex;align-items:center;gap:var(--space-3)}.stage-enter{animation:slideInRight .3s ease forwards}.stage-exit{animation:slideOutLeft .3s ease forwards}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}@media(max-width:768px){.capture-stage,.define-stage,.storyboard-stage,.illustrate-stage,.polish-stage,.export-stage{max-width:100%}.character-cards,.place-cards{grid-template-columns:1fr}.style-presets,.image-gallery{grid-template-columns:repeat(2,1fr)}.variant-picker{flex-wrap:wrap}.variant-option{flex:0 0 calc(50% - var(--space-1-5))}.export-formats{grid-template-columns:1fr}.generation-controls-row{flex-direction:column;align-items:stretch}.ai-suggestion-actions{flex-wrap:wrap}.wizard-footer{flex-direction:column;gap:var(--space-3)}.wizard-footer-left,.wizard-footer-right{width:100%;justify-content:center}.capture-methods{flex-wrap:wrap}.capture-method{flex:1;justify-content:center}}:root{--font-display: "Baloo 2", "Trebuchet MS", "Comic Sans MS", cursive;--font-body: "Nunito", "Trebuchet MS", sans-serif;--font-accent: "Fredoka", "Trebuchet MS", sans-serif;--play-bg: #fffaf2;--play-ink: #2f2451;--play-subtle: #766b95;--play-card: #ffffff;--play-line: #e4dcf4;--play-sky: #8ecbff;--play-peach: #ffc68a;--play-pink: #ffa5c9;--play-mint: #a9f2d4;--play-grape: #8358ff;--play-grape-dark: #5e36cc;--play-glow: 0 18px 45px rgba(95, 72, 170, .22)}body{font-family:var(--font-body);color:var(--play-ink);background:radial-gradient(circle at 12% 12%,rgba(255,198,138,.3),transparent 40%),radial-gradient(circle at 88% 16%,rgba(169,242,212,.35),transparent 35%),radial-gradient(circle at 50% 100%,rgba(142,203,255,.35),transparent 36%),var(--play-bg)}h1,h2,h3,h4{font-family:var(--font-display);color:var(--play-ink)}.project-page__loading,.project-page__error{min-height:100vh;display:grid;place-items:center;text-align:center;padding:2rem}.project-page__error h2{margin-bottom:.6rem}.card{background:var(--play-card);border:2px solid var(--play-line);border-radius:24px;box-shadow:var(--play-glow)}.card--interactive{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.card--interactive:hover{transform:translateY(-4px) rotate(-.3deg);box-shadow:0 25px 40px #49338a40;border-color:#c9bae9}.card--selected{border-color:var(--play-grape);box-shadow:0 0 0 4px #8358ff33,var(--play-glow)}.card--pad-none{padding:0}.card--pad-sm{padding:.75rem}.card--pad-md{padding:1rem}.card--pad-lg{padding:1.25rem}.btn{border-radius:999px;font-family:var(--font-accent);font-weight:600;letter-spacing:.01em;border:2px solid transparent;transition:transform .15s ease,box-shadow .2s ease,background-color .2s ease}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn--primary{color:#fff;background:linear-gradient(135deg,var(--play-grape) 0%,#9f7eff 100%);box-shadow:0 8px 16px #8358ff47}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--play-grape-dark) 0%,#8a67f4 100%)}.btn--secondary{color:var(--play-ink);background:linear-gradient(135deg,#ffe08c 0%,var(--play-peach) 100%);border-color:#f6c976}.btn--ghost{color:var(--play-ink);background:#fff;border-color:var(--play-line)}.btn--danger{color:#fff;background:linear-gradient(135deg,#ff6c7f,#ff4f69)}.btn--sm{padding:.45rem .8rem;font-size:.84rem}.btn--md{padding:.65rem 1.1rem;font-size:.95rem}.btn--lg{padding:.8rem 1.25rem;font-size:1rem}.btn--active{border-color:var(--play-grape)}.input-group{display:grid;gap:.4rem}.input-group__label{font-weight:700;color:var(--play-ink)}.input-group__error{font-size:.82rem;color:#d63f63}.input,.textarea{border:2px solid var(--play-line);border-radius:16px;background:#fff}.input:focus,.textarea:focus{border-color:var(--play-grape);box-shadow:0 0 0 4px #8358ff33}.badge{border-radius:999px;font-weight:700;border:1px solid transparent}.badge--default{background:#f2eefc;color:#5d4e95}.badge--primary{background:#e8ddff;color:#5b34be}.badge--success{background:#d8f7e8;color:#0f7c4f}.badge--warning{background:#ffecc7;color:#986107}.badge--danger{background:#ffdce7;color:#a12b52}.badge--info{background:#dff1ff;color:#0f5f93}.tag-selector{display:flex;flex-wrap:wrap;gap:.45rem}.tag-selector__tag{border:2px solid var(--play-line);border-radius:999px;background:#fff;padding:.35rem .7rem;font-weight:700;color:var(--play-subtle)}.tag-selector__tag--selected{border-color:var(--play-grape);color:var(--play-grape-dark);background:#f1eaff}.page-assignments{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--play-line)}.page-assignments__summary{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1.2rem}.page-assignments__group{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem}.page-assignments__group-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--play-subtle);margin-right:.1rem}.page-assignments__empty{color:var(--play-subtle);opacity:.55;font-weight:700}.page-assignments__edit-btn{margin-left:auto;border:2px solid var(--play-line);border-radius:999px;background:#fff;padding:.3rem .8rem;font-weight:700;font-size:.8rem;color:var(--play-grape-dark);cursor:pointer}.page-assignments__edit-btn:hover:not(:disabled){background:#f1eaff;border-color:var(--play-grape)}.page-assignments__edit-btn:disabled{opacity:.5;cursor:not-allowed}.page-assignments__hint{margin:.5rem 0 0;font-size:.8rem;color:var(--play-subtle);font-style:italic}.page-assignments__editor{margin-top:.8rem;padding:.9rem 1rem;background:#fbfaff;border:2px solid var(--play-line);border-radius:16px;display:flex;flex-direction:column;gap:.8rem}.page-assignments__section{display:flex;flex-direction:column;gap:.4rem}.page-assignments__section-title{margin:0;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--play-grape-dark)}.page-assignments__picker-chip--dimmed{opacity:.55}.page-assignments__stale-banner{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.5rem .75rem;background:#ffecc7;color:#986107;border-radius:12px;font-size:.85rem;font-weight:600}.page-assignments__footer{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.2rem;border-top:1px dashed var(--play-line);margin-top:.2rem}.text-layout-editor{display:flex;flex-direction:column;gap:.9rem;margin:.6rem 0 1rem;padding:.9rem;border:2px dashed var(--play-line);border-radius:18px;background:#fbfaff}.text-layout-editor__dropdown{display:flex;align-items:center;gap:.5rem}.text-layout-editor__label{display:flex;flex-direction:column;gap:.35rem;font-weight:700;color:var(--play-ink);font-size:.85rem}.text-layout-editor__select,.text-layout-editor__textarea{border:2px solid var(--play-line);border-radius:14px;padding:.45rem .7rem;background:#fff;font-family:var(--font-body);font-size:.9rem;color:var(--play-ink)}.text-layout-editor__select:focus,.text-layout-editor__textarea:focus{outline:none;border-color:var(--play-grape);box-shadow:0 0 0 4px #8358ff2e}.text-layout-editor__overlay-wrap{display:flex;flex-direction:column;gap:.7rem}.text-layout-editor__buttons{display:flex;flex-wrap:wrap;gap:.5rem}.text-layout-editor__overlay{position:relative;width:100%;aspect-ratio:1 / 1;background:#efe9ff;border:2px solid var(--play-line);border-radius:18px;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}.text-layout-editor__overlay-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;pointer-events:none}.text-layout-editor__overlay-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--play-subtle);font-weight:700}.text-layout-editor__region{position:absolute;border:2px solid rgba(131,88,255,.55);border-radius:10px;padding:.4rem .55rem;background:#ffffff8c;color:var(--play-ink);font-size:.85rem;font-weight:600;cursor:move;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.text-layout-editor__region--banner{background:#ffffffc7}.text-layout-editor__region--banner-dark{background:#140e32a6;color:#fff}.text-layout-editor__region--active{border:2px dashed var(--play-grape);box-shadow:0 0 0 3px #8358ff33;z-index:2}.text-layout-editor__region-content{white-space:pre-wrap;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.text-layout-editor__region-empty{color:var(--play-subtle);font-style:italic}.text-layout-editor__region-handle{position:absolute;right:0;bottom:0;width:14px;height:14px;background:var(--play-grape);border-top-left-radius:6px;cursor:nwse-resize}.text-layout-editor__toolbar{position:absolute;top:-2.1rem;left:0;display:flex;gap:.25rem;padding:.25rem .4rem;background:#fff;border:2px solid var(--play-line);border-radius:999px;box-shadow:0 6px 14px #5f48aa2e;z-index:3}.text-layout-editor__tool-group{display:flex;gap:.15rem}.text-layout-editor__tool{border:1px solid var(--play-line);border-radius:999px;background:#fff;color:var(--play-grape-dark);font-weight:700;font-size:.7rem;padding:.2rem .55rem;cursor:pointer}.text-layout-editor__tool:hover{background:#f1eaff}.text-layout-editor__tool--on{background:var(--play-grape);color:#fff;border-color:var(--play-grape)}.text-layout-editor__tool--danger{color:#b3324f;border-color:#ffd2dd}.text-layout-editor__content-edit{display:flex;flex-direction:column;gap:.4rem}.text-layout-editor__warning{display:block;margin-top:.4rem;font-size:.78rem;color:#986107;font-weight:600}.polish-stage__raw-text-disclosure{margin-top:.5rem}.polish-stage__raw-text-toggle{background:none;border:1px dashed var(--play-line);border-radius:999px;padding:.3rem .75rem;color:var(--play-grape-dark);font-weight:700;font-size:.78rem;cursor:pointer}.polish-stage__raw-text-toggle:hover{background:#f1eaff}.login-page{min-height:100vh;display:grid;place-items:center;padding:1.2rem}.login-page__container{width:min(100%,520px)}.login-page__card{position:relative;overflow:hidden}.login-page__card:after{content:"✨";position:absolute;right:1.25rem;top:1rem;font-size:1.35rem}.login-page__branding{text-align:center;margin-bottom:1.15rem}.login-page__logo{font-size:clamp(2rem,6vw,3rem);letter-spacing:.02em}.login-page__tagline{color:var(--play-subtle);margin-top:.45rem}.login-page__form{display:grid;gap:.85rem}.login-page__submit{width:100%;justify-content:center}.login-page__success{text-align:center;display:grid;gap:.75rem}.login-page__success-icon{font-size:2rem}.dashboard{min-height:100vh;background:linear-gradient(180deg,#fff9,#ffffff1a)}.dashboard__header{position:sticky;top:0;z-index:5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffaf2c7;border-bottom:1px solid #efe6ff;display:flex;justify-content:space-between;align-items:center;padding:1rem clamp(1rem,4vw,2.6rem)}.dashboard__logo{font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1}.dashboard__user-email{color:var(--play-subtle);font-size:.92rem}.dashboard__header-right{display:flex;gap:.65rem;align-items:center}.dashboard__main{padding:clamp(1rem,4vw,2.4rem)}.dashboard__toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.dashboard__title{font-size:clamp(1.5rem,3vw,2rem)}.dashboard__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.dashboard__project-thumbnail{aspect-ratio:16 / 11;background:#f8f2ff}.dashboard__project-cover{width:100%;height:100%;object-fit:cover}.dashboard__project-placeholder{height:100%;display:grid;place-items:center;font-size:2rem;background:linear-gradient(135deg,#d9ecff,#ffe4ef)}.dashboard__project-info{padding:1rem 1rem .8rem}.dashboard__project-title{font-size:1.1rem}.dashboard__project-meta{margin-top:.5rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.dashboard__project-date{color:var(--play-subtle);font-size:.84rem}.dashboard__project-delete{position:absolute;top:.7rem;right:.7rem;width:34px;height:34px;border-radius:999px;border:2px solid #ffd9e2;background:#fff}.dashboard__empty{margin-inline:auto;margin-top:2rem;width:min(100%,620px);text-align:center;background:#fff;border:2px dashed #d7caef;border-radius:32px;padding:2rem 1.2rem}.dashboard__empty-icon{font-size:2.2rem;display:inline-block}.dashboard__empty-title{margin-top:.55rem}.dashboard__empty-message{color:var(--play-subtle);margin:.4rem auto 1rem;max-width:44ch}.wizard-layout{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.wizard-sidebar{position:sticky;top:0;align-self:start;min-height:100vh;padding:1rem;border-right:2px dashed #d9cdee;background:#ffffffbd;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.wizard-sidebar__header{display:grid;gap:.7rem;margin-bottom:1rem}.wizard-sidebar__title{font-size:1.5rem;line-height:1.15}.wizard-stepper{display:grid;gap:.35rem}.wizard-step{width:100%;border:2px solid transparent;border-radius:16px;display:flex;text-align:left;gap:.72rem;align-items:center;padding:.58rem;color:var(--play-ink)}.wizard-step:hover:not(:disabled){background:#f5f1ff}.wizard-step__indicator{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;font-family:var(--font-accent);font-weight:700;background:#ece4ff}.wizard-step__label{display:block;font-weight:800}.wizard-step__description{display:block;font-size:.8rem;color:var(--play-subtle)}.wizard-step--current{border-color:#ccb8ff;background:#efe8ff}.wizard-step--current .wizard-step__indicator{background:#8358ff;color:#fff}.wizard-step--completed .wizard-step__indicator{background:#86e2b7;color:#115f41}.wizard-step--locked{opacity:.55}.wizard-content{padding:clamp(.9rem,2vw,1.5rem)}.stage{max-width:1080px;margin-inline:auto;display:grid;gap:1rem}.stage__header{background:#fff;border:2px solid var(--play-line);border-radius:26px;box-shadow:var(--play-glow);padding:clamp(.9rem,2vw,1.4rem)}.stage__title{font-size:clamp(1.55rem,3vw,2.1rem)}.stage__description{color:var(--play-subtle);max-width:70ch;margin-top:.35rem}.stage__footer{margin-top:.4rem;padding:.9rem 0;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.65rem}.define-stage__tabs{display:inline-flex;align-items:center;gap:.35rem;width:fit-content;max-width:100%;padding:.3rem;border:2px solid var(--play-line);border-radius:999px;background:linear-gradient(180deg,#fffffffa,#f7f1ffeb);box-shadow:0 10px 22px #5e36cc1f,inset 0 1px #fffffff2}.define-stage__tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:999px;background:transparent;color:var(--play-subtle);font-family:var(--font-accent);font-size:.92rem;font-weight:700;letter-spacing:.01em;padding:.48rem .9rem;line-height:1.15;cursor:pointer;transition:color .16s ease,background-color .16s ease,box-shadow .18s ease,transform .16s ease}.define-stage__tab:hover{color:var(--play-ink);background:#8358ff1f}.define-stage__tab:focus-visible{outline:none;box-shadow:0 0 0 3px #8358ff47}.define-stage__tab--active{color:#fff;background:linear-gradient(135deg,var(--play-grape) 0%,#9f7eff 100%);box-shadow:0 8px 16px #5f36cc57,inset 0 1px #ffffff38}.define-stage__tab--active:hover{color:#fff;background:linear-gradient(135deg,var(--play-grape-dark) 0%,#8a67f4 100%)}[class*=__toolbar],[class*=__panel],[class*=__preview],[class*=__actions]:not(.stage__footer),.capture-stage__input-area,.capture-stage__upload,.define-stage__item-card,.storyboard-stage__page-card,.illustrate-stage__page-card{background:#fff;border:2px solid var(--play-line);border-radius:22px}[class*=__toolbar],[class*=__panel],[class*=__preview],[class*=__actions]:not(.stage__footer){padding:.85rem}.capture-stage__textarea,.inline-edit__input{border:2px solid var(--play-line);border-radius:16px;background:#fff;font-family:var(--font-body)}.capture-stage__meta,.define-stage__item-preview,.illustrate-stage__page-text,.storyboard-stage__page-text,.export-stage__preview-info{color:var(--play-subtle)}.export-stage__option--select{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem}.export-stage__option-label{font-weight:700;color:var(--play-ink);font-size:.88rem}.export-stage__select{border:2px solid var(--play-line);border-radius:14px;padding:.45rem .7rem;background:#fff;font-family:var(--font-body);font-size:.9rem;color:var(--play-ink);min-width:220px}.export-stage__select:focus{outline:none;border-color:var(--play-grape);box-shadow:0 0 0 4px #8358ff2e}.export-stage__warning{font-size:.78rem;color:#986107;font-weight:600}.file-upload{border:2px dashed #d4c4f7;border-radius:18px;background:linear-gradient(180deg,#fff,#f8f3ff)}@media(max-width:980px){.wizard-layout{grid-template-columns:1fr}.wizard-sidebar{min-height:auto;position:static;border-right:none;border-bottom:2px dashed #d9cdee}.wizard-stepper{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.wizard-step__description{display:none}.define-stage__tabs{width:100%;justify-content:space-between}.define-stage__tab{flex:1;text-align:center;padding-inline:.5rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{min-height:100vh;line-height:1.6;text-rendering:optimizeLegibility}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{overflow-wrap:break-word;font-weight:var(--fw-bold)}p{overflow-wrap:break-word}input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none}:root{--color-primary-50: #f5f0ff;--color-primary-100: #ede5ff;--color-primary-200: #d9c7ff;--color-primary-300: #c1a1ff;--color-primary-400: #a574ff;--color-primary-500: #8b4fcf;--color-primary-600: #7538b2;--color-primary-700: #5e2d91;--color-primary-800: #482372;--color-primary-900: #351a56;--color-secondary-50: #fff8ed;--color-secondary-100: #ffeed4;--color-secondary-200: #ffd9a8;--color-secondary-300: #ffbe70;--color-secondary-400: #ff9e38;--color-secondary-500: #f58012;--color-secondary-600: #d96508;--color-secondary-700: #b44b0b;--color-secondary-800: #923b10;--color-secondary-900: #783310;--color-accent-50: #ecfdf7;--color-accent-100: #d1fae9;--color-accent-200: #a7f3d6;--color-accent-300: #6ee7be;--color-accent-400: #34d39e;--color-accent-500: #10b981;--color-accent-600: #059669;--color-accent-700: #047857;--color-accent-800: #065f46;--color-accent-900: #064e3b;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-success-700: #15803d;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-gray-50: #fafaf9;--color-gray-100: #f5f5f4;--color-gray-200: #e7e5e4;--color-gray-300: #d6d3d1;--color-gray-400: #a8a29e;--color-gray-500: #78716c;--color-gray-600: #57534e;--color-gray-700: #44403c;--color-gray-800: #292524;--color-gray-900: #1c1917;--color-white: #ffffff;--color-black: #1c1917;--color-bg: var(--color-white);--color-bg-subtle: var(--color-gray-50);--color-surface: var(--color-white);--color-border: var(--color-gray-200);--color-text: var(--color-gray-900);--color-text-secondary: var(--color-gray-500);--color-text-muted: var(--color-gray-400);--color-focus-ring: rgba(139, 79, 207, .4);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--space-0: 0;--space-0-5: .125rem;--space-1: .25rem;--space-1-5: .375rem;--space-2: .5rem;--space-2-5: .625rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--sidebar-width: 280px;--header-height: 64px;--content-max-width: 1200px}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--fw-normal);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-subtle)}h1{font-size:var(--text-4xl);line-height:var(--leading-tight);letter-spacing:-.025em}h2{font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:-.02em}h3{font-size:var(--text-2xl);line-height:var(--leading-snug)}h4{font-size:var(--text-xl);line-height:var(--leading-snug)}h5{font-size:var(--text-lg);line-height:var(--leading-snug)}h6{font-size:var(--text-base);line-height:var(--leading-normal);font-weight:var(--fw-semibold)}a{color:var(--color-primary-600);transition:color var(--transition-fast)}a:hover{color:var(--color-primary-700);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px;border-radius:var(--radius-sm)}code,kbd,samp,pre{font-family:var(--font-mono);font-size:.9em}code{background-color:var(--color-gray-100);padding:var(--space-0-5) var(--space-1);border-radius:var(--radius-sm)}pre{overflow-x:auto;padding:var(--space-4);background-color:var(--color-gray-100);border-radius:var(--radius-md)}pre code{background:none;padding:0}hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}::selection{background-color:var(--color-primary-200);color:var(--color-primary-900)}:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.flex{display:flex}.inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-none{flex:none}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.self-start{align-self:flex-start}.self-center{align-self:center}.self-end{align-self:flex-end}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-normal{font-weight:var(--fw-normal)}.font-medium{font-weight:var(--fw-medium)}.font-semibold{font-weight:var(--fw-semibold)}.font-bold{font-weight:var(--fw-bold)}.text-primary{color:var(--color-primary-600)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-error{color:var(--color-error-600)}.text-white{color:var(--color-white)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-auto{overflow-x:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-grab{cursor:grab}.border{border:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-l{border-left:1px solid var(--color-border)}.border-r{border-right:1px solid var(--color-border)}.border-none{border:none}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.pointer-events-none{pointer-events:none}.transition{transition-property:color,background-color,border-color,box-shadow,opacity,transform;transition-duration:.25s;transition-timing-function:ease}.transition-fast{transition-duration:.15s}.transition-slow{transition-duration:.4s}.m-0{margin:0}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-auto{margin:auto}.mt-0{margin-top:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-0{margin-left:0}.ml-1{margin-left:var(--space-1)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mr-1{margin-right:var(--space-1)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.pt-0{padding-top:0}.pt-2{padding-top:var(--space-2)}.pt-4{padding-top:var(--space-4)}.pt-6{padding-top:var(--space-6)}.pb-0{padding-bottom:0}.pb-2{padding-bottom:var(--space-2)}.pb-4{padding-bottom:var(--space-4)}.pb-6{padding-bottom:var(--space-6)}.pl-0{padding-left:0}.pl-2{padding-left:var(--space-2)}.pl-4{padding-left:var(--space-4)}.pr-0{padding-right:0}.pr-2{padding-right:var(--space-2)}.pr-4{padding-right:var(--space-4)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-spin{animation:spin 1s linear infinite}.animate-fadeIn{animation:fadeIn var(--transition-normal) ease forwards}.animate-slideIn{animation:slideInUp var(--transition-normal) ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-scaleIn{animation:scaleIn var(--transition-normal) ease forwards}.animate-bounce{animation:bounce .6s ease infinite}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4);background-color:var(--color-bg-subtle);color:var(--color-text-secondary);font-size:var(--text-lg)}.app-loading .spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}.spinner-sm{width:14px;height:14px;border-width:2px}.spinner-lg{width:32px;height:32px;border-width:3px}@media(max-width:640px){.sm\:hidden{display:none}}@media(min-width:641px){.sm\:block{display:block}.sm\:flex{display:flex}.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media(min-width:769px){.md\:block{display:block}.md\:flex{display:flex}.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}}@media(min-width:1025px){.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}
