@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--brand-900: #0f172a;--brand-800: #1e293b;--brand-700: #334155;--brand-600: #475569;--brand-500: #64748b;--brand-400: #94a3b8;--brand-200: #e2e8f0;--brand-100: #f1f5f9;--brand-50: #f8fafc;--accent: #4f46e5;--accent-dark: #4338ca;--accent-light: #eef2ff;--accent-ring: rgba(79, 70, 229, .15);--success: #059669;--success-light: #ecfdf5;--success-ring: rgba(5, 150, 105, .15);--warning: #d97706;--warning-light: #fffbeb;--danger: #dc2626;--danger-light: #fef2f2;--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-2: #334155;--text-3: #64748b;--text-4: #94a3b8;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 4px 12px rgba(15, 23, 42, .08), 0 1px 3px rgba(15, 23, 42, .05);--shadow-md: 0 8px 24px rgba(15, 23, 42, .1), 0 2px 6px rgba(15, 23, 42, .06);--shadow-lg: 0 16px 40px rgba(15, 23, 42, .12), 0 4px 12px rgba(15, 23, 42, .06);--radius-sm: .5rem;--radius: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--transition: .2s cubic-bezier(.4, 0, .2, 1);--font-family: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Manrope", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--accent-deep: #3730a3;--data-color: #06b6d4;--primary-color: var(--accent);--primary-hover: var(--accent-dark);--secondary-color: var(--success);--bg-color: var(--bg);--header-bg: linear-gradient(135deg, var(--brand-800) 0%, var(--brand-900) 100%);--text-color: var(--text);--card-bg: var(--surface)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:.9375rem;line-height:1.6}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-6xl{max-width:72rem}.mx-auto{margin-left:auto;margin-right:auto}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.pt-4{padding-top:1rem}.pb-2{padding-bottom:.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-12{margin-top:3rem}.mr-2{margin-right:.5rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1 1 0%}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media(min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:p-8{padding:2rem}}@media(min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:col-span-2{grid-column:span 2 / span 2}}.overflow-x-auto{overflow-x:auto}.whitespace-nowrap{white-space:nowrap}.text-center{text-align:center}.text-right{text-align:right}.select-none{-webkit-user-select:none;user-select:none}.italic{font-style:italic}.uppercase{text-transform:uppercase}.rounded{border-radius:var(--radius-sm)}.shadow-sm{box-shadow:var(--shadow-sm)}.border-t{border-top:1px solid var(--border)}.border-b{border-bottom:1px solid var(--border)}.border-l-4{border-left-width:4px}.border-red-500{border-color:var(--danger)}.w-4{width:1rem}.h-4{height:1rem}.h-10{height:2.5rem}.text-xs{font-size:.75rem;line-height:1.1rem}.text-sm{font-size:.8125rem;line-height:1.25rem}.text-base{font-size:.9375rem;line-height:1.5rem}.text-lg{font-size:1.0625rem;line-height:1.65rem}.text-xl{font-size:1.1875rem;line-height:1.75rem}.text-2xl{font-size:1.375rem;line-height:2rem}.text-3xl{font-size:1.75rem;line-height:2.25rem}.text-4xl{font-size:2.125rem;line-height:2.5rem}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-gray-300{color:var(--brand-400)}.text-gray-400{color:var(--text-4)}.text-gray-500{color:var(--text-3)}.text-gray-600{color:var(--brand-600)}.text-gray-700{color:var(--text-2)}.text-gray-800{color:var(--text)}.text-indigo-200{color:#c7d2fe}.text-indigo-700{color:var(--accent-dark)}.text-yellow-400{color:#fbbf24}.text-red-700{color:var(--danger)}.text-green-800{color:#065f46}.text-transparent{color:transparent}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-600{--tw-gradient-from: #2563eb;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent)}.to-indigo-600{--tw-gradient-to: #4f46e5}.from-blue-900{--tw-gradient-from: #1e3a8a;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent)}.to-indigo-900{--tw-gradient-to: #312e81}.bg-gray-50{background-color:var(--brand-50)}.bg-gray-100{background-color:var(--brand-100)}.bg-green-50{background-color:var(--success-light)}.bg-red-100{background-color:var(--danger-light)}.space-y-3>*+*{margin-top:.75rem}.min-w-\[150px\]{min-width:150px}.divide-y>:not([hidden])~:not([hidden]){border-top:1px solid var(--border)}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);transition:box-shadow var(--transition),transform var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card-static{transform:none!important}.section-header{display:flex;align-items:center;gap:.625rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.section-header h2,.section-header h3{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.section-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--accent-light);border-radius:var(--radius-sm);color:var(--accent);font-size:1rem}.contribuyente-header{background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-900) 100%);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.5rem;border:1px solid var(--brand-700);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.contribuyente-header .ch-avatar{width:2.5rem;height:2.5rem;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0}.contribuyente-header .ch-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--brand-400);display:block;margin-bottom:.15rem}.contribuyente-header .ch-value{font-size:1rem;font-weight:700;color:#fff;display:block}.contribuyente-header .ch-sub{font-size:.8rem;color:var(--brand-400);display:block}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group label{font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center}.input-field,.select-field{width:100%;padding:.5rem .75rem;font-size:.875rem;font-family:var(--font-family);color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);box-sizing:border-box;-webkit-appearance:none;appearance:none}.input-field:focus,.select-field:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);background:var(--surface)}.input-field::placeholder{color:var(--text-4)}select.input-field{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.input-prefix-group{position:relative;width:100%}.input-prefix-group .prefix{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.8rem;font-weight:600;color:var(--text-3);pointer-events:none;z-index:1}.input-prefix-group .input-field{padding-left:2rem}.contribuyente-input-card{background:linear-gradient(135deg,#eef2ff,#f5f3ff);border:1.5px solid #c7d2fe;border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.contribuyente-input-card .ci-title{font-size:.875rem;font-weight:700;color:#3730a3;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.8125rem;font-weight:600;font-family:var(--font-family);border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),box-shadow var(--transition),transform var(--transition),opacity var(--transition);letter-spacing:.01em;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;box-shadow:0 2px 8px #4f46e540}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #4f46e559;filter:brightness(1.06)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text-2);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--brand-100)}.btn-success{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 2px 8px #05966940}.btn-success:hover:not(:disabled){filter:brightness(1.06)}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid #fecaca}.btn-danger:hover{background:#fee2e2}.btn-ghost{background:transparent;color:var(--text-3);padding:.35rem .6rem}.btn-ghost:hover{background:var(--brand-100);color:var(--text)}.btn-submit{width:100%;padding:.75rem 1.5rem;font-size:.9rem;font-weight:700;border-radius:var(--radius);margin-top:.5rem}.obligacion-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition)}.obligacion-card:hover{box-shadow:var(--shadow)}.obligacion-card-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--brand-50);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;gap:.5rem}.obligacion-card-header:hover{background:var(--brand-100)}.obligacion-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .6rem;border-radius:999px;background:var(--accent-light);color:var(--accent-dark)}.obligacion-card-body{padding:1rem 1.25rem}.subsection{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--border)}.subsection-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-4);margin-bottom:.75rem;display:flex;align-items:center;gap:.4rem}.btn-add-item{width:100%;padding:.45rem .75rem;font-size:.78rem;font-weight:600;color:var(--accent);background:var(--accent-light);border:1.5px dashed #c7d2fe;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:.35rem;margin-top:.5rem}.btn-add-item:hover{background:#e0e7ff;border-color:var(--accent)}.item-row{display:grid;gap:.5rem;align-items:end;padding:.6rem .75rem;background:var(--brand-50);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:.4rem}.tab-nav{display:flex;flex-direction:column;gap:0;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}.nav-section{display:flex;align-items:center;gap:0;padding:0;border-bottom:1px solid var(--border)}.nav-section:last-child{border-bottom:none}.nav-section-label{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:0 .5rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-4);white-space:nowrap;width:140px;min-width:140px;border-right:1px solid var(--border);align-self:stretch;background:var(--brand-50);text-align:center}.nav-section-tabs{display:flex;align-items:center;gap:0;flex:1;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.nav-section-tabs::-webkit-scrollbar{display:none}.tab-btn{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.65rem .25rem;width:140px;min-width:140px;border:none;border-right:1px solid var(--border);background:transparent;border-bottom:2px solid transparent;font-size:.75rem;font-weight:500;color:var(--text-3);cursor:pointer;transition:all var(--transition);font-family:var(--font-family);white-space:nowrap;position:relative;overflow:hidden}.tab-btn:last-child{border-right:none}.tab-btn:hover{color:var(--accent);background:var(--brand-50)}.tab-btn-active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent);background:var(--accent-light)}.tab-btn-active:hover{color:var(--accent);background:var(--accent-light)}.tab-icon{font-size:1.1rem;line-height:1;display:flex;align-items:center}.tab-group{display:flex;gap:0;align-items:center}.tab-group:before{display:none}@media(max-width:768px){.nav-section{flex-direction:column;align-items:stretch}.nav-section-label{border-right:none;border-bottom:1px solid var(--border);padding:.5rem 1rem;min-width:unset}.nav-section-tabs{padding:.25rem}.tab-btn{padding:.5rem .75rem;font-size:.75rem}}.result-table{width:100%;border-collapse:collapse;font-size:.8125rem}.result-table thead tr{background:var(--brand-800);color:#fff}.result-table thead th{padding:.65rem 1rem;text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}.result-table thead th:first-child{border-radius:var(--radius-sm) 0 0 0}.result-table thead th:last-child{border-radius:0 var(--radius-sm) 0 0}.result-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}.result-table tbody tr:hover{background:var(--brand-50)}.result-table tbody tr:last-child{border-bottom:none}.result-table tbody td{padding:.6rem 1rem;color:var(--text-2)}.result-table tfoot td{padding:.65rem 1rem;font-weight:700;border-top:2px solid var(--border-strong);background:var(--surface-2);color:var(--text)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .2s ease,box-shadow .2s ease;padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.3rem}.stat-card .stat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-4)}.stat-card .stat-value{font-size:1.4rem;font-weight:800;color:var(--text);line-height:1;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.stat-card .stat-sub{font-size:.75rem;color:var(--text-3)}.stat-card-accent{border-left:3px solid var(--accent)}.stat-card-success{border-left:3px solid var(--success)}.stat-card-warning{border-left:3px solid var(--warning)}.stat-card-danger{border-left:3px solid var(--danger)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--border) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm);color:transparent!important;pointer-events:none}.skeleton::placeholder{color:transparent}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.input-field:focus-visible,.select-field:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.cuota-hero{background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-900) 100%);border-radius:var(--radius-xl);padding:1.5rem 2rem;color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.cuota-hero .ch-left h2{font-size:1.1rem;font-weight:700;margin-bottom:.2rem}.cuota-hero .ch-left p{font-size:.8rem;color:var(--brand-400)}.cuota-hero .ch-right .ch-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--brand-400);display:block;text-align:right}.cuota-hero .ch-right .ch-amount{font-size:2.2rem;font-weight:800;line-height:1;display:block;text-align:right}.alert{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius);font-size:.8125rem;font-weight:500;line-height:1.5}.alert-error{background:var(--danger-light);border:1px solid #fecaca;color:#991b1b}.alert-warning{background:var(--warning-light);border:1px solid #fde68a;color:#92400e}.alert-success{background:var(--success-light);border:1px solid #a7f3d0;color:#065f46}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:1.125rem;height:1.125rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.tooltip-container{position:relative;display:inline-flex;align-items:center;margin-left:.35rem;cursor:help}.tooltip-icon{width:20px;height:20px;background:var(--border-strong);color:var(--text-3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;transition:all var(--transition);line-height:1;cursor:pointer;flex-shrink:0}.tooltip-container:hover .tooltip-icon{background:var(--accent);color:#fff}.tooltip-text{visibility:hidden;position:absolute;z-index:100;bottom:130%;left:50%;transform:translate(-50%);width:200px;background:var(--brand-800);color:#e2e8f0;text-align:left;padding:.625rem .75rem;border-radius:var(--radius-sm);font-size:.72rem;font-weight:400;line-height:1.5;opacity:0;transition:opacity var(--transition),visibility var(--transition);box-shadow:var(--shadow-lg);pointer-events:none;text-transform:none}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;margin-left:-4px;border-width:4px;border-style:solid;border-color:var(--brand-800) transparent transparent transparent}.tooltip-container:hover .tooltip-text{visibility:visible;opacity:1}.currency-wrapper{position:relative;width:100%}.currency-symbol{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;font-weight:600;font-size:.8rem;z-index:10}.input-with-currency{padding-left:2.25rem!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-3px)}20%,40%,60%,80%{transform:translate(3px)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .5s ease-out forwards}.animate-fade-in-down{animation:fadeInDown .25s ease-out forwards}.animate-shake{animation:shake .35s cubic-bezier(.36,.07,.19,.97) both}.bg-primary{background-color:var(--primary-color)!important}.bg-primary\/10{background-color:rgba(var(--primary-rgb, 79, 70, 229),.1)!important}.bg-primary\/20{background-color:rgba(var(--primary-rgb, 79, 70, 229),.2)!important}.text-primary{color:var(--primary-color)!important}.border-primary{border-color:var(--primary-color)!important}.shadow-primary\/20{box-shadow:0 8px 20px rgba(var(--primary-rgb, 79, 70, 229),.2)!important}.bg-secondary{background-color:var(--secondary-color)!important}.text-secondary{color:var(--secondary-color)!important}.hero-gradient{background:radial-gradient(circle at top left,var(--primary-color),transparent),radial-gradient(circle at bottom right,var(--secondary-color),transparent),linear-gradient(to bottom,#0f172a,#020617)}.glass{background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.glass-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.8)}.hero-pattern{background-color:#1e3a8a;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%232563eb' fill-opacity='0.1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}@keyframes blob{0%{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}to{transform:translate(0) scale(1)}}.animate-blob{animation:blob 7s infinite}.animation-delay-2000{animation-delay:2s}.perspective-1000{perspective:1000px}.rotate-y-12{transform:rotateY(12deg)}.animate-pulse-slow{animation:pulse 3s cubic-bezier(.4,0,.6,1) infinite}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.animate-slide-in{animation:slideIn .3s ease-out forwards}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.animate-dropdown-fade{animation:dropdownFade .2s ease-out forwards}.animate-spin{animation:spin 1s linear infinite}.input-field--error{border-color:var(--danger)!important;box-shadow:0 0 0 3px #dc26261a!important}.input-field--error:focus{box-shadow:0 0 0 3px #dc262626!important}.field-error{font-size:.72rem;color:var(--danger);margin-top:.2rem;display:flex;align-items:center;gap:.3rem;line-height:1.3}.field-error:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--danger);flex-shrink:0}.field-hint{font-size:.68rem;color:var(--text-4);line-height:1.4;margin-top:.1rem;margin-bottom:.2rem}.empty-state-guide{display:flex;gap:.75rem;padding:.875rem 1rem;background:var(--brand-50);border:1px dashed var(--border-strong);border-radius:var(--radius);margin-bottom:.5rem}.empty-state-guide__title{font-size:.78rem;font-weight:700;color:var(--text-2);margin-bottom:.15rem}.empty-state-guide__text{font-size:.68rem;color:var(--text-4);line-height:1.4}.tooltip-text--visible{visibility:visible!important;opacity:1!important}.justify-end{justify-content:flex-end}.mb-5{margin-bottom:1.25rem}.gap-3{gap:.75rem}.border-indigo-200{border-color:#c7d2fe}.text-indigo-600{color:#4f46e5}.bg-indigo-50{background-color:#eef2ff}.bg-indigo-700{background-color:#3730a3}:root{--sidebar-width: 240px;--sidebar-collapsed: 64px;--sidebar-bg: var(--brand-900);--sidebar-text: var(--brand-400);--sidebar-text-active: #ffffff;--sidebar-accent: var(--accent);--sidebar-hover: rgba(255,255,255,.06);--sidebar-section-text: var(--brand-500);--sidebar-transition: .25s cubic-bezier(.4,0,.2,1);--chat-fab-size: 56px;--chat-panel-width: 380px;--chat-panel-height: 520px;--chat-z: 900}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg)}.sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;transition:width var(--sidebar-transition);flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:40;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.07);min-height:72px;overflow:hidden}.sidebar__brand-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar__brand-logo-text{color:#fff;font-weight:800;font-size:1rem;font-family:var(--font-display)}.sidebar__brand-img{width:100%;height:100%;object-fit:contain;border-radius:6px}.sidebar__brand-name{color:var(--sidebar-text-active);font-weight:700;font-size:.9rem;font-family:var(--font-display);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__brand-sub{color:var(--sidebar-section-text);font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0}.sidebar__nav::-webkit-scrollbar{width:3px}.sidebar__nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar__section{padding:.5rem 0}.sidebar__section-label{display:block;padding:.4rem 1rem .25rem;color:var(--sidebar-section-text);font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;overflow:hidden}.sidebar__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;background:transparent;border:none;color:var(--sidebar-text);font-size:.8125rem;font-weight:500;text-align:left;cursor:pointer;transition:background var(--sidebar-transition),color var(--sidebar-transition);white-space:nowrap;overflow:hidden;border-radius:0;position:relative}.sidebar__item:hover{background:var(--sidebar-hover);color:#fff}.sidebar__item--active{color:var(--sidebar-text-active);background:#4f46e51f}.sidebar__item--active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sidebar-accent);border-radius:0 2px 2px 0}.sidebar__item-icon{flex-shrink:0}.sidebar__item-label{overflow:hidden;text-overflow:ellipsis;transition:opacity var(--sidebar-transition),width var(--sidebar-transition)}.sidebar--collapsed .sidebar__item-label{opacity:0;width:0;overflow:hidden}.sidebar--collapsed .sidebar__section-label{opacity:0;height:0;padding:0;overflow:hidden}.sidebar__footer{padding:.75rem .5rem;border-top:1px solid rgba(255,255,255,.07)}.sidebar__toggle{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .75rem;background:transparent;border:none;color:var(--sidebar-section-text);font-size:.8125rem;cursor:pointer;border-radius:6px;transition:background var(--sidebar-transition),color var(--sidebar-transition);white-space:nowrap;overflow:hidden}.sidebar__toggle:hover{background:var(--sidebar-hover);color:#fff}.dashboard-content{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--sidebar-transition)}.dashboard-content--sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.dashboard-topbar{position:sticky;top:0;z-index:30;height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;padding:0 1.5rem;gap:.75rem}.dashboard-topbar__right{display:flex;align-items:center;gap:.75rem}.sidebar-hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:8px;color:var(--text-2);cursor:pointer;margin-right:auto}.sidebar-hamburger:hover{background:var(--brand-100)}.dashboard-main{flex:1;padding:2rem 1.5rem;max-width:72rem;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.session-badge{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;background:#f0fdf4;border:1px solid #dcfce7;color:#15803d;font-size:.75rem;font-weight:700}.session-badge__dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:10px;background:#fff;border:1px solid var(--border);color:var(--text-2);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.logout-btn:hover{color:#dc2626;border-color:#fee2e2;background:#fef2f2}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:45}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--sidebar-transition),width var(--sidebar-transition)}.sidebar--mobile-open{transform:translate(0)}.dashboard-content{margin-left:0!important}.sidebar-hamburger{display:flex}.chat-panel{width:calc(100vw - 2rem);right:1rem}.notif-popover{width:calc(100vw - 2rem);right:-1rem}}.chat-fab{position:fixed;bottom:1.5rem;right:1.5rem;width:var(--chat-fab-size);height:var(--chat-fab-size);border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #4f46e566;z-index:var(--chat-z);transition:transform .2s,box-shadow .2s}.chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #4f46e580}.chat-fab__badge{position:absolute;top:2px;right:2px;width:12px;height:12px;border-radius:50%;background:#22c55e;border:2px solid white}.chat-panel{position:fixed;bottom:calc(var(--chat-fab-size) + 1.5rem + .75rem);right:1.5rem;width:var(--chat-panel-width);height:var(--chat-panel-height);background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:var(--chat-z);animation:chatFadeInUp .25s cubic-bezier(.4,0,.2,1)}@keyframes chatFadeInUp{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-panel__header{padding:1rem 1.25rem;background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-900) 100%);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-panel__header-info{display:flex;align-items:center;gap:.75rem}.chat-panel__header-icon{width:36px;height:36px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;color:#fff}.chat-panel__header-title{color:#fff;font-size:.875rem;font-weight:700}.chat-panel__header-sub{color:var(--brand-400);font-size:.7rem;margin-top:1px}.chat-panel__close{background:transparent;border:none;color:var(--brand-400);cursor:pointer;padding:.25rem;border-radius:6px;display:flex;align-items:center;transition:color .15s}.chat-panel__close:hover{color:#fff}.chat-panel__body{flex:1;overflow-y:auto;padding:1rem;background:var(--brand-50);display:flex;flex-direction:column;gap:.75rem}.chat-panel__body::-webkit-scrollbar{width:4px}.chat-panel__body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}.chat-panel__empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-4);font-size:.8rem;font-style:italic;text-align:center;padding:1rem}.chat-bubble-row{display:flex}.chat-bubble-row--user{justify-content:flex-end}.chat-bubble-row--bot{justify-content:flex-start}.chat-bubble{max-width:85%;padding:.5rem .75rem;border-radius:12px;font-size:.8125rem;line-height:1.5}.chat-bubble--user{background:var(--accent);color:#fff;border-bottom-right-radius:3px}.chat-bubble--bot{background:#fff;color:var(--text);border:1px solid var(--border);border-bottom-left-radius:3px;box-shadow:var(--shadow-sm)}.chat-bubble--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-bottom-left-radius:3px}.chat-typing{display:flex;gap:4px;padding:.5rem .75rem;background:#e2e8f0;border-radius:12px 12px 12px 3px;width:fit-content}.chat-typing__dot{width:6px;height:6px;border-radius:50%;background:var(--text-3);animation:chatBounce 1.2s infinite}.chat-typing__dot:nth-child(2){animation-delay:.2s}.chat-typing__dot:nth-child(3){animation-delay:.4s}@keyframes chatBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.chat-panel__input-bar{padding:.75rem 1rem;background:#fff;border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem;flex-shrink:0}.chat-panel__input{flex:1;background:var(--brand-50);border:1px solid var(--border);border-radius:9999px;padding:.5rem 1rem;font-size:.8rem;font-family:var(--font-family);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.chat-panel__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.chat-panel__send{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),opacity var(--transition);flex-shrink:0}.chat-panel__send:disabled{background:var(--brand-200);cursor:not-allowed;opacity:.6}.chat-panel__send:not(:disabled):hover{background:var(--accent-dark)}.notif-trigger-wrapper{position:relative}.notif-trigger{position:relative;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:.85rem;color:var(--text-2);font-weight:500;transition:border-color var(--transition),background var(--transition)}.notif-trigger:hover{border-color:var(--border-strong);background:var(--brand-50)}.notif-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notif-popover{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;display:flex;flex-direction:column;overflow:hidden;animation:notifFadeIn .15s ease}@keyframes notifFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.notif-popover__header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-900) 100%);flex-shrink:0}.notif-popover__title{margin:0;font-size:.95rem;font-weight:700;color:#fff}.notif-popover__sub{margin:.2rem 0 0;font-size:.75rem;color:var(--brand-400)}.notif-popover__close{background:transparent;border:none;color:var(--brand-400);font-size:1.4rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:color .15s;line-height:1}.notif-popover__close:hover{color:#fff}.notif-mark-all-bar{padding:.6rem 1rem;border-bottom:1px solid var(--border-strong);flex-shrink:0}.notif-mark-all-btn{width:100%;padding:.45rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#2563eb;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.notif-mark-all-btn:hover{background:#dbeafe}.notif-popover__list{flex:1;overflow-y:auto}.text-white{color:#fff}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{animation:skeleton-shimmer 1.5s ease-in-out infinite}
