@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css);:root{--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-300:#93c5fd;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--blue-800:#1e40af;--blue-900:#1e3a8a;--red-50:#fef2f2;--red-100:#fee2e2;--red-200:#fecaca;--red-300:#fca5a5;--red-400:#f87171;--red-500:#ef4444;--red-600:#dc2626;--red-700:#b91c1c;--red-800:#991b1b;--red-900:#7f1d1d;--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-300:#86efac;--green-400:#4ade80;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--green-800:#166534;--green-900:#14532d;--yellow-50:#fefce8;--yellow-100:#fef3c7;--yellow-200:#fde68a;--yellow-300:#fcd34d;--yellow-400:#fbbf24;--yellow-500:#f59e0b;--yellow-600:#d97706;--yellow-700:#b45309;--yellow-800:#92400e;--yellow-900:#78350f;--purple-50:#faf5ff;--purple-100:#f3e8ff;--purple-200:#e9d5ff;--purple-300:#d8b4fe;--purple-400:#c084fc;--purple-500:#a855f7;--purple-600:#9333ea;--purple-700:#7c3aed;--purple-800:#6b21a8;--purple-900:#581c87;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--radius-none:0;--radius-sm:0.125rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-full:9999px;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-inner:inset 0 2px 4px 0 #0000000f;--transition-none:none;--transition-all:all 150ms cubic-bezier(0.4,0,0.2,1);--transition-colors:color 150ms cubic-bezier(0.4,0,0.2,1),background-color 150ms cubic-bezier(0.4,0,0.2,1),border-color 150ms cubic-bezier(0.4,0,0.2,1);--transition-opacity:opacity 150ms cubic-bezier(0.4,0,0.2,1);--transition-shadow:box-shadow 150ms cubic-bezier(0.4,0,0.2,1);--transition-transform:transform 150ms cubic-bezier(0.4,0,0.2,1);--duration-75:75ms;--duration-100:100ms;--duration-150:150ms;--duration-200:200ms;--duration-300:300ms;--duration-500:500ms;--duration-700:700ms;--duration-1000:1000ms;--z-0:0;--z-10:10;--z-20:20;--z-30:30;--z-40:40;--z-50:50;--z-auto:auto}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--gray-50) 0,var(--gray-100) 100%);color:#111827;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:1rem;line-height:1.6;margin:0;text-rendering:optimizeLegibility}.App{display:flex;min-height:100vh;overflow:visible;position:relative}h1,h2,h3,h4,h5,h6{color:#111827;color:var(--gray-900);font-weight:700;letter-spacing:-.025em;line-height:1.25;margin:0 0 1rem;margin:0 0 var(--spacing-4) 0}.custom-scrollbar::-webkit-scrollbar{height:6px;width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:8px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.column-list-item-helper{color:#9ca3af;color:var(--gray-400);font-size:.75rem;opacity:0;transition:opacity .15s ease}.column-list-item:hover .column-list-item-helper,.group:hover .column-list-item-helper{opacity:1}.calc-page-container{min-height:100%;overflow-x:auto;padding-bottom:1rem;padding-bottom:var(--spacing-4)}.calc-maxw{margin:0 auto;max-width:1120px}.calc-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 10px 24px #0f172a0f;padding:2rem}.calc-section-title{color:#1f2937;font-size:1.25rem;font-weight:800}.calc-subtext{color:#6b7280;font-size:.875rem}h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#111827,#2563eb);background:linear-gradient(135deg,var(--gray-900) 0,var(--blue-600) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.25rem;font-weight:800}h2{font-size:1.875rem;font-weight:700}h3{font-size:1.5rem}h3,h4{font-weight:600}h4{font-size:1.25rem}h5{font-size:1.125rem}h5,h6{font-weight:600}h6{font-size:1rem}p{color:#4b5563;color:var(--gray-600);line-height:1.7;margin:0 0 1rem;margin:0 0 var(--spacing-4) 0}:focus-visible{border-radius:.125rem;border-radius:var(--radius-sm);outline:2px solid #3b82f6;outline:2px solid var(--blue-500);outline-offset:2px}::selection{background-color:#dbeafe;background-color:var(--blue-100);color:#1e3a8a;color:var(--blue-900)}::-moz-selection{background-color:#dbeafe;background-color:var(--blue-100);color:#1e3a8a;color:var(--blue-900)}.sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(180deg,#0f172afa,#1e293bfa 50%,#334155fa);border-right:1px solid #ffffff14;box-shadow:0 0 0 1px #ffffff0d,0 25px 50px -12px #0009,0 0 100px #3b82f61a;color:#e5e7eb;color:var(--gray-200);display:flex;flex-direction:column;flex-shrink:0;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:18rem;z-index:10;z-index:var(--z-10)}.sidebar:before{background:radial-gradient(circle at 20% 20%,#3b82f614 0,#0000 50%),radial-gradient(circle at 80% 80%,#9333ea0f 0,#0000 50%),linear-gradient(135deg,#3b82f605,#9333ea05);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.sidebar-header{border-bottom:1px solid #ffffff14;font-size:1.75rem;font-weight:900;margin-bottom:1.5rem;margin-bottom:var(--spacing-6);padding:2rem 1.5rem 1.5rem;padding:var(--spacing-8) var(--spacing-6) var(--spacing-6);position:relative;text-align:center;z-index:1}.sidebar-header:after{background:linear-gradient(90deg,#0000,#3b82f680 50%,#0000);bottom:0;content:"";height:1px;left:1.5rem;left:var(--spacing-6);position:absolute;right:1.5rem;right:var(--spacing-6)}.sidebar-header .brand-red{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#3b82f6 25%,#8b5cf6 50%,#a855f7 75%,#ec4899);-webkit-background-clip:text;background-clip:text;letter-spacing:-.025em;position:relative}.sidebar-header .brand-red:after{background:linear-gradient(90deg,#0000,#3b82f6 50%,#0000);border-radius:1px;bottom:-4px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:40px}.sidebar-nav{flex:1 1;margin-bottom:1rem;margin-bottom:var(--spacing-4);overflow-y:auto;padding:0 1rem;padding:0 var(--spacing-4);position:relative;text-align:left;z-index:1}.sidebar-nav ul{display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-2);list-style:none;margin:0;padding:0;text-align:left}.sidebar-nav li{margin:0;position:relative}.nav-link{align-items:center;background:#0000;border:1px solid #0000;border-radius:.75rem;border-radius:var(--radius-xl);color:#d1d5db;color:var(--gray-300);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;justify-content:flex-start;letter-spacing:.025em;overflow:hidden;padding:1rem 1.25rem;padding:var(--spacing-4) var(--spacing-5);position:relative;text-align:left;text-decoration:none;width:100%}.nav-link,.nav-link:before{transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-link:before{background:linear-gradient(135deg,#3b82f614,#9333ea14);border-radius:.75rem;border-radius:var(--radius-xl);bottom:0;opacity:0;right:0;top:0}.nav-link:after,.nav-link:before{content:"";left:0;position:absolute;z-index:-1}.nav-link:after{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:0 .5rem .5rem 0;border-radius:0 var(--radius-lg) var(--radius-lg) 0;height:60%;top:50%;transform:translateY(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:0}.nav-link:hover{border-color:#3b82f633;box-shadow:0 4px 12px #3b82f626,0 0 0 1px #3b82f61a;color:#fff;transform:translateX(.5rem);transform:translateX(var(--spacing-2))}.nav-link:hover:before{opacity:1}.nav-link:hover:after{width:4px}.nav-link.active{background:linear-gradient(135deg,#3b82f626,#9333ea26);border-color:#3b82f64d;box-shadow:0 8px 25px #3b82f633,0 0 0 1px #3b82f633,inset 0 1px 0 #ffffff1a;color:#fff;font-weight:600;transform:translateX(-.75rem)}.nav-link.active:before{opacity:1}.nav-link.active:after{background:linear-gradient(135deg,#60a5fa,#a855f7);box-shadow:0 0 10px #3b82f680;width:4px}.nav-link i{color:#9ca3af;color:var(--gray-400);flex-shrink:0;font-size:1.125rem;margin-right:1rem;margin-right:var(--spacing-4);transition:all .3s cubic-bezier(.4,0,.2,1);width:1.25rem}.nav-link:hover i{filter:drop-shadow(0 0 8px rgba(96,165,250,.4))}.nav-link.active i,.nav-link:hover i{color:#60a5fa;transform:scale(1.1) rotate(2deg)}.nav-link.active i{filter:drop-shadow(0 0 8px rgba(96,165,250,.6))}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#3b82f680}.main-content{background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--gray-50) 0,var(--gray-100) 100%);display:flex;flex:1 1;flex-direction:column;margin-left:18rem;min-height:100vh;overflow-y:auto}.header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;flex-shrink:0;height:5rem;justify-content:space-between;padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6);position:-webkit-sticky;position:sticky;top:0;z-index:20;z-index:var(--z-20)}.header:before{background:linear-gradient(90deg,#3b82f605,#ef444405);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header-left{align-items:center;display:flex;position:relative;z-index:1}.header-left label{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:600;margin-right:.75rem;margin-right:var(--spacing-3)}.header-left select{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);font-size:.875rem;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.header-left select:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.header-right{align-items:center;display:flex;gap:10px;position:relative;z-index:1}.header-right span{background:#f3f4f6;background:var(--gray-100);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);color:#4b5563;color:var(--gray-600);font-size:.875rem;font-weight:500;margin-right:1rem;margin-right:var(--spacing-4);padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3)}.header-right button{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;padding:.5rem;padding:var(--spacing-2);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.header-right button.btn-logout{background:linear-gradient(135deg,#ef4444,#dc2626)!important;background:linear-gradient(135deg,var(--red-500) 0,var(--red-600) 100%)!important;color:#fff!important}.header-right button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.header-right i{font-size:1.25rem}.main{background:#0000;flex:1 1;overflow-y:visible;padding:2rem;padding:var(--spacing-8)}.main,button{position:relative}button{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;gap:var(--spacing-2);justify-content:center;letter-spacing:.025em;overflow:hidden;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;transition:left var(--duration-500);width:100%}button:hover:before{left:100%}button{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border:1px solid #2563eb;border:1px solid var(--blue-600);color:#fff}button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button:active{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(0)}button.secondary{background:linear-gradient(135deg,#6b7280,#4b5563);background:linear-gradient(135deg,var(--gray-500) 0,var(--gray-600) 100%);border:1px solid #4b5563;border:1px solid var(--gray-600);color:#fff}button.secondary:hover{background:linear-gradient(135deg,#4b5563,#374151);background:linear-gradient(135deg,var(--gray-600) 0,var(--gray-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);background:linear-gradient(135deg,var(--red-500) 0,var(--red-600) 100%);border:1px solid #dc2626;border:1px solid var(--red-600);color:#fff}button.danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);background:linear-gradient(135deg,var(--red-600) 0,var(--red-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button.success{background:linear-gradient(135deg,#22c55e,#16a34a);background:linear-gradient(135deg,var(--green-500) 0,var(--green-600) 100%);border:1px solid #16a34a;border:1px solid var(--green-600);color:#fff}button.success:hover{background:linear-gradient(135deg,#16a34a,#15803d);background:linear-gradient(135deg,var(--green-600) 0,var(--green-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button.warning{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border:1px solid #2563eb;border:1px solid var(--blue-600);color:#fff}button.warning:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button.purple{background:linear-gradient(135deg,#a855f7,#9333ea);background:linear-gradient(135deg,var(--purple-500) 0,var(--purple-600) 100%);border:1px solid #9333ea;border:1px solid var(--purple-600);color:#fff}button.purple:hover{background:linear-gradient(135deg,#9333ea,#7c3aed);background:linear-gradient(135deg,var(--purple-600) 0,var(--purple-700) 100%);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button:disabled{border-color:#d1d5db;border-color:var(--gray-300);color:#6b7280;color:var(--gray-500);cursor:not-allowed;opacity:.6}button:disabled,button:disabled:hover{background:#d1d5db;background:var(--gray-300);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);transform:none}button:disabled:before{display:none}.form-group{position:relative}.form-group label{color:#1f2937;color:var(--gray-800);display:block;letter-spacing:.05em;margin-bottom:.75rem;margin-bottom:var(--spacing-3);text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);font-family:inherit;font-size:1rem;padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 4px #3b82f61a,0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:0 0 0 4px #3b82f61a,var(--shadow-md);outline:none;transform:translateY(-1px)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:#d1d5db;border-color:var(--gray-300);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.form-group input::placeholder,.form-group input:focus::placeholder,.form-group textarea::placeholder,.form-group textarea:focus::placeholder{color:#9ca3af;color:var(--gray-400);font-style:italic}.form-error{align-items:center;color:#dc2626;color:var(--red-600);display:flex;font-size:.75rem;font-weight:500;gap:.25rem;gap:var(--spacing-1);margin-top:.5rem;margin-top:var(--spacing-2)}.form-error:before{content:"⚠️";font-size:.875rem}.form-success{align-items:center;color:#16a34a;color:var(--green-600);display:flex;font-size:.75rem;font-weight:500;gap:.25rem;gap:var(--spacing-1);margin-top:.5rem;margin-top:var(--spacing-2)}.form-success:before{content:"✅";font-size:.875rem}.success.demo-mode{background-color:#eff6ff;background-color:var(--blue-50);border:1px solid #bfdbfe;border:1px solid var(--blue-200);border-radius:.375rem;border-radius:var(--radius-md);color:#1d4ed8;color:var(--blue-700);font-size:.875rem;font-weight:500;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3)}.success.demo-mode:before{content:"ℹ️";margin-right:.5rem;margin-right:var(--spacing-2)}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #fff3;border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);margin-bottom:2rem;margin-bottom:var(--spacing-8);overflow:hidden;padding:2rem;padding:var(--spacing-8);position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.card:before{background:linear-gradient(90deg,#3b82f6,#ef4444 50%,#22c55e);background:linear-gradient(90deg,var(--blue-500) 0,var(--red-500) 50%,var(--green-500) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.card:hover{box-shadow:0 25px 50px -12px #00000040;box-shadow:var(--shadow-2xl);transform:translateY(-4px)}.card h2{font-size:1.75rem;font-weight:700;gap:.75rem;gap:var(--spacing-3);margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}.card h2,.card h3{align-items:center;color:#111827;color:var(--gray-900);display:flex}.card h3{font-size:1.25rem;font-weight:600;gap:.5rem;gap:var(--spacing-2);margin-bottom:1rem;margin-bottom:var(--spacing-4)}.card p{color:#4b5563;color:var(--gray-600);line-height:1.7;margin:0}.dashboard{margin:0 auto;max-width:1400px;position:relative}.dashboard h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#111827,#2563eb);background:linear-gradient(135deg,var(--gray-900) 0,var(--blue-600) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:1.5rem;margin-bottom:var(--spacing-6);position:relative;text-align:center}.mapping-container-simple{display:flex;flex-direction:column;gap:.75rem;gap:var(--spacing-3);margin:1.5rem 0;margin:var(--spacing-6) 0}.mapping-row-simple{grid-gap:1rem;grid-gap:var(--spacing-4);align-items:center;background-color:#f9fafb;background-color:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.375rem;border-radius:var(--radius-md);display:grid;gap:1rem;gap:var(--spacing-4);grid-template-columns:1fr auto 2fr;padding:.75rem;padding:var(--spacing-3)}.source-column-label{align-items:center;color:#374151;color:var(--gray-700);display:flex;font-weight:500;gap:.5rem;gap:var(--spacing-2)}.source-column-label i{color:#16a34a;color:var(--green-600)}.mapping-arrow{color:#2563eb;color:var(--blue-600);font-size:1.5rem;font-weight:700}.destination-dropdown{width:100%}.destination-select{background-color:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.125rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);width:100%}.destination-select:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--blue-100);outline:none}.auto-generated-info-box{background-color:#eff6ff;background-color:var(--blue-50);border:1px solid #bfdbfe;border:1px solid var(--blue-200);border-radius:.375rem;border-radius:var(--radius-md);margin-top:1.5rem;margin-top:var(--spacing-6);padding:1rem;padding:var(--spacing-4)}.auto-generated-info-box h4{color:#1d4ed8;color:var(--blue-700);font-size:1rem;margin:0 0 .5rem;margin:0 0 var(--spacing-2) 0}.auto-generated-info-box p{color:#2563eb;color:var(--blue-600);font-size:.875rem;margin:0 0 .75rem;margin:0 0 var(--spacing-3) 0}.auto-generated-info-box ul{color:#1d4ed8;color:var(--blue-700);margin:0;padding-left:1.25rem;padding-left:var(--spacing-5)}.auto-generated-info-box li{font-size:.875rem;margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.dashboard h1:after{background:linear-gradient(90deg,#3b82f6,#ef4444);background:linear-gradient(90deg,var(--blue-500) 0,var(--red-500) 100%);border-radius:9999px;border-radius:var(--radius-full);bottom:-var(--spacing-2);content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:100px}.dashboard-stats{grid-gap:2rem;grid-gap:var(--spacing-8);display:grid;gap:2rem;gap:var(--spacing-8);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem;margin-bottom:var(--spacing-12)}.stat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #fff3;border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);overflow:hidden;padding:2rem;padding:var(--spacing-8);position:relative;text-align:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.stat-card:before{background:linear-gradient(90deg,#3b82f6,#2563eb);background:linear-gradient(90deg,var(--blue-500) 0,var(--blue-600) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 25px 50px -12px #00000040;box-shadow:var(--shadow-2xl);transform:translateY(-4px) scale(1.02)}.stat-card i{font-size:3rem;margin-bottom:1rem;margin-bottom:var(--spacing-4);transition:transform .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-transform)}.stat-card:hover i{transform:scale(1.1) rotate(5deg)}.stat-card .text-blue-500{color:#3b82f6;color:var(--blue-500)}.stat-card .text-yellow-500{color:#f59e0b;color:var(--yellow-500)}.stat-card .text-red-500{color:#ef4444;color:var(--red-500)}.stat-card .text-green-500{color:#22c55e;color:var(--green-500)}.stat-card .stat-number{font-size:1.875rem;font-weight:700;margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.stat-card .stat-label{color:#6b7280;color:var(--gray-500);font-size:.875rem}.dashboard-cards{grid-gap:1.5rem;grid-gap:var(--spacing-6);gap:1.5rem;gap:var(--spacing-6)}.dashboard-card{background-color:#fff;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);cursor:pointer;padding:1.5rem;padding:var(--spacing-6);transition:transform .2s}.dashboard-card:hover{transform:translateY(-2px)}.dashboard-card-icon{align-items:center;border-radius:.5rem;border-radius:var(--radius-lg);color:#fff;display:flex;font-size:1.5rem;height:3rem;justify-content:center;margin-bottom:1rem;margin-bottom:var(--spacing-4);width:3rem}.dashboard-card-icon.upload{background-color:#3b82f6;background-color:var(--blue-500)}.dashboard-card-icon.analytics,.dashboard-card-icon.templates{background-color:#22c55e;background-color:var(--green-500)}.error,.success{border:1px solid #0000;border-radius:.375rem;border-radius:var(--radius-md);margin-bottom:1rem;margin-bottom:var(--spacing-4)}.error{background-color:#fef2f2;border-color:#fecaca;color:#b91c1c}.success{background-color:#f0fdf4;border-color:#bbf7d0;color:#15803d}table{border-collapse:collapse;font-size:.875rem;text-align:left;width:100%}table th{background-color:#f3f4f6;background-color:var(--gray-100);color:#374151;color:var(--gray-700);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}table td,table th{padding:.75rem;padding:var(--spacing-3)}table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200)}table tr:last-child td{border-bottom:none}table tr:hover{background-color:#f9fafb;background-color:var(--gray-50)}.status{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.status.active{background-color:#dcfce7;color:#166534}.status.draft{background-color:#fefce8;color:#854d0e}.status.inactive{background-color:#f3f4f6;color:#374151}.login-page{align-items:center;background:linear-gradient(135deg,#1f2937,#374151 50%,#2563eb);background:linear-gradient(135deg,var(--gray-800) 0,var(--gray-700) 50%,var(--blue-600) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-form{background:#fff;border-radius:.75rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:480px;padding:2rem;padding:var(--spacing-8);position:relative;width:100%;z-index:1}.login-form h2{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:1.5rem;font-weight:700;gap:.5rem;gap:var(--spacing-2);justify-content:center;margin-bottom:1.5rem;margin-bottom:var(--spacing-6);text-align:center}.login-form h2:before{content:"🔐";font-size:1.25rem}.demo-accounts{background:#f9fafb;background:var(--gray-50);border-radius:.375rem;border-radius:var(--radius-md);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);color:#4b5563;color:var(--gray-600);font-size:.875rem;margin-top:1.5rem;margin-top:var(--spacing-6);padding:1rem;padding:var(--spacing-4);text-align:center}.demo-accounts p{font-weight:500;margin:.25rem 0;margin:var(--spacing-1) 0}.demo-accounts p:first-child{color:#111827;color:var(--gray-900);font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.templates-page h2,.upload-page h2{color:#111827;color:var(--gray-900);font-size:1.875rem;font-weight:700;margin-bottom:1rem;margin-bottom:var(--spacing-4)}.column-mapping,.create-template-form,.template-step,.upload-step{background-color:#fff;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin-bottom:1.5rem;margin-bottom:var(--spacing-6);padding:1.5rem;padding:var(--spacing-6)}.mappings{display:flex;flex-direction:column;gap:.75rem;gap:var(--spacing-3);margin:1.5rem 0;margin:var(--spacing-6) 0}.mapping-row{grid-gap:1.5rem;grid-gap:var(--spacing-6);align-items:center;background-color:#f9fafb;background-color:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.375rem;border-radius:var(--radius-md);display:grid;gap:1.5rem;gap:var(--spacing-6);grid-template-columns:1fr 1fr;padding:1rem;padding:var(--spacing-4)}.column-info strong{display:block;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.required{color:#ef4444;color:var(--red-500);font-weight:400;margin-left:.25rem;margin-left:var(--spacing-1)}.actions{gap:1rem;gap:var(--spacing-4);margin-top:1.5rem;margin-top:var(--spacing-6)}.actions,.templates-header{display:flex;justify-content:flex-end}.templates-header{align-items:center;margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}.templates-header h2{margin:0}.templates-list{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden}.wave-group{margin-bottom:1rem;margin-bottom:var(--spacing-4);position:relative}.wave-group .input{background:#0000;border:none;border-bottom:1px solid #515151;color:#333;display:block;font-size:1rem;padding:.625rem .625rem .625rem .3125rem;width:100%}.wave-group .input:focus{outline:none}.wave-group .label{color:#999;display:flex;font-size:1.125rem;font-weight:400;left:.3125rem;pointer-events:none;position:absolute;top:.625rem}.wave-group .label-char{transition:all .2s ease;transition-delay:calc(var(--index)*.05s)}.wave-group .input:focus~.label .label-char,.wave-group .input:valid~.label .label-char{color:#5264ae;font-size:.875rem;transform:translateY(-1.25rem)}.wave-group .bar{display:block;position:relative;width:100%}.wave-group .bar:after,.wave-group .bar:before{background:#5264ae;bottom:1px;content:"";height:2px;position:absolute;transition:all .2s ease;width:0}.wave-group .bar:before{left:50%}.wave-group .bar:after{right:50%}.mapping-step{background-color:#fff;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin-bottom:1.5rem;margin-bottom:var(--spacing-6);padding:1.5rem;padding:var(--spacing-6)}.mapping-container{grid-gap:2rem;grid-gap:var(--spacing-8);display:grid;gap:2rem;gap:var(--spacing-8);grid-template-columns:1fr 1fr;margin:1.5rem 0;margin:var(--spacing-6) 0}.mapping-left,.mapping-right{background-color:#f9fafb;background-color:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.375rem;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-4)}.mapping-left h4,.mapping-right h4{color:#1f2937;color:var(--gray-800);font-size:1.125rem;font-weight:600;margin:0 0 1rem;margin:0 0 var(--spacing-4) 0}.destination-columns,.source-columns{display:flex;flex-direction:column;gap:.75rem;gap:var(--spacing-3)}.source-column{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.125rem;border-radius:var(--radius-sm);color:#374151;color:var(--gray-700);display:flex;font-weight:500;gap:.5rem;gap:var(--spacing-2);padding:.75rem;padding:var(--spacing-3)}.source-column i{color:#16a34a;color:var(--green-600)}.destination-column{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.125rem;border-radius:var(--radius-sm);gap:.5rem;gap:var(--spacing-2);padding:.75rem;padding:var(--spacing-3)}.column-info,.destination-column{display:flex;flex-direction:column}.column-info{gap:.25rem;gap:var(--spacing-1)}.column-info strong{color:#1f2937;color:var(--gray-800);font-size:1rem}.column-info .required{color:#ef4444;color:var(--red-500);margin-left:.25rem;margin-left:var(--spacing-1)}.column-info small{color:#4b5563;color:var(--gray-600);font-size:.875rem}.auto-generate-info{background-color:#eff6ff;background-color:var(--blue-50);border-left:3px solid #3b82f6;border-left:3px solid var(--blue-500);border-radius:.125rem;border-radius:var(--radius-sm);margin-top:.25rem;margin-top:var(--spacing-1);padding:.5rem;padding:var(--spacing-2)}.auto-generate-info small{color:#1d4ed8;color:var(--blue-700);font-weight:500}.mapping-control{margin-top:.5rem;margin-top:var(--spacing-2)}.mapping-control select{background-color:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.125rem;border-radius:var(--radius-sm);font-size:.875rem;padding:.5rem;padding:var(--spacing-2);width:100%}.mapping-control select:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--blue-100);outline:none}.auto-generated{align-items:center;background-color:#eff6ff;background-color:var(--blue-50);border:1px solid #bfdbfe;border:1px solid var(--blue-200);border-radius:.125rem;border-radius:var(--radius-sm);color:#1d4ed8;color:var(--blue-700);display:flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-2);padding:.5rem;padding:var(--spacing-2)}.auto-generated i{color:#2563eb;color:var(--blue-600)}.mapping-actions{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;margin-top:1.5rem;margin-top:var(--spacing-6);padding-top:1rem;padding-top:var(--spacing-4)}.mapping-actions-left,.mapping-actions-right{display:flex;gap:.75rem;gap:var(--spacing-3)}.mapping-actions button{border-radius:.375rem;border-radius:var(--radius-md);cursor:pointer;font-weight:500;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);transition:all .2s ease}.mapping-actions button.secondary{background-color:#f3f4f6;background-color:var(--gray-100);border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#374151;color:var(--gray-700)}.mapping-actions button.secondary:hover{background-color:#e5e7eb;background-color:var(--gray-200)}.mapping-actions button:not(.secondary){background-color:#2563eb;background-color:var(--blue-600);border:1px solid #2563eb;border:1px solid var(--blue-600);color:#fff}.mapping-actions button:not(.secondary):hover{background-color:#1d4ed8;background-color:var(--blue-700)}.mapping-actions button:disabled{cursor:not-allowed;opacity:.6}.mapping-input-group{display:flex;flex-direction:column;gap:.75rem;gap:var(--spacing-3)}.merge-options{background-color:#eff6ff;background-color:var(--blue-50);border:1px solid #bfdbfe;border:1px solid var(--blue-200);border-radius:.125rem;border-radius:var(--radius-sm);margin-top:.5rem;margin-top:var(--spacing-2);padding:.75rem;padding:var(--spacing-3)}.merge-label{align-items:center;color:#1d4ed8;color:var(--blue-700);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-2)}.merge-label input[type=checkbox]{cursor:pointer;margin:0}.merge-columns{border-top:1px solid #bfdbfe;border-top:1px solid var(--blue-200);margin-top:.75rem;margin-top:var(--spacing-3);padding-top:.75rem;padding-top:var(--spacing-3)}.merge-columns>label{color:#1d4ed8;color:var(--blue-700);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.merge-checkboxes{flex-direction:column}.merge-checkbox,.merge-checkboxes{display:flex;gap:.5rem;gap:var(--spacing-2)}.merge-checkbox{align-items:center;border-radius:.125rem;border-radius:var(--radius-sm);color:#2563eb;color:var(--blue-600);cursor:pointer;font-size:.875rem;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2);transition:background-color .2s ease}.merge-checkbox:hover{background-color:#dbeafe;background-color:var(--blue-100)}.merge-checkbox input[type=checkbox]{cursor:pointer;margin:0}.mapping-control select.auto-mapped{background-color:#f0fdf4;background-color:var(--green-50);border-color:#22c55e;border-color:var(--green-500)}.auto-mapped-indicator{align-items:center;background-color:#f0fdf4;background-color:var(--green-50);border:1px solid #bbf7d0;border:1px solid var(--green-200);border-radius:.125rem;border-radius:var(--radius-sm);color:#15803d;color:var(--green-700);display:flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-2);margin-top:.5rem;margin-top:var(--spacing-2);padding:.5rem;padding:var(--spacing-2)}.auto-mapped-indicator i{color:#16a34a;color:var(--green-600)}.wave-group .input:focus~.bar:after,.wave-group .input:focus~.bar:before{width:50%}.wave-group textarea{min-height:60px;resize:vertical}.file-upload-form{align-items:center;display:flex;height:-webkit-fit-content;height:fit-content;justify-content:center;margin-bottom:1rem;margin-bottom:var(--spacing-4);width:-webkit-fit-content;width:fit-content}.file-upload-label input{display:none}.file-upload-label svg{fill:#525252;height:50px;margin-bottom:20px}.file-upload-label{background-color:#ddd;border:2px dashed #525252;border-radius:40px;box-shadow:0 0 200px -50px rgba(0,0,0,.719);padding:30px 70px}.file-upload-label:hover{background-color:#e0e0e0;border-color:#5264ae}.file-upload-design{align-items:center;display:flex;flex-direction:column;gap:5px;justify-content:center}.browse-button{background-color:#525252;border-radius:10px;padding:5px 15px;transition:all .3s}.browse-button:hover{background-color:#0e0e0e}.loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-top-color:#fff;display:inline-block}.loading-spinner-large{border-width:4px;height:40px;width:40px}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffffff2;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-content{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:1.5rem;padding:var(--spacing-6);text-align:center}.loading-content h3{color:#111827;color:var(--gray-900);margin:1rem 0 .5rem;margin:var(--spacing-4) 0 var(--spacing-2) 0}.loading-content p{color:#4b5563;color:var(--gray-600);margin:0}@media (max-width:1024px){.sidebar{width:16rem}.main-content{margin-left:16rem}}@media (max-width:768px){.App{flex-direction:column}.sidebar{flex-direction:row;height:auto;overflow-x:auto;width:100%}.sidebar-header{font-size:1.25rem;padding:.5rem;padding:var(--spacing-2);white-space:nowrap}.sidebar-nav ul{display:flex;gap:.5rem;gap:var(--spacing-2);padding:.5rem 1rem;padding:var(--spacing-2) var(--spacing-4)}.sidebar-nav li{flex-shrink:0}.nav-link{margin:0;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);white-space:nowrap;width:auto}.nav-link i{margin:0 .5rem;margin:0 var(--spacing-2)}.main-content{height:auto;margin-left:0}.header{flex-direction:column;gap:.5rem;gap:var(--spacing-2);height:auto;padding:.5rem;padding:var(--spacing-2)}.header-left,.header-right{justify-content:center;width:100%}.main{padding:1rem;padding:var(--spacing-4)}.dashboard-stats{gap:1rem;gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.dashboard-cards{gap:1rem;gap:var(--spacing-4);grid-template-columns:1fr}.mapping-row{grid-template-columns:1fr;padding:.75rem;padding:var(--spacing-3)}.actions,.mapping-row{gap:.5rem;gap:var(--spacing-2)}.actions{flex-direction:column}.actions button{width:100%}.templates-header{align-items:stretch;flex-direction:column;gap:1rem;gap:var(--spacing-4)}.templates-list{overflow-x:auto}.templates-list table{min-width:600px}.login-form{margin:1rem;margin:var(--spacing-4);max-width:100%}.column-mapping,.create-template-form,.login-form,.template-step,.upload-step{padding:1rem;padding:var(--spacing-4)}}@media (max-width:480px){.dashboard-stats{grid-template-columns:1fr 1fr}.stat-card{padding:.75rem;padding:var(--spacing-3)}.dashboard-card{padding:1rem;padding:var(--spacing-4)}.login-form{margin:.5rem;margin:var(--spacing-2);padding:.75rem;padding:var(--spacing-3)}.wave-group .input{font-size:16px}.file-upload-label{padding:20px 40px}}@media print{.header,.sidebar{display:none}.main-content{height:auto;margin-left:0}.main{background:#fff;padding:0}.card,.dashboard-card{border:1px solid #ccc;box-shadow:none;break-inside:avoid;page-break-inside:avoid}}.loading{overflow:hidden;position:relative}.loading:after{animation:loading 1.5s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes loading{0%{left:-100%}to{left:100%}}.skeleton{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;border-radius:.375rem;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.skeleton-title{height:1.5rem;margin-bottom:1rem;margin-bottom:var(--spacing-4);width:60%}.skeleton-button{border-radius:.5rem;border-radius:var(--radius-lg);height:2.5rem;width:8rem}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bounce{animation:bounce 1s infinite}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}.fade-in{animation:fadeIn .5s ease-in-out}.slide-in-left{animation:slideInLeft .5s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.slide-in-right{animation:slideInRight .5s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.scale-in{animation:scaleIn .3s ease-out}.glass{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#9333ea);background:linear-gradient(135deg,var(--blue-600) 0,var(--purple-600) 100%);-webkit-background-clip:text;background-clip:text}.shadow-glow{box-shadow:0 0 20px #3b82f64d}.shadow-glow-red{box-shadow:0 0 20px #ef44444d}.shadow-glow-green{box-shadow:0 0 20px #22c55e4d}.rounded-full{border-radius:9999px;border-radius:var(--radius-full)}.rounded-2xl{border-radius:1rem;border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:1.5rem;border-radius:var(--radius-3xl)}.hover-lift{transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.hover-lift:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.hover-scale{transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.hover-glow:hover{box-shadow:0 0 30px #3b82f666}.focus-ring:focus{box-shadow:0 0 0 3px #3b82f64d;outline:none}.status-online{color:#22c55e;color:var(--green-500)}.status-offline{color:#9ca3af;color:var(--gray-400)}.status-warning{color:#f59e0b;color:var(--yellow-500)}.status-error{color:#ef4444;color:var(--red-500)}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3);text-transform:uppercase}table td{vertical-align:middle}table td .button-group{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-2);justify-content:center;width:100%}table td .button-group button{flex-shrink:0;margin:0}.badge-primary{background:#dbeafe;background:var(--blue-100);color:#1e40af;color:var(--blue-800)}.badge-success{background:#dcfce7;background:var(--green-100);color:#166534;color:var(--green-800)}.badge-warning{background:#fef3c7;background:var(--yellow-100);color:#92400e;color:var(--yellow-800)}.badge-danger{background:#fee2e2;background:var(--red-100);color:#991b1b;color:var(--red-800)}.badge-gray{background:#f3f4f6;background:var(--gray-100);color:#1f2937;color:var(--gray-800)}.audit-logs-page,.dashboard,.templates-page,.upload-page,.user-management-page{align-items:center;background:linear-gradient(135deg,#f9fafb,#eff6ff);background:linear-gradient(135deg,var(--gray-50) 0,var(--blue-50) 100%);display:flex;flex-direction:column;min-height:100vh;padding:2rem;padding:var(--spacing-8)}.audit-logs-page,.dashboard,.templates-page,.user-management-page{justify-content:center}.upload-container{margin:0 auto;width:100%}.upload-header{margin-bottom:2rem;margin-bottom:var(--spacing-8);text-align:center}.header-gradient-line{background:linear-gradient(90deg,#3b82f6,#22c55e);background:linear-gradient(90deg,var(--blue-500) 0,var(--green-500) 100%);border-radius:2px;box-shadow:0 2px 8px #3b82f64d;height:4px;margin:1rem auto 0;margin:var(--spacing-4) auto 0;width:200px}.upload-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #fff3;border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #0000001a,0 0 0 1px #fff3;overflow:hidden;padding:2rem;padding:var(--spacing-8);position:relative}.upload-card:before{background:linear-gradient(90deg,#3b82f6,#22c55e);background:linear-gradient(90deg,var(--blue-500) 0,var(--green-500) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.card-header{text-align:center}.card-header h2{align-items:center;color:#1f2937;color:var(--gray-800);display:flex;font-size:1.75rem;font-weight:700;gap:.75rem;gap:var(--spacing-3);justify-content:center;margin-bottom:.75rem;margin-bottom:var(--spacing-3)}.card-header h2 i{color:#3b82f6;color:var(--blue-500);font-size:1.5rem}.card-header p{color:#4b5563;color:var(--gray-600);font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px}.form-section{margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}.form-label{color:#374151;color:var(--gray-700);font-size:1rem}.form-select{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);font-size:1rem;padding:1rem;padding:var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.form-select:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.upload-form{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-6)}.file-upload-section{margin-bottom:1rem;margin-bottom:var(--spacing-4)}.upload-actions,.upload-btn{display:flex;justify-content:center}.upload-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border:none;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;gap:.75rem;gap:var(--spacing-3);min-width:200px;padding:1rem 2rem;padding:var(--spacing-4) var(--spacing-8);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.upload-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 10px 25px #3b82f64d;transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.upload-btn.disabled{background:#d1d5db;background:var(--gray-300);color:#6b7280;color:var(--gray-500)}.security-note{align-items:center;background:linear-gradient(135deg,#f0fdf4,#eff6ff);background:linear-gradient(135deg,var(--green-50) 0,var(--blue-50) 100%);border:1px solid #bbf7d0;border:1px solid var(--green-200);border-radius:.5rem;border-radius:var(--radius-lg);color:#374151;color:var(--gray-700);display:flex;font-size:.9rem;gap:.75rem;gap:var(--spacing-3);margin-top:1.5rem;margin-top:var(--spacing-6);padding:1rem;padding:var(--spacing-4)}.security-note i{color:#16a34a;color:var(--green-600);font-size:1.1rem}.file-upload-container{margin-bottom:1rem;margin-bottom:var(--spacing-4);width:100%}.file-upload-zone{align-items:center;background:linear-gradient(135deg,#f9fafb,#eff6ff);background:linear-gradient(135deg,var(--gray-50) 0,var(--blue-50) 100%);border:3px dashed #d1d5db;border:3px dashed var(--gray-300);border-radius:.75rem;border-radius:var(--radius-xl);cursor:pointer;display:flex;justify-content:center;min-height:200px;overflow:hidden;padding:2rem;padding:var(--spacing-8);position:relative;text-align:center}.file-upload-zone,.file-upload-zone:before{transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.file-upload-zone:before{background:linear-gradient(135deg,#3b82f60d,#22c55e0d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0}.file-upload-zone:hover:before{opacity:1}.file-upload-zone:hover{background:linear-gradient(135deg,#eff6ff,#f0fdf4);background:linear-gradient(135deg,var(--blue-50) 0,var(--green-50) 100%);border-color:#60a5fa;border-color:var(--blue-400);box-shadow:0 10px 25px #3b82f61a;transform:translateY(-2px)}.file-upload-zone.drag-over{background:linear-gradient(135deg,#dbeafe,#dcfce7);background:linear-gradient(135deg,var(--blue-100) 0,var(--green-100) 100%);border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 15px 35px #3b82f633;transform:scale(1.02)}.file-upload-zone.has-file{background:linear-gradient(135deg,#f0fdf4,#eff6ff);background:linear-gradient(135deg,var(--green-50) 0,var(--blue-50) 100%);border-color:#22c55e;border-color:var(--green-500)}.file-upload-content{position:relative;z-index:1}.upload-icon{color:#60a5fa;color:var(--blue-400);font-size:3rem;margin-bottom:1rem;margin-bottom:var(--spacing-4);transition:transform .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-transform)}.file-upload-zone:hover .upload-icon{color:#3b82f6;color:var(--blue-500);transform:scale(1.1)}.file-upload-text{color:#4b5563;color:var(--gray-600)}.drag-text{color:#374151;color:var(--gray-700);font-size:1.25rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.or-text{color:#6b7280;color:var(--gray-500);font-size:1rem;margin:.5rem 0;margin:var(--spacing-2) 0}.browse-button{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;display:inline-block;font-weight:600;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.browse-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.file-selected{color:#15803d;color:var(--green-700)}.file-selected i{color:#22c55e;color:var(--green-500);font-size:2.5rem;margin-bottom:.75rem;margin-bottom:var(--spacing-3)}.file-name{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.remove-file-btn{align-items:center;background:#ef4444;background:var(--red-500);border:none;border-radius:.375rem;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;gap:var(--spacing-2);margin:.75rem auto 0;margin:var(--spacing-3) auto 0;padding:.5rem 1rem;padding:var(--spacing-2) var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.remove-file-btn:hover{background:#dc2626;background:var(--red-600);box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.message{align-items:center;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;gap:.75rem;gap:var(--spacing-3);margin-bottom:1.5rem;margin-bottom:var(--spacing-6);padding:var(--spacing-4)}.message.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);background:linear-gradient(135deg,var(--green-50) 0,var(--green-100) 100%);border:1px solid #bbf7d0;border:1px solid var(--green-200);color:#166534;color:var(--green-800)}.message.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);background:linear-gradient(135deg,var(--red-50) 0,var(--red-100) 100%);border:1px solid #fecaca;border:1px solid var(--red-200);color:#991b1b;color:var(--red-800)}.message i{font-size:1.2rem}.history-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fffffff2,#ffffffe6);border:1px solid #fff3;border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #0000001a,0 0 0 1px #fff3;margin-top:2rem;margin-top:var(--spacing-8);overflow:hidden;padding:2rem;padding:var(--spacing-8);position:relative}.history-card:before{background:linear-gradient(90deg,#3b82f6,#22c55e);background:linear-gradient(90deg,var(--blue-500) 0,var(--green-500) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.history-header{align-items:center;border-bottom:1px solid #0000001a;display:flex;justify-content:space-between;margin-bottom:1.5rem;margin-bottom:var(--spacing-6);padding-bottom:1rem;padding-bottom:var(--spacing-4)}.history-header h2{align-items:center;color:#1f2937;color:var(--gray-800);display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;gap:var(--spacing-3);margin:0}.history-header h2 i{color:#3b82f6;color:var(--blue-500);font-size:1.25rem}.refresh-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);font-size:.9rem;font-weight:600;gap:var(--spacing-2);padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.refresh-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.refresh-btn i{transition:transform .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-transform)}.refresh-btn:hover i{transform:rotate(180deg)}.empty-history{color:#6b7280;color:var(--gray-500);padding:3rem 1.5rem;padding:var(--spacing-12) var(--spacing-6);text-align:center}.empty-history i{color:#d1d5db;color:var(--gray-300);font-size:3rem;margin-bottom:1rem;margin-bottom:var(--spacing-4)}.empty-history p{color:#4b5563;color:var(--gray-600);font-size:1.1rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.empty-history small{color:#6b7280;color:var(--gray-500);font-size:.9rem}.history-table-container{border:1px solid #0000001a;border-radius:.5rem;border-radius:var(--radius-lg);overflow-x:auto}.history-table{background:#fff;border-collapse:collapse;width:100%}.history-table thead{background:linear-gradient(135deg,#f9fafb,#eff6ff);background:linear-gradient(135deg,var(--gray-50) 0,var(--blue-50) 100%)}.history-table th{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--gray-200);color:#374151;color:var(--gray-700);font-size:.9rem;font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.history-table td,.history-table th{padding:1rem;padding:var(--spacing-4)}.history-table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);vertical-align:middle}.history-row:hover{background:linear-gradient(135deg,#eff6ff,#f0fdf4);background:linear-gradient(135deg,var(--blue-50) 0,var(--green-50) 100%);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.file-name{align-items:center;color:#1f2937;color:var(--gray-800);display:flex;font-weight:500;gap:.75rem;gap:var(--spacing-3)}.file-name i{color:#3b82f6;color:var(--blue-500);font-size:1.1rem}.type-badge{background:#f3f4f6;background:var(--gray-100);border-radius:.375rem;border-radius:var(--radius-md);color:#374151;color:var(--gray-700);font-size:.8rem;font-weight:500;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3)}.status-badge{border-radius:.5rem;border-radius:var(--radius-lg);font-size:.85rem;gap:.5rem;gap:var(--spacing-2);padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3)}.status-badge.status-success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);background:linear-gradient(135deg,var(--green-100) 0,var(--green-200) 100%);border:1px solid #86efac;border:1px solid var(--green-300);color:#166534;color:var(--green-800)}.status-badge.status-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);background:linear-gradient(135deg,var(--yellow-100) 0,var(--yellow-200) 100%);border:1px solid #fcd34d;border:1px solid var(--yellow-300);color:#92400e;color:var(--yellow-800)}.status-badge.status-error{background:linear-gradient(135deg,#fee2e2,#fecaca);background:linear-gradient(135deg,var(--red-100) 0,var(--red-200) 100%);border:1px solid #fca5a5;border:1px solid var(--red-300);color:#991b1b;color:var(--red-800)}.status-badge.status-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);background:linear-gradient(135deg,var(--blue-100) 0,var(--blue-200) 100%);border:1px solid #93c5fd;border:1px solid var(--blue-300);color:#1e40af;color:var(--blue-800)}.status-badge i{font-size:.9rem}.records{color:#374151;color:var(--gray-700);font-weight:500;text-align:right}.file-size{font-weight:500;text-align:right}.file-size,.timestamp{color:#4b5563;color:var(--gray-600);font-size:.9rem}.action-buttons{display:flex;gap:.5rem;gap:var(--spacing-2);justify-content:center}.action-btn{background:#0000;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.375rem;border-radius:var(--radius-md);color:#4b5563;color:var(--gray-600);height:32px;justify-content:center;padding:.5rem;padding:var(--spacing-2);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:32px}.action-btn:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.view-btn:hover{background:#3b82f6;background:var(--blue-500);border-color:#3b82f6;border-color:var(--blue-500);color:#fff}.action-btn.retry-btn:hover{background:#f59e0b;background:var(--yellow-500);border-color:#f59e0b;border-color:var(--yellow-500);color:#fff}.action-btn.delete-btn:hover{background:#ef4444;background:var(--red-500);border-color:#ef4444;border-color:var(--red-500);color:#fff}.action-btn i{font-size:.9rem}.loading-container{align-items:center;color:#4b5563;color:var(--gray-600);display:flex;flex-direction:column;justify-content:center;padding:3rem;padding:var(--spacing-12)}.loading-container i{color:#3b82f6;color:var(--blue-500);font-size:2rem;margin-bottom:1rem;margin-bottom:var(--spacing-4)}.loading-container p{font-size:1.1rem;font-weight:500}.error-message{align-items:center;background:linear-gradient(135deg,#fef2f2,#fee2e2);background:linear-gradient(135deg,var(--red-50) 0,var(--red-100) 100%);border:1px solid var(--red-200);border-radius:.5rem;border-radius:var(--radius-lg);color:#991b1b;color:var(--red-800);gap:var(--spacing-3);margin-bottom:var(--spacing-6);padding:var(--spacing-4)}.error-message i{color:#ef4444;color:var(--red-500);font-size:1.2rem}.retry-btn{background:#ef4444;background:var(--red-500);border-radius:.375rem;border-radius:var(--radius-md);font-size:.9rem;gap:var(--spacing-2);margin-left:auto;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.retry-btn:hover{background:#dc2626;background:var(--red-600);transform:translateY(-1px)}.retry-btn i{color:#fff;font-size:.9rem}.edit-template-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin-bottom:4rem;margin-bottom:var(--spacing-16);margin-left:auto;margin-right:auto;overflow:hidden;position:relative}.edit-template-container:before{background:linear-gradient(90deg,#3b82f6,#a855f7);background:linear-gradient(90deg,var(--blue-500) 0,var(--purple-500) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.edit-template-header{align-items:flex-start;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:2rem;padding:var(--spacing-8)}.header-content{flex:1 1}.edit-template-title{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:1.5rem;font-weight:600;gap:.75rem;gap:var(--spacing-3);margin:0 0 .75rem;margin:0 0 var(--spacing-3) 0}.edit-template-title i{color:#3b82f6;color:var(--blue-500);font-size:1.5rem}.template-name{color:#2563eb;color:var(--blue-600);font-weight:600}.template-info{align-items:center;display:flex;gap:1rem;gap:var(--spacing-4)}.template-id,.template-version{border-radius:.375rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3)}.close-btn,.template-id,.template-version{background:#f3f4f6;background:var(--gray-100);color:#4b5563;color:var(--gray-600)}.close-btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-lg);cursor:pointer;display:flex;height:44px;justify-content:center;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:44px}.close-btn:hover{background:#fee2e2;background:var(--red-100);color:#dc2626;color:var(--red-600);transform:translateY(-2px)}.edit-template-form{padding:2rem;padding:var(--spacing-8)}.form-section{margin-bottom:2rem;margin-bottom:var(--spacing-8)}.section-title{color:#111827;color:var(--gray-900);font-size:1.125rem;font-weight:600;gap:.5rem;gap:var(--spacing-2);margin-bottom:1.25rem;margin-bottom:var(--spacing-5);padding-bottom:.75rem;padding-bottom:var(--spacing-3)}.section-title i{color:#3b82f6;color:var(--blue-500);font-size:1.1rem}.section-header{margin-bottom:1rem;margin-bottom:var(--spacing-4)}.column-count{background:#dbeafe;background:var(--blue-100);border-radius:9999px;border-radius:var(--radius-full);color:#1d4ed8;color:var(--blue-700);font-size:.85rem;font-weight:600;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3)}.form-row{grid-gap:1.5rem;grid-gap:var(--spacing-6);gap:1.5rem;gap:var(--spacing-6);margin-bottom:1.25rem;margin-bottom:var(--spacing-5)}.form-group.full-width{grid-column:1/-1}.form-label{color:#1f2937;color:var(--gray-800);font-size:.875rem;gap:var(--spacing-2);letter-spacing:.05em;margin-bottom:.75rem;margin-bottom:var(--spacing-3);text-transform:uppercase}.form-label i{color:#3b82f6;color:var(--blue-500);font-size:.9rem;width:16px}.template-description-input,.template-name-input{width:100%}.columns-container{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-4)}.column-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a;overflow:hidden;padding:1.5rem;padding:var(--spacing-6);position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.column-card:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6);content:"";height:3px;left:0;position:absolute;right:0;top:0}.column-card:hover{border-color:#93c5fd;border-color:var(--blue-300);box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.column-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);justify-content:space-between;margin-bottom:1.25rem;margin-bottom:var(--spacing-5);padding-bottom:.75rem;padding-bottom:var(--spacing-3)}.column-header,.column-title{align-items:center;display:flex}.column-title{gap:.75rem;gap:var(--spacing-3)}.column-title i{color:#3b82f6;color:var(--blue-500);font-size:1.1rem}.column-name{color:#1f2937;color:var(--gray-800);font-size:1.1rem;font-weight:600}.required-badge{background:linear-gradient(135deg,#fee2e2,#fecaca);background:linear-gradient(135deg,var(--red-100) 0,var(--red-200) 100%);border:1px solid #fca5a5;border:1px solid var(--red-300);border-radius:.375rem;border-radius:var(--radius-md);color:#b91c1c;color:var(--red-700);font-size:.75rem;font-weight:600;gap:.25rem;gap:var(--spacing-1);padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2)}.column-actions,.required-badge{align-items:center;display:flex}.column-index{background:#f3f4f6;background:var(--gray-100);border-radius:.375rem;border-radius:var(--radius-md);color:#4b5563;color:var(--gray-600);font-size:.8rem;font-weight:600;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2)}.column-fields{display:flex;flex-direction:column}.column-fields,.field-row{gap:1rem;gap:var(--spacing-4)}.field-row{grid-gap:1rem;grid-gap:var(--spacing-4);align-items:end;display:grid;grid-template-columns:1fr 1fr;min-width:0}.field-row .checkbox-group{grid-column:2;justify-self:start}.checkbox-row{align-items:center;display:flex;justify-content:flex-start;margin-top:.5rem;margin-top:var(--spacing-2)}.checkbox-row .checkbox-group{grid-column:unset;justify-self:auto}.field-input,.field-select{background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.375rem;border-radius:var(--radius-md);color:#111827;color:var(--gray-900);font-size:.875rem;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.field-input:focus,.field-select:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 2px #3b82f633;outline:none}.field-select{cursor:pointer}.field-input::placeholder,.field-select::placeholder{color:#9ca3af;color:var(--gray-400);font-size:.875rem;font-style:italic}.checkbox-group{align-items:center;align-self:end;background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.375rem;border-radius:var(--radius-md);box-shadow:none;display:flex;justify-content:flex-start;min-height:42px;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.checkbox-group:hover{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 2px #3b82f633}.checkbox-label{align-items:center;color:#374151;color:var(--gray-700);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;gap:var(--spacing-3);letter-spacing:normal;text-transform:none!important;-webkit-user-select:none;user-select:none}.checkbox-input{display:none}.checkbox-label:hover{background:#3b82f60d;color:#2563eb;color:var(--blue-600)}.checkbox-custom{background:#fff;border:2px solid #9ca3af;border:2px solid var(--gray-400);border-radius:.375rem;border-radius:var(--radius-md);flex-shrink:0;height:22px;position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:22px}.checkbox-label:hover .checkbox-custom{border-color:#3b82f6;border-color:var(--blue-500);transform:scale(1.05)}.checkbox-input:checked+.checkbox-custom{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 2px 8px #3b82f64d}.checkbox-input:checked+.checkbox-custom:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:10px;left:7px;position:absolute;top:3px;transform:rotate(45deg);width:5px}.checkbox-text i{font-size:.85rem}.checkbox-text{align-items:center;color:#374151;color:var(--gray-700);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-2);-webkit-user-select:none;user-select:none}.checkbox-text i{color:#3b82f6;color:var(--blue-500);font-size:.9rem}.field-help{align-items:center;color:#6b7280;color:var(--gray-500);display:flex;font-size:.75rem;font-style:italic;gap:.5rem;gap:var(--spacing-2);margin-top:.5rem;margin-top:var(--spacing-2)}.field-help i{color:#60a5fa;color:var(--blue-400);font-size:.8rem}.form-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);gap:var(--spacing-4);margin-top:var(--spacing-6);padding-top:1.5rem;padding-top:var(--spacing-6)}.cancel-btn,.submit-btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;gap:var(--spacing-2);justify-content:center;min-width:140px;padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.cancel-btn{background:#f3f4f6;background:var(--gray-100);border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#374151;color:var(--gray-700)}.cancel-btn:hover{background:#e5e7eb;background:var(--gray-200);color:#1f2937;color:var(--gray-800);transform:translateY(-2px)}.submit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--blue-600) 0,var(--blue-700) 100%);box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.submit-btn:disabled{background:#d1d5db;background:var(--gray-300);box-shadow:none;color:#6b7280;color:var(--gray-500);cursor:not-allowed;transform:none}.submit-btn i{font-size:1rem}@media (max-width:768px){.edit-template-header{align-items:flex-start;flex-direction:column;gap:1rem;gap:var(--spacing-4)}.header-content{width:100%}.field-row,.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}.merge-columns-input{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);font-family:inherit;font-size:.875rem;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.merge-columns-input:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.merge-columns-input::placeholder{color:#9ca3af;color:var(--gray-400);font-style:italic}.required-asterisk{color:#3b82f6;color:var(--blue-500);font-size:.875rem;font-weight:600;margin-right:.5rem;margin-right:var(--spacing-2)}.success-popup-overlay{align-items:center;animation:fadeIn .3s ease-in-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.success-popup{animation:scaleIn .3s ease-out;background:#fff;border-radius:1rem;border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a;max-width:400px;padding:2rem;padding:var(--spacing-8);text-align:center;width:90%}.success-icon{align-items:center;animation:checkmark .5s ease-in-out;background:linear-gradient(135deg,#4ade80,#22c55e);background:linear-gradient(135deg,var(--green-400) 0,var(--green-500) 100%);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;margin:0 auto var(--spacing-4);width:80px}.success-icon i{color:#fff;font-size:2.5rem}.success-popup h3{color:#16a34a;color:var(--green-600);font-size:1.5rem;font-weight:700;letter-spacing:.05em;margin-bottom:.75rem;margin-bottom:var(--spacing-3)}.success-popup p{color:#374151;color:var(--gray-700);font-size:1rem;line-height:1.6;margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes checkmark{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.role-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.role-management-header h2{color:#1f2937;color:var(--gray-800);font-size:1.5rem}.create-role-btn,.role-management-header h2{align-items:center;display:flex;font-weight:600;gap:.5rem}.create-role-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue-500) 0,var(--blue-600) 100%);border:none;border-radius:.5rem;color:#fff;cursor:pointer;padding:.75rem 1.5rem;transition:all .3s ease}.create-role-btn:hover{box-shadow:0 10px 25px #3b82f64d;transform:translateY(-2px)}.create-role-form{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;margin-top:1rem;padding:2rem}.create-role-form h3{color:#1f2937;color:var(--gray-800);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.form-row{grid-template-columns:1fr 1fr;margin-bottom:1rem}.form-group label{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:600}.form-group input,.form-group textarea{border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;font-size:.875rem;padding:.75rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-actions{margin-top:1.5rem}.permission-matrix-header{margin-bottom:2rem}.permission-matrix-header h2{align-items:center;color:#1f2937;color:var(--gray-800);display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.permission-matrix-header p{color:#4b5563;color:var(--gray-600);margin-bottom:1rem}.save-permissions-btn{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);background:linear-gradient(135deg,var(--green-500) 0,var(--green-600) 100%);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.save-permissions-btn:hover:not(:disabled){box-shadow:0 10px 25px #22c55e4d;transform:translateY(-2px)}.save-permissions-btn:disabled{cursor:not-allowed;opacity:.6}.permission-matrix-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;max-height:70vh;overflow-x:auto;overflow-y:auto;position:relative}.permission-matrix-table{border-collapse:collapse;font-size:.875rem;position:relative;width:100%}.permission-matrix-table td,.permission-matrix-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:1rem}.permission-matrix-table thead th{border-bottom:2px solid #d1d5db;border-bottom:2px solid var(--gray-300);box-shadow:0 2px 4px #0000001a;color:#1f2937;color:var(--gray-800);top:0;z-index:100}.feature-column,.permission-matrix-table thead th{background:#f9fafb;background:var(--gray-50);font-weight:600;position:-webkit-sticky;position:sticky}.feature-column{box-shadow:2px 0 4px #0000001a;left:0;min-width:300px;z-index:150!important}.role-column{min-width:150px;text-align:center}.role-header{align-items:center;display:flex;flex-direction:column;gap:.5rem}.role-name{color:#1f2937;color:var(--gray-800);font-size:.875rem;font-weight:600}.role-actions{display:flex;gap:.25rem}.delete-role-btn{background:#ef4444;background:var(--red-500);border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .3s ease}.delete-role-btn:hover{background:#dc2626;background:var(--red-600);transform:scale(1.1)}.edit-role-btn{background:#3b82f6;background:var(--blue-500);border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .3s ease}.edit-role-btn:hover{background:#2563eb;background:var(--blue-600);transform:scale(1.1)}.system-role-badge{background:#3b82f6;background:var(--blue-500);border-radius:.25rem;color:#fff;cursor:default;font-size:.75rem;padding:.25rem .5rem}.category-row{box-shadow:0 2px 4px #0000001a;position:relative}.category-header,.category-row{background:#dbeafe;background:var(--blue-100);z-index:20}.category-header{align-items:center;border-bottom:2px solid #bfdbfe;border-bottom:2px solid var(--blue-200);color:#1e40af;color:var(--blue-800);display:flex;font-size:1rem;font-weight:600;gap:.5rem;left:0;padding:1rem;position:-webkit-sticky;position:sticky}.permission-row{transition:background-color .3s ease}.permission-row:hover{background:#f9fafb;background:var(--gray-50)}.permission-name{background:#fff;box-shadow:2px 0 4px #0000001a;color:#374151;color:var(--gray-700);left:0;position:-webkit-sticky;position:sticky;z-index:10}.permission-label{color:#1f2937;color:var(--gray-800);display:block;font-weight:500}.permission-id{color:#6b7280;color:var(--gray-500);display:block;font-family:Courier New,monospace;font-size:.75rem}.permission-cell{padding:.75rem;text-align:center}.permission-checkbox{cursor:pointer;display:inline-block;position:relative}.permission-checkbox input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.checkmark{background:#fff;border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:.25rem;display:inline-block;height:20px;position:relative;transition:all .3s ease;width:20px}.permission-checkbox input:checked~.checkmark,.permission-checkbox:hover input~.checkmark{border-color:#3b82f6;border-color:var(--blue-500)}.permission-checkbox input:checked~.checkmark{background:#3b82f6;background:var(--blue-500)}.checkmark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:10px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:6px}.permission-checkbox input:checked~.checkmark:after{display:block}.permission-checkbox.disabled{cursor:not-allowed;opacity:.5}.permission-checkbox.disabled input{cursor:not-allowed}.permission-checkbox.disabled .checkmark{background:#e5e7eb;background:var(--gray-200);border-color:#d1d5db;border-color:var(--gray-300)}.roles-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.role-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;display:flex;flex-direction:column;height:100%;padding:1.5rem;transition:all .3s ease}.role-card:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-2px)}.role-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.role-info h3{color:#1f2937;color:var(--gray-800);font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.role-id{color:#6b7280;color:var(--gray-500);font-family:Courier New,monospace;font-size:.875rem}.role-stats{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.permission-count{background:#eff6ff;background:var(--blue-50);border:1px solid #dbeafe;border:1px solid var(--blue-100);border-radius:9999px;color:#2563eb;color:var(--blue-600);font-size:.75rem;font-weight:600;padding:.25rem .75rem}.role-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#4b5563;color:var(--gray-600);display:-webkit-box;font-size:.875rem;height:3rem;line-height:1.5;margin-bottom:1.5rem;overflow:hidden;text-overflow:ellipsis}.role-permissions h4{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:600;margin-bottom:.75rem}.role-permissions{display:flex;flex-direction:column;flex-grow:1;min-height:0}.permissions-list{align-content:start;display:flex;flex-grow:1;flex-wrap:wrap;gap:.5rem;max-height:300px;overflow-y:auto;padding-right:.25rem}.permissions-list::-webkit-scrollbar{width:4px}.permissions-list::-webkit-scrollbar-track{background:#0000}.permissions-list::-webkit-scrollbar-thumb{background-color:#d1d5db;background-color:var(--gray-300);border-radius:4px}.permission-tag{background:#f0fdf4;background:var(--green-50);border:1px solid #dcfce7;border:1px solid var(--green-100);border-radius:6px;color:#15803d;color:var(--green-700);font-size:.75rem;font-weight:500;padding:.35rem .75rem;white-space:nowrap}.permission-tag:hover{background:#dcfce7;background:var(--green-100);border-color:#bbf7d0;border-color:var(--green-200)}@media (max-width:768px){.role-management-header{align-items:stretch;flex-direction:column;gap:1rem}.form-row{grid-template-columns:1fr}.permission-matrix-container{font-size:.75rem;max-height:60vh}.permission-matrix-table td,.permission-matrix-table th{padding:.5rem}.feature-column{min-width:200px}.role-column{min-width:100px}.roles-list{grid-template-columns:1fr}}.access-denied{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem}.access-denied .card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:400px;padding:2rem;text-align:center}.access-denied h2{color:#dc2626;color:var(--red-600);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.access-denied p{color:#4b5563;color:var(--gray-600);line-height:1.6;margin-bottom:1.5rem}.access-denied .primary{background:#2563eb;background:var(--blue-600);border:none;border-radius:.375rem;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.access-denied .primary:hover{background:#1d4ed8;background:var(--blue-700);transform:translateY(-1px)}.clickable{cursor:pointer;transition:all .2s ease}.clickable:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.clickable:active{box-shadow:0 4px 15px #0000001a;transform:translateY(0)}.calc-step-grid{grid-gap:1rem;grid-gap:var(--spacing-4);display:grid;gap:1rem;gap:var(--spacing-4);grid-template-columns:1fr}@media (min-width:1024px){.calc-step-grid{grid-template-columns:repeat(3,1fr);min-width:1260px}}.calc-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;margin-top:2rem;margin-top:var(--spacing-8);padding-top:1.5rem;padding-top:var(--spacing-6)}.calculations-container,.column-list,.formula-ref-list{display:flex;flex-direction:column;gap:.75rem;gap:var(--spacing-3);max-height:450px;min-height:0;overflow-y:auto;padding-right:.5rem;padding-right:var(--spacing-2)}.column-list-item{align-items:center;background-color:#f9fafb;background-color:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);color:#374151;color:var(--gray-700);cursor:pointer;display:flex;font-family:Courier New,monospace;font-size:.875rem;justify-content:space-between;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.column-list-item:hover{background-color:#eff6ff;background-color:var(--blue-50);border-color:#93c5fd;border-color:var(--blue-300);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1d4ed8;color:var(--blue-700);transform:translateY(-2px)}.calc-empty-state{background-color:#f9fafb;background-color:var(--gray-50);border:2px dashed #e5e7eb;border:2px dashed var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);color:#9ca3af;color:var(--gray-400);padding:3rem 1.5rem;padding:var(--spacing-12) var(--spacing-6);text-align:center}.calc-empty-state i{font-size:2.5rem;margin-bottom:1rem;margin-bottom:var(--spacing-4);opacity:.5}.calc-empty-state p{color:#6b7280;color:var(--gray-500);font-weight:500}.add-calc-button-container{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);margin-top:1.5rem;margin-top:var(--spacing-6);padding-top:1rem;padding-top:var(--spacing-4)}.add-calc-button{align-items:center;background-color:initial;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;gap:var(--spacing-2);justify-content:center;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.add-calc-button:hover{background-color:#f3f4f6;background-color:var(--gray-100);border-color:#60a5fa;border-color:var(--blue-400);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-sm);color:#2563eb;color:var(--blue-600)}.formula-category{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg)}.formula-category-header{align-items:center;background-color:#f9fafb;background-color:var(--gray-50);border:none;color:#fff;cursor:pointer;display:flex;font-weight:600;justify-content:space-between;padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);text-align:left;width:100%}.formula-category-header:hover{background-color:#f3f4f6;background-color:var(--gray-100)}.formula-category-header i{transition:transform .2s ease-in-out}.formula-category-header.is-open i{transform:rotate(90deg)}.formula-category-content{background-color:#fff;max-height:300px;min-height:0;overflow-y:auto;padding:.5rem;padding:var(--spacing-2)}.formula-item{border-radius:.375rem;border-radius:var(--radius-md);cursor:pointer;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.formula-item:hover{background-color:#eff6ff;background-color:var(--blue-50)}.formula-item-header{align-items:center;display:flex;justify-content:space-between}.formula-item-name{color:#2563eb;color:var(--blue-600);font-weight:600}.formula-item-syntax{background-color:#f3f4f6;background-color:var(--gray-100);border-radius:.125rem;border-radius:var(--radius-sm);color:#374151;color:var(--gray-700);display:block;font-size:.8rem;margin:.25rem 0;margin:var(--spacing-1) 0;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2)}.formula-item-desc{color:#6b7280;color:var(--gray-500);font-size:.75rem;margin:0}.calculation-card{background-color:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-xl);margin:10px;padding:1.25rem;padding:var(--spacing-5);position:relative;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.calculation-card.is-active{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 4px #3b82f61a}.calc-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--spacing-4)}.calc-card-index{background:#2563eb;background:var(--blue-600);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);font-size:.875rem;font-weight:700;left:-12px}.calc-card-index,.calc-card-remove-btn{align-items:center;border:2px solid #fff;border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;height:28px;justify-content:center;position:absolute;top:-12px;width:28px}.calc-card-remove-btn{background:#ef4444;background:var(--red-500);cursor:pointer;padding:0;right:-12px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.calc-card-remove-btn:hover{background:#dc2626;background:var(--red-600);transform:scale(1.1) rotate(90deg)}.calc-input,.calc-textarea{border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-lg);font-size:.9rem;padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.calc-input:focus,.calc-textarea:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.calc-textarea{font-family:Courier New,monospace;resize:vertical}.settings-container{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-6);margin:0 auto;max-width:1200px}.settings-section{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden}.section-title{align-items:center;background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--gray-50) 0,var(--gray-100) 100%);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#1f2937;color:var(--gray-800);display:flex;font-size:1.25rem;font-weight:700;gap:.75rem;gap:var(--spacing-3);margin:0;padding:1.5rem;padding:var(--spacing-6)}.section-title i{color:#2563eb;color:var(--blue-600);font-size:1.125rem}.info-card{padding:1.5rem;padding:var(--spacing-6)}.info-grid{grid-gap:1rem;grid-gap:var(--spacing-4);display:grid;gap:1rem;gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-item{flex-direction:column;gap:.25rem;gap:var(--spacing-1)}.info-item label{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.info-value{color:#111827;color:var(--gray-900);font-size:1rem;font-weight:500}.role-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;max-width:-webkit-fit-content;max-width:fit-content;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3);text-transform:uppercase}.role-badge.super-admin{background:linear-gradient(135deg,#fee2e2,#fecaca);background:linear-gradient(135deg,var(--red-100) 0,var(--red-200) 100%);border:1px solid #fca5a5;border:1px solid var(--red-300);color:#991b1b;color:var(--red-800)}.role-badge.admin{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);background:linear-gradient(135deg,var(--purple-100) 0,var(--purple-200) 100%);border:1px solid #d8b4fe;border:1px solid var(--purple-300);color:#6b21a8;color:var(--purple-800)}.role-badge.user{background:linear-gradient(135deg,#dbeafe,#bfdbfe);background:linear-gradient(135deg,var(--blue-100) 0,var(--blue-200) 100%);border:1px solid #93c5fd;border:1px solid var(--blue-300);color:#1e40af;color:var(--blue-800)}.status-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;letter-spacing:.05em;max-width:-webkit-fit-content;max-width:fit-content;padding:var(--spacing-1) var(--spacing-3);text-transform:uppercase}.status-badge.active{background:linear-gradient(135deg,#dcfce7,#bbf7d0);background:linear-gradient(135deg,var(--green-100) 0,var(--green-200) 100%);border:1px solid #86efac;border:1px solid var(--green-300);color:#166534;color:var(--green-800)}.status-badge.inactive{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);background:linear-gradient(135deg,var(--gray-100) 0,var(--gray-200) 100%);border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#1f2937;color:var(--gray-800)}.config-grid{grid-gap:1rem;grid-gap:var(--spacing-4);display:grid;gap:1rem;gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.config-item{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-lg);padding:1rem;padding:var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.config-item:hover{background:#f3f4f6;background:var(--gray-100);border-color:#d1d5db;border-color:var(--gray-300);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.config-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.config-header label{color:#1f2937;color:var(--gray-800);font-size:1rem;font-weight:700}.config-type{background:#dbeafe;background:var(--blue-100);border-radius:.375rem;border-radius:var(--radius-md);color:#1e40af;color:var(--blue-800);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2);text-transform:uppercase}.config-value{color:#111827;color:var(--gray-900);font-size:1.125rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.config-description{color:#4b5563;color:var(--gray-600);font-size:.875rem;line-height:1.5}.boolean-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;padding:var(--spacing-1) var(--spacing-3);text-transform:uppercase}.boolean-badge.enabled{background:linear-gradient(135deg,#dcfce7,#bbf7d0);background:linear-gradient(135deg,var(--green-100) 0,var(--green-200) 100%);border:1px solid #86efac;border:1px solid var(--green-300);color:#166534;color:var(--green-800)}.boolean-badge.disabled{background:linear-gradient(135deg,#fee2e2,#fecaca);background:linear-gradient(135deg,var(--red-100) 0,var(--red-200) 100%);border:1px solid #fca5a5;border:1px solid var(--red-300);color:#991b1b;color:var(--red-800)}.permissions-grid{grid-gap:.75rem;grid-gap:var(--spacing-3);display:grid;gap:.75rem;gap:var(--spacing-3);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.permission-item{align-items:center;background:#f0fdf4;background:var(--green-50);border:1px solid #bbf7d0;border:1px solid var(--green-200);border-radius:.5rem;border-radius:var(--radius-lg);display:flex;gap:.5rem;gap:var(--spacing-2);padding:.75rem;padding:var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.permission-item:hover{background:#dcfce7;background:var(--green-100);border-color:#86efac;border-color:var(--green-300);transform:translateY(-1px)}.permission-item i{font-size:1rem}.permission-name{color:#1f2937;color:var(--gray-800);font-size:.875rem;font-weight:500}.section-header{background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--gray-50) 0,var(--gray-100) 100%);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:1.5rem;padding:var(--spacing-6)}.section-actions{display:flex;gap:.75rem;gap:var(--spacing-3)}.btn-secondary{align-items:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);background:linear-gradient(135deg,var(--gray-100) 0,var(--gray-200) 100%);border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-lg);color:#374151;color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;gap:var(--spacing-2);padding:.5rem 1rem;padding:var(--spacing-2) var(--spacing-4);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.btn-secondary:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db);background:linear-gradient(135deg,var(--gray-200) 0,var(--gray-300) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.config-header-right{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-2)}.edit-btn,.toggle-btn{align-items:center;background:#3b82f6;background:var(--blue-500);border:none;border-radius:.375rem;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:28px;justify-content:center;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:28px}.edit-btn:hover{background:#2563eb;background:var(--blue-600);transform:scale(1.1)}.toggle-btn{background:#22c55e;background:var(--green-500);font-size:1rem}.toggle-btn:hover{background:#16a34a;background:var(--green-600);transform:scale(1.1)}.config-input{background:#fff;border:2px solid #93c5fd;border:2px solid var(--blue-300);border-radius:.375rem;border-radius:var(--radius-md);color:#111827;color:var(--gray-900);font-size:1rem;font-weight:600;max-width:120px;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all);width:100%}.config-input:focus{border-color:#3b82f6;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.config-input:hover{border-color:#60a5fa;border-color:var(--blue-400)}.config-item:hover .edit-btn{opacity:1;transform:scale(1)}.config-item .edit-btn{opacity:.7;transform:scale(.9);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.config-item:hover .toggle-btn{opacity:1;transform:scale(1)}.config-item .toggle-btn{opacity:.7;transform:scale(.9);transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.report-meta{align-items:center;display:flex;gap:1rem}.report-summary{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.summary-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;display:flex;flex-direction:column;padding:1rem;text-align:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.stat-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-item i{color:#3b82f6;color:var(--blue-500);font-size:1.5rem;margin-bottom:.5rem}.stat-value{color:#111827;color:var(--gray-900);font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#4b5563;color:var(--gray-600);font-size:.875rem;letter-spacing:.05em;text-transform:uppercase}.report-data{margin-bottom:2rem}.report-data h4{color:#111827;color:var(--gray-900);font-weight:600;margin-bottom:1rem}.table-container{border:1px solid #e5e7eb;border:1px solid var(--gray-200)}.data-table{font-size:.875rem}.data-table th{background:#f9fafb;background:var(--gray-50);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:.75rem 1rem}.data-table td,.data-table th{color:#374151;color:var(--gray-700);white-space:nowrap}.data-table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100)}.data-table tbody tr:hover{background:#f9fafb;background:var(--gray-50)}.data-table tbody tr:last-child td{border-bottom:none}.table-footer{background:#f9fafb;background:var(--gray-50);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);padding:1rem;text-align:center}.report-sql{margin-bottom:2rem}.report-sql h4{color:#111827;color:var(--gray-900);font-weight:600;margin-bottom:1rem}.sql-code{background:#111827;background:var(--gray-900);border:1px solid #374151;border:1px solid var(--gray-700);border-radius:8px;color:#f3f4f6;color:var(--gray-100);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;overflow-x:auto;padding:1.5rem}.sql-code code{background:none;color:inherit;padding:0}.report-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem}.report-actions .btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:var(--transition-all)}.report-actions .btn-secondary{background:#f3f4f6;background:var(--gray-100);color:#374151;color:var(--gray-700)}.report-actions .btn-secondary:hover{background:#e5e7eb;background:var(--gray-200);color:#1f2937;color:var(--gray-800)}.report-actions .btn-primary{background:#3b82f6;background:var(--blue-500);color:#fff}.report-actions .btn-primary:hover{background:#2563eb;background:var(--blue-600);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}@media (max-width:768px){.summary-stats{grid-template-columns:1fr}.report-actions{flex-direction:column}.report-actions .btn{justify-content:center;width:100%}.data-table{font-size:.75rem}.data-table td,.data-table th{padding:.5rem}}.enhanced-amendment-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin:0 auto;max-width:1200px;padding:2rem}.enhanced-amendment-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-bottom:2rem;padding:2rem;text-align:center}.enhanced-amendment-header h2{font-size:2rem;font-weight:700;margin:0 0 1rem}.enhanced-amendment-header p{font-size:1.1rem;margin:0;opacity:.9}.enhanced-amendment-content{display:flex;flex-direction:column;gap:2rem}.upload-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:2rem}.section-header h3{color:#495057;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.section-header p{color:#6c757d;font-size:.9rem;margin:0}.enhanced-amendment-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{align-items:center;color:#495057;display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.form-control{background:#fff;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;padding:.75rem;transition:all .3s ease}.form-control:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-help{color:#6c757d;font-size:.8rem;margin-top:.25rem}.file-upload-container{position:relative}.file-input{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%}.file-upload-label{align-items:center;background:#fff;border:2px dashed #e9ecef;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:2rem;text-align:center;transition:all .3s ease}.file-upload-label:hover{background:#f8f9ff;border-color:#667eea}.file-upload-label i{color:#667eea;font-size:2rem;margin-bottom:.5rem}.file-upload-label span{color:#495057;font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a6fd8;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.results-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:2rem}.results-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1.5rem 0}.result-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;text-align:center;transition:all .3s ease}.result-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.result-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:3rem;justify-content:center;margin:0 auto 1rem;width:3rem}.result-content h4{color:#495057;font-size:1rem;font-weight:600;margin:0 0 .5rem}.result-number{color:#667eea;font-size:2rem;font-weight:700;margin:0 0 .25rem}.result-content small{color:#6c757d;font-size:.8rem}.versioned-columns{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-top:1.5rem;padding:1.5rem}.versioned-columns h4{color:#495057;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.columns-list{display:flex;flex-direction:column;gap:.75rem}.column-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:1rem;padding:.75rem}.original-column{background:#e3f2fd;color:#1976d2}.original-column,.versioned-column{border-radius:4px;font-size:.9rem;font-weight:600;padding:.25rem .75rem}.versioned-column{background:#e8f5e8;color:#2e7d32}.column-item i{color:#6c757d;font-size:.9rem}.view-data-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:2rem}.versioned-data-table{margin-top:1.5rem}.versioned-data-table h4{color:#495057;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.table-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow-x:auto}.data-table{border-collapse:collapse;font-size:.9rem;width:100%}.data-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#495057;font-weight:600;padding:1rem;text-align:left}.data-table td{border-bottom:1px solid #e9ecef;color:#495057;padding:.75rem 1rem}.data-table tr:hover,.table-note{background:#f8f9fa}.table-note{border-top:1px solid #e9ecef;color:#6c757d;font-size:.8rem;margin:0;padding:1rem;text-align:center}.message{border-radius:6px;font-weight:500;margin:1rem 0;padding:1rem}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.dashboard{padding:2rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.dashboard-header p{color:#6c757d;font-size:1.1rem;margin:0}.dashboard-cards{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.dashboard-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem;transition:all .3s ease}.dashboard-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.card-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;font-size:1.5rem;height:4rem;justify-content:center;margin-bottom:1.5rem;width:4rem}.card-content h3{color:#495057;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.card-content p{color:#6c757d;line-height:1.5;margin:0 0 1.5rem}@media (max-width:768px){.enhanced-amendment-container{padding:1rem}.dashboard-cards,.form-row,.results-grid{grid-template-columns:1fr}.enhanced-amendment-header h2{font-size:1.5rem}.dashboard-header h1{font-size:2rem}}.modern-dashboard{background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:1.5rem}.user-info-grid{grid-gap:1rem;border-top:1px solid #e5e7eb;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem;padding-top:1rem}.user-info-item{align-items:center;background:#f8fafc;border-radius:6px;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem}.user-info-item i{color:#3b82f6;text-align:center;width:16px}.welcome-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem}.welcome-card h2{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0 0 .5rem}.welcome-card p{color:#6b7280;font-size:.875rem;margin:0 0 1rem}.error-message{align-items:flex-start;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.error-message i{color:#dc2626;flex-shrink:0;margin-top:.125rem}.error-content{flex:1 1}.error-text{color:#dc2626;font-weight:500;margin-bottom:.5rem}.error-help{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-top:.75rem;padding:1rem}.error-help h4{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .5rem}.error-help ol{color:#6b7280;font-size:.875rem;margin:0;padding-left:1.25rem}.error-help li{margin-bottom:.25rem}.error-help code{background:#f3f4f6;border-radius:3px;color:#374151;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;padding:.125rem .25rem}.retry-btn{align-items:center;background:#dc2626;border:none;border-radius:6px;display:flex;flex-shrink:0;font-size:.875rem;font-weight:500;gap:.5rem;transition:background-color .2s ease}.retry-btn:hover{background:#b91c1c}.dashboard-controls{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:1rem}.server-status{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem}.status-indicator{align-items:center;display:flex;font-size:.75rem;font-weight:500;gap:.25rem}.status-indicator.online{color:#059669}.status-indicator.offline{color:#dc2626}.refresh-btn{border-radius:6px;padding:.5rem 1rem}.last-updated{font-size:.75rem}.dashboard-header{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:2rem;padding:2rem}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.dashboard-title{align-items:center;color:#1f2937;display:flex;font-size:2rem;font-weight:700;gap:.75rem;margin:0}.welcome-section .dashboard-title{font-size:2rem}.welcome-subtitle{color:#6b7280;font-size:1.1rem;margin:.5rem 0 0}.header-actions{gap:1rem}.header-actions,.refresh-btn{align-items:center;display:flex}.refresh-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.refresh-btn:hover{background:#2563eb;box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.refresh-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.last-updated{color:#6b7280;font-size:.9rem;gap:.5rem}.error-banner,.last-updated{align-items:center;display:flex}.error-banner{background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:12px;box-shadow:0 10px 20px #ef44444d;color:#fff;gap:1rem;margin-bottom:2rem;padding:1rem 2rem}.retry-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:all .3s ease}.retry-btn:hover{background:#ffffff4d}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}.metrics-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;overflow:hidden;padding:1.5rem;position:relative;transition:all .2s ease}.metric-card:before{background:#3b82f6;content:"";height:3px;left:0;position:absolute;right:0;top:0}.metric-card.primary:before{background:#3b82f6}.metric-card.success:before{background:#10b981}.metric-card.warning:before{background:#f59e0b}.metric-card.danger:before{background:#ef4444}.metric-card.info:before{background:#06b6d4}.metric-card.secondary:before{background:#6b7280}.metric-card.dark:before{background:#374151}.metric-card.accent:before{background:#8b5cf6}.metric-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.metric-icon{align-items:center;border-radius:8px;color:#fff;display:flex;font-size:1.25rem;height:48px;justify-content:center;margin-bottom:1rem;width:48px}.metric-card.primary .metric-icon{background:#3b82f6}.metric-card.success .metric-icon{background:#10b981}.metric-card.warning .metric-icon{background:#f59e0b}.metric-card.danger .metric-icon{background:#ef4444}.metric-card.info .metric-icon{background:#06b6d4}.metric-card.secondary .metric-icon{background:#6b7280}.metric-card.dark .metric-icon{background:#374151}.metric-card.accent .metric-icon{background:#8b5cf6}.metric-value{color:#1f2937;font-size:3rem;font-weight:800;line-height:1;margin-bottom:.5rem}.metric-label{color:#6b7280;font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.metric-change{align-items:center;color:#9ca3af;display:flex;font-size:.9rem;gap:.5rem}.activity-section,.progress-section,.quick-actions-section,.uploads-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:2rem}.section-header{align-items:center;border-bottom:2px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h3{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin:0}.activity-count{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.activity-feed{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.activity-item:hover{background:#f3f4f6;transform:translateX(5px)}.activity-icon{align-items:center;background:#fff;border-radius:10px;box-shadow:0 4px 8px #0000001a;display:flex;font-size:1.1rem;height:40px;justify-content:center;width:40px}.activity-content{flex:1 1}.activity-title{color:#1f2937;font-weight:600;margin-bottom:.25rem}.activity-count{color:#6b7280;font-size:.875rem;font-weight:400;margin-left:.5rem}.activity-details{color:#6b7280;display:flex;font-size:.9rem;gap:1rem}.resource{background:#e5e7eb;border-radius:6px;font-weight:500;padding:.25rem .5rem}.timestamp{color:#9ca3af}.activity-status{align-items:center;display:flex}.status-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.status-badge.success{background:#dcfce7;color:#166534}.status-badge.error{background:#fef2f2;color:#dc2626}.status-badge.completed{background:#dcfce7;color:#166534}.status-badge.processing{background:#fef3c7;color:#d97706}.status-badge.failed{background:#fef2f2;color:#dc2626}.empty-activity{color:#6b7280;padding:3rem 2rem;text-align:center}.empty-activity i{font-size:3rem;margin-bottom:1rem;opacity:.5}.uploads-list{display:flex;flex-direction:column;gap:1rem}.upload-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.upload-item:hover{background:#f3f4f6;transform:translateX(5px)}.upload-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;color:#fff;display:flex;font-size:1.1rem;height:40px;justify-content:center;width:40px}.upload-content{flex:1 1}.upload-name{color:#1f2937;font-weight:600;margin-bottom:.25rem}.upload-meta{color:#6b7280;display:flex;font-size:.9rem;gap:1rem}.upload-time{color:#9ca3af}.upload-status{align-items:center;display:flex}.action-buttons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;padding:1rem 1.5rem;transition:all .3s ease}.action-btn.primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.action-btn.primary:hover{box-shadow:0 10px 20px #3b82f64d;transform:translateY(-2px)}.action-btn.secondary{background:#f3f4f6;border:2px solid #e5e7eb;color:#374151}.action-btn.secondary:hover{background:#e5e7eb;box-shadow:0 10px 20px #0000001a;transform:translateY(-2px)}.progress-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.progress-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.progress-item:hover{background:#f3f4f6;transform:translateY(-2px)}.progress-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;font-size:1.2rem;height:50px;justify-content:center;width:50px}.progress-content{flex:1 1}.progress-value{color:#1f2937;font-size:2rem;font-weight:800;line-height:1;margin-bottom:.25rem}.progress-label{color:#6b7280;font-size:.9rem;font-weight:600}.dashboard-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;margin-top:3rem;padding:2rem}.footer-info{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}.info-item{color:#fffc;font-size:.9rem;gap:.5rem}.info-item,.loading-indicator{align-items:center;display:flex}.loading-indicator{color:#6b7280;gap:1rem}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.modern-dashboard{padding:1rem}.dashboard-header{padding:1.5rem}.header-content{align-items:flex-start;flex-direction:column}.dashboard-title{font-size:2rem}.metrics-row{grid-template-columns:1fr}.metric-card{padding:1.5rem}.metric-value{font-size:2.5rem}.action-buttons{grid-template-columns:1fr}.footer-info{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:480px){.dashboard-title{font-size:1.5rem}.metric-value{font-size:2rem}.activity-item,.upload-item{align-items:flex-start;flex-direction:column;gap:.75rem}.activity-details,.upload-meta{flex-direction:column;gap:.5rem}}
/*# sourceMappingURL=main.85e1377e.css.map*/