:root{--primary-color: #4f46e5;--primary-hover: #4338ca;--primary-gradient-start: #4f46e5;--primary-gradient-end: #4338ca;--secondary-color: #e0e7ff;--secondary-text: #4338ca;--text-gray-900: #111827;--text-gray-700: #374151;--text-gray-500: #6b7280;--bg-gray-50: #f9fafb;--bg-white: #ffffff;--danger-color: #dc2626;--danger-bg: #fef2f2;--warning-bg: #fefce8;--warning-text: #854d0e;--border-color: #d1d5db;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: 1rem}html,body{height:100%;margin:0}body{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-gray-50);color:var(--text-gray-900)}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.justify-center{justify-content:center}.items-center{align-items:center}.text-center{text-align:center}.w-full{width:100%}.max-w-md{max-width:28rem}.max-w-2xl{max-width:42rem}.mx-auto{margin-left:auto;margin-right:auto}.mt-6{margin-top:1.5rem}.mb-6{margin-bottom:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.px-4{padding-left:1rem;padding-right:1rem}.grid{display:grid}.gap-1{gap:.25rem}.gap-x-1{column-gap:.25rem}.gap-y-1{row-gap:.25rem}.gap-2{gap:.5rem}.gap-x-2{column-gap:.5rem}.gap-y-2{row-gap:.5rem}.gap-4{gap:1rem}.gap-x-4{column-gap:1rem}.gap-y-4{row-gap:1rem}.gap-6{gap:1.5rem}.gap-x-6{column-gap:1.5rem}.gap-y-6{row-gap:1.5rem}.gap-8{gap:2rem}.gap-x-8{column-gap:2rem}.gap-y-8{row-gap:2rem}.gap-10{gap:2.5rem}.gap-x-10{column-gap:2.5rem}.gap-y-10{row-gap:2.5rem}.gap-12{gap:3rem}.gap-x-12{column-gap:3rem}.gap-y-12{row-gap:3rem}.gap-14{gap:3.5rem}.gap-x-14{column-gap:3.5rem}.gap-y-14{row-gap:3.5rem}.gap-16{gap:4rem}.gap-x-16{column-gap:4rem}.gap-y-16{row-gap:4rem}.gap-18{gap:4.5rem}.gap-x-18{column-gap:4.5rem}.gap-y-18{row-gap:4.5rem}.gap-20{gap:5rem}.gap-x-20{column-gap:5rem}.gap-y-20{row-gap:5rem}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.page-title{font-size:1.875rem;line-height:2.25rem;font-weight:800;color:var(--text-gray-900);margin-top:1.5rem}.card{background-color:var(--bg-white);padding:2.5rem 1.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid #f3f4f6}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-gray-700);margin-bottom:.5rem}.input-field{display:block;width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:.875rem;background-color:#fff;transition:all .2s ease-in-out;box-sizing:border-box}.input-field:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.input-field::placeholder{color:#9ca3af}.input-field[readonly]{background-color:#f3f4f6;color:var(--text-gray-500);cursor:not-allowed}.btn-primary{display:flex;justify-content:center;align-items:center;width:100%;padding:.75rem 1rem;border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:#fff;background-image:linear-gradient(to right,var(--primary-gradient-start),var(--primary-gradient-end));font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px #4f46e54d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.link-btn{color:var(--primary-color);font-weight:500;text-decoration:none;font-size:.875rem;cursor:pointer}.link-btn:hover{color:var(--primary-hover);text-decoration:underline}.error-msg{color:var(--danger-color);font-size:.75rem;margin-top:.25rem;font-weight:500}.alert-error{margin-top:1.5rem;padding:1rem;background-color:var(--danger-bg);border-radius:var(--radius-lg);border:1px solid #fee2e2;display:flex;align-items:flex-start}.alert-warning{margin-bottom:1.5rem;padding:1rem;background-color:var(--warning-bg);border-radius:var(--radius-lg);border:1px solid #fef3c7;color:var(--warning-text);font-size:.875rem;font-weight:500}.home-hero{background-color:#111827;color:#fff;padding-top:4rem;padding-bottom:6rem}.hero-title{font-size:3rem;font-weight:800;line-height:1}.hero-subtitle{font-size:1.25rem;color:#d1d5db;margin-top:1.25rem;max-width:40rem}.btn-hero-primary{padding:1rem 2.5rem;background-color:var(--primary-color);color:#fff;font-weight:700;border-radius:var(--radius-lg);font-size:1.125rem;border:none;cursor:pointer;transition:background-color .2s}.btn-hero-primary:hover{background-color:var(--primary-hover)}.btn-hero-secondary{padding:1rem 2.5rem;background-color:#eef2ff;color:var(--primary-color);font-weight:700;border-radius:var(--radius-lg);font-size:1.125rem;text-decoration:none;display:inline-block}.dashboard-charts-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.dashboard-charts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.w-4{width:1rem}.h-4{height:1rem}.w-6{width:1.5rem}.h-6{height:1.5rem}.w-8{width:2rem}.h-8{height:2rem}.w-10{width:2.5rem}.h-10{height:2.5rem}.w-12{width:3rem}.h-12{height:3rem}.w-14{width:3.5rem}.h-14{height:3.5rem}.w-16{width:4rem}.h-16{height:4rem}.w-18{width:4.5rem}.h-18{height:4.5rem}.w-20{width:5rem}.h-20{height:5rem}.w-22{width:5.5rem}.h-22{height:5.5rem}.w-24{width:6rem}.h-24{height:6rem}.w-26{width:6.5rem}.h-26{height:6.5rem}.w-28{width:7rem}.h-28{height:7rem}.w-30{width:7.5rem}.h-30{height:7.5rem}.w-32{width:8rem}.h-32{height:8rem}.w-34{width:8.5rem}.h-34{height:8.5rem}.w-36{width:9rem}.h-36{height:9rem}.w-38{width:9.5rem}.h-38{height:9.5rem}.w-40{width:10rem}.h-40{height:10rem}.spm-card{background-color:#1e3a8a40;border:1px solid rgba(59,130,246,.15);border-radius:.5rem;transition:all .3s ease;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spm-card:hover{transform:translateY(-4px);background-color:#1e3a8a66;box-shadow:0 10px 15px -3px #00000080,0 4px 6px -2px #1e3a8a4d;border-color:#60a5fa66}.spm-chart-layout{display:flex;align-items:center;width:100%}.spm-chart-wrapper{flex:1;display:flex;justify-content:center;align-items:center}.spm-chart-legend{padding-left:1rem}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:#1f293780;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#4b5563cc;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#6b7280}.btn-arrow-base{background:transparent;border:none;padding:8px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:inherit}.btn-arrow-base:hover{background-color:#ffffff1a}
