:root{--bg-main: #FFFFFF;--bg-section: #F7F6F3;--bg-card: #FFFFFF;--bg-card-hover: #FEFCFB;--bg-hero-gradient: linear-gradient(135deg, #FAD0C4 0%, #FFD1A6 50%, #E0C3FC 100%);--accent-primary: #E85D75;--accent-primary-light: #f0899b;--accent-primary-dark: #c94a60;--accent-secondary: #FFB26B;--accent-secondary-light: #ffd1a3;--accent-secondary-dark: #e0964c;--accent-lavender: #E0C3FC;--accent-lavender-dark: #c9a0f0;--gradient-hero: linear-gradient(135deg, #FAD0C4, #FFD1A6, #E0C3FC);--gradient-primary: linear-gradient(135deg, #E85D75, #FFB26B);--gradient-warm: linear-gradient(135deg, #FFB26B, #E85D75);--gradient-cool: linear-gradient(135deg, #E0C3FC, #E85D75);--text-primary: #111111;--text-secondary: #6B7280;--text-muted: #9CA3AF;--text-on-accent: #FFFFFF;--border-light: #E5E7EB;--border-accent: rgba(232, 93, 117, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-pill: 999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .03);--shadow-md: 0 4px 14px rgba(0, 0, 0, .06), 0 2px 6px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .08);--shadow-glow: 0 4px 24px rgba(232, 93, 117, .15);--transition: all .25s cubic-bezier(.4, 0, .2, 1);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{position:relative}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#e85d7533;border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:#e85d7566}h1,h2,h3,h4{font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:0 8px 30px #00000014,0 2px 8px #0000000a;transform:translateY(-3px)}.kpi-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.kpi-card:hover{box-shadow:0 8px 32px #0000001a}.section-title{display:flex;align-items:center;gap:12px;font-size:1.35rem;font-weight:700;margin-bottom:var(--space-lg);color:var(--text-primary)}.section-title .icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.chart-card{padding:var(--space-lg) var(--space-xl);min-height:380px;position:relative;overflow:hidden}.chart-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),var(--accent-lavender));opacity:0;transition:opacity .3s ease}.chart-card:hover:before{opacity:1}.chart-card h3{font-size:.82rem;font-weight:700;color:var(--text-secondary);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:8px}.chart-card h3:before{content:"";width:3px;height:14px;border-radius:2px;background:var(--gradient-primary);flex-shrink:0}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.charts-grid,.kpi-grid{grid-template-columns:1fr}}.custom-tooltip{background:#fffffffa!important;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-light)!important;border-left:3px solid var(--accent-primary)!important;border-radius:var(--radius-sm)!important;padding:12px 16px!important;box-shadow:0 8px 30px #0000001f,0 2px 6px #0000000d;min-width:140px}.custom-tooltip .label{color:var(--text-muted);font-size:.7rem;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.custom-tooltip .value{color:var(--text-primary);font-weight:700;font-size:.92rem;letter-spacing:-.01em}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(1deg)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.animate-in{animation:fadeInUp .6s ease-out both}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.stagger>*:nth-child(6){animation-delay:.3s}.skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.btn-primary{background:var(--accent-primary);color:var(--text-on-accent);box-shadow:0 4px 14px #e85d7540}.btn-primary:hover{background:var(--accent-primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #e85d7559}.btn-outline{background:transparent;color:var(--text-primary);border:1.5px solid var(--border-light)}.btn-outline:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 14px #ef444433}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;min-height:100vh}.app-main{width:100%;min-height:100vh}.app-shell.with-sidebar .app-main{flex:1;min-width:0;overflow-x:hidden}.sidebar{position:fixed;top:0;left:0;bottom:0;width:68px;z-index:100;display:flex;flex-direction:column;background:#fff;border-right:1px solid rgba(0,0,0,.06);transition:width .35s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 24px #0000000a;overflow:hidden}.sidebar.sidebar-expanded{width:230px}.app-shell.with-sidebar .app-main{margin-left:68px;transition:margin-left .35s cubic-bezier(.4,0,.2,1)}.sidebar-header{padding:20px 0 12px;display:flex;align-items:center;justify-content:center;gap:14px;flex-shrink:0;min-height:60px}.sidebar-expanded .sidebar-header{padding:20px 16px 12px;justify-content:flex-start}.sidebar-hamburger{width:40px;height:40px;border:none;background:transparent;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#9ca3af;transition:all .2s ease}.sidebar-hamburger:hover{background:#e85d7514;color:var(--accent-primary)}.sidebar-hamburger svg{display:block;transition:color .2s ease}.sidebar-brand{text-decoration:none;display:none;align-items:center;white-space:nowrap}.sidebar-expanded .sidebar-brand{display:flex}.sidebar-brand-text{font-weight:800;font-size:1.15rem;letter-spacing:-.03em;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.sidebar-divider{height:1px;background:#0000000f;margin:4px 18px;flex-shrink:0;transition:margin .35s ease}.sidebar-expanded .sidebar-divider{margin:4px 16px}.sidebar-nav{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 0;overflow-y:auto;overflow-x:hidden}.sidebar-expanded .sidebar-nav{align-items:stretch;padding:12px}.sidebar-item-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.sidebar-nav-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border-radius:14px;text-decoration:none;border:none;background:transparent;cursor:pointer;color:#b0b0b0;font-family:inherit;font-size:.88rem;font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-expanded .sidebar-nav-btn{width:100%;height:44px;padding:0 14px;border-radius:12px;justify-content:flex-start;gap:14px}.sidebar-nav-btn:hover{background:#e85d750f;color:var(--accent-primary)}.sidebar-nav-btn.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;box-shadow:0 4px 16px #e85d754d}.sidebar-nav-btn.active:hover{box-shadow:0 6px 22px #e85d7566}.sidebar-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{display:block}.sidebar-label{display:none;font-weight:500;overflow:hidden;text-overflow:ellipsis}.sidebar-expanded .sidebar-label{display:block}.sidebar-nav-btn.active .sidebar-label{font-weight:600}.sidebar-tooltip{position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%);background:#1e1e2e;color:#fff;padding:6px 14px;border-radius:8px;font-size:.78rem;font-weight:600;white-space:nowrap;pointer-events:none;z-index:1000;box-shadow:0 4px 14px #0000002e;animation:tooltipIn .15s ease-out;letter-spacing:.01em}.sidebar-tooltip:before{content:"";position:absolute;left:-4px;top:50%;transform:translateY(-50%) rotate(45deg);width:8px;height:8px;background:#1e1e2e}@keyframes tooltipIn{0%{opacity:0;transform:translateY(-50%) translate(-4px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.sidebar-footer{padding:12px 0 20px;display:flex;flex-direction:column;align-items:center}.sidebar-expanded .sidebar-footer{align-items:stretch;padding:12px 12px 20px}.logout-btn{color:#b0b0b0!important}.logout-btn:hover{color:#ef4444!important;background:#ef444414!important}.logout-tooltip{background:#dc2626!important}.logout-tooltip:before{background:#dc2626!important}.mobile-menu-btn{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-primary)}.page-container{max-width:1280px;margin:0 auto;padding:var(--space-2xl) var(--space-xl);min-height:80vh}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-xl)}.page-title{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.page-subtitle{font-size:1rem;color:var(--text-secondary);margin-top:4px}.hero{position:relative;min-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:100px var(--space-xl) var(--space-3xl);overflow:hidden}.hero-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(250,208,196,.15) 0%,rgba(255,209,166,.08) 50%,transparent 100%);z-index:-1}.hero-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.25;z-index:-1}.hero-blob-1{width:400px;height:400px;background:var(--accent-primary);top:-100px;right:-100px;animation:float 12s ease-in-out infinite}.hero-blob-2{width:300px;height:300px;background:var(--accent-secondary);bottom:-50px;left:-80px;animation:float 15s ease-in-out infinite reverse}.hero-blob-3{width:250px;height:250px;background:var(--accent-lavender);top:40%;left:65%;animation:float 10s ease-in-out infinite}.hero-content{max-width:800px}.hero-eyebrow{display:inline-block;padding:6px 16px;background:#e85d750f;color:var(--accent-primary);border-radius:var(--radius-full);font-size:.82rem;font-weight:600;margin-bottom:var(--space-lg)}.hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15;letter-spacing:-.04em;margin-bottom:var(--space-lg);color:var(--text-primary)}.highlight{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{font-size:1.1rem;line-height:1.7;color:var(--text-secondary);max-width:580px;margin:0 auto var(--space-xl)}.hero-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.hero-cards{display:flex;gap:var(--space-lg);justify-content:center;margin-top:var(--space-2xl);flex-wrap:wrap}.hero-float-card{padding:20px 24px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:left;min-width:170px;animation:float 6s ease-in-out infinite}.hero-float-card:nth-child(2){animation-delay:-1.5s}.hero-float-card:nth-child(3){animation-delay:-3s}.card-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600;margin-bottom:4px}.card-value{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.card-tag{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600}.tag-green{background:#10b9811a;color:#10b981}.tag-rose{background:#e85d751a;color:#e85d75}.tag-amber{background:#ffb26b1a;color:#d97706}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.feature-card{padding:var(--space-xl);text-align:center;transition:var(--transition-smooth)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{font-size:2rem;margin-bottom:var(--space-md)}.feature-card h4{font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--text-primary)}.feature-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.6}.deliverables-section{max-width:1280px;margin:0 auto;padding:var(--space-2xl)}.deliverables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg)}.deliverable-card{position:relative;padding:var(--space-xl);overflow:hidden;transition:var(--transition-smooth);cursor:pointer}.deliverable-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.deliverable-accent{position:absolute;top:0;left:0;right:0;height:3px}.deliverable-icon{font-size:2rem;margin-bottom:var(--space-sm)}.deliverable-card h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.deliverable-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.deliverable-arrow{position:absolute;bottom:16px;right:16px;font-size:1.2rem;color:var(--text-muted);transition:var(--transition-fast)}.deliverable-card:hover .deliverable-arrow{color:var(--accent-primary);transform:translate(3px)}.tech-stack-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm)}.tech-badge{display:flex;flex-direction:column;align-items:center;padding:14px 20px;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border);transition:var(--transition-fast)}.tech-badge:hover{border-color:var(--accent-primary);box-shadow:0 2px 12px #e85d7514}.tech-badge strong{font-size:.88rem;color:var(--text-primary)}.tech-badge span{font-size:.72rem;color:var(--text-muted)}.tab-nav{display:flex;justify-content:center;gap:4px;background:#ffffffa6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:5px 8px;border-radius:16px;margin:0 auto var(--space-xl) auto;width:fit-content;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 20px #0000000d,inset 0 1px #fffc}.tab-btn{display:flex;align-items:center;gap:8px;padding:11px 24px;border:none;background:transparent;border-radius:12px;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text-muted);white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;letter-spacing:.02em}.tab-btn:hover{color:var(--text-primary);background:#e85d750f;transform:translateY(-1px)}.tab-btn.active{background:#fff;color:var(--text-primary);font-weight:600;box-shadow:0 4px 16px #e85d751f,0 1px 4px #0000000f}.tab-btn.active:after{content:"";position:absolute;bottom:2px;left:25%;right:25%;height:3px;border-radius:3px;background:linear-gradient(90deg,#e85d75,#ffb26b);box-shadow:0 1px 6px #e85d754d}.tab-btn.active .tab-icon{color:#e85d75}.tab-icon{display:inline-flex;align-items:center;transition:color .3s ease}.btn svg,.tab-btn svg,.btn-primary svg,.btn-outline svg,.btn-danger svg,.btn-fix svg,.btn-scan svg{flex-shrink:0}.live-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;font-weight:600;color:#e85d75;background:#e85d7514;border:1px solid rgba(232,93,117,.15);border-radius:12px;box-shadow:0 2px 8px #e85d7514}.live-dot{width:7px;height:7px;border-radius:50%;background:#e85d75;box-shadow:0 0 6px #e85d7566;animation:pulse-dot 2s ease-in-out infinite}.dashboard-section{margin-bottom:var(--space-xl)}.section-title{display:flex;align-items:center;gap:var(--space-sm);font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-lg)}.section-title .icon{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}.section-bg{background:var(--bg-tint);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-lg)}.charts-grid .full-width{grid-column:1 / -1}.chart-card{padding:var(--space-xl)}.chart-card h3{font-size:.92rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md)}.arch-header-badge{display:flex;align-items:center;gap:8px;padding:6px 16px;font-size:.75rem;font-weight:600;color:#10b981;background:#10b98114;border:1px solid rgba(16,185,129,.15);border-radius:12px;position:relative}.arch-pulse-ring{width:8px;height:8px;border-radius:50%;background:#10b981;position:relative}.arch-pulse-ring:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid #10b981;animation:arch-pulse 2s ease-out infinite}@keyframes arch-pulse{0%{transform:scale(.8);opacity:.8}to{transform:scale(2);opacity:0}}.arch-pipeline{display:flex;flex-direction:column;align-items:center}.arch-connector{display:flex;flex-direction:column;align-items:center;height:52px;position:relative}.arch-connector-track{position:relative;width:2px;flex:1;overflow:visible}.arch-connector-line{width:100%;height:100%;border-radius:2px;opacity:.4}.arch-flow-dot{position:absolute;width:6px;height:6px;border-radius:50%;left:-2px;animation:arch-dot-flow 2s ease-in-out infinite}.arch-flow-dot-2{animation-delay:1s}@keyframes arch-dot-flow{0%{top:-4px;opacity:0}20%{opacity:1}80%{opacity:1}to{top:calc(100% + 4px);opacity:0}}.arch-connector-arrow{display:flex;align-items:center;justify-content:center;animation:arch-arrow-bounce 2s ease-in-out infinite}@keyframes arch-arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}.arch-stage{width:100%;max-width:720px;padding:28px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);position:relative;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);opacity:0;transform:translateY(30px) scale(.97);transition:all .5s cubic-bezier(.4,0,.2,1)}.arch-stage-visible{opacity:1;transform:translateY(0) scale(1)}.arch-stage:hover{box-shadow:0 12px 40px #0000001a,0 4px 12px #0000000d;transform:translateY(-3px) scale(1.005);border-color:var(--stage-color)}.arch-stage-expanded{border-color:var(--stage-color)}.arch-stage-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--stage-color),var(--stage-grad-end));opacity:.8;transition:height .3s ease,opacity .3s ease}.arch-stage:hover .arch-stage-accent,.arch-stage-expanded .arch-stage-accent{height:4px;opacity:1}.arch-stage-orb{position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;pointer-events:none;transition:transform .5s ease,opacity .3s ease;opacity:.5}.arch-stage:hover .arch-stage-orb{transform:scale(1.3);opacity:.8}.arch-stage-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;position:relative}.arch-stage-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .3s ease;flex-shrink:0}.arch-stage:hover .arch-stage-icon{transform:scale(1.1)}.arch-icon-ring{position:absolute;inset:-4px;border-radius:18px;border:2px dashed;opacity:0;transition:opacity .3s ease;animation:arch-spin 8s linear infinite}.arch-stage:hover .arch-icon-ring{opacity:1}@keyframes arch-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.arch-stage-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.arch-stage-step{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:2px}.arch-step-num{width:16px;height:16px;border-radius:50%;color:#fff;font-size:.55rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.arch-expand-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.arch-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;position:relative}.arch-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--bg-tint);border-radius:var(--radius-md);border:1px solid transparent;transition:all .2s ease}.arch-item:hover{border-color:var(--stage-color);background:#fffc;transform:translate(4px)}.arch-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}.arch-item-name{font-size:.82rem;font-weight:600;color:var(--text-primary)}.arch-item-desc{font-size:.7rem;color:var(--text-muted);margin-top:1px}.arch-item-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border:1px solid;white-space:nowrap;flex-shrink:0}.arch-detail{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .3s ease;opacity:0}.arch-detail-open{max-height:250px;opacity:1}.arch-detail-inner{padding-top:16px}.arch-detail-divider{height:1px;margin-bottom:14px}.arch-detail-inner p{font-size:.86rem;line-height:1.75;color:var(--text-secondary);margin:0}.arch-summary{margin-top:var(--space-2xl);padding:32px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.arch-summary-header{display:flex;align-items:center;gap:10px;margin-bottom:24px}.arch-summary-icon{width:36px;height:36px;border-radius:10px;background:#e85d7514;color:#e85d75;display:flex;align-items:center;justify-content:center}.arch-summary-header h3{font-size:1.1rem;font-weight:700;margin:0;color:var(--text-primary)}.arch-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:16px}.arch-summary-stat{text-align:center;padding:16px 8px;background:var(--bg-tint);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all .3s ease}.arch-summary-stat:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000000f;border-color:var(--stat-color)}.arch-stat-value{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--stat-color);display:block;transform:translateY(10px);opacity:0;transition:all .5s cubic-bezier(.4,0,.2,1)}.arch-stat-visible{transform:translateY(0);opacity:1}.arch-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:4px}.arch-stat-bar{height:3px;background:#0000000a;border-radius:3px;margin-top:10px;overflow:hidden}.arch-stat-bar-fill{height:100%;width:0;border-radius:3px;animation:arch-bar-fill 1s ease-out forwards}@keyframes arch-bar-fill{to{width:100%}}.pipeline-flow,.flow-summary-grid{display:none}.dq-score-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.dq-score-card{padding:var(--space-xl);display:flex;align-items:center;gap:var(--space-xl)}.dq-score-ring{position:relative;display:flex;align-items:center;justify-content:center}.dq-score-text{position:absolute;text-align:center}.dq-score-number{font-size:1.6rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.dq-score-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.dq-score-meta{display:flex;flex-direction:column;gap:var(--space-md)}.dq-meta-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.dq-meta-label{display:block;font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.dq-records-card{padding:var(--space-xl)}.dq-records-card h3{font-size:.95rem;font-weight:700;margin-bottom:var(--space-md)}.dq-record-bars{display:flex;flex-direction:column;gap:var(--space-md)}.record-bar-header{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-secondary);margin-bottom:4px}.record-count{font-weight:600;color:var(--text-primary)}.record-bar-bg{height:8px;background:var(--bg-tint);border-radius:var(--radius-full);overflow:hidden}.record-bar-fill{height:100%;border-radius:var(--radius-full);transition:width 1s ease}.dq-checks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-sm)}.dq-check-card{display:flex;align-items:center;gap:var(--space-sm);padding:14px var(--space-md);position:relative}.check-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.check-icon{font-size:1.1rem;flex-shrink:0}.check-info{flex:1;min-width:0}.check-name{font-size:.82rem;font-weight:600;color:var(--text-primary)}.check-table{font-size:.7rem;color:var(--text-muted)}.check-result{text-align:right;flex-shrink:0}.check-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:700;letter-spacing:.05em}.check-badge.pass{background:#10b9811a;color:#10b981}.check-badge.fail{background:#e85d751a;color:#e85d75}.check-count{font-size:.68rem;color:var(--text-muted);margin-top:2px}.check-type-badge{position:absolute;top:6px;right:8px;font-size:.58rem;color:var(--text-muted);background:var(--bg-tint);padding:1px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.profiling-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-sm)}.profiling-stat{padding:var(--space-md) var(--space-lg);position:relative;overflow:hidden}.profiling-accent{position:absolute;top:0;left:0;width:3px;height:100%}.profiling-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:4px}.profiling-value{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.schema-diagram{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl)}.schema-card{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;min-width:180px}.schema-card-header{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:2px 8px;border-radius:var(--radius-sm);display:inline-block;margin-bottom:6px}.schema-card-header.fact{background:#e85d751a;color:#e85d75}.schema-card-header.dim{background:#ffb26b1a;color:#d97706}.schema-card-header.scd{background:#8b5cf61a;color:#8b5cf6}.schema-card-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:8px;font-family:Courier New,monospace}.schema-cols{list-style:none;padding:0;margin:0;font-size:.78rem;color:var(--text-secondary);line-height:1.8;font-family:Courier New,monospace}.col-key{display:inline-block;width:24px;padding:0 4px;font-size:.62rem;font-weight:700;background:#e85d7514;color:#e85d75;border-radius:3px;text-align:center;margin-right:4px}.scd-badge{margin-top:8px;display:inline-block;padding:2px 8px;background:#8b5cf614;color:#8b5cf6;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600}.fact-card{border:2px solid var(--accent-primary)}.schema-dimensions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);width:100%}.dim-card{transition:var(--transition-fast)}.dim-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.schema-relations-label{font-size:.75rem;color:var(--text-muted);text-align:center;padding:8px}.comparison-table{width:100%;border-collapse:collapse;font-size:.85rem}.comparison-table th{text-align:left;padding:12px 16px;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:2px solid var(--border)}.comparison-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.comparison-table .feature-name{font-weight:600;color:var(--text-primary)}.comparison-table .highlight-col{background:#e85d7508}.comparison-table tr:hover td{background:#00000003}.partition-tree{font-family:Courier New,monospace;font-size:.85rem;line-height:2;color:var(--text-primary);margin-bottom:var(--space-xl)}.ptree-root{font-weight:700;font-size:1rem}.ptree-level-1{padding-left:var(--space-xl);border-left:2px solid var(--border)}.ptree-level-2{padding-left:var(--space-lg);border-left:2px dashed rgba(0,0,0,.08)}.ptree-level-3{padding-left:var(--space-lg);border-left:2px dashed rgba(0,0,0,.06)}.ptree-branch{font-weight:600}.ptree-icon{margin-right:6px}.ptree-size{color:var(--text-muted);font-size:.75rem}.ptree-more{color:var(--text-muted);font-style:italic}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md)}.benefit-item{display:flex;gap:var(--space-sm)}.benefit-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}.benefit-item strong{font-size:.88rem;color:var(--text-primary)}.benefit-item p{font-size:.78rem;color:var(--text-secondary);margin:2px 0 0;line-height:1.5}.partition-benefits h4{font-size:1rem;font-weight:700;margin-bottom:var(--space-md);color:var(--text-primary)}.security-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-md)}.security-card{padding:var(--space-xl);transition:var(--transition-smooth)}.security-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.security-icon{font-size:2rem;margin-bottom:var(--space-sm)}.security-card h4{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.security-card p{font-size:.82rem;color:var(--text-secondary);line-height:1.65}.site-footer{text-align:center;padding:var(--space-xl);font-size:.82rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:var(--space-xl)}.footer-brand{font-weight:700;color:var(--accent-primary)}.custom-tooltip{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;box-shadow:var(--shadow-md)}.custom-tooltip .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:600}.custom-tooltip .value{font-size:.92rem;font-weight:700;color:var(--text-primary)}@media(max-width:768px){.sidebar{display:none}.app-shell.with-sidebar .app-main{margin-left:0}.page-container{padding:var(--space-xl) var(--space-md)}.charts-grid,.dq-score-section{grid-template-columns:1fr}.tab-nav{flex-wrap:nowrap;overflow-x:auto}.hero h1{font-size:1.8rem}.hero-cards{flex-direction:column;align-items:center}.schema-dimensions{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:420px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted)}.manual-form{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:16px}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem}.form-group input:focus{border-color:var(--accent-primary);outline:none}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.btn-text{background:none;border:none;color:var(--text-secondary);font-weight:600;cursor:pointer}.btn-text:hover{color:var(--text-primary)}.btn-primary{background:linear-gradient(135deg,#ffb26b,#e85d75)!important;border:none!important;color:#fff!important;box-shadow:0 4px 15px #ffb26b66!important;background-size:200% auto!important;transition:all .4s ease!important}.btn-primary:hover{background-position:right center!important;transform:translateY(-2px);box-shadow:0 8px 25px #e85d7580!important}.tab-btn.active .tab-icon{color:var(--accent-secondary)!important}.tab-btn.active:after{background:linear-gradient(90deg,var(--accent-secondary),var(--accent-secondary-dark))!important}.start-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;background:var(--bg-main)}.start-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(250,208,196,.18) 0%,rgba(224,195,252,.1) 50%,transparent 100%);z-index:0}.start-blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.22;z-index:0}.start-blob-1{width:420px;height:420px;background:var(--accent-primary);top:-120px;right:-80px;animation:float 14s ease-in-out infinite}.start-blob-2{width:340px;height:340px;background:var(--accent-secondary);bottom:-80px;left:-100px;animation:float 17s ease-in-out infinite reverse}.start-blob-3{width:260px;height:260px;background:var(--accent-lavender);top:35%;left:60%;animation:float 11s ease-in-out infinite}.start-content{position:relative;z-index:1;max-width:620px;padding:var(--space-xl)}.start-logo{display:inline-flex;align-items:center;gap:10px;font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-2xl)}.start-logo .logo-dot{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))}.start-content h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;line-height:1.12;letter-spacing:-.04em;margin-bottom:var(--space-lg)}.start-content p{font-size:1.1rem;line-height:1.7;color:var(--text-secondary);max-width:480px;margin:0 auto var(--space-2xl)}.start-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 40px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-pill);font-family:inherit;font-size:1.05rem;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:0 6px 24px #e85d754d}.start-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 36px #e85d7566}.start-btn .arrow{font-size:1.2rem;transition:transform .25s ease}.start-btn:hover .arrow{transform:translate(4px)}.start-footer{position:absolute;bottom:var(--space-xl);font-size:.78rem;color:var(--text-muted);z-index:1}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-main)}.login-bg{position:absolute;inset:0;background:linear-gradient(135deg,#fad0c41f,#e0c3fc14);z-index:0}.login-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.18;z-index:0}.login-blob-1{width:350px;height:350px;background:var(--accent-primary);top:-100px;left:-60px;animation:float 13s ease-in-out infinite}.login-blob-2{width:280px;height:280px;background:var(--accent-lavender);bottom:-80px;right:-60px;animation:float 16s ease-in-out infinite reverse}.login-card{position:relative;z-index:1;width:100%;max-width:420px;padding:var(--space-2xl);background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);box-shadow:0 16px 64px #00000014,0 2px 8px #0000000a;margin:var(--space-xl)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{display:inline-flex;align-items:center;gap:8px;font-size:1.3rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-md)}.login-logo .logo-dot{width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))}.login-header h2{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.login-header p{font-size:.88rem;color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.82rem;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}.form-group input{padding:12px 16px;border:1.5px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:.92rem;color:var(--text-primary);background:#fffc;transition:var(--transition);outline:none}.form-group input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e85d751a}.form-group input::placeholder{color:var(--text-muted)}.login-error{padding:10px 14px;background:#ef444414;color:#dc2626;border-radius:var(--radius-sm);font-size:.82rem;font-weight:500;text-align:center;animation:fadeInUp .3s ease-out}.login-submit{padding:14px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:0 4px 16px #e85d7540;margin-top:var(--space-sm)}.login-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px #e85d7559}.login-submit:active{transform:translateY(0)}.login-credentials{margin-top:var(--space-md);padding:12px 14px;border:1px dashed var(--border-light);border-radius:var(--radius-md);background:#fff9;text-align:center}.login-credentials-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.login-credentials p{margin:2px 0;font-size:.84rem;color:var(--text-secondary)}.login-credentials strong{color:var(--text-primary)}.login-back{display:inline-flex;align-items:center;gap:6px;margin-top:var(--space-lg);background:none;border:none;color:var(--text-muted);font-family:inherit;font-size:.82rem;font-weight:500;cursor:pointer;transition:var(--transition);align-self:center}.login-back:hover{color:var(--accent-primary)}:root{--arch-card-bg: rgba(255, 255, 255, .85);--arch-card-border: rgba(255, 255, 255, .6);--arch-shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--arch-shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--arch-shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--arch-font-family: "Inter", system-ui, -apple-system, sans-serif}.arch-container{padding-bottom:5rem;font-family:var(--arch-font-family);color:var(--text-primary)}.arch-header-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#10b98114;border:1px solid rgba(16,185,129,.2);border-radius:9999px;color:#059669;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #10b9810d}.arch-pulse-ring{width:8px;height:8px;background:#10b981;border-radius:50%;position:relative}.arch-pulse-ring:after{content:"";position:absolute;inset:-4px;border-radius:50%;background:#10b98166;animation:pulse-ring 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.8}to{transform:scale(2.4);opacity:0}}.schema-section{margin:var(--space-2xl) 0;padding:0;background:linear-gradient(135deg,#f8fafc,#eff6ff);border:1px solid rgba(226,232,240,.8);border-radius:24px;position:relative;overflow:hidden;box-shadow:var(--arch-shadow-lg),inset 0 0 0 1px #ffffff80}.schema-bg-grid{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(rgba(148,163,184,.2) 1px,transparent 1px);background-size:24px 24px;-webkit-mask-image:radial-gradient(circle at center,black 40%,transparent 100%);mask-image:radial-gradient(circle at center,black 40%,transparent 100%);z-index:0}.schema-visual-container{position:relative;z-index:1;height:600px;width:100%;display:flex;justify-content:center;align-items:center}.schema-connections{position:absolute;inset:0;z-index:0;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.05))}.connection-path{fill:none;stroke:#cbd5e1;stroke-width:2;stroke-dasharray:8 8;stroke-linecap:round;animation:dash-flow 40s linear infinite;opacity:.6}.connection-path.highlighted{stroke:var(--accent-primary);stroke-width:3;stroke-dasharray:0;opacity:1;transition:all .3s ease;filter:drop-shadow(0 0 6px rgba(232,93,117,.4))}@keyframes dash-flow{to{stroke-dashoffset:-1000}}.schema-node{background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.8);border-radius:16px;width:240px;position:absolute;box-shadow:0 10px 40px -10px #0000001a,0 0 0 1px #00000005;transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;z-index:1}.schema-node:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 50px -12px #00000026,0 0 0 1px rgba(var(--accent-primary),.2);z-index:10;border-color:#e85d754d}.node-fact{background:#fff;border:1px solid rgba(15,23,42,.1)}.node-fact .node-header{background:linear-gradient(135deg,#0f172a,#334155);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.node-dim .node-header{background:linear-gradient(to bottom,#f8fafc,#f1f5f9);color:#334155;border-bottom:1px solid #e2e8f0}.node-header{padding:12px 16px;font-weight:700;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:10px}.node-columns{padding:8px 0}.node-col{padding:8px 16px;font-size:.8rem;color:#64748b;display:flex;justify-content:space-between;align-items:center;font-family:JetBrains Mono,Fira Code,monospace;transition:background .2s;cursor:default}.node-col:hover{background:#f8fafc;color:#0f172a}.node-col.pk{font-weight:700;color:#0f172a;background:#fef3c74d}.key-badge{font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:800;letter-spacing:.02em}.key-pk{background:#fef3c7;color:#d97706;border:1px solid #fcd34d}.key-fk{background:#f3e8ff;color:#9333ea;border:1px solid #d8b4fe}.pos-center{top:50%;left:50%;transform:translate(-50%,-50%);z-index:5}.pos-top-left{top:10%;left:10%}.pos-top-right{top:10%;right:10%}.pos-bottom-left{bottom:10%;left:10%}.pos-bottom-right{bottom:10%;right:10%}.arch-pipeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:40px;margin-bottom:60px}.arch-stage-card-simple{background:#fff;border-radius:16px;padding:24px;border:1px solid var(--border-light);box-shadow:var(--arch-shadow-sm);transition:all .3s ease;position:relative;overflow:hidden}.arch-stage-card-simple:hover{transform:translateY(-4px);box-shadow:var(--arch-shadow-lg);border-color:#0000001a}.arch-stage-card-simple:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,currentColor,transparent);opacity:.2}.arch-items-grid{display:flex;flex-direction:column;gap:8px;margin:16px 0}.arch-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-secondary)}.arch-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.arch-detail-text{font-size:.85rem;color:#94a3b8;line-height:1.6;border-top:1px solid #f1f5f9;padding-top:12px;margin-top:12px}.tech-stack-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.arch-tech-badge{display:inline-flex;align-items:center;background:#fff;border:1px solid #e2e8f0;padding:10px 18px;border-radius:12px;font-size:.9rem;font-weight:600;color:#475569;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d;cursor:default}.arch-tech-badge:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 12px #00000014;color:#0f172a}.animate-in{animation:fadeUp .8s cubic-bezier(.2,.8,.2,1) backwards}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}:root{--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .5);--glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, .07);--font-primary: "Inter", system-ui, -apple-system, sans-serif}.dq-container{display:flex;flex-direction:column;gap:var(--space-xl);padding-bottom:4rem;font-family:var(--font-primary)}.dq-section-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:12px;animation:slideUpFade .6s ease-out backwards}.dq-section-title .icon-bg{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e85d751a,#ffb26b1a);color:var(--accent-primary);box-shadow:0 2px 8px #e85d751a}.dq-hero-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}@media(max-width:1024px){.dq-hero-grid{grid-template-columns:1fr}}.dq-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:20px;padding:24px;box-shadow:var(--shadow-sm),0 4px 20px #00000005;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden;animation:slideUpFade .7s cubic-bezier(.2,.8,.2,1) backwards}.dq-card:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(135deg,#fff6,#fff0);pointer-events:none;z-index:0}.dq-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 30px #00000014,0 4px 12px #0000000a;border-color:#e85d7533}.dq-card-content{position:relative;z-index:1}.dq-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,.04)}.dq-card-title{font-size:1rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:10px}.score-circle-svg{transform:rotate(-90deg);transform-origin:50% 50%}.score-circle-bg{stroke:#0000000f}.score-circle-progress{stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.2,.8,.2,1);filter:drop-shadow(0 0 4px rgba(0,0,0,.1))}.score-value-display{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.dq-stat-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px dashed rgba(0,0,0,.08)}.dq-stat-row:last-child{border-bottom:none}.dq-stat-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.dq-stat-value{font-weight:700;font-size:1rem;color:var(--text-primary);font-feature-settings:"tnum"}.progress-group{display:flex;flex-direction:column;gap:16px;margin-top:12px}.progress-header{display:flex;justify-content:space-between;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}.progress-track{height:10px;background:#0000000a;border-radius:10px;overflow:hidden;box-shadow:inset 0 1px 2px #0000000d}.progress-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));box-shadow:0 0 10px #e85d7566;transition:width 1.2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;width:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transform:translate(-100%);animation:shimmer 2.5s infinite}.checks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.check-card{background:#fff;border:1px solid transparent;border-radius:16px;padding:20px;box-shadow:0 2px 10px #00000008;transition:all .3s ease;cursor:default;position:relative;overflow:hidden;animation:scaleIn .5s cubic-bezier(.175,.885,.32,1.275) backwards}.check-card:hover{transform:translateY(-3px);box-shadow:0 10px 25px #0000000f}.check-card.status-fail{background:linear-gradient(145deg,#fff5f6,#fff);border:1px solid rgba(232,93,117,.15)}.check-card.status-pass{background:linear-gradient(145deg,#f0fdf4,#fff);border:1px solid rgba(16,185,129,.15)}.check-badge{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px}.check-badge:before{content:"";display:block;width:6px;height:6px;border-radius:50%}.check-badge.pass{background:#fff;color:#10b981;box-shadow:0 2px 8px #10b98133}.check-badge.pass:before{background:#10b981}.check-badge.fail{background:#fff;color:#ef4444;box-shadow:0 2px 8px #ef444433}.check-badge.fail:before{background:#ef4444}.check-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:12px 0 4px}.check-table-tag{display:inline-block;padding:4px 8px;background:#0000000a;border-radius:6px;color:var(--text-secondary);font-size:.75rem;font-family:JetBrains Mono,monospace;font-weight:500;margin-bottom:12px}.check-stat-row{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(0,0,0,.04);font-size:.9rem}.profiling-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.profiling-card{background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:16px;padding:24px;display:flex;flex-direction:column;align-items:flex-start;transition:all .3s ease;animation:slideUpFade .6s ease-out backwards}.profiling-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000000f;border-color:#00000014}.profiling-icon-box{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:#fff;font-size:1.25rem;box-shadow:0 4px 12px #0000001a}.profiling-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.profiling-value{font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes pulse-ring{0%{transform:scale(.95);box-shadow:0 0 #e85d75b3}70%{transform:scale(1);box-shadow:0 0 0 10px #e85d7500}to{transform:scale(.95);box-shadow:0 0 #e85d7500}}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}:root{--sec-shield-color: #10b981;--sec-lock-color: #f59e0b;--sec-risk-color: #ef4444}.sec-container{padding-bottom:5rem;font-family:var(--font-primary, "Inter", sans-serif);color:var(--text-primary, #1e293b)}.sec-hero{position:relative;border-radius:24px;background:linear-gradient(135deg,#0f172a,#1e293b);padding:40px;color:#fff;overflow:hidden;box-shadow:0 20px 40px -10px #0f172a4d;margin-bottom:40px}.sec-hero-content{position:relative;z-index:1;max-width:600px}.sec-hero h1{font-size:2.5rem;font-weight:800;margin-bottom:12px;background:linear-gradient(to right,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sec-hero p{font-size:1.1rem;color:#cbd5e1;line-height:1.6}.sec-shield-bg{position:absolute;right:-50px;top:-50px;width:300px;height:300px;background:radial-gradient(circle,rgba(16,185,129,.15) 0%,transparent 70%);z-index:0;border-radius:50%;animation:pulse-shield 4s infinite ease-in-out}@keyframes pulse-shield{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}.sec-dictionary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.sec-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000000d}.sec-table-card:hover{transform:translateY(-4px);box-shadow:0 12px 20px -5px #0000001a;border-color:#cbd5e1}.sec-card-header{padding:16px 20px;font-weight:700;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.sec-card-header.fact{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#0f172a}.sec-card-header.dim{background:#fff;color:#475569}.sec-badge{font-size:.7rem;padding:4px 8px;border-radius:6px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sec-badge.scd{background:#fef3c7;color:#d97706}.sec-badge.static{background:#f1f5f9;color:#64748b}.sec-col-list{padding:16px 20px;display:flex;flex-direction:column;gap:8px}.sec-col-item{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-family:JetBrains Mono,monospace;color:#64748b;padding:4px 8px;border-radius:6px}.sec-col-item:hover{background:#f8fafc}.sec-key{font-size:.65rem;font-weight:800;padding:2px 6px;border-radius:4px;margin-right:8px}.sec-key.pk{background:#fef3c7;color:#b45309}.sec-key.fk{background:#f3e8ff;color:#7e22ce}.sec-tree-container{background:#0f172a;border-radius:16px;padding:24px;color:#bfdbfe;font-family:Fira Code,monospace;font-size:.9rem;box-shadow:inset 0 2px 10px #00000080;overflow-x:auto}.tree-line{display:flex;align-items:center;border-left:1px solid rgba(255,255,255,.1);margin-left:10px;padding:4px 0 4px 16px;position:relative}.tree-line:before{content:"";position:absolute;left:0;top:50%;width:12px;height:1px;background:#ffffff1a}.tree-icon{opacity:.7;margin-right:8px;color:#60a5fa}.tree-file{color:#e2e8f0}.tree-meta{margin-left:auto;color:#475569;font-size:.8rem}.rbac-wrapper{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:var(--arch-shadow-sm, 0 4px 6px rgba(0, 0, 0, .05))}.rbac-table{width:100%;border-collapse:collapse}.rbac-table th{background:#f8fafc;padding:16px;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.rbac-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;color:#334155}.perm-check{color:#10b981;font-weight:700}.perm-cross{color:#ef4444;opacity:.4}.perm-partial{color:#f59e0b;font-weight:500;font-size:.85rem}.sec-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.sec-feature-card{background:#fff;border-radius:16px;padding:24px;border:1px solid transparent;background-clip:padding-box;position:relative;transition:all .3s ease;box-shadow:0 4px 10px #00000008;display:flex;flex-direction:column;gap:12px}.sec-feature-card:after{content:"";position:absolute;inset:-1px;border-radius:16px;background:linear-gradient(135deg,#e2e8f0,#f1f5f9);z-index:-1;transition:background .3s ease}.sec-feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000000f}.sec-feature-card:hover:after{background:linear-gradient(135deg,var(--accent-primary, #E85D75),var(--accent-secondary, #FFB26B))}.sec-icon-box{width:48px;height:48px;border-radius:12px;background:#f1f5f9cc;display:flex;align-items:center;justify-content:center;color:#334155;margin-bottom:8px}.sec-feature-card:hover .sec-icon-box{background:#fff;color:var(--accent-primary)}.sec-feature-title{font-weight:700;font-size:1.05rem}.sec-feature-desc{font-size:.9rem;color:#64748b;line-height:1.5}.fade-in-up{animation:fadeInUp .6s ease-out backwards}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dl-explorer-container{background:#1e1e1e;border-radius:12px;overflow:hidden;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;color:#ccc;box-shadow:0 10px 30px #0000004d;border:1px solid #333}.dl-header{background:#252526;padding:10px 16px;border-bottom:1px solid #333;display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;text-transform:uppercase;color:#999}.dl-action-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-left:6px}.dl-tree-content{padding:8px 0;max-height:400px;overflow-y:auto}.dl-item-row{display:flex;align-items:center;padding:4px 8px;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none;border-left:2px solid transparent;width:100%}.dl-item-row:hover{background:#2a2d2e}.dl-item-row.active{background:#37373d;border-left-color:#007acc}.dl-arrow{margin-right:4px;font-size:10px;color:#c5c5c5;width:16px;display:flex;justify-content:center;transition:transform .15s ease}.dl-arrow.expanded{transform:rotate(90deg)}.dl-icon{margin-right:6px;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.dl-text-name{color:#e8e8e8}.dl-text-dim{color:#888;font-size:12px;margin-left:8px}.dl-size-badge{margin-left:auto;font-size:11px;color:#666;font-family:sans-serif}.dl-preview-pane{border-top:1px solid #333;padding:16px;background:#1e1e1e;font-family:JetBrains Mono,monospace;font-size:12px;color:#a9b7c6;max-height:300px;overflow:auto}.dl-line{display:block;line-height:1.5;white-space:pre}.dl-line-num{color:#606366;margin-right:12px;-webkit-user-select:none;user-select:none;display:inline-block;width:24px;text-align:right}.dl-key{color:#9cdcfe}.dl-str{color:#ce9178}.dl-num{color:#b5cea8}.dl-cmt{color:#6a9955}.chat-page{max-width:900px;margin:0 auto;padding:var(--space-2xl) var(--space-xl) var(--space-xl);display:flex;flex-direction:column;min-height:100vh}.chat-header{text-align:center;margin-bottom:var(--space-xl)}.chat-header h1{font-size:1.8rem;font-weight:800;letter-spacing:-.03em;display:flex;align-items:center;justify-content:center;gap:10px}.chat-header p{color:var(--text-secondary);font-size:.92rem;margin-top:4px}.chat-quick-asks{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:var(--space-lg)}.quick-ask-btn{padding:8px 16px;background:#ffb26b1a;color:#e0964c;border:1px solid rgba(255,178,107,.2);border-radius:var(--radius-pill);font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition)}.quick-ask-btn:hover{background:#ffb26b26;border-color:#e0964c;transform:translateY(-1px);color:#d97706}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md) 0;margin-bottom:var(--space-md)}.chat-bubble{max-width:85%;padding:14px 18px;border-radius:var(--radius-lg);font-size:.9rem;line-height:1.65;animation:fadeInUp .3s ease-out}.chat-bubble.user{align-self:flex-end;background:linear-gradient(135deg,#ffb26b,#e85d75);background-size:200% auto;color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 12px #ffb26b40}.chat-bubble.bot{align-self:flex-start;background:var(--bg-section);color:var(--text-primary);border:1px solid var(--border-light);border-bottom-left-radius:4px}.chat-bubble.bot pre{white-space:pre-wrap;word-wrap:break-word;font-family:inherit;margin:0;font-size:inherit;line-height:inherit}.chat-bubble .bubble-label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;opacity:.7}.chat-bubble.user .bubble-label{color:#ffffffd9}.chat-bubble.bot .bubble-label{color:#ffb26b}.chat-typing{align-self:flex-start;display:flex;align-items:center;gap:6px;padding:14px 18px;background:var(--bg-section);border:1px solid var(--border-light);border-radius:var(--radius-lg);border-bottom-left-radius:4px}.typing-dot{width:8px;height:8px;border-radius:50%;background:#ffb26b;opacity:.4;animation:typingBounce 1.4s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.chat-input-bar{display:flex;gap:var(--space-sm);padding:var(--space-md);background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);position:sticky;bottom:var(--space-md)}.chat-input-bar input{flex:1;padding:12px 16px;border:1.5px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:.92rem;color:var(--text-primary);background:#fff;outline:none;transition:var(--transition)}.chat-input-bar input:focus{border-color:#ffb26b;box-shadow:0 0 0 3px #ffb26b26}.chat-input-bar input::placeholder{color:var(--text-muted)}.chat-send-btn{padding:12px 20px;background:linear-gradient(135deg,#ffb26b,#e85d75);background-size:200% auto;color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .4s ease;box-shadow:0 4px 14px #ffb26b4d;display:flex;align-items:center;gap:6px}.chat-send-btn:hover{background-position:right center;transform:translateY(-2px);box-shadow:0 6px 20px #e85d7566}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.chat-welcome{text-align:center;padding:var(--space-2xl) var(--space-xl);color:var(--text-secondary)}.chat-welcome .welcome-icon{font-size:3rem;margin-bottom:var(--space-md);display:block}.chat-welcome h3{font-size:1.2rem;color:var(--text-primary);margin-bottom:var(--space-sm)}.chat-welcome p{font-size:.88rem;line-height:1.6;max-width:400px;margin:0 auto}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px dashed var(--border-light);border-radius:var(--radius-xl);text-align:center;margin-top:var(--space-xl);transition:all .3s ease;cursor:pointer}.upload-placeholder:hover{border-color:var(--accent-primary);background:#e85d7505;transform:translateY(-2px);box-shadow:0 8px 32px #e85d7514}.upload-placeholder .upload-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#e85d7514,#ffb26b14);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg)}.upload-placeholder h3{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.upload-placeholder p{font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-lg)}.custom-workspace{display:grid;grid-template-columns:380px 1fr;gap:var(--space-lg);align-items:flex-start}@media(max-width:1024px){.custom-workspace{grid-template-columns:1fr}}.workspace-left{display:flex;flex-direction:column;gap:var(--space-lg)}.workspace-right{min-width:0}.config-card{padding:var(--space-xl)}.config-card h3{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:8px}.config-grid{display:flex;flex-direction:column;gap:var(--space-md)}.config-card .form-group{display:flex;flex-direction:column;gap:6px}.config-card .form-group label{display:block;font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.config-card .form-group select,.config-card .form-group input[type=text]{width:100%;padding:10px 14px;border:1.5px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:.88rem;color:var(--text-primary);background:#fff;outline:none;transition:all .2s ease;-webkit-appearance:none;appearance:none}.config-card .form-group select:focus,.config-card .form-group input[type=text]:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e85d7514}.chart-type-selector{display:flex;gap:6px}.type-btn{flex:1;border:1.5px solid var(--border-light);background:#fff;padding:10px;cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.type-btn:hover{color:var(--accent-primary);border-color:#e85d754d;background:#e85d7508}.type-btn.active{background:#e85d7514;border-color:var(--accent-primary);color:var(--accent-primary);box-shadow:0 2px 8px #e85d751f}.analysis-chart-card{padding:var(--space-xl)}.analysis-chart-card h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.badge{display:inline-flex;align-items:center;padding:4px 12px;background:#e85d750f;color:var(--accent-primary);font-size:.72rem;font-weight:600;border-radius:var(--radius-pill);letter-spacing:.02em}.grid-card{padding:var(--space-xl)}.grid-card h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.table-wrapper{overflow:auto;max-height:540px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:#fff}.custom-table{width:100%;border-collapse:collapse;font-size:.84rem}.custom-table th{background:#f8f9fb;position:sticky;top:0;padding:10px 14px;text-align:left;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1.5px solid var(--border-light);z-index:10;white-space:nowrap}.custom-table td{border-bottom:1px solid #f3f4f6;padding:0;min-width:100px}.custom-table tr:hover td{background:#e85d7504}.cell-input{width:100%;border:none;padding:10px 14px;font-family:inherit;font-size:inherit;background:transparent;outline:none;transition:background .15s ease}.cell-input:focus{background:#e85d750a;box-shadow:inset 0 0 0 2px var(--accent-primary)}.action-bar{display:flex;gap:12px;margin-top:var(--space-lg)}.action-bar .btn{flex:1;justify-content:center}.btn-sm{padding:7px 14px;font-size:.8rem}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 14px #10b98140}.btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98159}.data-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.summary-stat{padding:12px 14px;background:#f8f9fb;border-radius:var(--radius-md);text-align:center}.summary-stat .stat-value{font-size:1.2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.summary-stat .stat-label{font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.delete-row-btn{border:none;background:none;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s ease}.delete-row-btn:hover{color:#ef4444;background:#ef44440f}.chart-title-input{width:100%;padding:10px 14px;border:1.5px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:.88rem;color:var(--text-primary);background:#fff;outline:none;transition:all .2s ease}.chart-title-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e85d7514}
