*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#f0f2f7;color:#1a1d2e;min-height:100vh}#root{min-height:100vh}.app-shell{display:flex;flex-direction:column;min-height:100vh}.top-nav{background:#fff;border-bottom:1px solid #e8eaf0;padding:0 32px;height:64px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000000a}.nav-logo-img{height:36px;width:auto;object-fit:contain}.nav-title{font-weight:700;font-size:18px;color:#1a1d2e}.nav-subtitle{font-size:13px;color:#8b92a5;margin-left:4px}.nav-user{margin-left:auto;display:flex;align-items:center;gap:16px}.nav-user-name{font-size:14px;font-weight:600;color:#374151}.btn-logout{background:transparent;color:#ef4444;border:1px solid #fecaca;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-logout:hover{background:#fef2f2;border-color:#f87171;color:#dc2626}.main-content{flex:1;padding:40px 32px;max-width:1280px;margin:0 auto;width:100%}.upload-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 64px);gap:48px;padding:40px 24px}.upload-hero h1{font-size:40px;font-weight:800;text-align:center;background:linear-gradient(135deg,#34cd65,#28a050);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.upload-hero p{margin-top:14px;font-size:17px;color:#6b7280;text-align:center;max-width:520px;line-height:1.6}.upload-card{background:#fff;border-radius:20px;padding:48px 56px;box-shadow:0 4px 32px #34cd6514;width:100%;max-width:560px;text-align:center}.dropzone{border:2px dashed #a7d4b4;border-radius:14px;padding:48px 32px;cursor:pointer;transition:all .25s ease;background:#f7fdf9;position:relative}.dropzone:hover,.dropzone.active{border-color:#34cd65;background:#f0fbf4}.dropzone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.dropzone-icon{width:56px;height:56px;margin:0 auto 16px;background:linear-gradient(135deg,#e6f9ee,#c8f5d8);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px}.dropzone h3{font-size:17px;font-weight:600;color:#1a1d2e}.dropzone p{font-size:13px;color:#9ca3af;margin-top:6px}.file-selected{margin-top:20px;padding:12px 18px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;font-size:14px;color:#166534;font-weight:500}.btn-primary{margin-top:28px;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#34cd65,#28a050);color:#fff;border:none;padding:14px 36px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #34cd6559;width:100%;justify-content:center}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 22px #34cd6573}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#34cd65;border:2px solid #34CD65;padding:10px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-outline:hover{background:#f0fbf4}.error-banner{margin-top:18px;padding:12px 16px;background:#fff1f2;border:1px solid #fecdd3;border-radius:10px;font-size:13.5px;color:#be123c;font-weight:500;text-align:left}.spinner-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 0}.spinner{width:44px;height:44px;border:4px solid #e5e7eb;border-top-color:#34cd65;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-wrap p{color:#6b7280;font-size:15px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:16px;flex-wrap:wrap}.dashboard-header h1{font-size:26px;font-weight:800}.dashboard-header span{font-size:14px;color:#8b92a5;margin-top:4px;display:block}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}@media (max-width: 768px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:#fff;border-radius:16px;padding:24px 28px;box-shadow:0 2px 16px #0000000d;display:flex;align-items:center;gap:20px;border-top:4px solid transparent;transition:transform .2s,box-shadow .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #00000014}.kpi-card:nth-child(1){border-color:#34cd65}.kpi-card:nth-child(2){border-color:#0ea5e9}.kpi-card:nth-child(3){border-color:#10b981}.kpi-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.kpi-card:nth-child(1) .kpi-icon{background:#e6f9ee}.kpi-card:nth-child(2) .kpi-icon{background:#d1fae5}.kpi-card:nth-child(3) .kpi-icon{background:#e6f9ee}.kpi-label{font-size:13px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:34px;font-weight:800;color:#1a1d2e;line-height:1.1;margin-top:4px}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width: 900px){.charts-grid{grid-template-columns:1fr}}.chart-panel{background:#fff;border-radius:16px;padding:28px 28px 16px;box-shadow:0 2px 16px #0000000d}.chart-panel.full-width{grid-column:1 / -1}.chart-title{font-size:15px;font-weight:700;color:#1a1d2e;margin-bottom:6px}.chart-subtitle{font-size:12.5px;color:#9ca3af;margin-bottom:20px}.module-table{width:100%;border-collapse:collapse;font-size:14px}.module-table th{text-align:left;padding:10px 14px;font-size:12px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f3f4f6}.module-table td{padding:12px 14px;border-bottom:1px solid #f9fafb;color:#374151}.module-table tr:last-child td{border-bottom:none}.module-table tr:hover td{background:#f7fdf9}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;background:#e6f9ee;color:#166534}.count-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;background:#f0fdf4;color:#166534}.schema-hint{background:#f2fdf6;border:1px solid #d1f5de;border-radius:12px;padding:16px 20px;width:100%;max-width:560px}.schema-hint h4{font-size:13px;font-weight:700;color:#34cd65;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.schema-hint ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px}.schema-hint li{background:#fff;border:1px solid #a7eac0;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;color:#14532d;font-family:monospace}.btn-save{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,#34cd65,#28a050);color:#fff;border:none;padding:10px 22px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 12px #34cd6559}.btn-save:hover{transform:translateY(-1px);box-shadow:0 5px 18px #10b98173}.saved-section{width:100%;max-width:560px;margin-top:8px}.saved-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.saved-title{font-size:14px;font-weight:700;color:#1a1d2e}.saved-count{background:#34cd65;color:#fff;font-size:11px;font-weight:700;border-radius:20px;padding:2px 8px}.saved-list{display:flex;flex-direction:column;gap:10px}.saved-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 1px 6px #0000000a;transition:box-shadow .15s,border-color .15s}.saved-card:hover{border-color:#a7eac0;box-shadow:0 3px 14px #34cd6514}.saved-card-info{display:flex;flex-direction:column;gap:3px;min-width:0}.saved-card-name{font-size:14px;font-weight:600;color:#1a1d2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-card-time{font-size:12px;color:#9ca3af}.saved-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-open{background:#e6f9ee;color:#34cd65;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-open:hover{background:#c8f5d8}.btn-delete{background:transparent;border:1px solid #e5e7eb;color:#9ca3af;border-radius:8px;padding:6px 10px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;line-height:1}.btn-delete:hover{background:#fff1f2;border-color:#fca5a5;color:#ef4444}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;overflow:hidden;background:#0f172a}.auth-bg-orb{position:absolute;border-radius:50%;filter:blur(100px);z-index:0;opacity:.6}.auth-bg-orb-1{width:600px;height:600px;background:#34cd6566;top:-200px;left:-200px;animation:floatOrb 15s ease-in-out infinite alternate}.auth-bg-orb-2{width:500px;height:500px;background:#0ea5e94d;bottom:-150px;right:-150px;animation:floatOrb 18s ease-in-out infinite alternate-reverse}@keyframes floatOrb{0%{transform:translate(0) scale(1)}to{transform:translate(50px,50px) scale(1.1)}}.auth-card{position:relative;z-index:1;background:#1e293b99;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:48px;width:100%;max-width:440px;box-shadow:0 25px 50px #00000040,inset 0 1px #ffffff1a;color:#f8fafc}.auth-brand{display:flex;align-items:center;gap:16px;margin-bottom:36px}.auth-logo{height:48px;width:auto;filter:drop-shadow(0 4px 6px rgba(0,0,0,.2))}.auth-brand-name{font-weight:800;font-size:22px;color:#fff;letter-spacing:-.5px;line-height:1.2}.auth-brand-tagline{font-size:13px;color:#94a3b8;font-weight:500}.auth-tabs{display:flex;background:#0f172a80;border-radius:12px;padding:6px;margin-bottom:32px;border:1px solid rgba(255,255,255,.05)}.auth-tab{flex:1;border:none;background:transparent;padding:12px 0;border-radius:8px;font-size:14px;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .25s ease}.auth-tab.active{background:#ffffff1a;color:#fff;box-shadow:0 4px 12px #0000001a}.auth-headline{margin-bottom:32px}.auth-headline h2{font-size:26px;font-weight:800;color:#fff;margin-bottom:8px;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-headline p{font-size:15px;color:#94a3b8;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-field{display:flex;flex-direction:column;gap:8px}.auth-field label{font-size:13.5px;font-weight:600;color:#cbd5e1}.auth-field input{padding:14px 16px;background:#0f172a66;border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:15px;color:#fff;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none}.auth-field input:focus{border-color:#34cd65;background:#0f172a99;box-shadow:0 0 0 4px #34cd6526}.auth-field input::placeholder{color:#64748b}.auth-error{padding:14px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;border-radius:12px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.auth-submit{margin-top:12px;background:linear-gradient(135deg,#34cd65,#28a050);color:#fff;border:none;padding:16px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 20px #34cd654d;display:flex;justify-content:center;align-items:center;min-height:54px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 24px #34cd6566}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.auth-switch{margin-top:36px;text-align:center;font-size:14px;color:#94a3b8}.auth-switch button{background:transparent;border:none;color:#34cd65;font-weight:600;font-size:14px;cursor:pointer;padding:0;margin-left:4px;transition:color .2s}.auth-switch button:hover{color:#a7d4b4;text-decoration:underline}
