@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.06d3mdzz5bre_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.11.cyxs5p-0z~.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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.16t1db8_9y2o~.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:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0q3udbd2bu5yp.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0gw~uztddq1df.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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.0.q-h669a_dqa.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:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
:root{--bg-base:#f8fafc;--bg-surface:#fff;--bg-card:#fff;--bg-elevated:#f1f5f9;--bg-hover:#f1f5f9;--bg-input:#fff;--border-default:#0f172a1a;--border-accent:#6366f166;--border-glow:#6366f126;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--text-link:#3b82f6;--accent-primary:#6366f1;--accent-primary-hover:#4f46e5;--accent-secondary:#8b5cf6;--accent-success:#10b981;--accent-success-dim:#10b9811a;--accent-warning:#f59e0b;--accent-warning-dim:#f59e0b1a;--accent-danger:#ef4444;--accent-danger-dim:#ef44441a;--accent-info:#3b82f6;--accent-info-dim:#3b82f61a;--gradient-primary:linear-gradient(135deg, #4f46e5, #7c3aed);--gradient-success:linear-gradient(135deg, #059669, #10b981);--gradient-warm:linear-gradient(135deg, #ea580c, #e11d48);--gradient-hero:linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);--glass-bg:#ffffffd9;--glass-border:#0f172a14;--glass-blur:24px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 20px #6366f126;--shadow-glow-lg:0 0 40px #6366f140;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--dur-fast:.15s;--dur-normal:.25s;--dur-slow:.4s}html.dark{--bg-base:#070b14;--bg-surface:#0b1120;--bg-card:#141c2f;--bg-elevated:#1e293b;--bg-hover:#1e293b;--bg-input:#0b1120;--border-default:#94a3b826;--border-accent:#6366f180;--border-glow:#6366f133;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--text-link:#60a5fa;--accent-primary:#6366f1;--accent-primary-hover:#818cf8;--accent-secondary:#8b5cf6;--accent-success:#10b981;--accent-success-dim:#10b98126;--accent-warning:#f59e0b;--accent-warning-dim:#f59e0b26;--accent-danger:#ef4444;--accent-danger-dim:#ef444426;--accent-info:#3b82f6;--accent-info-dim:#3b82f626;--gradient-primary:linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-success:linear-gradient(135deg, #10b981, #059669);--gradient-warm:linear-gradient(135deg, #f59e0b, #e11d48);--gradient-hero:linear-gradient(135deg, #818cf8 0%, #c084fc 50%, #f472b6 100%);--glass-bg:#0b1120b3;--glass-border:#ffffff14;--shadow-sm:0 2px 4px #0006;--shadow-md:0 8px 20px #00000080;--shadow-lg:0 16px 40px #0009;--shadow-glow:0 0 24px #6366f133;--shadow-glow-lg:0 0 50px #6366f159}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:radial-gradient(circle at 10% 20%, #6366f126 0%, transparent 40%), radial-gradient(circle at 90% 80%, #ec48991a 0%, transparent 40%), radial-gradient(circle at 50% 50%, #8b5cf60d 0%, transparent 60%), var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-header{z-index:10;-webkit-backdrop-filter:blur(32px);background:#0b112066;border:1px solid #ffffff0d;border-radius:24px;justify-content:space-between;align-items:center;width:calc(100% - 48px);max-width:1400px;margin:16px auto 32px;padding:14px 28px;transition:transform .3s;display:flex;position:relative;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff1a}.header-left{align-items:center;gap:12px;display:flex}.logo{border-radius:var(--radius-md);width:44px;height:44px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;display:flex;overflow:hidden}.logo svg{stroke:#fff;fill:none;width:20px;height:20px}.app-header h1{background:var(--gradient-hero);-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;margin-bottom:2px;font-size:1.4rem;font-weight:800}.version-badge{border-radius:var(--radius-full);background:var(--accent-info-dim);color:var(--accent-info);letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;font-size:.65rem;font-weight:600}.header-right{align-items:center;gap:8px;display:flex}.tab-nav{justify-content:center;padding:0 24px 20px;display:flex}.tab-nav-inner{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:20px;gap:8px;padding:6px;display:inline-flex;overflow-x:auto}.tab-btn{color:var(--text-secondary);transition:all var(--dur-normal) var(--ease-spring);white-space:nowrap;background:0 0;border-radius:14px;align-items:center;gap:8px;padding:10px 24px;font-size:.9rem;font-weight:500;display:flex;position:relative}.tab-btn svg{width:18px;height:18px}.tab-btn:hover:not(:disabled){color:#fff;background:#ffffff0d}.tab-btn.active{color:#fff;background:var(--gradient-primary);font-weight:600;box-shadow:0 4px 15px #6366f166}.tab-btn:disabled{opacity:.35;cursor:not-allowed}.tab-btn .tab-badge{border-radius:var(--radius-full);background:var(--accent-danger);color:#fff;padding:1px 6px;font-size:.65rem;font-weight:600}.tab-content{width:100%;max-width:1400px;margin:0 auto;padding:24px}.tab-panel{animation:fadeSlideUp var(--dur-slow) var(--ease-out);display:none}.tab-panel.active{display:block}.upload-zone{border-radius:var(--radius-xl);text-align:center;transition:all var(--dur-normal) var(--ease-spring);cursor:pointer;background:linear-gradient(#0b112000 0%,#6366f108 100%);border:2px dashed #6366f166;padding:64px 32px;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0003}.upload-zone:before{content:"";transition:opacity var(--dur-normal);opacity:0;background:radial-gradient(circle,#6366f11a 0%,#0000 60%);position:absolute;inset:0}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-primary);box-shadow:var(--shadow-glow-lg);background:#6366f10a}.upload-zone:hover:before,.upload-zone.drag-over:before{opacity:1}.upload-zone.drag-over{transform:scale(1.01)}.upload-icon{z-index:1;margin-bottom:20px;position:relative}.upload-main-icon{width:56px;height:56px;color:var(--accent-primary);animation:3s ease-in-out infinite floatIcon}.upload-zone h2{z-index:1;margin-bottom:8px;font-size:1.25rem;font-weight:600;position:relative}.upload-zone p{color:#58a6ff;z-index:1;font-size:.9rem;position:relative}.file-label{color:var(--accent-primary);cursor:pointer;text-underline-offset:3px;font-weight:600;text-decoration:underline}.file-label:hover{color:var(--accent-primary-hover)}.supported-formats{z-index:1;justify-content:center;gap:8px;margin-top:20px;display:flex;position:relative}.format-badge{border-radius:var(--radius-full);border:1px solid var(--border-default);color:#58a6ff;font-size:.75rem;font-weight:600;font-family:var(--font-mono);padding:4px 12px}.format-badge.xlsx{color:var(--accent-success);border-color:#10b9814d}.format-badge.xls{color:var(--accent-info);border-color:#3b82f64d}.format-badge.csv{color:var(--accent-warning);border-color:#f59e0b4d}.file-info{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);flex-wrap:wrap;align-items:center;gap:16px;margin-top:20px;padding:16px 20px;display:flex}.file-info-item{align-items:center;gap:8px;font-size:.875rem;display:flex}.file-info-item svg{width:16px;height:16px;color:var(--text-muted)}.file-info-item strong{color:var(--text-primary)}.file-info-item span{color:#58a6ff}.file-info .sheet-select{margin-left:auto}select,.styled-select{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--dur-fast);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236e7681' viewBox='0 0 16 16'%3E%3Cpath d='M8 12l-6-6h12z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:8px 30px 8px 14px;font-size:.875rem}select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f126}select option{background:var(--bg-card);color:var(--text-primary)}.data-preview{border-radius:var(--radius-lg);border:1px solid var(--border-default);margin-top:20px;overflow:hidden}.data-preview-header{background:var(--bg-card);border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.data-preview-header h3{color:#58a6ff;font-size:.875rem;font-weight:600}.table-wrapper{max-height:360px;overflow:auto}table.data-table{border-collapse:collapse;width:100%;font-size:.8125rem}table.data-table thead th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-default);white-space:nowrap;z-index:2;background:#161b22;padding:10px 14px;font-weight:600;position:sticky;top:0}table.data-table tbody td{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid #30363d4d;max-width:200px;padding:8px 14px;overflow:hidden}table.data-table tbody tr:hover{background:var(--bg-hover)}table.data-table tbody tr:nth-child(2n){background:#0d111766}table.data-table tbody tr:nth-child(2n):hover{background:var(--bg-hover)}.cell-null{color:var(--text-muted);font-style:italic}.col-index{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);text-align:center;width:40px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--dur-normal) var(--ease-out);padding:16px;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.primary:before{background:var(--gradient-primary)}.stat-card.success:before{background:var(--gradient-success)}.stat-card.warning:before{background:var(--accent-warning)}.stat-card.danger:before{background:var(--gradient-warm)}.stat-card-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;margin-bottom:10px;display:flex}.stat-card-icon svg{width:16px;height:16px}.stat-card-icon.primary{color:var(--accent-primary);background:#6366f11f}.stat-card-icon.success{background:var(--accent-success-dim);color:var(--accent-success)}.stat-card-icon.warning{background:var(--accent-warning-dim);color:var(--accent-warning)}.stat-card-icon.danger{background:var(--accent-danger-dim);color:var(--accent-danger)}.stat-card-value{margin-bottom:2px;font-size:1.375rem;font-weight:700;line-height:1.2}.stat-card-label{color:var(--text-secondary);font-size:.75rem}.profile-section{margin-bottom:20px}.profile-section h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:8px;margin-bottom:10px;font-size:.8125rem;font-weight:600;display:flex}.profile-section h3 svg{width:16px;height:16px;color:var(--accent-primary)}table.profile-table{border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-default);width:100%;font-size:.75rem;overflow:hidden}table.profile-table thead th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-default);text-transform:uppercase;letter-spacing:.04em;background:#161b22;padding:10px 12px;font-size:.7rem;font-weight:600}table.profile-table tbody td{border-bottom:1px solid #30363d4d;padding:8px 12px}table.profile-table tbody tr:hover{background:var(--bg-hover)}.type-badge{border-radius:var(--radius-full);font-size:.7rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.03em;align-items:center;gap:4px;padding:2px 10px;display:inline-flex}.type-badge.text{color:#60a5fa;background:#3b82f61f}.type-badge.number{color:#34d399;background:#10b9811f}.type-badge.date{color:#fbbf24;background:#f59e0b1f}.type-badge.currency{color:#f472b6;background:#ec48991f}.type-badge.boolean{color:#a78bfa;background:#8b5cf61f}.type-badge.mixed{color:#f87171;background:#ef44441f}.type-badge.empty{color:#8b949e;background:#6e76811f}.quality-bar{background:var(--bg-hover);border-radius:3px;width:100%;max-width:80px;height:6px;overflow:hidden}.quality-bar-fill{height:100%;transition:width var(--dur-slow) var(--ease-out);border-radius:3px}.quality-bar-fill.good{background:var(--accent-success)}.quality-bar-fill.ok{background:var(--accent-warning)}.quality-bar-fill.bad{background:var(--accent-danger)}.insights-list{flex-direction:column;gap:10px;display:flex}.insight-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--dur-normal) var(--ease-out);align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.insight-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.insight-severity{border-radius:2px;flex-shrink:0;align-self:stretch;width:3px}.insight-severity.high{background:var(--accent-danger)}.insight-severity.medium{background:var(--accent-warning)}.insight-severity.low{background:var(--accent-success)}.insight-severity.info{background:var(--accent-info)}.insight-body{flex:1;min-width:0}.insight-title{margin-bottom:3px;font-size:.8125rem;font-weight:600;line-height:1.3}.insight-desc{color:var(--text-secondary);font-size:.75rem;line-height:1.5}.insight-meta{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.insight-tag{border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font-mono);background:#161b22;padding:2px 6px;font-size:.65rem}.quality-score-container{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);align-items:center;gap:20px;margin-bottom:20px;padding:20px;display:flex}.quality-circle{flex-shrink:0;width:100px;height:100px;position:relative}.quality-circle svg{width:100px;height:100px;transform:rotate(-90deg)}.quality-circle-bg{fill:none;stroke:var(--bg-hover);stroke-width:8px}.quality-circle-fill{fill:none;stroke-width:8px;stroke-linecap:round;transition:stroke-dashoffset 1s var(--ease-out)}.quality-circle-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.quality-circle-value{font-size:1.5rem;font-weight:700;line-height:1}.quality-circle-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;font-size:.6rem}.quality-summary{flex:1}.quality-summary h3{margin-bottom:6px;font-size:.9375rem;font-weight:600}.quality-summary p{color:var(--text-secondary);font-size:.8125rem;line-height:1.5}.prompt-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.prompt-mode-group{border:1px solid var(--border-default);border-radius:var(--radius-sm);display:flex;overflow:hidden}.prompt-mode-btn{border-right:1px solid var(--border-default);transition:all var(--dur-fast);align-items:center;gap:5px;padding:7px 14px;font-size:.75rem;font-weight:500;display:flex}.prompt-mode-btn:last-child{border-right:none}.prompt-mode-btn:hover{background:var(--bg-hover)}.prompt-mode-btn.active{color:var(--accent-primary);background:#6366f11f}.prompt-mode-btn svg{width:13px;height:13px}.prompt-editor-wrapper{border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-card);margin-bottom:14px;position:relative;overflow:hidden}.prompt-editor-toolbar{border-bottom:1px solid var(--border-default);background:#161b22;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.prompt-editor-toolbar-left{color:var(--text-muted);align-items:center;gap:6px;font-size:.75rem;display:flex}.prompt-editor-toolbar-left svg{width:13px;height:13px}.prompt-editor{width:100%;min-height:300px;color:var(--text-primary);font-family:var(--font-mono);resize:vertical;background:0 0;border:none;outline:none;padding:14px;font-size:.8125rem;line-height:1.6}.prompt-editor::placeholder{color:var(--text-muted)}.prompt-actions{flex-wrap:wrap;gap:10px;display:flex}.user-context{margin-bottom:14px}.user-context label{color:var(--text-secondary);margin-bottom:6px;font-size:.8125rem;font-weight:600;display:block}.user-context textarea{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;min-height:70px;color:var(--text-primary);resize:vertical;transition:border-color var(--dur-fast);outline:none;padding:10px 14px;font-size:.8125rem;line-height:1.5}.user-context textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11f}.btn{border-radius:var(--radius-md);transition:all var(--dur-normal) var(--ease-out);white-space:nowrap;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f180}.btn-success{background:var(--accent-success);color:#fff}.btn-success:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-outline{border:1px solid var(--border-default);color:var(--text-secondary);background:0 0}.btn-outline:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f10f}.btn-ghost{color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;transition:all var(--dur-fast);color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon svg{width:18px;height:18px}.btn-danger{background:var(--accent-danger);color:#fff}.btn-danger:hover{filter:brightness(1.15)}.btn-api{color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);box-shadow:0 2px 8px #8b5cf64d}.btn-api:hover{transform:translateY(-1px);box-shadow:0 4px 16px #8b5cf680}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none!important;transform:none!important}.template-filters{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.filter-chip{border-radius:var(--radius-full);border:1px solid var(--border-default);color:var(--text-secondary);transition:all var(--dur-fast);padding:5px 12px;font-size:.75rem;font-weight:500}.filter-chip:hover,.filter-chip.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f114}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.template-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--dur-normal) var(--ease-out);cursor:pointer;padding:16px}.template-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.template-card-header{align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.template-emoji{font-size:1.25rem;line-height:1}.template-card-title{font-size:.875rem;font-weight:600;line-height:1.3}.template-card-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:3px;font-size:.65rem}.template-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:.75rem;line-height:1.5;display:-webkit-box;overflow:hidden}.modal-overlay{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn var(--dur-fast);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:90%;max-width:520px;max-height:85vh;box-shadow:var(--shadow-lg);animation:scaleIn var(--dur-normal) var(--ease-spring);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-body{padding:24px}.modal-body .form-group{margin-bottom:20px}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{color:var(--text-secondary);margin-bottom:6px;font-size:.8125rem;font-weight:600;display:block}.modal-body input[type=text],.modal-body input[type=password]{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--dur-fast);font-size:.875rem;font-family:var(--font-mono);outline:none;padding:10px 14px}.modal-body input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11f}.modal-footer{border-top:1px solid var(--border-default);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-hint{color:var(--text-muted);margin-top:6px;font-size:.75rem;line-height:1.4}.toast-container{z-index:1000;flex-direction:column-reverse;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:slideInRight var(--dur-normal) var(--ease-out);align-items:center;gap:10px;min-width:280px;max-width:420px;padding:12px 20px;font-size:.875rem;font-weight:500;display:flex}.toast svg{flex-shrink:0;width:18px;height:18px}.toast.success{color:#a7f3d0;background:#065f46;border:1px solid #10b9814d}.toast.error{color:#fecaca;background:#7f1d1d;border:1px solid #ef44444d}.toast.warning{color:#fde68a;background:#78350f;border:1px solid #f59e0b4d}.toast.info{color:#bfdbfe;background:#1e3a5f;border:1px solid #3b82f64d}.toast-exit{animation:slideOutRight var(--dur-normal) var(--ease-out) forwards}.ai-response-container{border:1px solid var(--border-default);border-radius:var(--radius-md);margin-top:16px;overflow:hidden}.ai-response-header{border-bottom:1px solid var(--border-default);background:#161b22;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.ai-response-header h3{align-items:center;gap:8px;font-size:.8125rem;font-weight:600;display:flex}.ai-response-body{background:var(--bg-card);padding:16px;font-size:.8125rem;line-height:1.6}.ai-response-body table{border-collapse:collapse;width:100%;margin:10px 0;font-size:.75rem}.ai-response-body table th,.ai-response-body table td{border:1px solid var(--border-default);text-align:left;padding:6px 10px}.ai-response-body table th{background:#161b22;font-weight:600}.ai-response-body :not(pre)>code{font-family:var(--font-mono);background:var(--bg-surface);color:#ff7b72;border-radius:4px;padding:2px 5px;font-size:.8em}.code-block-wrapper{border:1px solid var(--border-default);background:#0d1117;border-radius:6px;margin:12px 0;overflow:hidden}.code-block-header{border-bottom:1px solid var(--border-default);background:#161b22;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.code-block-lang{text-transform:uppercase;letter-spacing:.05em;color:#58a6ff;font-size:.65rem;font-weight:600;font-family:var(--font-mono)}.code-block-actions{align-items:center;gap:8px;display:flex}.code-block-btn{border:1px solid var(--border-default);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;align-items:center;gap:4px;padding:4px 10px;font-size:.65rem;font-weight:500;transition:all .15s;display:inline-flex}.code-block-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.code-block-btn:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.code-block-btn.copied{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.code-block-btn svg{flex-shrink:0;width:11px;height:11px}.code-block-btn-text{font-family:var(--font-sans)}.code-block-content{max-height:350px;padding:0;overflow:auto}.code-block-content pre{font-family:var(--font-mono);color:var(--text-primary);white-space:pre;background:0 0;border:none;margin:0;padding:12px 14px;font-size:.8rem;line-height:1.6;overflow-x:auto}.code-block-content pre code{font-size:inherit;color:inherit;line-height:inherit;background:0 0;padding:0}.code-block-content::-webkit-scrollbar{width:6px;height:6px}.code-block-content::-webkit-scrollbar-track{background:var(--bg-surface)}.code-block-content::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}.code-block-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.markdown-content,.ai-html-content,.ai-response-body{color:#e6edf3;font-size:.95rem;line-height:1.7}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.ai-html-content h1,.ai-html-content h2,.ai-html-content h3,.ai-html-content h4{font-family:var(--font-sans);color:#fff;margin-top:2em;margin-bottom:.8em;font-weight:600;line-height:1.3}.markdown-content h1,.ai-html-content h1{border-bottom:1px solid var(--border-default);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;width:fit-content;padding-bottom:.3em;font-size:1.5rem}.markdown-content h2,.ai-html-content h2{border-bottom:1px solid #30363d66;padding-bottom:.3em;font-size:1.25rem}.markdown-content h3,.ai-html-content h3{color:var(--text-link);font-size:1.1rem}.markdown-content p,.ai-html-content p{margin-top:0;margin-bottom:20px}.markdown-content ul,.markdown-content ol,.ai-html-content ul,.ai-html-content ol{margin-top:0;margin-bottom:20px;padding-left:24px}.markdown-content li,.ai-html-content li{margin-bottom:8px}.markdown-content li::marker{color:var(--accent-primary)}.ai-html-content li::marker{color:var(--accent-primary)}.markdown-content strong,.ai-html-content strong{color:#fff;font-weight:600}.markdown-content em,.ai-html-content em{color:#a3b3cc;font-style:italic}.markdown-content blockquote,.ai-html-content blockquote{color:var(--text-secondary);border-left:4px solid var(--accent-primary);background:#6366f10d;border-radius:0 8px 8px 0;margin:0 0 20px;padding:12px 20px;font-style:italic}.markdown-content :not(pre,.code-block-content)>code,.ai-html-content :not(pre,.code-block-content)>code{font-family:var(--font-mono);color:#ff7b72;background:#6e768133;border-radius:6px;padding:.2em .4em;font-size:.85em}.table-wrapper{border:1px solid var(--border-default);background:var(--bg-card);border-radius:8px;margin-bottom:24px;overflow-x:auto}.markdown-content table,.ai-html-content table{border-collapse:collapse;width:100%;font-size:.85rem}.markdown-content th,.markdown-content td,.ai-html-content th,.ai-html-content td{text-align:left;border-bottom:1px solid var(--border-default);padding:12px 16px}.markdown-content th,.ai-html-content th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:#161b22;font-size:.75rem;font-weight:600}.markdown-content tbody tr:last-child td,.ai-html-content tbody tr:last-child td{border-bottom:none}.markdown-content tbody tr:hover,.ai-html-content tbody tr:hover{background:#ffffff05}.markdown-content img.dl-chart-img,.ai-html-content img.dl-chart-img{border:1px solid var(--border-default);border-radius:8px;max-width:100%;height:auto;margin:24px 0;display:block;box-shadow:0 4px 20px #0000004d}.markdown-content a,.ai-html-content a{color:var(--text-link);transition:border-color var(--dur-fast);border-bottom:1px solid #0000;text-decoration:none}.markdown-content a:hover,.ai-html-content a:hover{border-bottom-color:var(--text-link)}.loading-spinner{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.loading-dots{align-items:center;gap:4px;display:inline-flex}.loading-dots span{background:var(--accent-primary);border-radius:50%;width:6px;height:6px;animation:1.2s infinite dotPulse}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.skeleton{background:linear-gradient(90deg, var(--bg-elevated) 25%, var(--bg-hover) 50%, var(--bg-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.progress-bar{background:var(--bg-hover);border-radius:2px;width:100%;height:4px;margin-top:12px;overflow:hidden}.progress-bar-fill{background:var(--gradient-primary);height:100%;transition:width var(--dur-normal) var(--ease-out);border-radius:2px}.chart-container{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:20px;padding:20px}.chart-container h4{color:var(--text-secondary);margin-bottom:16px;font-size:.875rem;font-weight:600}.chart-canvas-wrapper{max-height:280px;position:relative}.charts-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:8px 0 0;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:12px}.chart-card h3{color:var(--text-secondary);margin:0 0 8px;font-size:.8rem;font-weight:600}.chart-card canvas{width:100%!important;height:240px!important}.readiness-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:16px;display:grid}.readiness-item{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);align-items:center;gap:10px;padding:14px;display:flex}.readiness-icon{text-align:center;width:32px;font-size:1.25rem}.readiness-label{font-size:.8125rem;font-weight:500}.readiness-status{color:var(--text-muted);font-size:.75rem}.section-divider{align-items:center;gap:12px;margin:20px 0 14px;display:flex}.section-divider h3{white-space:nowrap;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.section-divider:after{content:"";background:var(--border-default);flex:1;height:1px}.section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;font-size:.875rem;font-weight:600}.hidden{display:none!important}.text-center{text-align:center}.text-mono{font-family:var(--font-mono)}.text-muted{color:var(--text-muted)}.text-sm{font-size:.8125rem}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mb-md{margin-bottom:16px}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-sm{gap:8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeSlideUp{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 slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100px)}}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes dotPulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glowPulse{0%,to{box-shadow:0 0 8px #6366f126}50%{box-shadow:0 0 24px #6366f14d}}.header-inner{justify-content:space-between;align-items:center;width:100%;max-width:1400px;margin:0 auto;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand-icon{background:var(--gradient-primary);border-radius:var(--radius-md);width:40px;height:40px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;display:flex}.brand-icon svg{width:20px;height:20px}.brand h1{background:var(--gradient-hero);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.25rem;font-weight:700}.brand-sub{color:var(--text-muted);letter-spacing:.04em;font-size:.7rem;display:block}.header-actions{align-items:center;gap:8px;display:flex}.tab-nav-inner{gap:2px;width:100%;max-width:1400px;margin:0 auto;display:flex}.app-main{width:100%;max-width:1400px;min-height:calc(100vh - 200px);margin:0 auto;padding:24px}.app-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-default);padding:20px 24px;font-size:.75rem}.upload-section{max-width:800px;margin:0 auto}.dropzone{border:2px dashed var(--border-default);border-radius:var(--radius-xl);text-align:center;transition:all var(--dur-normal) var(--ease-out);cursor:pointer;background:var(--bg-surface);padding:48px 32px;position:relative;overflow:hidden}.dropzone:before{content:"";opacity:0;transition:opacity var(--dur-normal);background:radial-gradient(circle,#6366f10a 0%,#0000 70%);position:absolute;inset:0}.dropzone:hover,.dropzone.drag-over{border-color:var(--accent-primary);box-shadow:var(--shadow-glow-lg);background:#6366f10a}.dropzone:hover:before,.dropzone.drag-over:before{opacity:1}.dropzone.drag-over{transform:scale(1.01)}.dropzone-icon{z-index:1;justify-content:center;margin-bottom:16px;display:flex;position:relative}.dropzone-icon svg{width:44px;height:44px;color:var(--accent-primary);animation:3s ease-in-out infinite floatIcon}.dropzone-text{z-index:1;max-width:400px;margin:0 auto;position:relative}.dropzone-text h3{color:var(--text-primary);margin-bottom:6px;font-size:1rem;font-weight:600;line-height:1.4}.dropzone-text p{color:var(--text-secondary);font-size:.8125rem;line-height:1.5}.dropzone-label{color:var(--accent-primary);cursor:pointer;text-underline-offset:3px;font-weight:600;text-decoration:underline}.dropzone-label:hover{color:var(--accent-primary-hover)}.privacy-note{align-items:flex-start;gap:14px;margin-top:24px;padding:18px 20px;display:flex}.privacy-note svg{width:24px;height:24px;color:var(--accent-success)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.form-input{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--dur-fast);font-size:.875rem;font-family:var(--font-mono);outline:none;padding:10px 14px}.form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11f}.btn-sm{padding:6px 14px;font-size:.8125rem}@media (max-width:768px){.tab-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.templates-grid{grid-template-columns:1fr}.upload-zone{padding:40px 20px}.prompt-controls{flex-direction:column;align-items:stretch}.prompt-mode-group{width:100%}.prompt-mode-btn{flex:1;justify-content:center}.quality-score-container{text-align:center;flex-direction:column}.file-info{flex-direction:column;align-items:flex-start}.file-info .sheet-select{margin-left:0}.ai-response-body{padding:12px;font-size:.75rem}.ai-response-body h1{font-size:.85rem}.ai-response-body h2{font-size:.8rem}.ai-response-body h3{font-size:.775rem}.ai-response-body h4{font-size:.75rem}.ai-response-body pre code{padding:10px 12px;font-size:.7rem}.code-block-content{max-height:280px}.ai-response-body table{font-size:.7rem}.code-block-wrapper{margin:10px 0}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.tab-btn span{display:none}.tab-btn{padding:10px 14px}.app-header h1{font-size:1.1rem}.ai-response-body{padding:10px;font-size:.7rem}.ai-response-body h1{font-size:.8rem}.ai-response-body h2{font-size:.775rem}.ai-response-body h3{font-size:.75rem}.ai-response-body h4{font-size:.725rem}.ai-response-body pre code{padding:8px 10px;font-size:.65rem}.ai-response-body pre{margin:8px 0}.code-block-content{max-height:200px}.ai-response-body table{font-size:.65rem}.ai-response-body table th,.ai-response-body table td{padding:4px 6px}}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--bg-hover);border:1px solid var(--border-default);border-radius:24px;transition:all .4s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:var(--text-secondary);border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:2px;left:2px}input:checked+.toggle-slider{background-color:var(--accent-success);border-color:var(--accent-success)}input:checked+.toggle-slider:before{background-color:#fff;transform:translate(20px)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--dur-fast) var(--ease-out);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg);animation:fadeSlideUp var(--dur-normal) var(--ease-spring);flex-direction:column;display:flex}.modal-header{border-bottom:1px solid var(--border-default);background:var(--bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{color:var(--text-primary);margin:0;font-size:1.125rem;font-weight:600}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-default);background:var(--bg-card);border-radius:0 0 var(--radius-lg) var(--radius-lg);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:.875rem;font-weight:500;display:block}.form-control{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--dur-fast);padding:10px 14px;font-size:.875rem}.form-control:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #6366f126}.checkbox-group{align-items:flex-start;gap:12px;display:flex}.checkbox-group input[type=checkbox]{accent-color:var(--accent-primary);width:16px;height:16px;margin-top:4px}.fab-scroll-top{background:var(--gradient-primary);color:#fff;cursor:pointer;z-index:999;width:48px;height:48px;transition:all var(--dur-normal) var(--ease-spring);opacity:0;pointer-events:none;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;bottom:32px;right:32px;transform:translateY(20px)scale(.8);box-shadow:0 4px 15px #6366f166}.fab-scroll-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.fab-scroll-top:hover{transform:translateY(-4px)scale(1.05);box-shadow:0 8px 25px #6366f180}.fab-scroll-top:active{transform:translateY(0)scale(.95)}.mcode-fab{color:#fff;cursor:pointer;z-index:1000;background:linear-gradient(135deg,#a855f7,#6366f1);border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:90px;right:32px;box-shadow:0 4px 15px #8b5cf666}.mcode-fab:hover{transform:scale(1.1)translateY(-5px);box-shadow:0 8px 25px #8b5cf699}.mcode-panel{background:var(--bg-card);border:1px solid var(--border-color);z-index:1000;border-radius:20px;flex-direction:column;width:420px;height:min(600px,100vh - 120px);transition:all .3s cubic-bezier(.16,1,.3,1);animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp;display:flex;position:fixed;bottom:100px;right:32px;overflow:hidden;box-shadow:0 10px 40px #0009,inset 0 0 0 1px #ffffff1a}.mcode-panel.expanded{width:min(800px,90vw);height:calc(100vh - 60px);bottom:30px;right:32px}@keyframes slideUp{0%{opacity:0;transform-origin:100% 100%;transform:translateY(20px)scale(.95)}to{opacity:1;transform-origin:100% 100%;transform:translateY(0)scale(1)}}.mcode-header{border-bottom:1px solid var(--border-color);background:#0003;justify-content:space-between;align-items:center;padding:15px 20px;display:flex}.mcode-icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.mcode-icon-btn:hover{color:#fff;background:#ffffff1a}.mcode-messages{scrollbar-width:thin;scroll-behavior:smooth;flex:1;overflow-y:auto}.mcode-suggestions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.mcode-chip{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;text-align:left;background:#ffffff0d;border-radius:20px;padding:8px 14px;font-size:13px;transition:all .2s}.mcode-chip:hover{color:#fff;background:#8b5cf626;border-color:#8b5cf680;transform:translateY(-2px)}.mcode-msg-wrapper{gap:12px;width:100%;display:flex}.mcode-msg--user{justify-content:flex-end}.mcode-msg--ai{justify-content:flex-start}.mcode-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:4px;display:flex}.mcode-avatar.ai{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 0 10px #3b82f64d}.mcode-avatar.user{background:var(--surface-color);border:1px solid var(--border-color)}.mcode-msg-content{border-radius:16px;max-width:85%;padding:12px 16px;line-height:1.5}.user-bubble{background:var(--accent-primary);color:#fff;border-top-right-radius:4px;box-shadow:0 2px 10px #8b5cf633}.ai-bubble{border:1px solid var(--border-color);color:var(--text-primary);background:#0003;border-top-left-radius:4px;font-size:14px}.mcode-msg-image{border:1px solid var(--border-color);border-radius:8px;max-width:100%;margin-bottom:8px}.mcode-msg-file{background:#0003;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;margin-bottom:8px;padding:8px 12px;font-family:monospace;font-size:13px;display:flex}.mcode-input-area{border-top:1px solid var(--border-color);background:#0000004d;flex-direction:column;gap:10px;padding:15px;display:flex}.mcode-attachment-preview{background:var(--surface-color);border:1px solid var(--accent-primary);border-radius:10px;align-items:center;gap:10px;width:fit-content;max-width:100%;padding:8px 12px;display:flex;position:relative}.mcode-attachment-preview img{object-fit:cover;border-radius:6px;width:40px;height:40px}.mcode-attachment-preview .file-icon{width:40px;height:40px;color:var(--accent-primary);background:#ffffff0d;border-radius:6px;justify-content:center;align-items:center;display:flex}.mcode-attachment-preview .file-name{white-space:nowrap;text-overflow:ellipsis;max-width:200px;color:var(--text-secondary);font-size:13px;overflow:hidden}.mcode-attachment-preview .remove-btn{background:var(--danger-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 5px #00000080}.mcode-input-form{background:var(--bg-color);border:1px solid var(--border-color);border-radius:24px;align-items:flex-end;gap:10px;padding:6px 6px 6px 15px;transition:border-color .2s;display:flex}.mcode-input-form:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.mcode-textarea{color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;flex:1;max-height:120px;padding:8px 0;font-family:inherit;font-size:14px;overflow-y:auto}.mcode-textarea::placeholder{color:var(--text-muted)}.input-toolbar{border-right:1px solid var(--border-color);gap:4px;margin-right:8px;padding-bottom:6px;padding-right:8px;display:flex}.toolbar-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.toolbar-btn:hover{color:var(--accent-primary);background:#ffffff1a}.mcode-send-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:2px;transition:all .2s;display:flex}.mcode-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 0 15px #8b5cf666}.mcode-send-btn:disabled{background:var(--border-color);color:var(--text-muted);cursor:not-allowed}@media print{.app-header,.tab-nav,button.no-print,.mcode-fab,.mcode-panel,.ai-chat-container{display:none!important}body,.app-container{-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#000!important;background:#fff!important}.panel,.stat-card,.chart-container{page-break-inside:avoid;break-inside:avoid;box-shadow:none!important;background:#fff!important;border:1px solid #ddd!important}.table-wrapper,div[style*=overflow]{max-height:none!important;overflow:visible!important}h1,h2,h3,h4,h5,.stat-card-value,.stat-card-label,.panel-title{color:#000!important}.badge{color:#333!important;border:1px solid #333!important}canvas{background:#fff!important}}.spin{animation:1s linear infinite spin}.typing-indicator{align-items:center;gap:4px;height:24px;padding:8px 12px;display:flex}.typing-indicator span{background-color:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both bounce}.typing-indicator span:first-child{animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;transform:scale(1)}}
