@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&family=Pretendard:wght@400;500;600;700&display=swap";:root{--cream: #FAF8F5;--cream-dark: #F5F1EB;--warm-white: #FFFEFB;--charcoal: #2D2926;--charcoal-light: #4A4543;--stone: #8B8582;--stone-light: #B5B0AC;--copper: #C17F59;--copper-dark: #A66B47;--copper-glow: rgba(193, 127, 89, .15);--sage: #7A8B7A;--sage-light: rgba(122, 139, 122, .12);--ink: #1A1918;--paper: #FDFCFA;--primary: var(--copper);--primary-dark: var(--copper-dark);--text-primary: var(--charcoal);--text-secondary: var(--stone);--text-muted: var(--stone-light);--bg-body: var(--cream);--bg-card: var(--warm-white);--bg-elevated: var(--paper);--border-subtle: rgba(45, 41, 38, .06);--border-light: rgba(45, 41, 38, .1);--border-medium: rgba(45, 41, 38, .15);--shadow-sm: 0 1px 3px rgba(45, 41, 38, .04), 0 1px 2px rgba(45, 41, 38, .06);--shadow-md: 0 4px 12px rgba(45, 41, 38, .06), 0 2px 4px rgba(45, 41, 38, .04);--shadow-lg: 0 12px 40px rgba(45, 41, 38, .08), 0 4px 12px rgba(45, 41, 38, .04);--shadow-xl: 0 24px 60px rgba(45, 41, 38, .1), 0 8px 20px rgba(45, 41, 38, .06);--shadow-glow: 0 0 0 3px var(--copper-glow);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--font-display: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono: "IBM Plex Mono", "SF Mono", Consolas, monospace;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-body);line-height:1.6;min-width:1024px;position:relative}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.02;pointer-events:none;z-index:0}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--cream-dark)}::-webkit-scrollbar-thumb{background:var(--stone-light);border-radius:5px;border:2px solid var(--cream-dark)}::-webkit-scrollbar-thumb:hover{background:var(--stone)}::selection{background:var(--copper-glow);color:var(--charcoal)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner--dark{border-color:var(--border-light);border-top-color:var(--copper)}@keyframes spin{to{transform:rotate(360deg)}}:focus-visible{outline:2px solid var(--copper);outline-offset:2px}button:focus:not(:focus-visible){outline:none}a{color:var(--copper);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--copper-dark);text-decoration:underline}.font-display{font-family:var(--font-display)}.font-body,button{font-family:var(--font-body)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pencilSketch{0%{stroke-dashoffset:1000}to{stroke-dashoffset:0}}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:#ffffffb3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.06);position:sticky;top:0;z-index:100}.header__brand{display:flex;align-items:center;gap:14px}.header__logo{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;box-shadow:0 4px 12px #667eea4d}.header__text{display:flex;flex-direction:column;gap:2px}.header__title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.5px}.header__subtitle{font-size:12px;color:var(--text-secondary);font-weight:500}.header__actions{display:flex;align-items:center;gap:12px}.header__key-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:12px;font-family:SF Mono,Fira Code,monospace;font-weight:500}.header__key-badge--active{background:#10b9811a;color:#065f46;border:1px solid rgba(16,185,129,.2)}.header__key-badge--inactive{background:#ef444414;color:#dc2626;border:1px solid rgba(239,68,68,.15)}.header__settings-btn{background:#0000000a;border:1px solid rgba(0,0,0,.08);border-radius:10px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all .2s}.header__settings-btn:hover{background:#00000014;transform:rotate(45deg)}.toast{position:fixed;top:24px;right:24px;z-index:1000;display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:12px;font-size:14px;font-weight:500;box-shadow:0 8px 32px #0000001f;animation:toast-slide-in .35s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);max-width:420px}.toast--success{background:#10b9811f;border:1px solid rgba(16,185,129,.3);color:#065f46}.toast--warning{background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);color:#92400e}.toast--error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#991b1b}.toast__icon{font-size:18px;flex-shrink:0}.toast__msg{flex:1;line-height:1.4}.toast__close{background:none;border:none;font-size:18px;cursor:pointer;opacity:.5;padding:0 2px;color:inherit;transition:opacity .2s}.toast__close:hover{opacity:1}@keyframes toast-slide-in{0%{opacity:0;transform:translate(40px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.mode-sel{display:flex;flex-direction:column;gap:8px}.mode-sel__label{font-size:13px;font-weight:600;color:var(--text-primary)}.mode-sel__tabs{display:flex;gap:8px;background:#00000008;border-radius:12px;padding:4px}.mode-sel__tab{flex:1;padding:10px 16px;border-radius:10px;border:none;background:transparent;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;color:var(--text-secondary)}.mode-sel__tab--active{background:#fff;color:var(--text-primary);box-shadow:0 2px 8px #00000014}.mode-sel__tab:disabled{opacity:.5;cursor:not-allowed}.style-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.style-selector__btn{padding:.5rem 1rem;border:2px solid rgba(0,0,0,.08);background:#ffffff80;color:var(--text-secondary);border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1 1 calc(33.333% - .5rem);min-width:80px}.style-selector__btn:hover:not(:disabled){border-color:var(--primary, #667eea);color:var(--primary, #667eea);transform:translateY(-1px)}.style-selector__btn.active{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important;border-color:#667eea!important;box-shadow:0 4px 12px #667eea4d}.style-selector__btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.diff-slider{display:flex;flex-direction:column;gap:8px}.diff-slider__label{font-size:13px;font-weight:600;color:var(--text-primary)}.diff-slider__options{display:flex;gap:8px}.diff-slider__btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border-radius:12px;border:1.5px solid rgba(0,0,0,.08);background:#ffffff80;cursor:pointer;transition:all .2s}.diff-slider__btn:hover:not(:disabled){border-color:var(--primary);background:#667eea0a}.diff-slider__btn--active{border-color:var(--primary);background:#667eea14;box-shadow:0 2px 8px #667eea26}.diff-slider__btn:disabled{opacity:.5;cursor:not-allowed}.diff-slider__icon{font-size:20px}.diff-slider__name{font-size:13px;font-weight:600;color:var(--text-primary)}.diff-slider__desc{font-size:11px;color:var(--text-secondary);text-align:center;line-height:1.3}.orient-sel{display:flex;flex-direction:column;gap:10px}.orient-sel__label{font-size:13px;font-weight:600;color:var(--text-primary)}.orient-sel__options{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.orient-sel__btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border-radius:14px;border:2px solid rgba(0,0,0,.08);background:#ffffff80;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.orient-sel__btn:hover:not(:disabled){border-color:#667eea4d;background:#fffc;transform:translateY(-2px)}.orient-sel__btn--active{border-color:var(--primary);background:linear-gradient(135deg,#667eea14,#764ba214);box-shadow:0 4px 16px #667eea33}.orient-sel__btn--active .orient-sel__preview{background:linear-gradient(135deg,#667eea,#764ba2)}.orient-sel__btn--active .orient-sel__preview-inner{color:#fff}.orient-sel__btn:disabled{opacity:.5;cursor:not-allowed}.orient-sel__preview{width:64px;height:64px;border-radius:10px;background:#0000000a;display:flex;align-items:center;justify-content:center;transition:all .25s}.orient-sel__preview-inner{color:var(--text-secondary);transition:color .25s}.orient-sel__icon{width:36px;height:36px}.orient-sel__name{font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:.3px}.orient-sel__desc{font-size:11px;color:var(--text-secondary);text-align:center;line-height:1.3}.paper-sel{display:flex;flex-direction:column;gap:10px}.paper-sel__label{font-size:13px;font-weight:600;color:var(--text-primary)}.paper-sel__groups{display:flex;flex-direction:column;gap:12px}.paper-sel__group{display:flex;flex-direction:column;gap:6px}.paper-sel__group-label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.paper-sel__options{display:flex;gap:6px;flex-wrap:wrap}.paper-sel__btn{padding:8px 14px;border-radius:8px;border:1.5px solid rgba(0,0,0,.08);background:#ffffff80;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.paper-sel__btn:hover:not(:disabled){border-color:#667eea4d;background:#fffc;transform:translateY(-1px)}.paper-sel__btn--active{border-color:var(--primary);background:linear-gradient(135deg,#667eea1a,#764ba21a);color:var(--primary);box-shadow:0 2px 8px #667eea33}.paper-sel__btn:disabled{opacity:.5;cursor:not-allowed}.paper-sel__info{display:flex;align-items:center;justify-content:center;padding:8px 12px;background:#00000008;border-radius:8px}.paper-sel__dimensions{font-size:12px;font-weight:500;color:var(--text-secondary)}.grid-sel{display:flex;flex-direction:column;gap:10px}.grid-sel__label{font-size:13px;font-weight:600;color:var(--text-primary)}.grid-sel__row{display:flex;align-items:flex-end;gap:12px}.grid-sel__field{display:flex;flex-direction:column;gap:4px;flex:1}.grid-sel__dim{font-size:12px;color:var(--text-secondary);font-weight:500}.grid-sel__select{padding:10px 14px;border-radius:10px;border:1.5px solid rgba(0,0,0,.1);font-size:14px;font-weight:600;background:#fff9;cursor:pointer;outline:none;transition:border-color .2s}.grid-sel__select:focus{border-color:var(--primary)}.grid-sel__select:disabled{opacity:.5;cursor:not-allowed}.grid-sel__x{font-size:18px;font-weight:700;color:var(--text-secondary);padding-bottom:10px}.grid-sel__preview{display:flex;align-items:center;gap:16px;padding:12px;background:#00000005;border-radius:12px}.grid-sel__grid{display:grid;width:80px;border:2px solid var(--primary);border-radius:4px;overflow:hidden;flex-shrink:0}.grid-sel__cell{border:.5px dashed rgba(102,126,234,.3);min-height:12px}.grid-sel__info{font-size:13px;color:var(--text-secondary);font-weight:500}.mandala-presets{display:flex;flex-direction:column;gap:8px}.mandala-presets__label{font-size:13px;font-weight:600;color:var(--text-primary)}.mandala-presets__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.mandala-presets__chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border-radius:12px;border:1.5px solid rgba(0,0,0,.08);background:#ffffff80;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.mandala-presets__chip:hover:not(:disabled){border-color:var(--primary);background:#667eea0d}.mandala-presets__chip--active{border-color:var(--primary);background:#667eea14;color:var(--primary);box-shadow:0 2px 8px #667eea26}.mandala-presets__chip:disabled{opacity:.5;cursor:not-allowed}.mandala-presets__icon{font-size:22px}.gen-count{display:flex;flex-direction:column;gap:10px}.gen-count__label{font-size:13px;font-weight:600;color:var(--text-primary)}.gen-count__options{display:flex;gap:8px}.gen-count__btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:12px 8px;border-radius:12px;border:2px solid rgba(0,0,0,.08);background:#ffffff80;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.gen-count__btn:hover:not(:disabled){border-color:#667eea4d;background:#fffc;transform:translateY(-2px)}.gen-count__btn--active{border-color:var(--primary);background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 4px 12px #667eea33}.gen-count__btn--active .gen-count__number{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gen-count__btn:disabled{opacity:.5;cursor:not-allowed}.gen-count__number{font-size:24px;font-weight:800;color:var(--text-primary);line-height:1}.gen-count__unit{font-size:11px;font-weight:500;color:var(--text-secondary)}.gen-count__hint{font-size:11px;color:var(--text-secondary);margin:0;text-align:center}.gen-form{display:flex;flex-direction:column;gap:24px;background:#ffffffb3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;padding:28px;border:1px solid rgba(0,0,0,.05);box-shadow:0 4px 20px #0000000a}.gen-form__title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}.gen-form__field{display:flex;flex-direction:column;gap:8px}.gen-form__label{font-size:13px;font-weight:600;color:var(--text-primary)}.gen-form__input{padding:12px 16px;border:1.5px solid rgba(0,0,0,.1);border-radius:12px;font-size:14px;background:#fff9;transition:all .2s;outline:none}.gen-form__input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #667eea1f}.gen-form__input:disabled{opacity:.5;cursor:not-allowed}.gen-form__submit{padding:14px 24px;border-radius:14px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.3px}.gen-form__submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.gen-form__submit:active:not(:disabled){transform:translateY(0)}.gen-form__submit:disabled{opacity:.5;cursor:not-allowed}.gen-form__font-selector{display:flex;gap:8px}.gen-form__font-btn{flex:1;padding:10px 16px;border:1.5px solid rgba(0,0,0,.1);border-radius:12px;background:#fff9;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s}.gen-form__font-btn:hover:not(:disabled){border-color:var(--primary);background:#667eea0f}.gen-form__font-btn--active{border-color:var(--primary);background:linear-gradient(135deg,#667eea1f,#764ba21f);color:var(--primary)}.gen-form__font-btn:disabled{opacity:.5;cursor:not-allowed}.canvas-preview{width:100%}.canvas-preview__container{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(0,0,0,.06);background:#fff;animation:canvas-fade-in .5s ease}@keyframes canvas-fade-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.canvas-preview__image{display:block;width:100%;height:100%;object-fit:cover}.canvas-preview__info{margin-top:12px;text-align:center;font-size:13px;font-weight:500;color:var(--text-secondary)}.canvas-preview__overlay{position:absolute;inset:0;pointer-events:none}.canvas-preview__guide{position:absolute}.canvas-preview__guide--v{top:0;bottom:0;width:2px;background:repeating-linear-gradient(to bottom,rgba(239,68,68,.6) 0,rgba(239,68,68,.6) 6px,transparent 6px,transparent 12px)}.canvas-preview__guide--h{left:0;right:0;height:2px;background:repeating-linear-gradient(to right,rgba(239,68,68,.6) 0,rgba(239,68,68,.6) 6px,transparent 6px,transparent 12px)}.skeleton{width:100%}.skeleton__box{position:relative;border-radius:16px;overflow:hidden;background:#ffffffb3;border:1px solid rgba(0,0,0,.06);min-height:300px;display:flex;align-items:center;justify-content:center}.skeleton__pulse{position:absolute;inset:0;background:linear-gradient(110deg,#00000005,#0000000a 40%,#00000005 60%,#0000000a);background-size:200% 100%;animation:skeleton-pulse 1.8s ease-in-out infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:12px}.skeleton__icon{font-size:48px;animation:skeleton-bounce 1.2s ease-in-out infinite}@keyframes skeleton-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.skeleton__text{font-size:15px;font-weight:600;color:var(--text-secondary);margin:0;animation:skeleton-text-in .4s ease}@keyframes skeleton-text-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.skeleton__progress{font-size:13px;font-weight:700;color:var(--primary);margin:0;padding:6px 14px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:20px}.quick-edit{display:flex;flex-direction:column;gap:12px}.quick-edit__warning{font-size:12px;font-weight:600;color:#dc2626;background:#ef44440f;padding:8px 14px;border-radius:10px;border:1px solid rgba(239,68,68,.12);text-align:center}.quick-edit__chips{display:flex;flex-wrap:wrap;gap:8px}.quick-edit__chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;border:1.5px solid rgba(0,0,0,.08);background:#ffffffb3;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:var(--text-primary)}.quick-edit__chip:hover:not(:disabled){border-color:var(--primary);background:#667eea0f;transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.quick-edit__chip:disabled{opacity:.4;cursor:not-allowed}.history{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff9;border-radius:14px;border:1px solid rgba(0,0,0,.05)}.history__info{display:flex;align-items:center;gap:10px}.history__dots{display:flex;gap:5px}.history__dot{width:8px;height:8px;border-radius:50%;background:#0000001a;transition:background .3s}.history__dot--filled{background:var(--primary);box-shadow:0 0 6px #667eea66}.history__label{font-size:13px;font-weight:500;color:var(--text-secondary)}.history__undo-btn{padding:8px 16px;border-radius:10px;border:1.5px solid rgba(0,0,0,.1);background:#fff9;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;color:var(--text-primary)}.history__undo-btn:hover:not(:disabled){border-color:var(--primary);background:#667eea0f}.history__undo-btn:disabled{opacity:.4;cursor:not-allowed}.export-panel{background:#ffffffb3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;padding:24px;border:1px solid rgba(0,0,0,.05);box-shadow:0 4px 20px #0000000a}.export-panel__title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 14px}.export-panel__buttons{display:flex;flex-direction:column;gap:8px}.export-panel__btn{padding:12px 16px;border-radius:12px;border:1.5px solid rgba(0,0,0,.08);background:#fff9;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;color:var(--text-primary)}.export-panel__btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.export-panel__btn:disabled{opacity:.5;cursor:not-allowed}.export-panel__btn--pdf{background:linear-gradient(135deg,#ef444414,#ef44440a);border-color:#ef444426}.export-panel__btn--pdf:hover:not(:disabled){border-color:#ef44444d}.export-panel__btn--svg{background:linear-gradient(135deg,#10b98114,#10b9810a);border-color:#10b98126}.export-panel__btn--svg:hover:not(:disabled){border-color:#10b9814d}.spinner--sm{width:14px;height:14px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--text-primary);border-radius:50%;animation:spin .6s linear infinite}.gallery{display:flex;flex-direction:column;gap:20px}.gallery--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#ffffff80;border-radius:20px;text-align:center}.gallery__empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.gallery--empty h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.gallery--empty p{font-size:14px;color:var(--text-secondary);margin:0}.gallery__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.gallery__title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}.gallery__count{font-size:14px;font-weight:500;color:var(--text-secondary)}.gallery__actions{display:flex;gap:8px;flex-wrap:wrap}.gallery__action-btn{padding:8px 14px;border-radius:10px;border:1.5px solid rgba(0,0,0,.1);background:#fffc;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s}.gallery__action-btn:hover:not(:disabled){background:#fff;border-color:#00000026;transform:translateY(-1px)}.gallery__action-btn:disabled{opacity:.4;cursor:not-allowed}.gallery__action-btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.gallery__action-btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd6,#6a4190);border-color:transparent;box-shadow:0 4px 12px #667eea4d}.gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.gallery__item{position:relative;background:#fff;border-radius:14px;overflow:hidden;border:2px solid transparent;box-shadow:0 2px 12px #0000000f;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer}.gallery__item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.gallery__item--selected{border-color:var(--primary);box-shadow:0 4px 16px #667eea4d}.gallery__checkbox{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:6px;background:#ffffffe6;border:2px solid rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;z-index:2}.gallery__checkbox:hover{border-color:var(--primary)}.gallery__item--selected .gallery__checkbox{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent}.gallery__thumbnail{width:100%;aspect-ratio:1;object-fit:cover;display:block}.gallery__item-info{padding:10px 12px;display:flex;justify-content:space-between;align-items:center;background:#00000005}.gallery__item-mode{font-size:12px;font-weight:600;color:var(--text-primary)}.gallery__item-time{font-size:11px;color:var(--text-secondary)}.app{min-height:100vh;position:relative;z-index:1}.workspace{display:grid;grid-template-columns:400px 1fr;gap:32px;padding:32px 40px;max-width:1480px;margin:0 auto;min-height:calc(100vh - 72px)}.workspace__sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:104px;align-self:start}.workspace__canvas{display:flex;flex-direction:column;gap:20px}.workspace__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:480px;background:var(--bg-card);border-radius:var(--radius-xl);border:2px dashed var(--border-light);text-align:center;padding:60px 48px;animation:fadeIn .5s ease}.workspace__empty-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--cream-dark);border-radius:50%;margin-bottom:24px;position:relative}.workspace__empty-icon:before{content:"";position:absolute;inset:-4px;border:2px dashed var(--border-light);border-radius:50%;animation:spin 20s linear infinite}.workspace__empty-icon svg{width:36px;height:36px;color:var(--stone)}.workspace__empty h2{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px;letter-spacing:-.02em}.workspace__empty p{font-size:15px;color:var(--text-secondary);line-height:1.7;margin:0}.workspace__actions{display:flex;flex-direction:column;gap:16px}.key-modal-overlay{position:fixed;inset:0;background:#2d292680;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;animation:fadeIn .2s ease}.key-modal{background:var(--bg-card);border-radius:var(--radius-xl);max-width:520px;width:100%;box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn .3s ease}.key-modal .onboarding{min-height:auto;background:none;padding:0}.key-modal .onboarding__card{box-shadow:none;border:none;border-radius:0;background:transparent}.key-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--border-subtle)}.key-modal__header h2{font-family:var(--font-display);font-size:20px;font-weight:600;margin:0;color:var(--text-primary)}.key-modal__close{background:none;border:none;font-size:24px;cursor:pointer;opacity:.4;transition:all var(--transition-fast);padding:4px;color:var(--text-primary);line-height:1}.key-modal__close:hover{opacity:1;transform:rotate(90deg)}.key-modal__logout{display:block;width:calc(100% - 56px);margin:0 28px 28px;padding:14px;border-radius:var(--radius-md);border:1.5px solid rgba(180,83,83,.2);background:#b453530a;color:#9b4b4b;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.key-modal__logout:hover{background:#b4535314;border-color:#b453534d}.sidebar__gallery-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:14px;border:2px solid rgba(102,126,234,.2);background:linear-gradient(135deg,#667eea0d,#764ba20d);font-size:15px;font-weight:600;color:var(--primary);cursor:pointer;transition:all .25s}.sidebar__gallery-btn:hover{border-color:#667eea66;background:linear-gradient(135deg,#667eea1a,#764ba21a);transform:translateY(-2px);box-shadow:0 4px 16px #667eea33}.workspace__back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:10px;border:1.5px solid rgba(0,0,0,.1);background:#fffc;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s;align-self:flex-start}.workspace__back-btn:hover{background:#fff;border-color:#00000026;transform:translate(-4px)}
