@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_2fe1ab3d-module__-T-KAq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_2fe1ab3d-module__-T-KAq__variable{--font-inter:"Inter","Inter Fallback"}
:root{--dh-purple:#7c3aed;--dh-purple-mid:#8b5cf6;--dh-purple-light:#a78bfa;--dh-purple-xlight:#ede9fe;--dh-purple-dark:#5b21b6;--dh-coral:#f97066;--dh-coral-dark:#e85d52;--dh-coral-light:#fbcab9;--dh-cyan:#06b6d4;--dh-green:#10b981;--dh-amber:#f59e0b;--dh-blue:#3b82f6;--dh-pink:#ec4899;--dh-indigo:#4f46e5;--grad-brand:linear-gradient(135deg,#7c3aed 0%,#f97066 100%);--grad-purple:linear-gradient(135deg,#7c3aed 0%,#4f46e5 100%);--grad-warm:linear-gradient(135deg,#f97066 0%,#f59e0b 100%);--grad-cool:linear-gradient(135deg,#06b6d4 0%,#3b82f6 100%);--grad-rose:linear-gradient(135deg,#ec4899 0%,#f97066 100%);--grad-emerald:linear-gradient(135deg,#10b981 0%,#06b6d4 100%);--grad-violet:linear-gradient(135deg,#8b5cf6 0%,#ec4899 100%);--grad-hero:linear-gradient(135deg,#f5f3ff 0%,#fff7ed 50%,#f0fffe 100%);--bg-page:#f7f5ff;--bg-base:#f7f5ff;--bg-surface:#fff;--bg-card:#fff;--bg-raised:#f9f7ff;--bg-overlay:#f3f0fe;--bg-muted:#f9fafb;--bg-hover:#7c3aed0d;--bg-void:#f7f5ff;--text-1:#111827;--text-2:#374151;--text-3:#6b7280;--text-4:#9ca3af;--border-1:#0000000d;--border-2:#e5e7eb;--border-3:#d1d5db;--border-accent:#7c3aed40;--border-focus:#7c3aed;--success:#059669;--warning:#d97706;--error:#dc2626;--info:#2563eb;--success-bg:#05966914;--error-bg:#dc262614;--shadow-xs:0 1px 2px #0000000f;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014,0 2px 4px #0000000d;--shadow-lg:0 10px 24px #00000017,0 4px 8px #0000000f;--shadow-xl:0 20px 40px #0000001a,0 8px 16px #0000000f;--shadow-glow:0 0 0 3px #7c3aed1f,0 8px 24px #7c3aed1a;--shadow-brand:0 4px 14px #7c3aed66;--shadow-card:0 2px 8px #00000012,0 0 0 1px #0000000a;--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.9375rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.5rem;--text-5xl:3.5rem;--text-6xl:4.5rem;--r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-2xl:32px;--r-full:9999px;--t-fast:.12s ease;--t-base:.2s ease;--t-slow:.35s cubic-bezier(.4,0,.2,1);--t-spring:.4s cubic-bezier(.34,1.56,.64,1);--sidebar-width:252px;--header-height:60px;--mobile-nav-height:64px;--content-max:1100px;--z-sidebar:100;--z-header:200;--z-modal:300;--z-tooltip:400;--blue:var(--dh-purple);--blue-bright:var(--dh-purple-light);--blue-deep:var(--dh-purple-dark);--violet:var(--dh-purple);--violet-bright:var(--dh-purple-light);--glow-blue:#7c3aed26;--glow-violet:#7c3aed1f;--color-bg-primary:var(--bg-base);--color-bg-secondary:var(--bg-surface);--color-bg-tertiary:var(--bg-card);--color-bg-card:var(--bg-card);--color-bg-glass:var(--bg-raised);--color-bg-glass-hover:var(--bg-overlay);--color-text-primary:var(--text-1);--color-text-secondary:var(--text-2);--color-text-muted:var(--text-3);--color-accent:var(--dh-purple);--color-accent-primary:var(--dh-purple);--color-accent-secondary:var(--dh-purple-mid);--color-accent-gradient:var(--grad-brand);--color-border:var(--border-2);--color-border-hover:var(--border-3);--color-success:var(--success);--color-warning:var(--warning);--color-error:var(--error);--color-info:var(--info);--shadow-glow-accent:var(--shadow-glow);--surface-light:var(--bg-card);--primary:var(--dh-purple);--font-size-xs:var(--text-xs);--font-size-sm:var(--text-sm);--font-size-md:var(--text-base);--font-size-lg:var(--text-lg);--font-size-xl:var(--text-xl);--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:var(--r-sm);--radius-md:var(--r-md);--radius-lg:var(--r-lg);--radius-xl:var(--r-xl);--radius-full:var(--r-full);--transition-fast:var(--t-fast);--transition-base:var(--t-base);--font-family:var(--font)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:16px;overflow-x:hidden}body{font-family:var(--font);font-size:var(--text-base);color:var(--text-2);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img,svg{max-width:100%;display:block}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-muted)}::-webkit-scrollbar-thumb{background:var(--border-3);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-4)}.app-layout{background:var(--bg-base);width:100%;min-height:100vh;display:flex;overflow-x:hidden}.app-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.app-content{padding:var(--space-8);padding-top:calc(var(--header-height) + var(--space-8));max-width:var(--content-max);flex:1;width:100%;margin:0 auto}@media (max-width:1024px){.app-main{margin-left:0}.app-content{padding:var(--space-5);padding-top:calc(var(--header-height) + var(--space-5));padding-bottom:calc(var(--mobile-nav-height) + var(--space-6))}}@media (max-width:480px){.app-content{padding:var(--space-4);padding-top:calc(var(--header-height) + var(--space-4));padding-bottom:calc(var(--mobile-nav-height) + var(--space-5))}}.glass-card{background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:border-color var(--t-base),box-shadow var(--t-base),transform var(--t-base)}.glass-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.btn{border-radius:var(--r-md);font-weight:600;font-size:var(--text-sm);transition:all var(--t-base);white-space:nowrap;letter-spacing:-.01em;justify-content:center;align-items:center;gap:.5rem;padding:.5625rem 1.125rem;line-height:1;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:var(--shadow-brand)}.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 6px 28px #7c3aed73}.btn-primary:active{filter:brightness(.97);transform:translateY(0)}.btn-secondary{background:var(--bg-card);border:1.5px solid var(--border-2);color:var(--text-2);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-raised);border-color:var(--border-accent);color:var(--text-1);box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--text-3);background:0 0}.btn-ghost:hover{background:var(--bg-raised);color:var(--text-1)}.btn-lg{font-size:var(--text-base);border-radius:var(--r-lg);padding:.8125rem 1.75rem}.btn-icon{border-radius:var(--r-md);width:38px;height:38px;padding:0}.form-group{margin-bottom:1.25rem}.form-label{font-size:var(--text-sm);color:var(--text-2);margin-bottom:.4rem;font-weight:500;display:block}.form-input{background:var(--bg-surface);border:1.5px solid var(--border-2);border-radius:var(--r-md);width:100%;color:var(--text-1);font-size:var(--text-sm);transition:border-color var(--t-fast),box-shadow var(--t-fast);padding:.625rem .875rem}.form-input:focus{border-color:var(--dh-purple);outline:none;box-shadow:0 0 0 3px #7c3aed1f}.form-input::placeholder{color:var(--text-4)}textarea.form-input{resize:vertical;min-height:110px}.badge{border-radius:var(--r-full);font-size:var(--text-xs);align-items:center;gap:.3rem;padding:.25rem .625rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--dh-purple-xlight);color:var(--dh-purple-dark);border:1px solid #7c3aed33}.badge-success{color:#065f46;background:#0596691a;border:1px solid #05966933}.badge-warning{color:#92400e;background:#d977061a;border:1px solid #d9770633}.badge-info{color:#1e40af;background:#2563eb1a;border:1px solid #2563eb33}.progress-bar{background:var(--border-2);border-radius:var(--r-full);width:100%;height:4px;overflow:hidden}.progress-bar-fill{background:var(--grad-brand);border-radius:var(--r-full);height:100%;transition:width var(--t-slow)}.drop-zone{border:2px dashed var(--border-3);border-radius:var(--r-xl);text-align:center;cursor:pointer;transition:all var(--t-base);background:var(--bg-surface);padding:4rem 2rem;position:relative;overflow:hidden}.drop-zone:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 50% 0,#7c3aed0a 0%,#0000 70%);position:absolute;inset:0}.drop-zone:hover,.drop-zone.dragging{border-color:var(--dh-purple);background:var(--dh-purple-xlight);box-shadow:0 0 0 1px #7c3aed26,inset 0 0 60px #7c3aed0a}.drop-zone-icon{color:var(--dh-purple);margin-bottom:1rem;font-size:44px}.drop-zone-text{font-size:var(--text-md);color:var(--text-1);margin-bottom:.25rem;font-weight:600}.drop-zone-hint{font-size:var(--text-sm);color:var(--text-3)}.section-title{font-size:var(--text-xl);color:var(--text-1);margin-bottom:var(--space-5);letter-spacing:-.02em;font-weight:700}.tool-page{animation:.35s fadeInUp}.tool-page-header{margin-bottom:var(--space-8)}.tool-page-title{font-size:var(--text-2xl);color:var(--text-1);letter-spacing:-.025em;margin-bottom:.25rem;font-weight:700}.tool-page-desc{font-size:var(--text-base);color:var(--text-2)}.loading-spinner{border:2px solid var(--border-2);border-top-color:var(--dh-purple);border-radius:50%;width:26px;height:26px;animation:.7s linear infinite spin}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{opacity:.5}50%{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.animate-fade-in-up{animation:.45s forwards fadeInUp}.animate-fade-in{animation:.3s forwards fadeIn}.animate-pop-in{animation:popIn .35s var(--t-spring)forwards}.stagger>*{opacity:0;animation:.4s forwards fadeInUp}.stagger>:first-child{animation-delay:40ms}.stagger>:nth-child(2){animation-delay:80ms}.stagger>:nth-child(3){animation-delay:.12s}.stagger>:nth-child(4){animation-delay:.16s}.stagger>:nth-child(5){animation-delay:.2s}.stagger>:nth-child(6){animation-delay:.24s}.stagger>:nth-child(7){animation-delay:.28s}.stagger>:nth-child(8){animation-delay:.32s}.stagger>:nth-child(9){animation-delay:.36s}.stagger>:nth-child(10){animation-delay:.4s}.text-gradient{background:var(--grad-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.text-gradient-2{background:var(--grad-purple);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@media (max-width:768px){:root{--text-5xl:2.5rem;--text-4xl:2rem;--text-3xl:1.5rem}.drop-zone{padding:2.5rem 1.25rem}}@media (max-width:480px){.drop-zone{padding:2rem 1rem}.btn-lg{font-size:var(--text-base);padding:.75rem 1.25rem}}
.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border-2);z-index:var(--z-sidebar);background:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto;box-shadow:2px 0 12px #0000000a}.sidebar-brand{border-bottom:1px solid var(--border-1);flex-shrink:0;align-items:center;gap:.625rem;padding:1.125rem 1rem;text-decoration:none;display:flex}.sidebar-brand-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden;box-shadow:0 4px 12px #7c3aed4d}.sidebar-brand-icon svg{width:36px;height:36px}.sidebar-brand-text{color:var(--text-1);letter-spacing:-.03em;font-size:1rem;font-weight:800}.sidebar-brand-badge{letter-spacing:.06em;text-transform:uppercase;color:var(--dh-purple);background:var(--dh-purple-xlight);border-radius:var(--r-full);border:1px solid #7c3aed33;flex-shrink:0;margin-left:auto;padding:2px 7px;font-size:9px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:.625rem;display:flex}.sidebar-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-4);-webkit-user-select:none;user-select:none;padding:1rem .75rem .3rem;font-size:10px;font-weight:700}.sidebar-link{border-radius:var(--r-md);font-size:var(--text-sm);color:var(--text-3);transition:all var(--t-fast);align-items:center;gap:.625rem;padding:.5rem .75rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link svg{width:16px;height:16px;transition:color var(--t-fast);flex-shrink:0}.sidebar-link:hover{background:var(--bg-raised);color:var(--text-1)}.sidebar-link.active{background:var(--dh-purple-xlight);color:var(--dh-purple-dark);font-weight:600}.sidebar-link.active svg{color:var(--dh-purple)}.sidebar-link.active:before{content:"";background:var(--grad-brand);border-radius:0 var(--r-full)var(--r-full)0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.sidebar-footer{border-top:1px solid var(--border-1);flex-shrink:0;padding:.75rem .625rem}.sidebar-user{align-items:center;gap:.5rem;display:flex}.sidebar-user-info{border-radius:var(--r-md);transition:background var(--t-fast);flex:1;align-items:center;gap:.5625rem;padding:.4rem .5rem;text-decoration:none;display:flex;overflow:hidden}.sidebar-user-info:hover{background:var(--bg-raised)}.sidebar-user-avatar{background:var(--grad-brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 8px #7c3aed40}.sidebar-user-details{flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar-user-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;font-size:10.5px;overflow:hidden}.sidebar-logout-btn{border-radius:var(--r-sm);width:30px;height:30px;color:var(--text-3);transition:all var(--t-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout-btn svg{width:15px;height:15px}.sidebar-logout-btn:hover{color:var(--error);background:#dc262614}.sidebar-login-btn{border-radius:var(--r-md);background:var(--grad-brand);color:#fff;font-size:var(--text-sm);transition:all var(--t-base);justify-content:center;align-items:center;gap:.5rem;padding:.5625rem .75rem;font-weight:600;text-decoration:none;display:flex;box-shadow:0 2px 8px #7c3aed4d}.sidebar-login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed66}.sidebar-logo-icon{border-radius:var(--r-md);color:#fff;background:var(--grad-brand);justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex;box-shadow:0 4px 12px #7c3aed4d}.sidebar-logo-text{color:var(--text-1);letter-spacing:-.03em;font-size:.9375rem;font-weight:800}@media (max-width:1024px){.sidebar{display:none}}
.header{top:0;right:0;left:var(--sidebar-width);height:var(--header-height);-webkit-backdrop-filter:blur(16px)saturate(180%);border-bottom:1px solid var(--border-2);z-index:var(--z-header);background:#ffffffeb;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:fixed;box-shadow:0 1px #0000000f}.header-left{align-items:center;gap:.875rem;display:flex}.header-mobile-logo{align-items:center;gap:.5rem;text-decoration:none;display:none}.header-title{font-size:var(--text-base);color:var(--text-1);letter-spacing:-.01em;font-weight:600}.header-sep{background:var(--border-2);border-radius:1px;width:1px;height:16px}.header-right{align-items:center;gap:.625rem;display:flex}.header-user-btn{border-radius:var(--r-full);background:var(--bg-surface);border:1.5px solid var(--border-2);transition:all var(--t-fast);box-shadow:var(--shadow-xs);align-items:center;gap:.5rem;padding:4px 12px 4px 4px;text-decoration:none;display:flex}.header-user-btn:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.header-avatar{background:var(--grad-brand);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 6px #7c3aed40}.header-user-name{font-size:var(--text-sm);color:var(--text-2);font-weight:500}@media (max-width:1024px){.header{padding:0 1.25rem;left:0}.header-mobile-logo{display:flex}.header-user-name{display:none}}@media (max-width:480px){.header{padding:0 1rem}.header-title{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;max-width:130px;overflow:hidden}.header-right .btn{padding:.3rem .625rem;font-size:11px}.header-mobile-logo .sidebar-logo-text{display:none}}
.mobile-nav{height:var(--mobile-nav-height);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-2);z-index:var(--z-header);background:#fffffff5;justify-content:space-around;align-items:center;padding:0 .5rem;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000f}.mobile-nav-link{border-radius:var(--r-lg);color:var(--text-3);transition:all var(--t-fast);flex-direction:column;flex:1;align-items:center;gap:3px;min-width:52px;max-width:72px;padding:.375rem .5rem;text-decoration:none;display:flex}.mobile-nav-link.active{color:var(--dh-purple)}.mobile-nav-icon-wrap{justify-content:center;align-items:center;width:28px;height:28px;font-size:22px;display:flex;position:relative}.mobile-nav-dot{background:var(--dh-purple);border-radius:50%;width:4px;height:4px;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.mobile-nav-label{letter-spacing:.01em;text-align:center;font-size:9.5px;font-weight:700;line-height:1}.mobile-nav-link.active .mobile-nav-label{color:var(--dh-purple)}@media (max-width:1024px){.mobile-nav{display:flex}}@supports (padding-bottom:env(safe-area-inset-bottom)){.mobile-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom))}}
