@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&family=Merriweather:wght@300;400;700&display=swap";
@tailwind base;@tailwind components;@tailwind utilities;:root{--c-primary:#059669;--c-primary-hover:#047857;--c-primary-dark:#064e3b;--c-primary-light:#10b981;--c-graphite:#0f172a;--c-graphite-light:#1e293b;--c-black:#020617;--c-bg:#f8fafc;--c-surface:#fffc;--c-border:#e2e8f0cc;--c-border-subtle:#f1f5f980;--c-text-main:#1e293b;--c-text-muted:#64748b;--c-text-inverse:#f8fafc;--f-heading:"Montserrat", sans-serif;--f-body:"Montserrat", sans-serif;--shadow-premium:0 10px 30px -10px #0000000a, 0 4px 10px -5px #00000005;--shadow-hover:0 20px 40px -15px #0596691f, 0 10px 20px -10px #0000000d;--transition-smooth:all .4s cubic-bezier(.16, 1, .3, 1);--glass-bg:#ffffffb3;--glass-blur:blur(12px);--sidebar-w:280px;--header-h:74px}body{font-family:var(--f-body);background-color:var(--c-bg);color:var(--c-text-main);-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--f-heading);letter-spacing:-.02em;font-weight:600}p{line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:var(--f-heading);transition:var(--transition-smooth)}#sidebar{width:var(--sidebar-w);background:linear-gradient(180deg, var(--c-graphite) 0%, var(--c-black) 100%);color:var(--c-text-inverse);z-index:100;flex-direction:column;height:100vh;transition:transform .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;left:0;box-shadow:10px 0 30px #0000001a}.brand{height:var(--header-h);border-bottom:1px solid #ffffff1a;align-items:center;padding:0 24px;display:flex}.brand-logo{align-items:center;gap:8px;display:flex}.brand-bars{align-items:center;gap:2px;display:flex}.brand-bars .bar{background:var(--c-primary);height:24px}.brand-bars .bar:first-child{opacity:.8;border-radius:12px 0 0 12px;width:10px}.brand-bars .bar:nth-child(2){width:6px}.brand h1{letter-spacing:.1em;font-size:1.1rem;font-weight:800}.nav-links{flex-direction:column;flex:1;gap:6px;padding:24px 16px;display:flex;overflow-y:auto}.nav-category{font-family:var(--f-heading);letter-spacing:.1em;text-transform:uppercase;color:#fff6;margin:16px 0 8px 12px;font-size:.7rem}.nav-link{font-family:var(--f-heading);color:#ffffffb3;transition:var(--transition-smooth);border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:.85rem;display:flex}.nav-link i{opacity:.7;transition:var(--transition-smooth);font-size:1.1rem}.nav-link:hover{color:#fff;background-color:#ffffff0d}.nav-link.active{background-color:var(--c-primary);color:#fff;font-weight:500}.nav-link.active i{opacity:1}.user-profile{border-top:1px solid #ffffff1a;align-items:center;gap:12px;padding:16px;display:flex}.avatar{background-color:var(--c-primary);width:36px;height:36px;font-family:var(--f-heading);color:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex;overflow:hidden}.user-name{font-family:var(--f-heading);white-space:nowrap;text-overflow:ellipsis;color:#fff;font-size:.85rem;font-weight:500;overflow:hidden}.user-role{color:#ffffff80;font-size:.7rem}#main-wrapper{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex}#header{height:var(--header-h);background-color:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--c-border);z-index:90;transition:var(--transition-smooth);justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.mobile-toggle{color:var(--c-graphite);cursor:pointer;background:0 0;border:none;font-size:1.5rem;display:none}.breadcrumbs{font-family:var(--f-heading);color:var(--c-text-muted);align-items:center;gap:8px;font-size:.85rem;display:flex}.breadcrumbs .current{color:var(--c-graphite);font-weight:600}.header-actions{align-items:center;gap:24px;display:flex}.search-box{align-items:center;display:flex;position:relative}.search-box i{color:var(--c-text-muted);font-size:.9rem;position:absolute;left:12px}.search-box input{font-family:var(--f-heading);transition:var(--transition-smooth);color:#000;background-color:#fff;border:1px solid #cbd5e1;border-radius:20px;outline:none;width:220px;padding:8px 16px 8px 36px;font-size:.85rem;font-weight:600}.search-box input:focus{color:#000;background-color:#fff;border-color:#000;box-shadow:0 0 0 2px #0000000d}.notification{color:var(--c-text-muted);cursor:pointer;font-size:1.2rem;transition:color .2s;position:relative}.notification:hover{color:var(--c-primary)}.notification .badge-dot{background:#c0392b;border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:0;right:0}#content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:32px}.view-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;display:flex}.view-header h2{margin-bottom:6px;font-size:1.8rem}.view-header p{color:var(--c-text-muted);font-size:.9rem;font-family:var(--f-heading)}.filters{gap:12px;display:flex}.filter-btn{background-color:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text-muted);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500}.filter-btn.active{border-color:var(--c-primary);color:var(--c-primary);background-color:#0596690d}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.kpi-card{background:var(--c-surface);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--c-border);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:20px;flex-direction:column;padding:24px;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:linear-gradient(90deg, transparent, var(--c-primary), transparent);opacity:0;width:100%;height:4px;transition:var(--transition-smooth);position:absolute;top:0;left:0}.kpi-card:hover{box-shadow:var(--shadow-hover);border-color:var(--c-primary-light);transform:translateY(-6px)}.kpi-card:hover:before{opacity:.6}.kpi-h{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.kpi-label{font-family:var(--f-heading);text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-muted);font-size:.75rem;font-weight:600}.kpi-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.icon-primary{color:var(--c-primary);background:#0596691a}.kpi-value{font-family:var(--f-heading);color:var(--c-graphite);margin-bottom:8px;font-size:2rem;font-weight:700;line-height:1}.kpi-trend{font-family:var(--f-heading);align-items:center;gap:4px;font-size:.8rem;font-weight:500;display:flex}.trend-up{color:#059669}.trend-down{color:#ef4444}.charts-grid{grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px;display:grid}.chart-card{background:var(--c-surface);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--c-border);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:20px;padding:24px}.chart-card:hover{box-shadow:var(--shadow-hover);border-color:var(--c-border)}.chart-header{margin-bottom:24px}.chart-header h3{font-size:1.1rem}.chart-container-large{width:100%;height:320px;position:relative}.chart-container-small{justify-content:center;width:100%;height:280px;display:flex;position:relative}.table-card{background:var(--c-surface);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--c-border);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:20px;margin-bottom:32px;overflow:hidden}.table-card .chart-header{margin-bottom:16px;padding:24px 24px 0}table{border-collapse:collapse;width:100%;font-family:var(--f-heading);font-size:.85rem}th{text-align:left;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--c-border);background:#faf9f8;padding:16px 24px;font-size:.7rem;font-weight:600}td{border-bottom:1px solid var(--c-border-subtle);color:var(--c-text-main);padding:16px 24px;font-weight:500}tr:last-child td{border-bottom:none}tr:hover td{background:#00000003}.badge{letter-spacing:.05em;border-radius:20px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-block}.bg-meta{color:#1877f2;background:#1877f21a}.bg-google{color:#4285f4;background:#4285f41a}.ai-view-wrapper{grid-template-columns:1fr 320px;gap:32px;display:grid}.ai-document{background:var(--c-surface);border:1px solid var(--c-border-subtle);box-shadow:var(--shadow-premium);border-radius:16px;padding:48px 64px}.ai-document h2{color:var(--c-primary);margin-bottom:24px;font-size:2rem}.ai-document p{color:#4a4a4a;margin-bottom:24px;font-size:1rem}.ai-document h3{margin-top:32px;margin-bottom:16px;font-size:1.2rem}.ai-sidebar .ai-status{background:var(--c-surface);border:1px solid var(--c-border-subtle);border-radius:16px;margin-bottom:24px;padding:24px}.ai-status h4{margin-bottom:16px;font-size:.9rem}.status-row{font-family:var(--f-heading);border-bottom:1px dashed var(--c-border);justify-content:space-between;margin-bottom:12px;padding-bottom:12px;font-size:.85rem;display:flex}.status-row:last-child{border:none;margin:0;padding:0}.status-label{color:var(--c-text-muted)}.status-val{font-weight:600}.btn-generate{background:var(--c-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px;font-size:.9rem;font-weight:600;display:flex}.btn-generate:hover{background:var(--c-primary-dark);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.upload-area{background:var(--c-surface);border:2px dashed var(--c-border);text-align:center;transition:var(--transition-smooth);cursor:pointer;border-radius:16px;margin-bottom:32px;padding:64px 32px}.upload-area:hover,.upload-area.dragover{border-color:var(--c-primary);background:#05966905}.upload-icon{color:var(--c-primary);opacity:.8;margin-bottom:16px;font-size:3rem}.upload-area h3{margin-bottom:8px}.upload-area p{color:var(--c-text-muted);font-size:.9rem;font-family:var(--f-heading)}@media (max-width:1024px){.charts-grid,.ai-view-wrapper{grid-template-columns:1fr}}@media (max-width:768px){#sidebar{transform:translate(-100%)}#sidebar.open{transform:translate(0)}#main-wrapper{margin-left:0}.mobile-toggle{display:block}.breadcrumbs{display:none}#content{padding:16px}.ai-document{padding:24px}}.login-container{width:100vw;height:100vh;display:flex;overflow:hidden}.login-left{z-index:10;background:radial-gradient(circle at 0 0,#1f2937,#111827);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.login-right{background-color:#000;flex:1.2;display:none;position:relative}@media (min-width:1024px){.login-right{display:block}}.login-bg-img{object-fit:cover;object-position:center left;width:100%;height:100%;animation:30s ease-in-out infinite alternate bgBreathe;position:absolute;top:0;left:0}@keyframes bgBreathe{0%{transform:scale(1)}to{transform:scale(1.03)}}.login-right:after{content:"";background:linear-gradient(90deg,#111827 0%,#0000 20%,#0006 100%);width:100%;height:100%;position:absolute;top:0;left:0}.glass-form-wrapper{-webkit-backdrop-filter:blur(24px);background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:440px;padding:48px;animation:1s cubic-bezier(.16,1,.3,1) forwards slideUpFade;position:relative;overflow:hidden;box-shadow:0 24px 80px #00000080}.glass-form-wrapper:before{content:"";background:var(--c-primary);filter:blur(80px);opacity:.15;z-index:-1;border-radius:50%;width:150px;height:150px;position:absolute;top:-50px;left:-50px}@keyframes slideUpFade{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.login-brand-logo{align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-brand-icon{background:linear-gradient(135deg,#10b981,#047857);width:32px;height:32px;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12 2L2 22h20L12 2z\" fill=\"white\"/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12 2L2 22h20L12 2z\" fill=\"white\"/></svg>");-webkit-mask-size:cover;mask-size:cover}.login-brand-text h1{font-family:var(--f-heading);letter-spacing:.05em;color:#fff;font-size:1.1rem;font-weight:700}.login-brand-text span{color:#ffffff80;letter-spacing:.1em;font-size:.65rem;font-weight:400;display:block}.welcome-text{margin-bottom:32px}.welcome-text h2{font-family:var(--f-heading);background:linear-gradient(90deg,#fff,#a7f3d0);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:1.8rem;font-weight:600}.welcome-text p{color:#fff9;font-size:.9rem;line-height:1.5;font-family:var(--f-heading)}.login-form-group{margin-bottom:20px;position:relative}.login-input-icon{color:#fff6;font-size:.9rem;transition:all .3s;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.login-form-control{color:#fff;width:100%;font-family:var(--f-heading);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;outline:none;padding:16px 16px 16px 44px;font-size:.9rem;transition:all .3s}.form-input{color:#0f172a;width:100%;font-family:var(--f-heading);background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:12px;font-size:.85rem}.form-label{color:#334155;font-size:.8rem;font-weight:600;font-family:var(--f-heading);margin-bottom:4px;display:block}.login-form-control::placeholder{color:#ffffff4d}.login-form-control:focus{background:#ffffff14;border-color:#10b98180;box-shadow:0 0 0 4px #10b9811a}.login-form-control:focus+.login-input-icon{color:#10b981}.login-form-extras{font-family:var(--f-heading);justify-content:space-between;align-items:center;margin-bottom:32px;font-size:.8rem;display:flex}.login-forgot-pass{color:#fff9;text-decoration:none;transition:all .2s}.login-forgot-pass:hover{color:#10b981}.btn-submit{color:#fff;width:100%;font-family:var(--f-heading);letter-spacing:.05em;cursor:pointer;background:linear-gradient(90deg,#059669,#10b981);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:16px;font-size:.95rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 10px 20px -10px #10b98199}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 15px 25px -10px #10b981cc}.btn-submit:disabled{opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.loader-spinner{border:3px solid #05966926;border-top-color:var(--c-primary);border-radius:50%;width:24px;height:24px;animation:.8s cubic-bezier(.4,0,.2,1) infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.view-section{animation:.6s cubic-bezier(.16,1,.3,1) forwards fadeInDown}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.login-footer{text-align:center;font-family:var(--f-heading);color:#fff6;margin-top:32px;font-size:.75rem}input:not(.login-form-control),select:not(.login-form-control),textarea:not(.login-form-control){color:#0f172a!important;background-color:#fff!important;border:1px solid #cbd5e1!important}input::placeholder{color:#94a3b8!important}label{font-weight:500;color:#334155!important}
