*{box-sizing:border-box;margin:0;padding:0}:root{--mouse-x: 50%;--mouse-y: 50%;--c-bg: #F0F4F8;--c-text: #1D2C3B;--c-text-secondary: #5A6D80;--c-text-tertiary: #8B9AAE;--c-text-on-accent: #ffffff;--c-bg-panel: #FFFFFF;--c-bg-panel-translucent: rgba(255, 255, 255, .45);--c-bg-input: #E9EEF3;--c-bg-input-translucent: rgba(255, 255, 255, .3);--c-bg-input-secondary: #DAE2EA;--c-bg-hover: #D0D9E2;--c-bg-active: #C1CCD6;--c-border: #D1DAE3;--c-border-light: #E4E9EF;--c-glass-border: rgba(255, 255, 255, .2);--c-primary: #a2d2ff;--c-primary-dark: #8CB8E3;--c-primary-light: rgba(162, 210, 255, .15);--c-primary-rgb: 162, 210, 255;--c-secondary: #F038A4;--c-secondary-dark: #C72A88;--c-secondary-light: rgba(240, 56, 164, .1);--c-secondary-rgb: 240, 56, 164;--c-accent: #9432F6;--c-accent-rgb: 148, 50, 246;--c-danger: #F038A4;--c-danger-hover: #C72A88;--c-shadow-color-light: rgba(29, 44, 59, .08);--c-shadow-color-medium: rgba(29, 44, 59, .15);--c-grid-line: rgba(29, 44, 59, .07);--c-white: #ffffff;--c-black: #000000;--c-disabled: #B0B9C4;--bg-gradient-1: #EAD5FF;--bg-gradient-2: #B7D9FF;--bg-gradient-3: #FFD4F3;--bg-gradient-4: #D5FFFA;--sparkle-color: #FFFFFF}body[data-theme=dark]{--c-bg: #0D0F1A;--c-text: #E8EAF6;--c-text-secondary: #9FA8DA;--c-text-tertiary: #7986CB;--c-text-on-accent: #ffffff;--c-bg-panel: #1A1C2A;--c-bg-panel-translucent: rgba(26, 28, 42, .45);--c-bg-input: #2A2D42;--c-bg-input-translucent: rgba(42, 45, 66, .3);--c-bg-input-secondary: #2A2D42;--c-bg-hover: #393C58;--c-bg-active: #484B6A;--c-border: #2A2D42;--c-border-light: #2A2D42;--c-glass-border: rgba(255, 255, 255, .1);--c-primary: #8EBBFF;--c-primary-dark: #6F9EE8;--c-primary-light: rgba(142, 187, 255, .15);--c-primary-rgb: 142, 187, 255;--c-secondary: #FF73C3;--c-secondary-dark: #FF40A1;--c-secondary-light: rgba(255, 115, 195, .1);--c-secondary-rgb: 255, 115, 195;--c-accent: #BE88FF;--c-accent-rgb: 190, 136, 255;--c-danger: #FF73C3;--c-danger-hover: #FF40A1;--c-shadow-color-light: rgba(0, 0, 0, .2);--c-shadow-color-medium: rgba(0, 0, 0, .4);--c-grid-line: rgba(232, 234, 246, .08);--c-disabled: #4A4D64;--bg-gradient-1: #3D1C52;--bg-gradient-2: #1C3252;--bg-gradient-3: #521C4A;--bg-gradient-4: #1C524E;--sparkle-color: #E8EAF6}body[data-theme=solaris]{--c-bg: #2c1e18;--c-text: #fdf6e3;--c-text-secondary: #d6c6a4;--c-text-tertiary: #a19174;--c-text-on-accent: #ffffff;--c-bg-panel: #423028;--c-bg-panel-translucent: rgba(66, 48, 40, .45);--c-bg-input: #5a453c;--c-bg-input-translucent: rgba(90, 69, 60, .3);--c-bg-input-secondary: #5a453c;--c-bg-hover: #73584d;--c-bg-active: #8c6c5f;--c-border: #5a453c;--c-border-light: #5a453c;--c-glass-border: rgba(253, 246, 227, .1);--c-primary: #ffb347;--c-primary-dark: #e5a140;--c-primary-light: rgba(255, 179, 71, .15);--c-primary-rgb: 255, 179, 71;--c-secondary: #e58c8a;--c-secondary-dark: #ce7e7c;--c-secondary-light: rgba(229, 140, 138, .1);--c-secondary-rgb: 229, 140, 138;--c-accent: #ffb347;--c-accent-rgb: 255, 179, 71;--c-danger: #e58c8a;--c-danger-hover: #ce7e7c;--c-shadow-color-light: rgba(0, 0, 0, .2);--c-shadow-color-medium: rgba(0, 0, 0, .4);--c-grid-line: rgba(253, 246, 227, .08);--c-disabled: #73584d;--bg-gradient-1: #d35400;--bg-gradient-2: #c0392b;--bg-gradient-3: #8e44ad;--bg-gradient-4: #f39c12;--sparkle-color: #fdf6e3}body[data-theme=noir]{--c-bg: #0a0b1e;--c-text: #e0e0e0;--c-text-secondary: #a0a0a0;--c-text-tertiary: #707070;--c-text-on-accent: #0a0b1e;--c-bg-panel: #14152b;--c-bg-panel-translucent: rgba(20, 21, 43, .45);--c-bg-input: #242541;--c-bg-input-translucent: rgba(36, 37, 65, .3);--c-bg-input-secondary: #242541;--c-bg-hover: #34355a;--c-bg-active: #454673;--c-border: #242541;--c-border-light: #242541;--c-glass-border: rgba(0, 255, 255, .2);--c-primary: #00ffff;--c-primary-dark: #00e5e5;--c-primary-light: rgba(0, 255, 255, .15);--c-primary-rgb: 0, 255, 255;--c-secondary: #ff00ff;--c-secondary-dark: #e500e5;--c-secondary-light: rgba(255, 0, 255, .1);--c-secondary-rgb: 255, 0, 255;--c-accent: #9400d3;--c-accent-rgb: 148, 0, 211;--c-danger: #ff00ff;--c-danger-hover: #e500e5;--c-shadow-color-light: rgba(0, 255, 255, .1);--c-shadow-color-medium: rgba(0, 255, 255, .2);--c-grid-line: rgba(0, 255, 255, .1);--c-disabled: #454673;--bg-gradient-1: #2c003e;--bg-gradient-2: #001f3f;--bg-gradient-3: #3d003d;--bg-gradient-4: #003333;--sparkle-color: #00ffff}body[data-theme=sakura]{--c-bg: #fff0f5;--c-text: #4a4a4a;--c-text-secondary: #7a7a7a;--c-text-tertiary: #a0a0a0;--c-text-on-accent: #ffffff;--c-bg-panel: #ffffff;--c-bg-panel-translucent: rgba(255, 255, 255, .45);--c-bg-input: #ffe4e1;--c-bg-input-translucent: rgba(255, 228, 225, .3);--c-bg-input-secondary: #ffdae0;--c-bg-hover: #ffcdd2;--c-bg-active: #ffb7c5;--c-border: #ffdae0;--c-border-light: #ffe4e1;--c-glass-border: rgba(74, 74, 74, .2);--c-primary: #ffb7c5;--c-primary-dark: #fca6b5;--c-primary-light: rgba(255, 183, 197, .15);--c-primary-rgb: 255, 183, 197;--c-secondary: #a3d6c3;--c-secondary-dark: #91c0b0;--c-secondary-light: rgba(163, 214, 195, .1);--c-secondary-rgb: 163, 214, 195;--c-accent: #ff8fa3;--c-accent-rgb: 255, 143, 163;--c-danger: #ff8fa3;--c-danger-hover: #ff758f;--c-shadow-color-light: rgba(74, 74, 74, .08);--c-shadow-color-medium: rgba(74, 74, 74, .15);--c-grid-line: rgba(74, 74, 74, .07);--c-disabled: #d1b3b8;--bg-gradient-1: #ffe4e1;--bg-gradient-2: #e6e6fa;--bg-gradient-3: #fff0f5;--bg-gradient-4: #f0fff0;--sparkle-color: #4a4a4a}body[data-theme=bw]{--c-bg: #000000;--c-text: #ffffff;--c-text-secondary: #cccccc;--c-text-tertiary: #999999;--c-text-on-accent: #000000;--c-bg-panel: #1a1a1a;--c-bg-panel-translucent: rgba(26, 26, 26, .45);--c-bg-input: #333333;--c-bg-input-translucent: rgba(51, 51, 51, .3);--c-bg-input-secondary: #333333;--c-bg-hover: #4d4d4d;--c-bg-active: #666666;--c-border: #444444;--c-border-light: #444444;--c-glass-border: rgba(255, 255, 255, .1);--c-primary: #ffffff;--c-primary-dark: #e5e5e5;--c-primary-light: rgba(255, 255, 255, .15);--c-primary-rgb: 255, 255, 255;--c-secondary: #888888;--c-secondary-dark: #777777;--c-secondary-light: rgba(136, 136, 136, .1);--c-secondary-rgb: 136, 136, 136;--c-accent: #ffffff;--c-accent-rgb: 255, 255, 255;--c-danger: #cccccc;--c-danger-hover: #bbbbbb;--c-shadow-color-light: rgba(255, 255, 255, .1);--c-shadow-color-medium: rgba(255, 255, 255, .2);--c-grid-line: rgba(255, 255, 255, .1);--c-disabled: #666666;--bg-gradient-1: #111111;--bg-gradient-2: #222222;--bg-gradient-3: #000000;--bg-gradient-4: #1a1a1a;--sparkle-color: #ffffff}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--c-text);overflow:hidden;-webkit-user-select:none;user-select:none;background-color:var(--c-bg)}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at var(--mouse-x) var(--mouse-y),rgba(var(--c-accent-rgb),.15) 0%,transparent S40%);z-index:-2;pointer-events:none;transition:background .2s ease-out}body:after{content:"";position:fixed;top:0;left:0;width:200%;height:200%;background-image:radial-gradient(circle at 10% 20%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 50% 30%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 80% 10%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 30% 80%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 70% 60%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 90% 90%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 15% 65%,var(--sparkle-color),transparent 1px),radial-gradient(circle at 45% 5%,var(--sparkle-color),transparent 1px);background-size:1px 1px;background-repeat:no-repeat;z-index:-1;opacity:.3;animation:twinkle 60s linear infinite}@keyframes twinkle{0%{transform:translate(0)}to{transform:translate(-50%,-50%)}}#root{width:100vw;height:100vh;position:relative;background:linear-gradient(135deg,var(--bg-gradient-1),var(--bg-gradient-2),var(--bg-gradient-3),var(--bg-gradient-4));background-size:400% 400%;animation:cosmicFlow 30s ease infinite;z-index:0}@keyframes cosmicFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.sparkle-burst{position:fixed;width:1px;height:1px;pointer-events:none;z-index:9999}.sparkle-burst .sparkle{position:absolute;top:0;left:0;width:6px;height:6px;background:var(--sparkle-color);border-radius:50%;opacity:1;animation:sparkle-anim .7s ease-out forwards;box-shadow:0 0 4px var(--sparkle-color),0 0 8px var(--sparkle-color)}@keyframes sparkle-anim{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5) var(--transform);opacity:0}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0003;display:flex;justify-content:center;align-items:center;z-index:1200;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.modal-content{background-color:var(--c-bg-panel-translucent);color:var(--c-text);border-radius:16px;box-shadow:0 8px 32px var(--c-shadow-color-medium);width:90%;max-width:450px;overflow:hidden;border:1px solid var(--c-glass-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--c-glass-border)}.modal-header h2{font-size:18px;font-weight:600}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-body p{font-size:16px;line-height:1.5;color:var(--c-text)}.modal-body input[type=text]{width:100%;padding:12px 15px;border:1px solid var(--c-glass-border);background-color:var(--c-bg-input);color:var(--c-text);border-radius:8px;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s}.modal-body input[type=text]:focus{border-color:var(--c-secondary);box-shadow:0 0 0 3px var(--c-secondary-light)}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.modal-actions button{padding:10px 20px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;border:none;transition:background-color .2s,color .2s}.modal-actions button.secondary{background-color:var(--c-bg-input-secondary);color:var(--c-text)}.modal-actions button.secondary:hover{background-color:var(--c-bg-hover)}.modal-actions button:not(.secondary){background-color:var(--c-primary);color:var(--c-text-on-accent)}.modal-actions button:not(.secondary):hover{background-color:var(--c-primary-dark)}.modal-actions button.danger{background-color:var(--c-danger)}.modal-actions button.danger:hover{background-color:var(--c-danger-hover)}.settings-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0003;display:flex;justify-content:center;align-items:center;z-index:1100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.settings-panel{background-color:var(--c-bg-panel-translucent);color:var(--c-text);border-radius:16px;box-shadow:0 8px 32px var(--c-shadow-color-medium);width:90%;max-width:450px;overflow:hidden;border:1px solid var(--c-glass-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--c-glass-border)}.settings-header h2{font-size:18px;font-weight:600}.close-button{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--c-text-secondary);padding:0 4px}.close-button:hover{color:var(--c-text)}.settings-body{padding:20px;display:flex;flex-direction:column;gap:24px}.setting-item{display:flex;justify-content:space-between;align-items:center}.setting-item-column{display:flex;flex-direction:column;gap:12px}.setting-item-column>label{font-size:16px;font-weight:500;color:var(--c-text)}.theme-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px}.theme-button{display:flex;align-items:center;gap:10px;padding:10px;border:2px solid var(--c-border);border-radius:8px;background-color:var(--c-bg-input);cursor:pointer;font-size:14px;font-weight:500;color:var(--c-text);text-align:left;transition:border-color .2s,background-color .2s,box-shadow .2s}.theme-button:hover{background-color:var(--c-bg-hover);border-color:var(--c-border-light)}.theme-button.active{border-color:var(--c-primary);box-shadow:0 0 0 2px var(--c-primary-light)}.theme-swatch{display:flex;width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0;transform:rotate(45deg);border:1px solid rgba(0,0,0,.1)}.theme-swatch span{width:25%;height:100%}.theme-button[data-theme-preview=light] .swatch-color-1{background-color:#ead5ff}.theme-button[data-theme-preview=light] .swatch-color-2{background-color:#b7d9ff}.theme-button[data-theme-preview=light] .swatch-color-3{background-color:#ffd4f3}.theme-button[data-theme-preview=light] .swatch-color-4{background-color:#d5fffa}.theme-button[data-theme-preview=dark] .swatch-color-1{background-color:#3d1c52}.theme-button[data-theme-preview=dark] .swatch-color-2{background-color:#1c3252}.theme-button[data-theme-preview=dark] .swatch-color-3{background-color:#521c4a}.theme-button[data-theme-preview=dark] .swatch-color-4{background-color:#1c524e}.theme-button[data-theme-preview=solaris] .swatch-color-1{background-color:#d35400}.theme-button[data-theme-preview=solaris] .swatch-color-2{background-color:#c0392b}.theme-button[data-theme-preview=solaris] .swatch-color-3{background-color:#8e44ad}.theme-button[data-theme-preview=solaris] .swatch-color-4{background-color:#f39c12}.theme-button[data-theme-preview=noir] .swatch-color-1{background-color:#2c003e}.theme-button[data-theme-preview=noir] .swatch-color-2{background-color:#001f3f}.theme-button[data-theme-preview=noir] .swatch-color-3{background-color:#f0f}.theme-button[data-theme-preview=noir] .swatch-color-4{background-color:#0ff}.theme-button[data-theme-preview=sakura] .swatch-color-1{background-color:#ffe4e1}.theme-button[data-theme-preview=sakura] .swatch-color-2{background-color:#e6e6fa}.theme-button[data-theme-preview=sakura] .swatch-color-3{background-color:#fff0f5}.theme-button[data-theme-preview=sakura] .swatch-color-4{background-color:#a3d6c3}.theme-button[data-theme-preview=bw] .swatch-color-1{background-color:#000}.theme-button[data-theme-preview=bw] .swatch-color-2{background-color:#333}.theme-button[data-theme-preview=bw] .swatch-color-3{background-color:#888}.theme-button[data-theme-preview=bw] .swatch-color-4{background-color:#fff}.setting-item label{font-size:16px;font-weight:500;color:var(--c-text)}.setting-item select,.setting-item input[type=number]{border:1px solid var(--c-glass-border);border-radius:8px;padding:8px 12px;font-size:14px;background-color:var(--c-bg-input);color:var(--c-text)}.setting-item select:disabled{color:var(--c-disabled)}.setting-item .aspect-ratio-select-wrapper{width:180px}.setting-item .aspect-ratio-select-button{width:100%;height:36px}.setting-item.disabled{opacity:.5;pointer-events:none}.setting-item .toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.setting-item .toggle-switch input{opacity:0;width:0;height:0}.toggle-switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--c-bg-hover);transition:.4s;border-radius:28px}.toggle-switch-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:var(--c-white);transition:.4s;border-radius:50%}.setting-item input:checked+.toggle-switch-slider{background-color:var(--c-primary)}.setting-item input:checked+.toggle-switch-slider:before{transform:translate(22px)}.settings-panel .number-input{display:flex;align-items:center;background-color:var(--c-bg-input);border-radius:8px;border:1px solid var(--c-glass-border);overflow:hidden}.settings-panel .number-input span{padding:0 16px;font-weight:500;font-size:14px;min-width:40px;text-align:center;color:var(--c-text)}.settings-panel .number-input button{background-color:var(--c-bg-input-secondary);color:var(--c-text);width:32px;height:32px;border:none;border-radius:0;font-size:20px;line-height:1;cursor:pointer;transition:background-color .2s}.settings-panel .number-input button:hover{background-color:var(--c-bg-hover)}.settings-panel .aspect-ratio-popover{left:auto;right:0;transform:translate(0);animation-name:settings-popover-fade-in}.settings-panel .aspect-ratio-popover:before{left:auto;right:84px;transform:none}@keyframes settings-popover-fade-in{0%{opacity:0;transform:translate(0) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.toolbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:10px;align-items:center;background-color:var(--c-bg-panel-translucent);padding:12px;border-radius:12px;box-shadow:0 4px 20px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:100;border:1px solid var(--c-glass-border)}.toolbar input[type=text],.toolbar textarea{width:300px;padding:10px 15px;border:1px solid var(--c-glass-border);background-color:var(--c-bg-input-translucent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--c-text);border-radius:8px;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit;line-height:1.4;min-height:40px}.toolbar input[type=text]:focus,.toolbar textarea:focus{border-color:var(--c-secondary);box-shadow:0 0 0 3px var(--c-secondary-light)}.toolbar button{padding:10px 15px;border:none;background-color:var(--c-primary);color:var(--c-text-on-accent);border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s,transform .1s}.toolbar button.generate-btn{background-color:var(--c-secondary)}.toolbar button.generate-btn:hover{background-color:var(--c-secondary-dark)}.toolbar button.icon-btn{background-color:var(--c-bg-input-secondary);color:var(--c-text-tertiary);padding:10px;width:40px;height:40px;justify-content:center;border:1px solid transparent}.toolbar button.icon-btn:hover{background-color:var(--c-bg-hover);color:var(--c-primary)}.toolbar button.icon-btn svg{width:20px;height:20px}.toolbar button:hover{background-color:var(--c-primary-dark)}.toolbar button:active{transform:scale(.98)}.toolbar button:disabled{background-color:var(--c-disabled);cursor:not-allowed}.combine-controls,.context-toolbar{position:fixed;display:flex;gap:8px;align-items:center;background-color:var(--c-bg-panel-translucent);padding:8px;border-radius:12px;box-shadow:0 4px 20px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:101;border:1px solid var(--c-glass-border);transition:opacity .2s ease-out,transform .2s ease-out;will-change:transform,opacity}.combine-controls{flex-direction:column;padding:12px;gap:8px}.variation-panel textarea,.combine-controls textarea{width:100%;padding:8px 12px;border:1px solid var(--c-glass-border);border-radius:8px;font-size:14px;background-color:var(--c-bg-input-translucent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--c-text);transition:border-color .2s,box-shadow .2s,background-color .2s;outline:none;resize:vertical;font-family:inherit;line-height:1.4;overflow:hidden}.variation-panel textarea:focus,.combine-controls textarea:focus{border-color:var(--c-secondary);box-shadow:0 0 0 3px var(--c-secondary-light)}.combine-actions{display:flex;gap:8px;width:100%;align-items:center}.combine-actions button{flex-grow:1}.combine-controls button{width:auto;padding:8px 12px;border:none;background-color:var(--c-primary);color:var(--c-text-on-accent);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap;flex-shrink:0;height:34px}.combine-controls button:hover{background-color:var(--c-primary-dark)}.combine-controls .secondary-button{background-color:var(--c-bg-input-secondary);color:var(--c-text);border:1px solid var(--c-border);flex-shrink:0}.combine-controls .secondary-button:hover{background-color:var(--c-bg-hover)}.context-toolbar{gap:4px;transform:translate(-50%,-10px)}.context-toolbar.visible{transform:translate(-50%)}.context-toolbar .icon-button{background:transparent;border:none;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--c-text);transition:background-color .2s ease,color .2s ease}.context-toolbar .icon-button:hover:not(:disabled){background-color:var(--c-primary-light);color:var(--c-primary-dark)}.context-toolbar .icon-button.liked-btn:hover:not(:disabled):not(.active){background-color:var(--c-secondary-light);color:var(--c-secondary-dark)}.context-toolbar .icon-button:disabled{color:var(--c-disabled);cursor:not-allowed;background-color:transparent}.context-toolbar>.icon-button.active{background-color:var(--c-primary);color:var(--c-text-on-accent)}.context-toolbar>.icon-button.active:hover:not(:disabled){background-color:var(--c-primary-dark)}.context-toolbar>.icon-button.liked-btn.active{background-color:var(--c-secondary);color:var(--c-text-on-accent)}.context-toolbar>.icon-button.liked-btn.active:hover:not(:disabled){background-color:var(--c-secondary-dark)}.context-toolbar .icon-button svg{width:20px;height:20px;fill:currentColor}.context-toolbar .separator{width:1px;height:20px;background-color:var(--c-border);margin:0 4px}.context-toolbar select,.context-toolbar input[type=number]{border:none;background-color:var(--c-bg-input-translucent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--c-text);border-radius:6px;padding:6px 8px;font-size:14px;outline:none}.context-toolbar input[type=number]{width:60px;text-align:center}.color-control-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.color-picker-popover{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background-color:var(--c-bg-panel);padding:12px;border-radius:12px;box-shadow:0 6px 24px var(--c-shadow-color-medium);z-index:60;display:flex;flex-direction:column;gap:10px;border:1px solid var(--c-glass-border);width:200px}.color-picker-popover:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:var(--c-bg-panel) transparent transparent transparent}.color-picker-popover .color-palette{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.color-picker-popover .color-swatch{width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,0,0,.1);box-shadow:inset 0 0 0 1px #0000000d;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;background:none;padding:0}.color-picker-popover .color-swatch:hover{transform:scale(1.15);box-shadow:0 2px 4px var(--c-shadow-color-light)}.color-picker-popover .custom-color-picker{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px;margin-top:4px;border-top:1px solid var(--c-border-light)}.color-picker-popover .custom-color-picker label{font-size:14px;font-weight:500;color:var(--c-text)}.color-picker-popover .custom-color-picker input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:30px;height:30px;padding:0;border:none;border-radius:50%;cursor:pointer;overflow:hidden;border:1px solid rgba(0,0,0,.1)}.color-picker-popover .custom-color-picker input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-popover .custom-color-picker input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.variation-panel{display:flex;align-items:center;gap:8px;margin-left:4px}.variation-panel .generate-button{padding:6px 12px;border:none;background-color:var(--c-secondary);color:var(--c-text-on-accent);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.variation-panel .generate-button:hover{background-color:var(--c-secondary-dark)}.number-input{display:flex;align-items:center;background-color:var(--c-bg-input-secondary);border-radius:8px;overflow:hidden}.number-input span{padding:0 16px;font-weight:500;font-size:16px;min-width:40px;text-align:center;color:var(--c-text)}.number-input button{background-color:var(--c-bg-hover);color:var(--c-text);width:32px;height:32px;border:none;border-radius:0;font-size:20px;line-height:1;cursor:pointer;transition:background-color .2s}.number-input button:hover{background-color:var(--c-bg-active)}.opacity-control-in-popover{display:flex;align-items:center;gap:8px;padding-top:10px;margin-top:4px;border-top:1px solid var(--c-border-light)}.opacity-control-in-popover svg{width:18px;height:18px;color:var(--c-text-tertiary);flex-shrink:0}.opacity-control-in-popover span{font-size:13px;color:var(--c-text-secondary);width:40px;text-align:right;flex-shrink:0}.opacity-control-in-popover input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--c-bg-hover);border-radius:3px;outline:none;cursor:pointer;flex-grow:1}.opacity-control-in-popover input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--c-primary);border-radius:50%;border:2px solid var(--c-bg-panel);box-shadow:0 1px 3px var(--c-shadow-color-light)}.opacity-control-in-popover input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--c-primary);border-radius:50%;border:2px solid var(--c-bg-panel);box-shadow:0 1px 3px var(--c-shadow-color-light)}.filter-toolbar{position:fixed;transform:translate(-50%);display:flex;gap:4px;align-items:center;background-color:var(--c-bg-panel-translucent);padding:4px;border-radius:12px;box-shadow:0 4px 20px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:100;cursor:grab;border:1px solid var(--c-glass-border)}.filter-toolbar .filter-button{background:transparent;border:none;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--c-text-tertiary);transition:background-color .2s ease,color .2s ease}.filter-toolbar .filter-button:hover:not(.active){background-color:var(--c-primary-light)}.filter-toolbar .filter-button.liked-filter:hover:not(.active){background-color:var(--c-secondary-light)}.filter-toolbar .filter-button.active{background-color:var(--c-primary-light);color:var(--c-primary-dark)}.filter-toolbar .filter-button.liked-filter.active{background-color:var(--c-secondary-light);color:var(--c-secondary-dark)}body[data-theme=dark] .filter-toolbar .filter-button.active{color:var(--c-primary)}body[data-theme=dark] .filter-toolbar .filter-button.liked-filter.active{color:var(--c-secondary)}.filter-toolbar .filter-button svg{width:22px;height:22px;fill:currentColor}.aspect-ratio-select-wrapper{position:relative;flex-shrink:0}.aspect-ratio-select-button{border:none;background-color:var(--c-primary);color:var(--c-text-on-accent);border-radius:8px;outline:none;transition:background-color .2s,box-shadow .2s;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:500}.toolbar .aspect-ratio-select-button{height:40px;font-size:14px;padding:0 15px}.combine-controls .aspect-ratio-select-button,.variation-panel .aspect-ratio-select-button{height:34px;font-size:14px;padding:0 12px;flex-shrink:0}.aspect-ratio-select-button:focus,.aspect-ratio-select-button:hover{background-color:var(--c-primary-dark);box-shadow:0 0 0 3px var(--c-primary-light)}.aspect-ratio-popover{position:absolute;left:50%;transform:translate(-50%);width:240px;background-color:var(--c-bg-panel);border:1px solid var(--c-glass-border);border-radius:12px;padding:12px;z-index:20;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 24px var(--c-shadow-color-medium);animation:popover-fade-in .15s ease-out forwards}.aspect-ratio-popover.up{bottom:calc(100% + 10px);transform-origin:bottom center}.aspect-ratio-popover.down{top:calc(100% + 10px);transform-origin:top center}@keyframes popover-fade-in{0%{opacity:0;transform:translate(-50%) scale(.95)}to{opacity:1;transform:translate(-50%) scale(1)}}.aspect-ratio-popover:before{content:"";position:absolute;left:50%;transform:translate(-50%);border-width:6px;border-style:solid}.aspect-ratio-popover.up:before{top:100%;border-color:var(--c-bg-panel) transparent transparent transparent}.aspect-ratio-popover.down:before{bottom:100%;border-color:transparent transparent var(--c-bg-panel) transparent}.aspect-ratio-group .group-name{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--c-text-tertiary);margin-bottom:8px;display:block;padding-left:2px;transition:color .2s ease}.aspect-ratio-group .group-name.active{color:var(--c-primary);font-weight:700}.ratios-container{display:flex;gap:10px}.ratio-button{flex:1;background-color:var(--c-bg-input-secondary);border:2px solid transparent;border-radius:6px;cursor:pointer;padding:4px;transition:all .2s ease;position:relative;height:44px;display:flex;align-items:center;justify-content:center}.ratio-button:hover{border-color:var(--c-primary);background-color:var(--c-bg-hover)}.ratio-button.active{border-color:var(--c-primary);background-color:var(--c-primary)}.ratio-visual{background-color:var(--c-text-secondary);border-radius:3px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:background-color .2s ease,opacity .2s ease}.ratio-button.active .ratio-visual{opacity:0}.ratio-text{position:relative;z-index:1;font-size:13px;font-weight:600;color:var(--c-text);text-shadow:0 0 4px var(--c-bg-panel),0 0 8px var(--c-bg-panel)}.ratio-button.active .ratio-text{color:var(--c-text-on-accent);text-shadow:none}.ratio-button[data-ratio="16:9"] .ratio-visual{width:32px;height:18px}.ratio-button[data-ratio="4:3"] .ratio-visual{width:28px;height:21px}.ratio-button[data-ratio="1:1"] .ratio-visual{width:24px;height:24px}.ratio-button[data-ratio="9:16"] .ratio-visual{width:18px;height:32px}.ratio-button[data-ratio="3:4"] .ratio-visual{width:21px;height:28px}.dashboard-container{width:100%;height:100%;display:flex;flex-direction:column;color:var(--c-text)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;flex-shrink:0;position:relative;z-index:10;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--c-glass-border)}.dashboard-header h1{font-family:Gowun Dodum,sans-serif;font-size:32px;font-weight:400;letter-spacing:1.5px;display:flex;align-items:center;gap:12px}.dashboard-header h1 img{height:36px;width:auto;transition:filter .3s ease}body[data-theme=dark] .dashboard-header h1 img,body[data-theme=solaris] .dashboard-header h1 img,body[data-theme=noir] .dashboard-header h1 img,body[data-theme=bw] .dashboard-header h1 img{filter:invert(1)}.dashboard-header h1 span{background:linear-gradient(110deg,rgba(var(--c-secondary-rgb),.95),rgba(var(--c-primary-rgb),.95) 45%,rgba(var(--c-accent-rgb),.95) 60%,rgba(var(--c-secondary-rgb),.95));background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:.5px rgba(255,255,255,.15);text-shadow:0 2px 5px var(--c-shadow-color-light);animation:liquid-flow 4s ease-in-out infinite}.header-actions{display:flex;align-items:center;gap:12px}.sync-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background-color:var(--c-bg-input-secondary);border:1px solid var(--c-border);border-radius:6px;font-size:12px;color:var(--c-text-secondary)}.sync-icon{width:16px;height:16px;animation:spin 1s linear infinite}.user-info{display:flex;align-items:center;gap:12px;margin-right:8px}.user-profile{display:flex;align-items:center;gap:8px}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--c-border)}.user-name{font-size:14px;color:var(--c-text);font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{padding:6px 12px;background:var(--c-bg-button-secondary);color:var(--c-text);border:1px solid var(--c-border);border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:var(--c-bg-button-secondary-hover);border-color:var(--c-border-hover)}.new-project-btn{padding:10px 20px;border:none;background-color:var(--c-secondary);color:var(--c-text-on-accent);border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.new-project-btn:hover{background-color:var(--c-secondary-dark)}.new-project-btn.secondary{background-color:var(--c-bg-input-secondary);color:var(--c-text)}.new-project-btn.secondary:hover{background-color:var(--c-bg-hover)}.settings-btn-header{width:44px;height:44px;background-color:var(--c-bg-input-secondary);border:none;border-radius:8px;display:flex;justify-content:center;align-items:center;cursor:pointer;color:var(--c-text-tertiary);transition:all .2s ease}.settings-btn-header:hover{background-color:var(--c-bg-hover);color:var(--c-text)}.settings-btn-header svg{width:24px;height:24px}.dashboard-main{flex-grow:1;overflow-y:auto;padding:32px 40px}.dashboard-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-section-header h2{font-size:18px;font-weight:600;color:var(--c-text-tertiary)}.dashboard-controls{display:flex;gap:12px;align-items:center}.sort-control{position:relative}.sort-button{display:flex;align-items:center;gap:8px;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 16px;border-radius:8px;border:1px solid var(--c-glass-border);font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px var(--c-shadow-color-light)}.sort-button:hover{border-color:var(--c-bg-active);box-shadow:0 2px 4px var(--c-shadow-color-light)}.sort-button[aria-expanded=true]{border-color:var(--c-text-secondary)}.sort-button span{color:var(--c-text-tertiary)}.sort-button strong{color:var(--c-text);font-weight:500}.sort-button svg{width:16px;height:16px;color:var(--c-text-secondary);transition:transform .2s ease-in-out}.sort-button[aria-expanded=true] svg{transform:rotate(180deg)}.sort-menu{position:absolute;top:calc(100% + 6px);right:0;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:8px;box-shadow:0 4px 20px var(--c-shadow-color-medium);z-index:20;padding:6px;width:160px;border:1px solid var(--c-glass-border);opacity:0;transform:translateY(-5px);animation:fadeIn .15s ease-out forwards}@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}.sort-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;font-size:14px;background:none;border:none;border-radius:4px;cursor:pointer;text-align:left;transition:background-color .1s ease-in-out;color:var(--c-text)}.sort-option:hover{background-color:var(--c-bg-input-secondary)}.sort-option.active{color:var(--c-primary);font-weight:600}.sort-option svg{width:18px;height:18px;fill:var(--c-primary)}.view-toggle{display:flex;gap:4px;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:4px;border-radius:8px;border:1px solid var(--c-glass-border)}.view-toggle button{padding:6px 10px;border:none;border-radius:6px;background-color:transparent;cursor:pointer;color:var(--c-text-tertiary);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease;font-size:14px;font-weight:500}.view-toggle button svg{width:18px;height:18px}.view-toggle button:hover:not(.active){background-color:var(--c-bg-hover)}.view-toggle button.active{background-color:var(--c-bg-panel);color:var(--c-primary);box-shadow:0 1px 3px var(--c-shadow-color-light)}.filter-toggle{display:flex;padding:4px;border-radius:10px;transition:background-color .3s ease-in-out;border:1px solid var(--c-glass-border);background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.filter-toggle.filter-toggle-all{background-color:rgba(var(--c-primary-rgb),.1)}.filter-toggle.filter-toggle-liked{background-color:rgba(var(--c-secondary-rgb),.1)}.filter-toggle.filter-toggle-trashed{background-color:var(--c-bg-input-secondary)}.filter-toggle button{padding:8px 20px;margin:0;border:1px solid transparent;border-radius:8px;background-color:transparent;cursor:pointer;color:var(--c-text-secondary);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .25s ease;font-size:14px;font-weight:500}.filter-toggle button svg{width:18px;height:18px}.filter-toggle button:hover:not(.active){color:var(--c-text)}.filter-toggle button.active{background-color:var(--c-bg-panel);border-color:var(--c-border);box-shadow:0 2px 5px var(--c-shadow-color-light)}.filter-toggle button.all-filter.active{color:var(--c-primary)}.filter-toggle button.liked-filter.active{color:var(--c-secondary)}.filter-toggle button.trash-filter.active{color:var(--c-text-secondary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px}.project-card{background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--c-glass-border);border-radius:12px;box-shadow:0 4px 12px var(--c-shadow-color-light);display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,opacity .2s ease;position:relative;overflow:hidden}.project-card.liked{border-color:rgba(var(--c-secondary-rgb),.5);box-shadow:0 6px 16px rgba(var(--c-secondary-rgb),.1)}.project-card:not(.trashed):hover{transform:translateY(-5px);box-shadow:0 8px 24px var(--c-shadow-color-medium)}.project-card-thumbnail{width:100%;height:180px;background-color:var(--c-bg-input-translucent);border-bottom:1px solid var(--c-glass-border);display:flex;justify-content:center;align-items:center;color:var(--c-text-secondary);cursor:pointer;overflow:hidden;position:relative}.project-card-thumbnail img{width:100%;height:100%;object-fit:contain;transition:transform .3s ease}.project-card:not(.trashed):hover .project-card-thumbnail img{transform:scale(1.05)}.project-card-thumbnail svg{width:50px;height:50px}.project-card-info{padding:16px;display:flex;flex-direction:column;cursor:pointer;flex-grow:1}.project-card.trashed .project-card-info,.project-card.trashed .project-card-thumbnail{cursor:default}.project-title{font-size:16px;font-weight:600;color:var(--c-text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-date{font-size:13px;color:var(--c-text-secondary)}.card-actions{position:absolute;top:10px;right:10px;display:flex;gap:6px;opacity:0;transition:opacity .2s}.project-card:hover .card-actions,.project-card.trashed .card-actions{opacity:1}.like-btn,.more-btn{width:32px;height:32px;background:transparent;border:none;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;color:var(--c-text);transition:background-color .2s,color .2s}.like-btn:hover,.more-btn:hover{background:var(--c-bg-panel)}.like-btn.liked{color:var(--c-secondary);background:transparent}.like-btn.liked:hover{background:var(--c-secondary-light)}.project-card-menu{position:absolute;top:48px;right:10px;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:8px;box-shadow:0 2px 10px var(--c-shadow-color-medium);z-index:10;overflow:hidden;display:flex;flex-direction:column;padding:4px;border:1px solid var(--c-glass-border)}.project-card-menu button{background:none;border:none;padding:8px 12px;width:140px;text-align:left;cursor:pointer;font-size:14px;border-radius:4px;display:flex;align-items:center;gap:8px;color:var(--c-text)}.project-card-menu button svg{width:16px;height:16px;opacity:.7}.project-card-menu button:hover{background-color:var(--c-bg-input-secondary)}.project-card-menu button.delete{color:var(--c-danger)}.project-card-menu button.delete:hover{background-color:var(--c-secondary-light)}.projects-list{display:flex;flex-direction:column;gap:12px}.project-list-item{display:flex;align-items:center;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--c-glass-border);padding:12px;border-radius:10px;box-shadow:0 2px 8px var(--c-shadow-color-light);transition:transform .2s,box-shadow .2s,opacity .2s ease;cursor:pointer}.project-list-item:not(.trashed):hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--c-shadow-color-medium)}.project-list-item.trashed{cursor:default}.project-list-item .project-card-thumbnail{width:80px;height:50px;border-radius:6px;margin-right:16px;flex-shrink:0}.project-list-item .project-card-info{padding:0;flex-grow:1;overflow:hidden}.project-list-item .project-title{margin-bottom:2px}.project-list-item .project-date{font-size:12px}.project-list-item .card-actions{position:static;opacity:1;margin-left:16px}.project-card.trashed,.project-list-item.trashed{opacity:.6}.project-card.trashed:hover,.project-list-item.trashed:hover{background-color:var(--c-bg-panel-translucent)}.empty-state{width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--c-text-secondary);padding:40px 0}.dashboard-main>.empty-state{padding-top:calc(33vh - 120px)}.projects-grid>.empty-state{grid-column:1 / -1;min-height:300px}.empty-state h2{font-size:22px;margin-bottom:12px;background:linear-gradient(45deg,var(--c-primary),var(--c-secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.empty-state p{font-size:16px;line-height:1.5;margin-bottom:24px;max-width:400px}.empty-state .new-project-btn{font-size:18px;padding:12px 24px}@keyframes liquid-flow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.image-count-indicator{position:absolute;bottom:8px;left:8px;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:500;display:flex;align-items:center;gap:5px;z-index:1;pointer-events:none;opacity:0;transition:opacity .2s ease-in-out}.project-card:hover .image-count-indicator,.project-list-item:hover .image-count-indicator{opacity:1}.image-count-indicator svg{width:14px;height:14px}.preview-slider{position:absolute;bottom:0;left:0;right:0;height:4px;background-color:#ffffff40;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .2s ease-in-out,transform .2s ease-in-out}.project-card:hover .preview-slider{opacity:1;transform:translateY(0)}.preview-slider-progress{height:100%;background-color:var(--c-white);box-shadow:0 0 8px #ffffffb3;border-radius:2px;transition:width .05s linear}.project-list-item .image-count-indicator{bottom:4px;left:4px;padding:2px 5px;font-size:10px}.project-list-item .image-count-indicator svg{width:10px;height:10px}.project-list-item .preview-slider{display:none}.context-menu{position:fixed;background-color:var(--c-bg-panel-translucent);border-radius:8px;box-shadow:0 4px 20px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:1000;border:1px solid var(--c-glass-border);padding:6px;min-width:200px}.context-menu ul{list-style:none;margin:0;padding:0}.context-menu li{padding:8px 12px;font-size:14px;cursor:pointer;border-radius:4px;transition:background-color .1s ease-in-out;display:flex;align-items:center;gap:10px;color:var(--c-text)}.context-menu li:not(.disabled):hover{background-color:var(--c-primary-light);color:var(--c-primary-dark)}.context-menu li.liked-item:not(.disabled):hover{background-color:var(--c-secondary-light);color:var(--c-secondary-dark)}.context-menu li.disabled{color:var(--c-disabled);cursor:not-allowed;background-color:transparent!important}.context-menu li svg{width:18px;height:18px;fill:currentColor}.context-menu .separator{height:1px;background-color:var(--c-glass-border);margin:4px;padding:0}.context-menu li.has-submenu{position:relative}.context-menu .submenu{display:none;position:absolute;left:100%;top:-6px;background-color:var(--c-bg-panel-translucent);border-radius:8px;box-shadow:0 4px 20px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--c-glass-border);padding:6px;min-width:180px;list-style:none}.context-menu li.has-submenu:hover .submenu{display:block}#canvas{width:100%;height:100%;cursor:default;position:relative;overflow:hidden;background-image:linear-gradient(var(--c-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--c-grid-line) 1px,transparent 1px);background-size:20px 20px}#canvas-content{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}body.dragging-on-canvas .context-toolbar,body.dragging-on-canvas .combine-controls,body.dragging-on-canvas .filter-toolbar,body.dragging-on-canvas .toolbar{pointer-events:none}.selection-box{position:absolute;border:2px solid var(--c-secondary);background-color:rgba(var(--c-secondary-rgb),.25);border-radius:4px;z-index:200;pointer-events:none}.node{position:absolute;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:transform .1s ease-out,box-shadow .2s ease,border-color .2s ease;border:2px solid transparent;overflow:visible;backface-visibility:hidden}.node.dimmed .node-content-wrapper{opacity:.3}.node:hover .node-content-wrapper{box-shadow:0 8px 24px var(--c-shadow-color-medium),0 2px 6px var(--c-shadow-color-light)}.node.selected{border-color:var(--c-primary)}.node.selected .node-content-wrapper{box-shadow:0 0 0 3px var(--c-primary-light),0 8px 24px var(--c-shadow-color-medium)}.node.liked{border-color:rgba(var(--c-secondary-rgb),.6)}.node.liked .node-content-wrapper{box-shadow:0 0 0 4px rgba(var(--c-secondary-rgb),.3),0 8px 24px rgba(var(--c-secondary-rgb),.15)}.node-content-wrapper{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--c-glass-border);border-radius:8px;box-shadow:0 4px 12px var(--c-shadow-color-medium),0 1px 3px var(--c-shadow-color-light);transition:box-shadow .2s ease,opacity .2s ease,background-color .2s ease}.node.image-node .node-content-wrapper img,.node.object-node .node-content-wrapper img,.node.pose3d-node .node-content-wrapper img{width:100%;height:100%;object-fit:cover;pointer-events:none;border-radius:6px;image-rendering:high-quality}.node.text-node{border-color:transparent!important;height:auto!important}.node.text-node .node-content-wrapper{background-color:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-color:transparent;box-shadow:none;padding:10px;line-height:1.4;overflow:hidden;border-radius:8px;height:auto;align-items:flex-start}.node.text-node:hover:not(.selected) .node-content-wrapper{box-shadow:0 4px 12px var(--c-shadow-color-medium)}.text-content{width:100%;outline:none;overflow-wrap:break-word;word-break:break-word;pointer-events:none;white-space:pre-wrap}.node.text-node.editing{cursor:text;border:2px dashed var(--c-primary)!important}.node.text-node.editing .node-content-wrapper{background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--c-glass-border)}.node.text-node.editing .text-content{pointer-events:all}.node.background-node .node-content-wrapper{border-radius:12px}.node.background-node:hover .node-content-wrapper{box-shadow:0 8px 24px var(--c-shadow-color-medium),0 2px 6px var(--c-shadow-color-light)}.resize-handle{position:absolute;bottom:-9px;right:-9px;width:18px;height:18px;background-color:var(--c-primary);border:2px solid var(--c-bg-panel);border-radius:50%;cursor:nwse-resize;z-index:10;box-shadow:0 2px 8px var(--c-shadow-color-light);transform-origin:bottom right}.corner-controls{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:100}.settings-button,.fit-view-button,.back-button{pointer-events:all;position:absolute;width:44px;height:44px;background-color:var(--c-bg-panel-translucent);border:1px solid var(--c-glass-border);border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 4px 12px var(--c-shadow-color-medium);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transition:all .2s ease;color:var(--c-text-tertiary)}.settings-button{top:20px;right:20px}.back-button{top:20px;left:20px}.fit-view-button{bottom:20px;right:20px}.settings-button:hover,.fit-view-button:hover,.back-button:hover{transform:scale(1.1);box-shadow:0 6px 16px var(--c-shadow-color-medium);color:var(--c-primary);background-color:#fffc}body[data-theme=dark] .settings-button:hover,body[data-theme=dark] .fit-view-button:hover,body[data-theme=dark] .back-button:hover{background-color:#2a2d42cc}.settings-button:active,.fit-view-button:active,.back-button:active{transform:scale(1.05);background-color:var(--c-bg-panel)}.settings-button svg,.fit-view-button svg,.back-button svg{width:22px;height:22px}.loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;justify-content:center;align-items:center;z-index:1000;flex-direction:column;gap:40px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes combined-transform{0%{transform:rotate(0) scale(.8);box-shadow:0 0 5px #ffeb3b,0 0 15px #ffc107,0 0 30px #ffa000,0 0 40px #ffffe0}50%{transform:rotate(180deg) scale(1.1);box-shadow:0 0 10px #ffeb3b,0 0 35px #ffc107,0 0 60px #ffa000,0 0 80px #ffffe0}to{transform:rotate(360deg) scale(.8);box-shadow:0 0 5px #ffeb3b,0 0 15px #ffc107,0 0 30px #ffa000,0 0 40px #ffffe0}}@keyframes pulse-star{0%,to{clip-path:polygon(50% 0%,55% 45%,100% 50%,55% 55%,50% 100%,45% 55%,0% 50%,45% 45%)}50%{clip-path:polygon(50% -10%,60% 40%,110% 50%,60% 60%,50% 110%,40% 60%,-10% 50%,40% 40%)}}.loader-star{width:50px;height:50px;background-color:#ffffe0;clip-path:polygon(50% 0%,55% 45%,100% 50%,55% 55%,50% 100%,45% 55%,0% 50%,45% 45%);will-change:transform,clip-path;transform-origin:center;animation:combined-transform 1.5s linear infinite,pulse-star 1.5s ease-in-out infinite}.loader-overlay p{color:#fff;text-shadow:0 0 5px #FFC107;font-size:18px;font-weight:500}.welcome-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--c-text-secondary);max-width:450px;pointer-events:none}.welcome-message h1{font-size:24px;margin-bottom:10px;background:linear-gradient(45deg,var(--c-primary),var(--c-secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.welcome-message p{font-size:16px;line-height:1.5}.cropper-container{position:absolute;z-index:300}.cropper-image-bg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;object-fit:cover;border-radius:6px}.crop-box{position:absolute;cursor:move;box-shadow:0 0 0 9999px #0009;outline:1px solid rgba(255,255,255,.7)}.crop-handle{--handle-scale: 1;position:absolute}.crop-handle:before{content:"";position:absolute;background-color:var(--c-white);box-shadow:0 calc(1px * var(--handle-scale)) calc(2px * var(--handle-scale)) var(--c-shadow-color-light)}.crop-handle.tm,.crop-handle.bm{width:calc(50px * var(--handle-scale));height:calc(20px * var(--handle-scale));left:50%;transform:translate(-50%)}.crop-handle.tm{top:calc(-16px * var(--handle-scale));cursor:ns-resize}.crop-handle.bm{bottom:calc(-16px * var(--handle-scale));cursor:ns-resize}.crop-handle.tm:before,.crop-handle.bm:before{width:calc(25px * var(--handle-scale));height:calc(4px * var(--handle-scale));left:50%;top:50%;transform:translate(-50%,-50%);border-radius:calc(2px * var(--handle-scale))}.crop-handle.ml,.crop-handle.mr{width:calc(20px * var(--handle-scale));height:calc(50px * var(--handle-scale));top:50%;transform:translateY(-50%)}.crop-handle.ml{left:calc(-16px * var(--handle-scale));cursor:ew-resize}.crop-handle.mr{right:calc(-16px * var(--handle-scale));cursor:ew-resize}.crop-handle.ml:before,.crop-handle.mr:before{width:calc(4px * var(--handle-scale));height:calc(25px * var(--handle-scale));left:50%;top:50%;transform:translate(-50%,-50%);border-radius:calc(2px * var(--handle-scale))}.crop-handle.tl,.crop-handle.tr,.crop-handle.bl,.crop-handle.br{width:calc(24px * var(--handle-scale));height:calc(24px * var(--handle-scale))}.crop-handle.tl{top:calc(-12px * var(--handle-scale));left:calc(-12px * var(--handle-scale));cursor:nwse-resize}.crop-handle.tr{top:calc(-12px * var(--handle-scale));right:calc(-12px * var(--handle-scale));cursor:nesw-resize}.crop-handle.bl{bottom:calc(-12px * var(--handle-scale));left:calc(-12px * var(--handle-scale));cursor:nesw-resize}.crop-handle.br{bottom:calc(-12px * var(--handle-scale));right:calc(-12px * var(--handle-scale));cursor:nwse-resize}.crop-handle.tl:before,.crop-handle.tr:before,.crop-handle.bl:before,.crop-handle.br:before{width:calc(16px * var(--handle-scale));height:calc(16px * var(--handle-scale));border-color:var(--c-white);border-style:solid;background-color:transparent;box-shadow:none;filter:drop-shadow(0 calc(1px * var(--handle-scale)) calc(1px * var(--handle-scale)) rgba(0,0,0,.3));border-width:0;left:50%;top:50%;transform:translate(-50%,-50%)}.crop-handle.tl:before{border-top-width:calc(4px * var(--handle-scale));border-left-width:calc(4px * var(--handle-scale))}.crop-handle.tr:before{border-top-width:calc(4px * var(--handle-scale));border-right-width:calc(4px * var(--handle-scale))}.crop-handle.bl:before{border-bottom-width:calc(4px * var(--handle-scale));border-left-width:calc(4px * var(--handle-scale))}.crop-handle.br:before{border-bottom-width:calc(4px * var(--handle-scale));border-right-width:calc(4px * var(--handle-scale))}.cropper-actions{--handle-scale: 1;position:absolute;top:100%;margin-top:calc(15px * var(--handle-scale));left:50%;transform-origin:top center;transform:translate(-50%) scale(var(--handle-scale));display:flex;gap:12px;background-color:var(--c-bg-panel-translucent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:10px;border-radius:10px;box-shadow:0 2px 10px var(--c-shadow-color-light);border:1px solid var(--c-glass-border)}.cropper-actions button{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.cropper-actions button.confirm{background-color:var(--c-primary);color:var(--c-text-on-accent)}.cropper-actions button.confirm:hover{background-color:var(--c-primary-dark)}.cropper-actions button.cancel{background-color:var(--c-secondary);color:var(--c-text-on-accent)}.cropper-actions button.cancel:hover{background-color:var(--c-secondary-dark)}.cropper-actions svg{width:20px;height:20px}.pose-editor-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1200;display:flex;justify-content:center;align-items:center}.pose-editor-content{width:90vw;height:90vh;max-width:1400px;background-color:var(--c-bg-panel);border-radius:16px;box-shadow:0 8px 32px var(--c-shadow-color-medium);border:1px solid var(--c-glass-border);display:flex;flex-direction:column;overflow:hidden}.pose-editor-header{padding:12px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--c-glass-border);flex-shrink:0}.pose-editor-header h2{font-size:18px;font-weight:600}.pose-editor-header .close-button{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--c-text-secondary);padding:0 4px}.pose-editor-header .close-button:hover{color:var(--c-text)}.pose-editor-main{display:flex;flex-grow:1;overflow:hidden}.pose-editor-canvas-wrapper{flex-grow:1;position:relative;background-color:#2c2c2c;display:flex;justify-content:center;align-items:center;color:var(--c-text-tertiary)}.pose-editor-sidebar{width:280px;flex-shrink:0;border-left:1px solid var(--c-glass-border);display:flex;flex-direction:column}.pose-editor-sidebar-content{flex-grow:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:16px}.pose-editor-sidebar h3{padding:12px 16px;font-size:14px;font-weight:600;border-bottom:1px solid var(--c-glass-border);flex-shrink:0;margin:0 -8px 8px}.joints-list{flex-grow:1;overflow-y:auto}.joint-button{width:100%;padding:8px 12px;text-align:left;background:none;border:none;border-radius:4px;color:var(--c-text);cursor:pointer;font-size:14px;transition:background-color .1s ease-in-out}.joint-button:hover{background-color:var(--c-bg-hover)}.joint-button.selected{background-color:var(--c-primary);color:var(--c-text-on-accent);font-weight:500}.pose-editor-footer{padding:12px;border-top:1px solid var(--c-glass-border);display:flex;align-items:center;gap:10px;background-color:var(--c-bg-input)}.pose-editor-footer input{flex-grow:1;padding:8px 12px;border:1px solid var(--c-glass-border);background-color:var(--c-bg-input-secondary);color:var(--c-text);border-radius:8px;font-size:14px;outline:none}.pose-editor-footer input:focus{border-color:var(--c-secondary)}.pose-editor-footer button{padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.pose-editor-footer .generate-btn{background-color:var(--c-secondary);color:var(--c-text-on-accent)}.pose-editor-footer .generate-btn:hover{background-color:var(--c-secondary-dark)}.pose-editor-footer .save-btn{background-color:var(--c-primary);color:var(--c-text-on-accent)}.pose-editor-footer .save-btn:hover{background-color:var(--c-primary-dark)}.pose-editor-footer button:disabled{background-color:var(--c-disabled);cursor:not-allowed}.pose-camera-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:8px;background-color:var(--c-bg-panel-translucent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:8px;border-radius:10px;border:1px solid var(--c-glass-border)}.pose-camera-controls button{background-color:var(--c-bg-input-secondary);border:1px solid var(--c-glass-border);color:var(--c-text);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.pose-camera-controls button:hover:not(:disabled){background-color:var(--c-bg-hover);border-color:var(--c-border)}.pose-camera-controls button.active{background-color:var(--c-secondary);color:var(--c-text-on-accent);border-color:transparent}.pose-camera-controls button:disabled{opacity:.4;cursor:not-allowed}.pose-library-tabs{display:flex;border-bottom:1px solid var(--c-glass-border);margin:0 -8px;padding:0 8px}.pose-library-tab{padding:8px 12px;background:none;border:none;color:var(--c-text-secondary);cursor:pointer;font-size:14px;position:relative;font-weight:500}.pose-library-tab.active{color:var(--c-primary)}.pose-library-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background-color:var(--c-primary)}.pose-library-content{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.pose-item button{width:100%;background-color:var(--c-bg-input-secondary);border:1px solid var(--c-glass-border);border-radius:8px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .2s;color:var(--c-text)}.pose-item button:hover{background-color:var(--c-bg-hover);border-color:var(--c-border)}.pose-item img{width:64px;height:64px;border-radius:4px;background-color:#444}.pose-item span{font-size:13px;white-space:nowrap}.save-pose-button{margin-top:12px;padding:8px 12px;width:100%;background-color:var(--c-primary-light);color:var(--c-primary-dark);font-weight:500;border:1px solid var(--c-primary);border-radius:8px;cursor:pointer}.save-pose-button:hover{background-color:var(--c-primary);color:var(--c-text-on-accent)}.no-custom-poses{grid-column:1 / -1;text-align:center;color:var(--c-text-secondary);font-size:13px;padding:20px 0}.joints-list.accordion{display:flex;flex-direction:column;gap:4px;flex-grow:1;overflow-y:auto}.joint-group{border-radius:6px;background-color:var(--c-bg-input);overflow:hidden;border:1px solid var(--c-glass-border)}.joint-group-header{width:100%;padding:10px 12px;text-align:left;background-color:transparent;border:none;color:var(--c-text);cursor:pointer;font-size:15px;font-weight:600;display:flex;justify-content:space-between;align-items:center;transition:background-color .1s ease-in-out}.joint-group-header:hover{background-color:var(--c-bg-hover)}.joint-group-header .chevron{transition:transform .2s ease-in-out;font-size:12px}.joint-group-header .chevron.expanded{transform:rotate(180deg)}.joint-group-content{padding:4px 8px 8px;background-color:var(--c-bg-input-secondary);border-top:1px solid var(--c-glass-border)}.joint-group-content .joint-button{padding:6px 12px;font-size:13px}.landing-page{width:100%;min-height:100vh;overflow-x:hidden;overflow-y:auto;position:relative}.landing-hero{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:40px 20px 80px 40%;position:relative;overflow:hidden}.logo-ARTOVA{font-size:80px;font-weight:700;font-family:Gowun Dodum,sans-serif;background:linear-gradient(110deg,rgba(var(--c-secondary-rgb),1),rgba(var(--c-primary-rgb),1) 45%,rgba(var(--c-accent-rgb),1) 60%,rgba(var(--c-secondary-rgb),1));background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:liquid-flow 4s ease-in-out infinite,logo-appear .8s ease-out;text-shadow:0 0 60px rgba(var(--c-accent-rgb),.6);margin-bottom:16px;position:relative;z-index:10;letter-spacing:2px}@keyframes logo-appear{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.slogan-container{margin-bottom:32px;animation:slogan-appear .8s ease-out .5s backwards;position:relative;z-index:10}.slogan-main{font-size:36px;font-weight:700;color:var(--c-text);margin-bottom:12px;line-height:1.3}.slogan-sub{font-size:24px;color:var(--c-text-secondary);line-height:1.5;max-width:500px;margin:0 auto}@keyframes slogan-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.peacock-container{position:absolute;width:100%;max-width:1400px;height:600px;top:50%;left:10%;transform:translateY(-50%);display:flex;justify-content:center;align-items:center;opacity:.9;pointer-events:none;z-index:1}.peacock-image{position:absolute;width:200px;height:280px;left:50%;top:50%;transform-origin:center center;animation:peacock-unfold .8s cubic-bezier(.34,1.56,.64,1) var(--delay) backwards,peacock-float 3s ease-in-out infinite;animation-delay:var(--delay),calc(var(--delay) + .8s);transition:transform .3s ease,left .3s ease,top .3s ease;z-index:1;pointer-events:auto;cursor:pointer}.peacock-image.dragged{animation:none;transition:none;transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(0) scale(1)}.peacock-image.deck-card{animation:none!important;transform:translate(-50%,-50%) rotate(180deg) scale(1)!important;z-index:10}@keyframes peacock-unfold{0%{transform:translate(-50%,-50%) rotate(180deg) scale(1);opacity:1}to{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--angle)) scale(1);opacity:1}}@keyframes peacock-float{0%,to{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--angle)) scale(1) translateY(0)}50%{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--angle)) scale(1) translateY(-10px)}}.peacock-image:hover{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--angle)) scale(1.1)!important;z-index:100;filter:brightness(1.15)}.peacock-image.deck-card:hover{transform:translate(-50%,-50%) rotate(180deg) scale(1.1)!important}.peacock-image:hover .image-placeholder{border-color:var(--c-primary);box-shadow:0 12px 50px rgba(var(--c-primary-rgb),.4)}.image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--color),transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--c-glass-border);border-radius:12px;display:flex;flex-direction:column;justify-content:center;align-items:center;box-shadow:0 4px 16px #0003;position:relative;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none}.image-placeholder:active{cursor:grabbing}.image-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-bg-panel-translucent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:.6}.image-placeholder img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;border-radius:12px;z-index:0;transform:rotate(180deg)}.image-placeholder img.dragged-img{transform:rotate(0)}.placeholder-icon{font-size:48px;position:relative;z-index:1;opacity:.8;animation:icon-pulse 2s ease-in-out infinite;pointer-events:none}@keyframes icon-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.cta-button{padding:20px 60px;font-size:22px;font-weight:600;background:#fff;color:#1f1f1f;border:none;border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 12px 40px #00000040;transition:all .3s cubic-bezier(.34,1.56,.64,1);animation:cta-appear .8s ease-out 1.5s backwards,cta-pulse 2s ease-in-out 3s infinite;position:relative;z-index:100;margin-top:24px}.cta-button:hover{transform:translateY(-5px) scale(1.08);box-shadow:0 20px 60px #00000059}.cta-button:active{transform:translateY(-2px) scale(1.05)}@keyframes cta-pulse{0%,to{box-shadow:0 12px 40px #00000040}50%{box-shadow:0 12px 40px rgba(var(--c-primary-rgb),.4)}}.cta-button.secondary{background:#fff;color:#1f1f1f;border:none;box-shadow:0 4px 12px #00000026}.cta-button.secondary:hover{box-shadow:0 8px 24px #00000040}.cta-icon{font-size:24px}@keyframes cta-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--c-text-tertiary);font-size:14px;animation:scroll-bounce 2s ease-in-out infinite;opacity:.5;transition:opacity .3s ease;cursor:pointer;z-index:100}.scroll-indicator:hover{opacity:1}.scroll-arrow{font-size:24px;animation:arrow-bounce 1.5s ease-in-out infinite}@keyframes scroll-bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-10px)}}@keyframes arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.landing-features{min-height:100vh;padding:120px 40px;display:flex;flex-direction:column;align-items:center;position:relative}.section-title{font-size:48px;font-weight:700;color:var(--c-text);margin-bottom:80px;text-align:center;background:linear-gradient(45deg,var(--c-primary),var(--c-secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;max-width:1200px;width:100%;margin-bottom:100px}.feature-card{padding:48px 32px;background:var(--c-bg-panel-translucent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--c-glass-border);border-radius:24px;text-align:center;transition:all .3s ease;box-shadow:0 4px 20px var(--c-shadow-color-light)}.feature-card:hover{transform:translateY(-10px);box-shadow:0 15px 40px var(--c-shadow-color-medium);border-color:var(--c-primary)}.feature-icon{font-size:64px;margin-bottom:24px;display:inline-block;animation:icon-float 3s ease-in-out infinite}.feature-card:nth-child(1) .feature-icon{animation-delay:0s}.feature-card:nth-child(2) .feature-icon{animation-delay:.5s}.feature-card:nth-child(3) .feature-icon{animation-delay:1s}@keyframes icon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.feature-card h3{font-size:24px;font-weight:600;color:var(--c-text);margin-bottom:16px}.feature-card p{font-size:16px;line-height:1.6;color:var(--c-text-secondary)}.back-to-top-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--c-text-tertiary);font-size:14px;margin-bottom:40px;cursor:pointer;opacity:.7;transition:opacity .3s ease}.back-to-top-indicator:hover{opacity:1}.back-to-top-indicator .back-arrow{font-size:24px;animation:arrow-float 1.5s ease-in-out infinite}@keyframes arrow-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.final-cta{text-align:center;padding:60px 40px;background:var(--c-bg-panel-translucent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid var(--c-glass-border);border-radius:32px;max-width:800px;box-shadow:0 10px 40px var(--c-shadow-color-medium);display:flex;flex-direction:column;align-items:center}.final-cta h3{font-size:32px;font-weight:700;color:var(--c-text);margin-bottom:32px}.final-cta .cta-button{margin:0}@media(max-width:1200px){.landing-hero{padding-right:10%}.peacock-container{height:500px;left:5%;opacity:.8}.peacock-image{width:160px;height:220px}}@media(max-width:768px){.landing-hero{padding:40px 20px 80px}.logo-ARTOVA{font-size:56px}.slogan-main{font-size:28px}.slogan-sub{font-size:16px}.peacock-container{height:350px;left:0%;transform:translate(-20%,-50%);opacity:.6}.peacock-image{width:120px;height:170px}.placeholder-icon{font-size:36px}.cta-button{padding:16px 40px;font-size:18px}.section-title{font-size:32px;margin-bottom:60px}.features-grid{grid-template-columns:1fr;gap:24px}.feature-card{padding:32px 24px}.final-cta h3{font-size:24px}.landing-features{padding:80px 20px}}@media(max-width:480px){.logo-ARTOVA{font-size:42px}.slogan-main{font-size:22px}.peacock-container{height:250px;left:0%;transform:translate(-30%,-50%);opacity:.5}.peacock-image{width:80px;height:110px}.placeholder-icon{font-size:28px}.back-to-top-indicator{margin-bottom:30px}.cta-button{padding:14px 32px;font-size:16px}}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.auth-modal{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:400px;position:relative;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:.25rem;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f3f4f6}.auth-form h2{margin:0 0 1.5rem;text-align:center;color:#1f2937;font-size:1.5rem;font-weight:600}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#374151;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background-color:#f9fafb;cursor:not-allowed}.error-message{color:#dc2626;font-size:.875rem;margin-bottom:1rem;padding:.5rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:4px}.primary-button{width:100%;padding:.75rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-bottom:1rem}.primary-button:hover:not(:disabled){background-color:#2563eb}.primary-button:disabled{background-color:#9ca3af;cursor:not-allowed}.divider{text-align:center;margin:1rem 0;position:relative}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#e5e7eb}.divider span{background:#fff;padding:0 1rem;color:#6b7280;font-size:.875rem}.google-button{width:100%;padding:.75rem;background-color:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,border-color .2s;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.google-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.google-button:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.auth-switch{text-align:center;margin-top:1rem;color:#6b7280;font-size:.875rem}.link-button{background:none;border:none;color:#3b82f6;cursor:pointer;text-decoration:underline;font-size:inherit}.link-button:hover{color:#2563eb}.google-signin{text-align:center;padding:1rem 0}.google-signin-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.google-logo{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a}.google-signin h2{margin:0;color:#1f2937;font-size:1.5rem;font-weight:600}.google-signin p{margin:0;color:#6b7280;font-size:.875rem}.google-signin-button{display:flex;align-items:center;justify-content:center;width:100%;padding:.75rem 1rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.google-signin-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;box-shadow:0 2px 6px #00000026}.google-signin-button:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}
