*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sans:system-ui, "Segoe UI", Roboto, sans-serif;--bg:#f5f4f8;--surface:#fff;--surface-2:#f0eef5;--border:#e2e0ea;--text:#3b3847;--text-muted:#8b879a;--text-h:#0d0b14;--accent:#7c3aed;--accent-hover:#6d28d9;--accent-fg:#fff;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 16px #0000001a, 0 2px 6px #0000000f;--shadow-lg:0 10px 40px #00000024, 0 4px 12px #00000014;--radius:10px;--radius-sm:6px;--sidebar-w:320px;--transition:.18s ease;--topbar-h:56px}@media (prefers-color-scheme:dark){:root{--bg:#0e0d14;--surface:#18172a;--surface-2:#211f35;--border:#2e2b45;--text:#b0adc0;--text-muted:#6b6880;--text-h:#f3f1ff;--accent:#a78bfa;--accent-hover:#c4b5fd;--accent-fg:#0e0d14;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #0006;--shadow-lg:0 10px 40px #00000080}}html,body,#root{height:100%;font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:100dvh;display:flex;position:relative;overflow:hidden}.controls-wrapper{display:contents}.controls{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;height:100%;display:flex;overflow:hidden auto}.controls-header{background:var(--surface);z-index:2;border-bottom:1px solid var(--border);flex-shrink:0;padding:16px 20px;position:sticky;top:0}.controls-header-row{justify-content:space-between;align-items:center;display:flex}.controls-brand{align-items:center;gap:10px;display:flex}.controls-logo{flex-shrink:0;width:28px;height:28px}.controls-header h1{letter-spacing:-.4px;color:var(--text-h);font-size:17px;font-weight:700}.controls-header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.locale-toggle{width:auto;padding:2px}.locale-toggle .tab-btn{min-width:38px;padding:4px 9px;font-size:12px}.controls-close{border-radius:var(--radius-sm);color:var(--text-muted);padding:6px}.control-section{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:14px 20px;display:flex}.download-section{border-bottom:none;padding-bottom:24px}.control-label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.control-value{color:var(--accent);text-transform:none;letter-spacing:0;font-size:12px;font-weight:500}.control-input,.control-textarea,.control-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-h);font-family:var(--sans);transition:border-color var(--transition), box-shadow var(--transition);appearance:none;outline:none;padding:8px 10px;font-size:14px}.control-input:focus,.control-textarea:focus,.control-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed26}.control-textarea{resize:vertical;min-height:88px;line-height:1.5}.control-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b879a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.control-range{width:100%;accent-color:var(--accent);cursor:pointer;height:4px}.btn{font-family:var(--sans);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), color var(--transition), opacity var(--transition);white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-fg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-sm);padding:10px;font-size:14px;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0;padding:4px 8px;font-size:12px}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.randomize-btn{width:100%}.align-group{gap:6px;display:flex}.align-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;padding:8px;display:flex}.align-btn:hover{border-color:var(--accent);color:var(--accent)}.align-btn.active{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.dir-align-row{align-items:stretch;gap:8px;display:flex}.dir-toggle{flex-shrink:0;width:90px}.dir-align-row .align-group{flex:1}.ratio-group{flex-direction:column;gap:4px;display:flex}.ratio-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:100%;font-family:var(--sans);color:var(--text);text-align:left;transition:all var(--transition);-webkit-tap-highlight-color:transparent;padding:7px 10px;font-size:13px}.ratio-btn:hover{border-color:var(--accent);color:var(--accent)}.ratio-btn.active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent);font-weight:600}.tab-group{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);gap:3px;padding:3px;display:flex}.tab-btn{cursor:pointer;font-family:var(--sans);color:var(--text-muted);transition:all var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:4px;flex:1;padding:6px;font-size:13px;font-weight:500}.tab-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.tab-btn:hover:not(.active){color:var(--text)}.color-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.color-swatch{border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;width:32px;height:32px;padding:0}.color-swatch::-webkit-color-swatch-wrapper{padding:0}.color-swatch::-webkit-color-swatch{border:none;border-radius:4px}.color-hex{color:var(--text-muted);flex:1;font-family:ui-monospace,Consolas,monospace;font-size:12px}.mini-label{color:var(--text-muted);letter-spacing:.4px;font-size:11px;font-weight:600}.gradient-controls{flex-direction:column;gap:10px;display:flex}.gradient-presets{flex-wrap:wrap;gap:6px;display:flex}.gradient-preset{border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;flex-shrink:0;width:32px;height:32px}.gradient-preset:hover{border-color:var(--accent)}.spinner{border:2px solid;border-top-color:#0000;border-radius:50%;width:13px;height:13px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.preview-area{padding:32px 24px;padding-bottom:max(32px, env(safe-area-inset-bottom));background:radial-gradient(ellipse at 60% 30%, color-mix(in srgb, var(--accent) 6%, transparent), transparent 60%), var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-height:0;display:flex;overflow:auto}.preview-container{width:100%;max-width:460px}.preview-footer{flex-direction:column;align-items:center;gap:10px;display:flex}.preview-hint{color:var(--text-muted);letter-spacing:.2px;font-size:12px}.preview-links{align-items:center;gap:16px;display:flex}.preview-link{color:var(--text-muted);transition:color var(--transition);align-items:center;gap:5px;font-size:12px;font-weight:500;text-decoration:none;display:inline-flex}.preview-link:hover{color:var(--accent)}.card-wrapper{width:100%;height:0;box-shadow:var(--shadow-lg);border-radius:16px;position:relative;overflow:hidden}.quote-card{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:44px 48px;display:flex;position:absolute;inset:0;overflow:hidden}.quote-mark{opacity:.25;-webkit-user-select:none;user-select:none;flex-shrink:0;font-family:Georgia,Times New Roman,serif;font-size:80px;line-height:.6}.open-quote{align-self:flex-start;margin-bottom:-8px}.close-quote{align-self:flex-end;margin-top:-8px}.quote-text{flex:1;align-items:center;width:100%;font-style:italic;font-weight:400;line-height:1.55;list-style:none;display:flex}.quote-author{opacity:.75;letter-spacing:.04em;width:100%;margin-top:8px;font-style:normal}.mobile-topbar{justify-content:space-between;align-items:center;gap:12px;width:100%;max-width:460px;display:none}.mobile-topbar-brand{color:var(--text-h);align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.mobile-logo{width:26px;height:26px}.mobile-menu-btn{gap:6px;padding:8px 12px;font-size:13px}.mobile-download-btn{width:100%;max-width:460px;display:none}.drawer-backdrop{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;position:fixed;inset:0}.drawer{z-index:101;background:var(--surface);max-height:88dvh;padding-bottom:env(safe-area-inset-bottom);border-radius:20px 20px 0 0;flex-direction:column;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.drawer .controls{width:100%;min-width:unset;border-right:none;border-radius:0;flex:1;height:100%;min-height:0}.drawer-handle-bar{background:var(--border);border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:10px auto 0}@media (width>=700px){.mobile-topbar,.mobile-download-btn{display:none!important}.desktop-only{display:contents}}@media (width<=699px){.app{flex-direction:column}.desktop-only{display:none!important}.mobile-topbar{display:flex}.mobile-download-btn{display:inline-flex}.preview-area{padding:20px 16px 16px;padding-bottom:max(20px, env(safe-area-inset-bottom));justify-content:flex-start;gap:16px}.preview-container{max-width:100%}.quote-card{padding:32px 36px}.quote-mark{font-size:60px}}.toast-stack{bottom:max(24px, env(safe-area-inset-bottom));z-index:200;pointer-events:none;flex-direction:column;align-items:center;gap:8px;width:max-content;max-width:calc(100vw - 32px);display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);color:var(--text-h);pointer-events:all;white-space:nowrap;align-items:center;gap:10px;max-width:320px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.toast--success{border-color:#22c55e}.toast--success .toast-icon{color:#22c55e}.toast--error{border-color:#ef4444}.toast--error .toast-icon{color:#ef4444}.toast--info .toast-icon{color:var(--accent)}.toast-icon{flex-shrink:0;display:flex}.toast-message{text-overflow:ellipsis;flex:1;overflow:hidden}.toast-close{cursor:pointer;color:var(--text-muted);transition:color var(--transition), background var(--transition);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:flex}.toast-close:hover{color:var(--text-h);background:var(--surface-2)}
