@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.btn-primary{background:var(--color-primary);color:#fff;border:none;box-shadow:0 2px 4px #1e40af33}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 4px 8px #1e40af4d;transform:translateY(-2px)}.btn-secondary{background:#fff;color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:0 2px 4px #0000000d}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary-hover);transform:translateY(-2px)}.btn-white{background:#fff;color:var(--color-primary);border:none;box-shadow:0 2px 4px #0000001a}.btn-white:hover:not(:disabled){background:var(--color-primary-light);color:var(--color-primary-hover);box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.container{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--spacing-xl)}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin:0;cursor:pointer}.header-nav{display:flex;gap:1rem;align-items:center}.section-title{text-align:center;font-size:1.875rem;font-weight:700;margin-bottom:3rem;color:var(--color-text-primary)}.form-group{margin-bottom:var(--spacing-xl)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--color-text-primary);font-size:1rem}.form-control{width:100%;padding:.875rem 1rem;border:2px solid var(--color-border);border-radius:var(--border-radius-md);font-size:1rem;font-family:inherit;transition:var(--transition-default);background-color:#fff;color:var(--color-text-primary)}.alert{padding:1rem 1.5rem;border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);font-size:1rem;font-weight:500}.alert-success{background-color:#d1fae5;color:#065f46;border-left:4px solid var(--color-success)}.alert-error{background-color:#fee2e2;color:#991b1b;border-left:4px solid var(--color-error)}@media(min-width:768px)and (max-width:1023px){.container{padding:0 var(--section-padding-tablet-horizontal)}.section-title{font-size:var(--font-size-h2-mobile)}}@media(max-width:767px){.container{padding:0 var(--section-padding-mobile-horizontal)}.section-title{font-size:var(--font-size-h2-mobile)}.header-nav{flex-direction:column;gap:var(--spacing-sm)}.header-nav button{width:100%;font-size:.9rem;padding:.6rem 1rem}.btn-primary,.btn-secondary{width:100%}}:root{--color-primary: #1e40af;--color-primary-hover: #1e3a8a;--color-primary-light: #dbeafe;--color-secondary: #64748b;--color-secondary-hover: #475569;--color-accent: #F59E0B;--color-accent-light: #FEF3C7;--color-success: #4caf50;--color-warning: #ff9800;--color-error: #f44336;--color-info: #1e40af;--color-text-primary: #0F172A;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #E2E8F0;--color-background: #FFFFFF;--color-background-alt: #F8FAFC;--color-background-dark: #0F172A;--color-primary-dark: #1565C0;--color-surface: #F8FAFC;--color-card: #FFFFFF;--color-text-light: #94A3B8;--color-hover: #dbeafe;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1), 0 10px 10px rgba(0, 0, 0, .04);--font-family-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-h1-mobile: 1.75rem;--font-size-h1-desktop: 2rem;--font-size-h2-mobile: 1.375rem;--font-size-h2-desktop: 1.625rem;--font-size-h3-mobile: 1.125rem;--font-size-h3-desktop: 1.25rem;--font-size-h4-mobile: 1rem;--font-size-h4-desktop: 1.125rem;--font-size-body-mobile: 1rem;--font-size-body-desktop: 1rem;--font-size-small-mobile: .8125rem;--font-size-small-desktop: .875rem;--font-size-caption: .75rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-heading: 1.2;--line-height-body: 1.6;--line-height-caption: 1.4;--letter-spacing-heading: -.02em;--letter-spacing-body: 0;--letter-spacing-button: .01em;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--section-padding-mobile-vertical: 2rem;--section-padding-mobile-horizontal: 1rem;--section-padding-tablet-vertical: 3rem;--section-padding-tablet-horizontal: 2rem;--section-padding-desktop-vertical: 4rem;--section-padding-desktop-horizontal: 2rem;--container-max-width: 1200px;--breakpoint-mobile: 768px;--breakpoint-tablet: 1024px;--breakpoint-desktop: 1280px;--transition-fast: all .15s ease-in-out;--transition-default: all .2s ease-in-out;--transition-slow: all .3s ease-in-out;--border-radius-sm: 6px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-full: 50%;--z-index-dropdown: 100;--z-index-sticky: 200;--z-index-modal: 1000;--z-index-toast: 2000;font-family:var(--font-family-primary);line-height:var(--line-height-body);font-weight:var(--font-weight-regular);color:var(--color-text-primary);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}.skip-to-content{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:.5rem 1rem;text-decoration:none;z-index:100;border-radius:0 0 var(--border-radius-md) 0}.skip-to-content:focus{top:0}a{font-weight:500;color:var(--color-primary);text-decoration:none;transition:var(--transition-default)}a:hover{color:var(--color-primary-hover);text-decoration:underline}a:focus,a:focus-visible{outline:3px solid var(--color-primary-light);outline-offset:2px;border-radius:var(--border-radius-sm)}body{margin:0;min-width:320px;min-height:100vh;background:#fafafa;font-size:1rem}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);margin-top:0;line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-heading)}h1{font-size:var(--font-size-h1-mobile);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-h2-mobile)}h3{font-size:var(--font-size-h3-mobile)}h4{font-size:var(--font-size-h4-mobile)}@media(min-width:1024px){h1{font-size:var(--font-size-h1-desktop)}h2{font-size:var(--font-size-h2-desktop)}h3{font-size:var(--font-size-h3-desktop)}h4{font-size:var(--font-size-h4-desktop)}body{font-size:var(--font-size-body-desktop)}}input,select,textarea{border:2px solid var(--color-border);border-radius:6px;padding:.6em;font-family:inherit;font-size:1em;transition:border-color .3s ease,box-shadow .3s ease;background-color:#fff;color:var(--color-text-primary)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-hover)}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.bg-primary-dark{background-color:var(--color-primary-dark)}.bg-white{background-color:var(--color-background)}.bg-surface{background-color:var(--color-surface)}.bg-card{background-color:var(--color-card)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-light{color:var(--color-text-light)}.text-blue{color:var(--color-primary)}.text-white{color:#fff}.btn{display:inline-block;padding:.7em 1.5em;font-size:1em;font-weight:600;text-align:center;text-decoration:none;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:#fff;color:var(--color-primary);border-color:var(--color-primary)}.btn-secondary:hover{background-color:var(--color-hover)}.btn-outline{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover{background-color:var(--color-primary);color:#fff}.card-modern{background-color:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:all .3s ease}.card-modern:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-header{padding-bottom:1rem;margin-bottom:1rem;border-bottom:2px solid var(--color-primary)}.form-control{width:100%;padding:.7rem;border:2px solid var(--color-border);border-radius:8px;font-size:1rem;transition:all .3s ease;background-color:#fff;color:var(--color-text-primary)}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-hover)}.form-control:disabled{background-color:var(--color-surface);cursor:not-allowed;opacity:.6}.container-fluid{width:100%;padding:2rem;min-height:100vh}.container-centered{max-width:1400px;margin:0 auto;padding:2rem}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;justify-content:center;align-items:center}.flex-column{display:flex;flex-direction:column}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.gap-lg{gap:1.5rem}.gap-xl{gap:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-normal{font-weight:400}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:2rem}.border{border:1px solid var(--color-border)}.border-2{border:2px solid var(--color-border)}.border-primary{border-color:var(--color-primary)}.border-radius{border-radius:8px}.border-radius-lg{border-radius:12px}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}@media(max-width:768px){.grid-responsive{grid-template-columns:1fr}.container-centered{padding:1rem}.btn{width:100%}}.status-badge{display:inline-block;padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:700;text-align:center;box-shadow:var(--shadow-sm)}.status-success{background-color:var(--color-success);color:#fff}.status-warning{background-color:var(--color-warning);color:#fff}.status-error{background-color:var(--color-error);color:#fff}.status-info{background-color:var(--color-primary);color:#fff}.alert{padding:1rem 1.5rem;border-radius:8px;margin:1rem 0;border-left:4px solid}.alert-success{background-color:#e8f5e9;color:var(--color-success);border-left-color:var(--color-success)}.alert-error{background-color:#ffebee;color:var(--color-error);border-left-color:var(--color-error)}.alert-info{background-color:var(--color-hover);color:var(--color-primary);border-left-color:var(--color-primary)}.alert-warning{background-color:#fff3e0;color:var(--color-warning);border-left-color:var(--color-warning)}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}.icon-sm,.icon-small{width:16px;height:16px}.icon-md,.icon-medium{width:20px;height:20px}.icon-lg,.icon-large{width:24px;height:24px}.icon-primary{color:var(--color-primary, #1e40af)}.icon-success{color:var(--color-success, #10B981)}.icon-warning{color:var(--color-warning, #F59E0B)}.icon-danger,.icon-error{color:var(--color-error, #EF4444)}.icon-muted{color:var(--color-text-muted, #94A3B8)}.icon-secondary{color:var(--color-secondary, #64748b)}.icon-info{color:var(--color-info, #1e40af)}button .icon,.btn .icon{margin-right:8px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem;background-color:#f9fafb}.error-boundary-content{max-width:600px;width:100%;text-align:center;background:#fff;border-radius:8px;padding:3rem 2rem;box-shadow:0 2px 8px #0000001a}.error-boundary .error-icon{color:#dc2626;margin-bottom:1rem}.error-boundary h2{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:.5rem}.error-boundary .error-message{color:#6b7280;font-size:1rem;margin-bottom:2rem;line-height:1.5}.error-boundary .error-details{text-align:left;margin:2rem 0;padding:1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:4px;cursor:pointer}.error-boundary .error-details summary{font-weight:600;color:#991b1b;cursor:pointer;-webkit-user-select:none;user-select:none}.error-boundary .error-details summary:hover{color:#7f1d1d}.error-boundary .error-stack{margin-top:1rem;padding:1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:4px;overflow-x:auto;font-size:.875rem;line-height:1.5;color:#374151;white-space:pre-wrap;word-break:break-word}.error-boundary .error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-boundary .btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:6px;border:none;cursor:pointer;font-weight:500;transition:all .2s}.error-boundary .btn-primary{background-color:#2563eb;color:#fff}.error-boundary .btn-primary:hover{background-color:#1d4ed8}.error-boundary .btn-secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.error-boundary .btn-secondary:hover{background-color:#e5e7eb}@media(max-width:640px){.error-boundary{padding:1rem}.error-boundary-content{padding:2rem 1.5rem}.error-boundary h2{font-size:1.25rem}.error-boundary .error-message{font-size:.875rem}.error-boundary .error-actions{flex-direction:column}.error-boundary .btn{width:100%}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:2px solid var(--color-primary);box-shadow:0 -4px 6px #0000001a,0 -2px 4px #0000000f;z-index:var(--z-index-modal);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-banner-content{max-width:var(--container-max-width);margin:0 auto;padding:var(--spacing-xl);display:flex;gap:var(--spacing-xl);align-items:center;justify-content:space-between}.cookie-banner-text{flex:1}.cookie-banner-title{font-size:1.25rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.cookie-banner-description{font-size:.9375rem;line-height:1.6;color:var(--color-text-secondary);margin:0}.cookie-banner-link{color:var(--color-primary);text-decoration:underline;font-weight:var(--font-weight-medium)}.cookie-banner-link:hover{color:var(--color-primary-hover)}.cookie-banner-actions{display:flex;gap:var(--spacing-md);flex-shrink:0}.cookie-btn{padding:.75rem 1.5rem;min-height:44px;border-radius:var(--border-radius-md);font-size:.9375rem;font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-button);cursor:pointer;transition:var(--transition-default);border:2px solid transparent;white-space:nowrap;touch-action:manipulation}.cookie-btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.cookie-btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.cookie-btn-secondary{background:#fff;color:var(--color-text-primary);border:2px solid var(--color-border);box-shadow:var(--shadow-sm)}.cookie-btn-secondary:hover{background:var(--color-background-alt);border-color:var(--color-text-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.cookie-btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.cookie-btn-outline:hover{background:var(--color-primary-light);border-color:var(--color-primary-hover);transform:translateY(-2px)}.cookie-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-index-modal) + 1);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);animation:fadeIn .2s ease-out}.cookie-modal{background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.cookie-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:2px solid var(--color-border)}.cookie-modal-title{font-size:1.5rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.cookie-modal-close{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-sm);display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:var(--transition-default);min-height:auto}.cookie-modal-close:hover{background:var(--color-background-alt);color:var(--color-text-primary);transform:none}.cookie-modal-body{padding:var(--spacing-xl)}.cookie-modal-intro{font-size:.9375rem;line-height:1.6;color:var(--color-text-secondary);margin:0 0 var(--spacing-xl) 0}.cookie-preference-item{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.cookie-preference-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.cookie-preference-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.cookie-preference-info{flex:1}.cookie-preference-title{font-size:1.125rem;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.cookie-preference-description{font-size:.875rem;line-height:1.6;color:var(--color-text-secondary);margin:0}.cookie-toggle{position:relative;width:52px;height:28px;flex-shrink:0}.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}.cookie-toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--color-border);transition:var(--transition-default);border-radius:28px}.cookie-toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:var(--transition-default);border-radius:50%;box-shadow:0 2px 4px #0003}.cookie-toggle input:checked+.cookie-toggle-slider{background-color:var(--color-primary)}.cookie-toggle input:checked+.cookie-toggle-slider:before{transform:translate(24px)}.cookie-toggle-disabled{opacity:.6;cursor:not-allowed}.cookie-toggle-disabled .cookie-toggle-slider{cursor:not-allowed;background-color:var(--color-success)}.cookie-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-xl);border-top:2px solid var(--color-border)}@media(min-width:768px)and (max-width:1023px){.cookie-banner-content{flex-direction:column;align-items:flex-start}.cookie-banner-actions{width:100%;justify-content:flex-start}}@media(max-width:767px){.cookie-banner-content{flex-direction:column;align-items:flex-start;padding:var(--spacing-lg)}.cookie-banner-title{font-size:1.125rem}.cookie-banner-description{font-size:.875rem}.cookie-banner-actions{flex-direction:column;width:100%}.cookie-btn{width:100%;justify-content:center}.cookie-modal-overlay{padding:var(--spacing-md)}.cookie-modal{max-height:95vh}.cookie-modal-header,.cookie-modal-body,.cookie-modal-footer{padding:var(--spacing-lg)}.cookie-modal-title{font-size:1.25rem}.cookie-preference-header{flex-direction:column;gap:var(--spacing-md)}.cookie-toggle{align-self:flex-start}.cookie-modal-footer{flex-direction:column-reverse}.cookie-modal-footer .cookie-btn{width:100%}}.cookie-btn:focus,.cookie-btn:focus-visible{outline:3px solid var(--color-primary-light);outline-offset:2px}.cookie-modal-close:focus,.cookie-modal-close:focus-visible{outline:3px solid var(--color-primary-light);outline-offset:2px}.cookie-toggle input:focus+.cookie-toggle-slider{box-shadow:0 0 0 3px var(--color-primary-light)}.homepage{min-height:100vh;background:#f8fafc}.homepage-header{background:#fff;padding:1rem 0;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--color-border);box-shadow:0 2px 4px #0000000a}.hero{padding:6rem 0;text-align:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);color:#fff}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:2.5rem;font-weight:800;margin-bottom:1.5rem;line-height:1.2;color:#fff}.hero-subtitle{font-size:1.125rem;line-height:1.8;margin-bottom:2rem;opacity:.95;color:#fff}.hero-features{list-style:none;padding:0;margin:0 auto 3rem;max-width:900px;display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.hero-features li{font-size:1rem;line-height:1.6;margin-bottom:0;padding:1rem 1.5rem;position:relative;background:#fff;color:var(--color-text-primary);border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:.75rem;transition:all .2s ease}.hero-features li:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.hero-features li:before{content:"✓";display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;flex-shrink:0;position:static;font-weight:700;font-size:1rem}.hero-cta{margin-top:2rem}.problem-section{background:#fff;padding:5rem 0}.problem-section .section-title{text-align:center;font-size:1.875rem;font-weight:700;margin-bottom:3rem;color:var(--color-text-primary)}.problem-content{max-width:700px;margin:0 auto;text-align:center}.problem-description{font-size:1rem;line-height:1.8;color:#2d3748;margin-bottom:1.5rem}.problem-closing{font-size:1.125rem;line-height:1.8;color:var(--color-primary);font-weight:700;margin-top:2rem}.solution-section{background:var(--color-background-alt);padding:5rem 0}.solution-section .section-title{text-align:center;font-size:1.875rem;font-weight:700;margin-bottom:3rem;color:var(--color-text-primary)}.solution-content{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.solution-text{text-align:left}.solution-description{font-size:1rem;line-height:1.8;color:#2d3748;margin-bottom:2rem}.solution-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.solution-features li{font-size:1rem;line-height:1.6;padding:1rem 1.5rem;background:#fff;color:var(--color-text-primary);border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:.75rem;transition:all .2s ease}.solution-features li:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.solution-features li:before{content:"✓";display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;flex-shrink:0;font-weight:700;font-size:1rem}.solution-image{width:100%;height:400px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:1.125rem;font-weight:600;box-shadow:0 4px 16px #1e40af26}.solution-emphasis{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #1e40af14;border:1px solid var(--color-border);transition:all .2s ease;font-size:1rem;line-height:1.8;color:var(--color-primary);font-weight:700;display:none}.solution-emphasis:hover{box-shadow:0 4px 16px #1e40af1f;transform:translateY(-2px)}.target-audience-section{background:#fff;padding:5rem 0}.target-audience-section .section-title{text-align:center;font-size:1.875rem;font-weight:700;margin-bottom:3rem;color:var(--color-text-primary)}.target-segments-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1100px;margin-left:auto;margin-right:auto}.target-segment{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #1e40af14;border:1px solid var(--color-border);transition:all .2s ease;text-align:center}.target-segment:hover{box-shadow:0 4px 16px #1e40af1f;transform:translateY(-2px)}.target-segment-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:50%;color:var(--color-primary)}.target-segment h4{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:#1a202c;line-height:1.4}.target-segment p{font-size:1rem;line-height:1.7;color:#2d3748}.differentiation-section{background:var(--color-background-alt);padding:5rem 0}.differentiation-section .section-title{text-align:center;font-size:1.875rem;font-weight:700;margin-bottom:3rem;color:var(--color-text-primary)}.differentiation-content{max-width:800px;margin:0 auto;text-align:center}.differentiation-description{font-size:1rem;line-height:1.8;color:#2d3748;margin-bottom:1.5rem}.critical-question{margin:2rem 0}.critical-question p{margin:0;font-size:1.125rem;line-height:1.8;color:var(--color-primary);font-weight:700}.final-cta{background:linear-gradient(135deg,#1e40af,#1e3a8a);padding:5rem 0;text-align:center;color:#fff}.final-cta h3{font-size:1.875rem;font-weight:700;margin-bottom:1rem;color:#fff}.final-cta p{font-size:1rem;margin-bottom:2rem;opacity:.95}.homepage-footer{background:var(--color-text-primary);padding:3rem 0 1rem;color:#fff}.homepage-footer .footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.homepage-footer .footer-section h4{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:#fff}.homepage-footer .footer-section p{color:#fff}.homepage-footer .footer-section ul{list-style:none;padding:0}.homepage-footer .footer-section ul li{margin-bottom:.5rem}.homepage-footer .footer-section a{color:#fff!important;text-decoration:none;transition:color .3s ease}.homepage-footer .footer-section a:hover{color:#fffc!important;text-decoration:none}.homepage-footer .footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.2);color:#fff}@media(min-width:1024px){.hero-title{font-size:var(--font-size-h1-desktop)}.hero-subtitle{font-size:1.125rem}.hero-features,.hero-features li{flex-direction:row}}@media(min-width:768px)and (max-width:1023px){.hero,.problem-section,.solution-section,.target-audience-section,.differentiation-section,.final-cta{padding:var(--section-padding-tablet-vertical) 0}.target-segments-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.hero{padding:var(--section-padding-mobile-vertical) 0}.hero-title{font-size:var(--font-size-h1-mobile)}.hero-subtitle{font-size:1.125rem}.hero-features{flex-direction:column;gap:1rem}.hero-features li{flex-direction:column;text-align:center}.section-title{font-size:var(--font-size-h2-mobile)}.problem-section .section-title{font-size:1.75rem}.problem-description{font-size:1.125rem}.problem-closing{font-size:1.25rem}.solution-section .section-title{font-size:1.75rem}.solution-content{grid-template-columns:1fr;gap:2rem}.solution-image{height:300px;order:-1}.solution-description{font-size:1.125rem}.solution-emphasis{font-size:1.25rem}.target-audience-section .section-title{font-size:1.75rem}.target-segments-grid{grid-template-columns:1fr}.target-segment h4{font-size:1.25rem}.target-segment p{font-size:1rem}.differentiation-section .section-title{font-size:1.75rem}.differentiation-description{font-size:1.125rem}.critical-question p{font-size:1.375rem}.problem-section,.solution-section,.target-audience-section,.differentiation-section,.final-cta{padding:var(--section-padding-mobile-vertical) 0}}.MuiContainer-root{min-height:100vh;background:transparent;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.MuiPaper-root{background:#fff!important;border-radius:12px!important;padding:2.5rem!important;box-shadow:0 2px 8px #1e40af14!important;border:1px solid var(--color-border)!important;max-width:480px;width:100%}.MuiPaper-root:hover{box-shadow:0 4px 16px #1e40af1f!important}.MuiTypography-h4{font-size:1.75rem!important;font-weight:700!important;color:var(--color-text-primary)!important;margin-bottom:.5rem!important}.MuiTypography-body2{font-size:1rem!important;color:var(--color-text-secondary)!important}.MuiTextField-root{margin-bottom:1rem!important}.MuiOutlinedInput-root{border-radius:8px!important;font-size:1rem!important}.MuiOutlinedInput-root .MuiOutlinedInput-notchedOutline{border-color:var(--color-border)!important;border-width:1px!important}.MuiOutlinedInput-root:hover .MuiOutlinedInput-notchedOutline{border-color:var(--color-primary)!important}.MuiOutlinedInput-root.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:var(--color-primary)!important;border-width:2px!important}.MuiInputLabel-root{font-size:1rem!important;color:var(--color-text-secondary)!important}.MuiInputLabel-root.Mui-focused{color:var(--color-primary)!important}.MuiFormHelperText-root{font-size:.8125rem!important}.MuiButton-root{background:var(--color-primary)!important;color:#fff!important;border-radius:8px!important;padding:.75rem 1.5rem!important;font-size:1rem!important;font-weight:600!important;text-transform:none!important;box-shadow:0 2px 4px #1e40af33!important;transition:all .2s ease!important;min-height:48px!important}.MuiButton-root:hover{background:var(--color-primary-hover)!important;box-shadow:0 4px 8px #1e40af4d!important;transform:none!important}.MuiButton-root:disabled{background:var(--color-border)!important;color:var(--color-text-muted)!important;box-shadow:none!important}.MuiAlert-root{border-radius:8px!important;font-size:1rem!important;padding:1rem 1.25rem!important;margin-bottom:1.5rem!important}.MuiAlert-standardError{background-color:#fee2e2!important;color:#991b1b!important;border-left:3px solid var(--color-error)!important}.MuiAlert-standardSuccess{background-color:#d1fae5!important;color:#065f46!important;border-left:3px solid var(--color-success)!important}a{color:var(--color-primary)!important;text-decoration:none!important;font-weight:500!important;transition:color .2s ease!important}a:hover{color:var(--color-primary-hover)!important;text-decoration:underline!important}.MuiCircularProgress-root{color:#fff!important}@media(max-width:768px){.MuiContainer-root{padding:1rem}.MuiPaper-root{padding:2rem 1.5rem!important}.MuiTypography-h4{font-size:1.5rem!important}}.profile-avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;color:#fff;font-weight:600;-webkit-user-select:none;user-select:none}.profile-avatar.clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.profile-avatar.clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.profile-avatar.clickable:focus{outline:2px solid #1976d2;outline-offset:2px}.profile-avatar-small{width:32px;height:32px;font-size:12px}.profile-avatar-medium{width:48px;height:48px;font-size:16px}.profile-avatar-large{width:96px;height:96px;font-size:32px}.profile-avatar-image{width:100%;height:100%;object-fit:cover}.profile-avatar-initials{text-transform:uppercase;letter-spacing:1px}.nav-container{display:flex;gap:2rem;align-items:center;padding:1rem 2rem;background-color:#fff;border-bottom:1px solid #E0E0E0;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:1000}.nav-logo-section{display:flex;align-items:center}.nav-logo{font-size:1.6rem;font-weight:700;color:#1e40af;cursor:pointer;display:flex;align-items:center;text-decoration:none;transition:opacity .2s ease}.nav-logo:hover{opacity:.8}.nav-add-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:#1e40af;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #1e40af33;font-size:1rem;font-weight:600;white-space:nowrap}.nav-add-button:hover{background:#1e3a8a;box-shadow:0 4px 8px #1e40af4d;transform:translateY(-2px)}.nav-add-button:active{transform:translateY(0)}.nav-add-button svg{flex-shrink:0}.nav-add-button span{display:inline}.nav-links{display:flex;gap:2rem;align-items:center;flex:1}.nav-link{font-size:1rem;font-weight:500;color:#757575;cursor:pointer;text-decoration:none;transition:color .2s ease;padding:.5rem 0;border:none;background:none}.nav-link:hover,.nav-link.active{color:#1e40af}.nav-right-section{margin-left:auto;display:flex;align-items:center;gap:1rem}.nav-separator{width:1px;height:24px;background-color:#d1d5db}.nav-profile-wrapper{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:20px;transition:background-color .2s ease}.nav-profile-wrapper:hover{background-color:#f3f4f6}.nav-trial-badge{font-size:.7rem;font-weight:600;color:#059669;background-color:#d1fae5;padding:.15rem .5rem;border-radius:10px;white-space:nowrap}.nav-logout{font-size:1rem;font-weight:500;color:#f44336;cursor:pointer;text-decoration:none;transition:color .2s ease;padding:.5rem 0;display:flex;align-items:center;gap:.5rem;border:none;background:none}.nav-logout:hover{color:#d32f2f}.nav-logout-icon{width:18px;height:18px;vertical-align:middle}@media(max-width:768px){.nav-container{padding:1rem;gap:1rem}.nav-links{gap:1rem}.nav-logo-section{margin-right:0}.nav-logo{font-size:1.4rem}.nav-add-button{padding:.4rem .8rem;font-size:.9rem}.nav-add-button svg{width:18px;height:18px}.nav-add-button span{display:none}.nav-link,.nav-logout{font-size:.9rem}}.profile-page{min-height:calc(100vh - 70px);background-color:#f8fafc;padding:2rem 1rem}.profile-container{max-width:500px;margin:0 auto}.profile-loading{display:flex;justify-content:center;align-items:center;min-height:300px}.profile-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#1e40af;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.profile-header-card{background:#fff;border-radius:16px;padding:2rem;text-align:center;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.profile-avatar-section{display:flex;justify-content:center;margin-bottom:1rem}.profile-name{font-size:1.5rem;font-weight:600;color:#1e293b;margin:0 0 .25rem}.profile-email{font-size:.875rem;color:#64748b;margin:0 0 1rem}.profile-badges{display:flex;justify-content:center;gap:.5rem;margin-bottom:.5rem}.profile-badge{font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:9999px}.profile-badge-primary{background-color:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.profile-badge-success{background-color:#d1fae5;color:#059669}.profile-badge-error{background-color:#fee2e2;color:#dc2626}.profile-badge-default{background-color:#f1f5f9;color:#64748b}.profile-trial-info{font-size:.75rem;color:#64748b;margin:.5rem 0 0}.profile-divider{height:1px;background-color:#e2e8f0;margin:1.5rem 0}.profile-upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;color:#1e40af;background-color:#fff;border:1px solid #1e40af;border-radius:8px;cursor:pointer;transition:all .2s ease}.profile-upload-btn:hover:not(:disabled){background-color:#eff6ff}.profile-upload-btn:disabled{opacity:.6;cursor:not-allowed}.profile-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;overflow:hidden}.profile-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#fff;border:none;cursor:pointer;transition:background-color .2s ease}.profile-section-header:hover{background-color:#f8fafc}.profile-section-title{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:500;color:#1e293b}.profile-section-title svg{color:#1e40af}.profile-section-chevron{color:#94a3b8;transition:transform .2s ease}.profile-section-header.open .profile-section-chevron{transform:rotate(180deg)}.profile-section-content{padding:0 1.25rem 1.25rem;border-top:1px solid #e2e8f0}.profile-form-group{margin-bottom:1rem}.profile-form-group:first-child{margin-top:1rem}.profile-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.375rem}.profile-input{width:100%;padding:.625rem .875rem;font-size:.875rem;color:#1e293b;background-color:#fff;border:1px solid #d1d5db;border-radius:8px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.profile-input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.profile-input:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.profile-input.error{border-color:#dc2626}.profile-input.error:focus{box-shadow:0 0 0 3px #dc26261a}.profile-input-with-icon{position:relative;display:flex;align-items:center}.profile-input-with-icon svg{position:absolute;left:.75rem;color:#9ca3af}.profile-input-with-icon .profile-input{padding-left:2.5rem}.profile-helper-text{font-size:.75rem;color:#6b7280;margin:.25rem 0 0}.profile-error-text{font-size:.75rem;color:#dc2626;margin:.25rem 0 0}.profile-alert{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem}.profile-alert:first-child{margin-top:1rem}.profile-alert-error{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}.profile-alert-success{background-color:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.profile-requirements{list-style:none;padding:0;margin:0 0 1rem}.profile-requirements li{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280;padding:.25rem 0}.profile-requirements li svg{color:#dc2626;flex-shrink:0}.profile-requirements li.met{color:#16a34a}.profile-requirements li.met svg{color:#16a34a}.profile-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none}.profile-btn-primary{background-color:#1e40af;color:#fff}.profile-btn-primary:hover:not(:disabled){background-color:#1e3a8a}.profile-btn-primary:disabled{background-color:#93c5fd;cursor:not-allowed}.profile-btn-logout{background-color:#fff;color:#dc2626;border:1px solid #fecaca}.profile-btn-logout:hover{background-color:#fef2f2;border-color:#dc2626}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:640px){.profile-page{padding:1rem}.profile-header-card{padding:1.5rem}.profile-name{font-size:1.25rem}}.deadline-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:1rem}.deadline-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.deadline-card.status-expired{border-left:4px solid #f44336}.deadline-card.status-expiring_soon{border-left:4px solid #ff9800}.deadline-card.status-valid{border-left:4px solid #4caf50}.deadline-card-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.type-badge{padding:.25rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600}.type-badge.type-training{background-color:#dbeafe;color:#1e3a8a}.type-badge.type-medical{background-color:#f3e5f5;color:#7b1fa2}.type-badge.type-equipment{background-color:#fff3e0;color:#f57c00}.type-badge.type-generic{background-color:#e0f2f1;color:#00796b}.badge{padding:.25rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600}.badge-success{background-color:#e8f5e9;color:#4caf50}.badge-warning{background-color:#fff3e0;color:#ff9800}.badge-danger{background-color:#ffebee;color:#f44336}.deadline-card-body{flex:1;display:flex;flex-direction:column;gap:.75rem}.deadline-title{font-size:1.1rem;font-weight:600;color:#212121;margin:0;line-height:1.4}.deadline-info{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.info-label{color:#757575;font-weight:500}.info-value{color:#212121;font-weight:600;text-align:right}.info-value.days-expired{color:#f44336}.info-value.days-expiring_soon{color:#ff9800}.info-value.days-valid{color:#4caf50}.deadline-card-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid #E0E0E0}.action-btn{flex:1;padding:.6rem 1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.25rem}.action-btn.view{background-color:#dbeafe;color:#1e3a8a}.action-btn.view:hover{background-color:#bbdefb}.action-btn.edit{background-color:#fff3e0;color:#f57c00}.action-btn.edit:hover{background-color:#ffe0b2}.action-btn.delete{background-color:#ffebee;color:#f44336}.action-btn.delete:hover{background-color:#ffcdd2}@media(max-width:768px){.deadline-card{padding:1rem}.deadline-card-actions{flex-direction:column}.action-btn{width:100%}}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl)}.spinner-fullpage{min-height:60vh;width:100%}.spinner{display:inline-block;position:relative}.spinner-sm{width:24px;height:24px}.spinner-md{width:40px;height:40px}.spinner-lg{width:56px;height:56px}.spinner-circle{width:100%;height:100%;border:3px solid transparent;border-top-color:var(--color-primary);border-right-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm .spinner-circle{border-width:2px}.spinner-lg .spinner-circle{border-width:4px}.spinner-text{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-body-desktop);font-weight:var(--font-weight-medium)}.loading-indicator{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-small-desktop);margin-left:var(--spacing-sm)}.dashboard-container{width:100%;min-height:100vh;background:#fafafa;padding:2rem max(2rem,(100% - 1400px) / 2)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:3px solid #1e40af}.dashboard-header h1{margin:0;color:#1a202c;font-size:2.5rem;font-weight:700}.btn-primary{background:#1e40af;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.btn-primary:hover:not(:disabled){background:#1e3a8a;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:#1e40af;border:2px solid #1e40af;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#e0e7ff}.btn-success{background:#10b981;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.btn-success:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.loading-state p{color:#757575;font-size:1.1rem}.error-state{text-align:center;max-width:500px;margin:4rem auto}.error-message{background:#ffebee;color:#f44336;padding:1.5rem;border-radius:12px;border-left:4px solid #f44336;margin-bottom:1.5rem}.empty-state{text-align:center;margin-top:4rem;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;border:2px dashed #E0E0E0}.empty-state p{font-size:1.2rem;color:#757575;margin:0}.search-input{flex:1;padding:.8rem 1rem;font-size:1rem;border:2px solid #E0E0E0;border-radius:8px;transition:border-color .3s ease}.search-results{margin-bottom:2rem}.search-results-header{background:#e0e7ff;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.search-results-header h2{margin:0;font-size:1.3rem;color:#1e40af}.search-result-card{border:3px solid #7C3AED;border-radius:12px;padding:1.5rem;background:#fff;display:flex;flex-direction:column;gap:1rem;box-shadow:0 4px 6px #0000001a;transition:all .3s ease}.search-result-card:hover{box-shadow:0 10px 20px #00000026;transform:translateY(-4px)}.company-badge{background:#f3e5f5;color:#7c3aed;padding:.5rem .8rem;border-radius:6px;font-size:.85rem;font-weight:600;display:inline-block}.search-result-card h3{margin:0;font-size:1.2rem;color:#1a202c;font-weight:600}.certificate-details{font-size:.9rem;color:#757575;display:flex;flex-direction:column;gap:.5rem}.certificate-details strong{color:#1a202c}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;border:3px solid}.stat-card.stat-primary{border-color:#1e40af}.stat-card.stat-purple{border-color:#7c3aed}.stat-card.stat-warning{border-color:#f59e0b}.stat-card.stat-danger{border-color:#ef4444}.stat-card.stat-success{border-color:#10b981}.stat-label{font-size:.9rem;color:#757575;margin-bottom:.5rem;font-weight:600}.stat-card.stat-primary .stat-value{color:#1e40af}.stat-card.stat-purple .stat-value{color:#7c3aed}.stat-card.stat-warning .stat-value{color:#f59e0b}.stat-card.stat-danger .stat-value{color:#ef4444}.stat-card.stat-success .stat-value{color:#10b981}.sort-controls{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;align-items:center}.sort-controls span{font-weight:600;color:#1a202c}.sort-controls button{padding:.6rem 1rem;background:#fff;color:#757575;border:2px solid #E0E0E0;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.3rem;transition:all .3s ease}.sort-controls button:hover{border-color:#1e40af;color:#1e40af}.sort-controls button.active{background:#1e40af;color:#fff;border-color:#1e40af}.companies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;margin-top:2rem}.company-card{border:3px solid #1e40af;border-radius:12px;padding:1.5rem;background:#fff;display:flex;flex-direction:column;gap:1rem;box-shadow:0 4px 6px #0000001a;transition:all .3s ease}.company-card:hover{box-shadow:0 10px 20px #00000026;transform:translateY(-4px)}.company-card h3{margin:0;font-size:1.3rem;color:#1a202c;font-weight:600}.company-card-header{display:flex;justify-content:space-between;align-items:start;gap:1rem}.company-card-menu{position:relative}.menu-trigger{background:none;border:none;font-size:1.5rem;color:#757575;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease}.menu-trigger:hover{background:#fafafa;color:#1e40af}.menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:2px solid #E0E0E0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:150px;z-index:100;overflow:hidden}.menu-dropdown button{display:block;width:100%;padding:.75rem 1rem;background:#fff;border:none;text-align:left;font-size:.95rem;font-weight:600;color:#1a202c;cursor:pointer;transition:background .2s ease}.menu-dropdown button:hover{background:#fafafa}.menu-dropdown button:first-child{color:#1e40af}.menu-dropdown button:last-child{color:#ef4444}.menu-dropdown button:not(:last-child){border-bottom:1px solid #E0E0E0}.company-stats{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.stat-badge{padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.3rem}.stat-badge.stat-primary{background:#dbeafe;color:#1e40af}.stat-badge.stat-success{background:#d1fae5;color:#10b981}.stat-badge.stat-warning{background:#fef3c7;color:#f59e0b}.stat-badge.stat-danger{background:#fee2e2;color:#ef4444}.company-meta{font-size:.85rem;color:#757575;margin-top:.5rem}.company-meta strong{color:#1a202c}.company-actions{display:flex;gap:.75rem;margin-top:.5rem}.company-actions button{flex:1;padding:.8rem;font-size:.95rem;border-radius:10px;font-weight:600;transition:all .3s ease}.certificates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;margin-top:2rem}.pagination button{padding:.6rem 1rem;background:#fff;color:#757575;border:2px solid #E0E0E0;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;min-width:40px;transition:all .3s ease}.pagination button:hover:not(:disabled){border-color:#1e40af;color:#1e40af}.pagination button:disabled{background:#e0e0e0;color:#757575;cursor:not-allowed}.pagination button.active{background:#1e40af;color:#fff;border-color:#1e40af}.pagination-pages{display:flex;gap:.3rem}.pagination-ellipsis{padding:.6rem;color:#757575}.pagination-info{margin-left:1rem;color:#757575;font-size:.9rem}@media(min-width:768px)and (max-width:1023px){.dashboard-container{padding:1.5rem}.dashboard-header h1{font-size:2rem}.companies-grid,.certificates-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.dashboard-container{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-header h1{font-size:1.75rem}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%}.search-bar{flex-direction:column}.search-bar button{width:100%}.stats-grid{grid-template-columns:1fr}.sort-controls{flex-direction:column;align-items:flex-start}.sort-controls button{width:100%}.companies-grid,.certificates-grid{grid-template-columns:1fr}.company-actions{flex-direction:column}.pagination{flex-wrap:wrap}.pagination-info{width:100%;text-align:center;margin-left:0;margin-top:.5rem}}.dashboard-page{min-height:100vh;background:#fafafa}.dashboard-container{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #1e40af14;border:1px solid var(--color-border);margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.dashboard-title{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:0}.dashboard-actions{display:flex;gap:1rem;flex-wrap:wrap}.dashboard-content{display:grid;gap:1.5rem}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.dashboard-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #1e40af14;border:1px solid var(--color-border);transition:all .2s ease}.dashboard-card:hover{box-shadow:0 4px 16px #1e40af1f;transform:translateY(-2px)}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #1e40af14;border:3px solid;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1e40af1f}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #1e40af14;border:2px dashed var(--color-border)}.empty-state-text{font-size:1.125rem;color:var(--color-text-secondary);margin:0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;max-width:500px;margin:0 auto}.error-message{background:#ffebee;color:var(--color-error);padding:1.5rem;border-radius:12px;border-left:4px solid var(--color-error);margin-bottom:1.5rem;width:100%}@media(max-width:768px){.dashboard-container{padding:1rem}.dashboard-header{flex-direction:column;align-items:stretch;padding:1.5rem}.dashboard-title{font-size:1.75rem}.dashboard-actions{flex-direction:column}.dashboard-actions button{width:100%}.cards-grid,.stats-grid{grid-template-columns:1fr}}.dashboard-container,.create-scadenza-container,.edit-scadenza-container,.detail-container{min-height:100vh;background:#fafafa;padding:2rem}.dashboard-card,.scadenza-form-card,.detail-card,.card-modern{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #1e40af14;border:1px solid var(--color-border);transition:all .2s ease}.dashboard-card:hover,.card-modern:hover{box-shadow:0 4px 16px #1e40af1f;border-color:var(--color-primary)}.page-header{background:#fff;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 2px 8px #1e40af14;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--color-border)}.page-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin:0}.btn-primary,button.btn-primary{background:var(--color-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #1e40af33;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover,button.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 4px 8px #1e40af4d}.btn-primary:before,button.btn-primary:before{display:none}.btn-primary svg,button.btn-primary svg{color:#fff;stroke:#fff}.btn-primary:disabled,button.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary,button.btn-secondary{background:#fff;color:var(--color-primary);border:1px solid var(--color-primary);padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover,button.btn-secondary:hover{background:#4b5563;border-color:#4b5563;color:#fff}.btn-danger,button.btn-danger{background:var(--color-error);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #ef444433}.btn-danger:hover,button.btn-danger:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text-primary);font-size:1rem}.form-control,input.form-control,select.form-control,textarea.form-control{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease;background-color:#fff;color:var(--color-text-primary)}.form-control:focus,input.form-control:focus,select.form-control:focus,textarea.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-hover)}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600;text-align:center}.status-success,.status-badge.success{background:#d1fae5;color:#065f46}.status-warning,.status-badge.warning{background:#fef3c7;color:#92400e}.status-error,.status-badge.error{background:#fee2e2;color:#991b1b}.status-info,.status-badge.info{background:var(--color-primary-light);color:var(--color-primary-hover)}.alert{padding:1rem 1.25rem;border-radius:8px;margin:1rem 0;border-left:3px solid;font-weight:500;font-size:1rem}.alert-success{background-color:#d1fae5;color:#065f46;border-left-color:var(--color-success)}.alert-error{background-color:#fee2e2;color:#991b1b;border-left-color:var(--color-error)}.alert-info{background-color:var(--color-hover);color:var(--color-primary-hover);border-left-color:var(--color-primary)}.alert-warning{background-color:#fef3c7;color:#92400e;border-left-color:var(--color-warning)}.navbar{background:#fff;padding:1rem 2rem;border-radius:12px;box-shadow:0 2px 8px #1e40af14;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--color-border)}.navbar-brand{font-size:1.375rem;font-weight:700;color:var(--color-primary);text-decoration:none}.navbar-nav{display:flex;gap:1rem;align-items:center}.grid-responsive{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}@media(max-width:768px){.dashboard-container,.create-scadenza-container,.edit-scadenza-container,.detail-container{padding:1rem}.dashboard-card,.scadenza-form-card,.detail-card,.card-modern{padding:1.5rem;border-radius:16px}.page-header{flex-direction:column;gap:1rem;padding:1rem;border-radius:16px}.page-title{font-size:1.5rem}.navbar{flex-direction:column;gap:1rem;padding:1rem;border-radius:16px}.navbar-nav{flex-direction:column;width:100%}.navbar-nav button,.navbar-nav a{width:100%}.grid-responsive{grid-template-columns:1fr}.btn-primary,.btn-secondary,.btn-danger,button.btn-primary,button.btn-secondary,button.btn-danger{width:100%;padding:.75rem 1.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes slideIn{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}.slide-in{animation:slideIn .4s ease-out}.page-container{width:100%;min-height:100vh;background:#fafafa;padding:2rem max(2rem,(100% - 1400px) / 2)}.page-title-simple{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:0 0 2rem;padding:0}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2rem;color:#6c757d}.error{padding:2rem;background:#f8d7da;color:#721c24;border-radius:8px;margin:2rem;text-align:center}.error-banner{padding:1rem;background:#f8d7da;color:#721c24;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.search-bar{margin-bottom:1.5rem}.search-bar input{width:100%;padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.table-container th{padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6}.table-container button{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;margin:0 .25rem}.form-card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;align-items:stretch}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;border:3px solid;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;justify-content:center;min-height:100px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card.stat-blue,.stat-card.stat-primary{border-color:#1e40af}.stat-card.stat-green,.stat-card.stat-success{border-color:#4caf50}.stat-card.stat-yellow,.stat-card.stat-warning{border-color:#ff9800}.stat-card.stat-red,.stat-card.stat-danger,.stat-card.stat-error{border-color:#f44336}.stat-card.valid{border-color:#4caf50}.stat-card.warning{border-color:#ff9800}.stat-card.danger{border-color:#f44336}.stat-card.primary{border-color:#1e40af}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-card.stat-blue .stat-value,.stat-card.stat-primary .stat-value,.stat-card.primary .stat-value{color:#1e40af}.stat-card.stat-green .stat-value,.stat-card.stat-success .stat-value,.stat-card.valid .stat-value{color:#4caf50}.stat-card.stat-yellow .stat-value,.stat-card.stat-warning .stat-value,.stat-card.warning .stat-value{color:#ff9800}.stat-card.stat-red .stat-value,.stat-card.stat-danger .stat-value,.stat-card.stat-error .stat-value,.stat-card.danger .stat-value{color:#f44336}.stat-label{color:#6c757d;font-size:.95rem;font-weight:600}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.detail-card h3{margin-top:0;margin-bottom:1rem;color:#212529}.detail-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f8f9fa}.detail-row .label{font-weight:500;color:#6c757d}.header-actions{display:flex;gap:1rem}.icon-sm,.icon-small{width:16px;height:16px;flex-shrink:0}.icon-md,.icon-medium{width:20px;height:20px;flex-shrink:0}.icon-lg,.icon-large{width:24px;height:24px;flex-shrink:0}.icon-primary{color:var(--color-primary)}.icon-success{color:var(--color-success)}.icon-warning{color:var(--color-warning)}.icon-danger,.icon-error{color:var(--color-error)}.icon-white{color:#fff}.icon-muted{color:var(--color-text-muted)}.icon-secondary{color:var(--color-secondary)}.icon-info{color:var(--color-info)}button .icon,.btn .icon,.btn-primary .icon,.btn-secondary .icon,.btn-danger .icon{margin-right:.5rem;vertical-align:middle}button .icon:last-child:first-child,.btn .icon:last-child:first-child{margin-right:0}.btn-primary .icon,.btn-primary svg{color:#fff;stroke:#fff}button:hover .icon{opacity:.9}.action-button .icon,.icon-button .icon{margin:0}.icon svg,svg.icon{display:block}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-container{padding:1rem}.form-row,.stats-grid,.detail-grid{grid-template-columns:1fr}.header-actions{flex-direction:column;width:100%}.header-actions button{width:100%}}.legal-page{min-height:100vh;background:var(--color-background);display:flex;flex-direction:column}.legal-content{flex:1;padding:3rem 0;background:var(--color-background-alt)}.legal-container{max-width:800px;margin:0 auto;padding:0 var(--spacing-xl);background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-3xl) var(--spacing-2xl)}.legal-title{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-md);text-align:center;border-bottom:3px solid var(--color-primary);padding-bottom:var(--spacing-lg)}.legal-subtitle{text-align:center;font-size:1.125rem;color:var(--color-text-secondary);margin-top:.5rem}.legal-update-date{text-align:center;color:var(--color-text-secondary);font-size:.95rem;margin-bottom:var(--spacing-3xl);font-style:italic}.legal-section{margin-bottom:var(--spacing-3xl)}.legal-section:last-child{margin-bottom:0}.legal-section h2{font-size:1.75rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-lg);margin-top:0;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.legal-section:first-of-type h2{border-top:none;padding-top:0}.legal-section h3{font-size:1.375rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md);margin-top:var(--spacing-xl)}.legal-section p{font-size:1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.legal-section p:last-child{margin-bottom:0}.legal-section ul{list-style:none;padding:0;margin:var(--spacing-lg) 0}.legal-section ul li{font-size:1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);padding-left:var(--spacing-xl);position:relative}.legal-section ul li:before{content:"•";position:absolute;left:var(--spacing-md);color:var(--color-primary);font-weight:700;font-size:1.25rem}.legal-section ul li strong{color:var(--color-text-primary);font-weight:600}.legal-section ol{padding-left:var(--spacing-2xl);margin:var(--spacing-lg) 0}.legal-section ol li{font-size:1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.legal-section a{color:var(--color-primary);text-decoration:underline;font-weight:500;transition:var(--transition-default)}.legal-section a:hover{color:var(--color-primary-hover)}.legal-section strong{color:var(--color-text-primary);font-weight:600}.back-button{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);padding:.5rem 1rem;border-radius:var(--border-radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition-default);margin-bottom:1rem}.back-button:hover{background:var(--color-primary);color:#fff;transform:translate(-4px)}.contact-form-wrapper{max-width:700px;margin:0 auto;background:#fff;border-radius:20px;padding:var(--spacing-3xl);box-shadow:0 10px 30px #0ea5e91a,0 1px 8px #0ea5e914}.contact-form{margin-bottom:var(--spacing-3xl)}.form-note{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-md);text-align:center}.contact-info{padding-top:var(--spacing-2xl);border-top:2px solid var(--color-border);text-align:center}.contact-info h3{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-lg)}.contact-info p{font-size:1rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}@media(min-width:768px)and (max-width:1023px){.legal-container{padding:var(--spacing-2xl) var(--spacing-xl)}.legal-title{font-size:2rem}.legal-section h2{font-size:1.5rem}}@media(max-width:767px){.legal-content{padding:2rem 0}.legal-container{padding:var(--spacing-xl) var(--spacing-lg);border-radius:0;box-shadow:none}.legal-title{font-size:1.75rem;padding-bottom:var(--spacing-md)}.legal-subtitle{font-size:1rem}.legal-update-date{font-size:.875rem;margin-bottom:var(--spacing-xl)}.legal-section{margin-bottom:var(--spacing-xl)}.legal-section h2{font-size:1.375rem;margin-bottom:var(--spacing-md);padding-top:var(--spacing-md)}.legal-section h3{font-size:1.25rem;margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg)}.legal-section p,.legal-section ul li,.legal-section ol li{font-size:1rem;line-height:1.7}.legal-section ul li{padding-left:var(--spacing-lg)}.legal-section ul li:before{left:var(--spacing-sm)}.contact-form-wrapper{padding:var(--spacing-xl) var(--spacing-lg);border-radius:var(--border-radius-lg)}.back-button{width:100%;text-align:center}.contact-info h3{font-size:1.25rem}.contact-info p{font-size:1rem}}@media(min-width:1024px){.legal-content{padding:4rem 0}.legal-container{padding:var(--spacing-4xl) var(--spacing-3xl)}}@media print{.page-header,.page-footer{display:none}.legal-page{background:#fff}.legal-container{box-shadow:none;max-width:100%}.legal-section{page-break-inside:avoid}.legal-section h2{page-break-after:avoid}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;min-height:44px;border-radius:10px;font-size:.95rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);touch-action:manipulation;border:none;font-family:inherit;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-primary{background:#1e40af;color:#fff;border:none;box-shadow:0 2px 4px #1e40af33}.btn-primary:hover:not(:disabled){background:#1e3a8a;box-shadow:0 4px 8px #1e40af4d;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #1e40af33}.btn-secondary{background:#fff;color:var(--color-text-primary);border:2px solid var(--color-border);box-shadow:0 2px 4px #0000000d}.btn-secondary:hover:not(:disabled){background:#4b5563;border-color:#4b5563;color:#fff;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.btn-secondary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000000d}.btn-white{background:#fff;color:#1e40af;border:none;box-shadow:0 2px 4px #0000001a}.btn-white:hover:not(:disabled){background:#dbeafe;color:#1e3a8a;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.btn-white:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000001a}.btn-success{background:var(--color-success);color:#fff;border:none;box-shadow:0 2px 4px #10b98133}.btn-success:hover:not(:disabled){background:#059669;box-shadow:0 4px 8px #10b9814d;transform:translateY(-2px)}.btn-success:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #10b98133}.btn-danger{background:#fff;color:var(--color-error);border:2px solid var(--color-border);box-shadow:0 2px 4px #0000000d}.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:var(--color-error);box-shadow:0 4px 8px #ef444433;transform:translateY(-2px)}.btn-danger:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000000d}.btn-nav{background:#fff;color:var(--color-text-primary);border:2px solid var(--color-border);box-shadow:0 2px 4px #0000000d}.btn-nav:hover:not(:disabled):not(.active){background:#f5f5f5;border-color:#1e40af;color:#1e40af;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.btn-nav.active{background:#1e40af;color:#fff;border-color:#1e40af;box-shadow:0 4px 12px #1e40af4d}.btn-nav.active:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #1e40af66}.btn-small{padding:.5rem 1rem;min-height:36px;font-size:.875rem}.btn-large{padding:.875rem 1.75rem;min-height:48px;font-size:1rem}.btn-xl{padding:1rem 2rem;min-height:52px;font-size:1.1rem}.btn-icon{display:inline-flex;align-items:center;gap:.5rem}.btn-icon svg{width:18px;height:18px;flex-shrink:0}.btn-icon.btn-small svg{width:16px;height:16px}.btn-icon.btn-large svg{width:20px;height:20px}.btn-block{width:100%;display:flex}.btn-group{display:flex;gap:.75rem;flex-wrap:wrap}.btn-group .btn{flex:1;min-width:fit-content}.page-container{width:100%;padding:2rem max(2rem,(100% - 1400px) / 2);min-height:100vh;background-color:#f5f5f5}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:3px solid #1e40af}.page-title{margin:0;color:var(--color-text-primary);font-size:2.5rem;font-weight:700}.page-actions{display:flex;gap:1rem}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;transition:all .3s ease}.card:hover{box-shadow:0 10px 20px #00000026;transform:translateY(-4px)}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.card-title{margin:0;font-size:1.3rem;color:var(--color-text-primary);font-weight:600}.card-body{display:flex;flex-direction:column;gap:1rem}.card-footer{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.stat-label{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:.5rem;font-weight:600}.stat-value{font-size:2.5rem;font-weight:700}.stat-card.primary{border:3px solid #1e40af}.stat-card.primary .stat-value{color:#1e40af}.stat-card.success{border:3px solid var(--color-success)}.stat-card.success .stat-value{color:var(--color-success)}.stat-card.warning{border:3px solid var(--color-warning)}.stat-card.warning .stat-value{color:var(--color-warning)}.stat-card.error{border:3px solid var(--color-error)}.stat-card.error .stat-value{color:var(--color-error)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:600}.badge.primary{background-color:#dbeafe;color:#1e3a8a}.badge.success{background-color:#e8f5e9;color:#4caf50}.badge.warning{background-color:#fff3e0;color:#ff9800}.badge.error{background-color:#ffebee;color:#f44336}.loading-container{padding:2rem;text-align:center;min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-spinner{width:48px;height:48px;border:4px solid transparent;border-top-color:var(--color-primary);border-right-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-text{color:var(--color-text-secondary);font-size:1.1rem}.empty-state{text-align:center;padding:4rem 3rem;background:#fff;border-radius:16px;box-shadow:0 8px 16px #0000001a;border:3px dashed #1e40af;max-width:600px;margin:4rem auto}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem}.empty-state-title{font-size:1.8rem;color:var(--color-text-primary);margin-bottom:1rem;font-weight:700}.empty-state-description{font-size:1.1rem;color:var(--color-text-secondary);margin-bottom:2rem;line-height:1.6}.error-container{padding:2rem;text-align:center;min-height:100vh;display:flex;align-items:center;justify-content:center}.error-content{max-width:500px}.error-message{background-color:#ffebee;color:#f44336;padding:1.5rem;border-radius:12px;border-left:4px solid #f44336;margin-bottom:1.5rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-4{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text-primary);font-size:.95rem}.form-control{width:100%;padding:.8rem 1rem;border:2px solid var(--color-border);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .3s ease;background-color:#fff;color:var(--color-text-primary)}.form-control:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #dbeafe}.form-control::placeholder{color:var(--color-text-muted)}textarea.form-control{resize:vertical;min-height:120px}.form-error{color:var(--color-error);font-size:.875rem;margin-top:.25rem}.form-help{color:var(--color-text-secondary);font-size:.875rem;margin-top:.25rem}.search-bar{display:flex;gap:.5rem;margin-bottom:2rem}.search-input{flex:1;padding:.8rem 1rem;font-size:1rem;border:2px solid var(--color-border);border-radius:8px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#1e40af}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;padding:1rem}.pagination-button{padding:.6rem 1rem;background-color:#fff;color:var(--color-text-secondary);border:2px solid var(--color-border);border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;min-width:40px;transition:all .3s ease}.pagination-button:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-info{margin-left:1rem;color:var(--color-text-secondary);font-size:.9rem}@media(max-width:767px){.page-container{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-title{font-size:1.75rem}.page-actions{width:100%;flex-direction:column}.page-actions .btn{width:100%}.btn{padding:.7rem 1.2rem;font-size:.9rem}.btn-large{padding:.8rem 1.5rem;font-size:.95rem}.btn-group{flex-direction:column}.btn-group .btn{width:100%}.stats-grid,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.card-footer{flex-direction:column}.card-footer .btn{width:100%}}.btn:focus-visible{outline:3px solid #DBEAFE;outline-offset:2px}.btn-danger:focus-visible{outline-color:#fee2e2}.btn-success:focus-visible{outline-color:#d1fae5}.table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.table-container table{width:100%;border-collapse:collapse}.table-container thead{background:#f8f9fa}.table-container th{padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;white-space:nowrap}.table-container th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table-container th.sortable:hover{background:#e9ecef}.table-container td{padding:1rem;border-bottom:1px solid #dee2e6}.table-container tbody tr:hover{background:#f8f9fa}.table-container tbody tr:last-child td{border-bottom:none}.table-container td.actions{text-align:center;white-space:nowrap}.table-container td.actions>*{display:inline-flex;vertical-align:middle;margin:0 .25rem}.table-container .action-btn{background:none;border:none;cursor:pointer;padding:.25rem;transition:transform .2s ease;display:inline-flex;align-items:center;justify-content:center}.table-container .action-btn:hover{transform:scale(1.2)}.table-container .action-btn:disabled{opacity:.5;cursor:not-allowed}.table-container .no-data{text-align:center;padding:3rem 2rem;color:#6c757d;font-size:1rem}.sort-indicator{font-size:.7em;margin-left:.3rem;display:inline-block;transition:opacity .2s ease}.sort-indicator.inactive{opacity:.3}.sort-indicator.active{opacity:1}@media(max-width:767px){.table-container{overflow-x:auto}.table-container th,.table-container td{padding:.75rem .5rem;font-size:.9rem}.table-container .action-btn{padding:.2rem}}.company-selector{width:100%;margin-bottom:1rem}.company-selector-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem;color:#212529}.required-indicator{color:#dc3545;margin-left:.25rem}.company-selector-dropdown{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.company-selector-dropdown:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.company-selector-dropdown:required:invalid{border-color:#dc3545}.company-selector-dropdown:disabled{background-color:#e9ecef;cursor:not-allowed;opacity:.6}.company-selector-loading{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;color:#6c757d;font-size:.9rem}.company-selector-loading .spinner{animation:spin 1s linear infinite}.company-selector-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;font-size:.9rem}.company-selector-empty{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff3cd;color:#856404;border:1px solid #ffeaa7;border-radius:4px;font-size:.9rem}@media(max-width:768px){.company-selector-dropdown{font-size:.9rem;padding:.65rem}}.deadline-list-view{width:100%}.type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.type-badge.type-training{background:#e3f2fd;color:#1976d2}.type-badge.type-medical{background:#fce4ec;color:#c2185b}.type-badge.type-equipment{background:#fff3e0;color:#f57c00}.type-badge.type-generic{background:#f3e5f5;color:#7b1fa2}.deadline-list-view .badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:6px;font-size:.8rem;font-weight:600;line-height:1}.deadline-list-view .badge-success{background:#d4edda;color:#155724}.deadline-list-view .badge-warning{background:#fff3cd;color:#856404}.deadline-list-view .badge-danger{background:#f8d7da;color:#721c24}.deadline-list-view .pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.deadline-list-view .pagination button{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:.9rem}.deadline-list-view .pagination button:hover:not(:disabled){background:#f8f9fa}.deadline-list-view .pagination button:disabled{opacity:.5;cursor:not-allowed}.deadline-list-view .pagination span{font-size:.9rem;color:#6c757d}.employee-selector{position:relative;width:100%}.search-container{position:relative}.search-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.loading-indicator{position:absolute;right:1rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.85rem}.loading-indicator:before{content:"";display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:var(--color-primary);border-right-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 4px 4px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px #0000001a}.dropdown-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f8f9fa}.dropdown-item:hover{background:#f8f9fa}.dropdown-item.no-results{color:#6c757d;cursor:default}.dropdown-item.no-results:hover{background:#fff}.dropdown-item.create-new{background:#e3f2fd;color:#1976d2;font-weight:500;border-top:2px solid #ddd}.dropdown-item.create-new:hover{background:#bbdefb}.employee-name{font-weight:500;margin-bottom:.25rem}.employee-cf{font-size:.85rem;color:#6c757d}.create-form{padding:1.5rem;background:#f8f9fa;border:1px solid #ddd;border-radius:4px}.create-form h4{margin-top:0;margin-bottom:1rem;color:#212529}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn{padding:.5rem 1.5rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background .2s}.error-message{padding:.75rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:1rem;font-size:.9rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.deadline-type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.type-card{padding:1.5rem;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center;background:#fff}.type-card:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff33}.type-card.selected{border-color:#007bff;background:#e3f2fd;box-shadow:0 2px 8px #007bff4d}.type-icon{font-size:3rem;margin-bottom:.5rem}.type-label{font-weight:600;font-size:1rem;margin-bottom:.5rem;color:#212529}.type-expiry-info{font-size:.85rem;color:#6c757d}@media(max-width:768px){.deadline-type-selector{grid-template-columns:1fr}}.unified-upload-box{width:100%}.drop-zone{border:2px dashed #ddd;border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#f8f9fa}.drop-zone:hover:not(.disabled){border-color:#007bff;background:#e3f2fd}.drop-zone.drag-active{border-color:#007bff;background:#e3f2fd;box-shadow:0 0 10px #007bff4d}.drop-zone.disabled{cursor:not-allowed;opacity:.6;background:#e9ecef}.drop-zone-icon{font-size:4rem;margin-bottom:1rem;color:#6c757d;display:flex;justify-content:center;align-items:center}.drop-zone-text{font-size:1.1rem;font-weight:500;color:#212529;margin-bottom:.5rem}.drop-zone-info{font-size:.9rem;color:#6c757d}.upload-errors{margin-top:1rem}.upload-error{padding:.75rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;font-size:.9rem;margin-bottom:.5rem}.upload-error:last-child{margin-bottom:0}.file-list{margin-top:1.5rem}.file-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.file-list-header h4{margin:0;color:#212529;font-size:1rem;font-weight:600}.remove-all-btn{background:#6c757d;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer;font-size:.9rem;transition:background .2s}.remove-all-btn:hover:not(:disabled){background:#545b62}.remove-all-btn:disabled{cursor:not-allowed;opacity:.6}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border:1px solid #ddd;border-radius:4px;margin-bottom:.5rem;transition:box-shadow .2s}.file-item:hover{box-shadow:0 2px 4px #0000001a}.file-item:last-child{margin-bottom:0}.file-info{flex:1;min-width:0}.file-name{font-weight:500;margin-bottom:.25rem;display:flex;align-items:center;color:#212529;word-break:break-word}.file-size{font-size:.85rem;color:#6c757d}.remove-btn{background:#dc3545;color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;margin-left:1rem}.remove-btn:hover:not(:disabled){background:#c82333}.remove-btn:disabled{cursor:not-allowed;opacity:.6}.deadline-form-evolved{max-width:1200px;margin:0 auto;padding:2rem}.error-banner{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:#721c24;font-size:1.2rem;cursor:pointer}.form-section{background:#fff;border:1px solid #ddd;border-radius:8px;padding:2rem;margin-bottom:2rem}.section-header{margin-bottom:1.5rem}.section-header h3{margin:0 0 .5rem;color:#212529}.section-header p{margin:0;color:#6c757d;font-size:.9rem}.generic-form{max-width:800px}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-large{width:100%;margin-top:1rem;padding:1rem;font-size:1.1rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.upload-mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mode-option{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:left}.mode-option:hover{border-color:#007bff;background:#f8f9fa}.mode-option.active{border-color:#007bff;background:#e7f3ff}.mode-content h4{margin:0 0 .5rem;font-size:1rem;color:#212529}.mode-content p{margin:0;font-size:.85rem;color:#6c757d}@media(max-width:768px){.deadline-form-evolved,.form-section{padding:1rem}.form-row,.upload-mode-selector{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:600px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.employee-edit-modal{max-width:600px}.modal-header{padding:20px 24px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-body{padding:24px;overflow-y:auto;flex:1}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:.95rem}.form-group .required{color:#d32f2f;margin-left:2px}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper .form-control{padding-right:40px}.input-wrapper .validation-icon{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;pointer-events:none}.input-wrapper .validation-icon.success{color:#2e7d32}.input-wrapper .validation-icon.error{color:#d32f2f}.form-control{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:4px;font-size:1rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-control.valid{border-color:#2e7d32}.form-control:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.form-control.error{border-color:#d32f2f}.form-control.error:focus{box-shadow:0 0 0 3px #d32f2f1a}.form-control.low-confidence{background-color:#fff3e0;border-color:#ff9800}.form-control.medium-confidence{background-color:#fff9c4;border-color:#fbc02d}.error-message{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 14px;background-color:#fef2f2;border:1px solid #fecaca;border-left:3px solid #ef4444;border-radius:6px;color:#991b1b;font-size:.875rem;font-weight:500}.error-icon{font-weight:700;color:#ef4444}.success-message{display:none}.success-icon{font-weight:700}.info-message{display:flex;align-items:center;gap:6px;margin-top:6px;color:#1976d2;font-size:.875rem}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:var(--color-primary);border-right-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px}.modal-footer .btn{padding:10px 20px;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;border:none}.modal-footer .btn:active{transform:scale(.98)}.modal-footer .btn-secondary{background-color:#fff;color:#1e40af;border:2px solid #1e40af}.modal-footer .btn-secondary:hover{background-color:#f0f4ff}.modal-footer .btn-primary{background-color:#1e40af;color:#fff}.modal-footer .btn-primary:hover{background-color:#1e3a8a}.modal-footer .btn-primary:disabled{background-color:#bdbdbd;cursor:not-allowed}@media(max-width:768px){.modal-content{width:95%;max-height:95vh}.modal-header{padding:16px 20px}.modal-header h2{font-size:1.25rem}.modal-body{padding:20px}.modal-footer{padding:12px 20px}.modal-footer .btn{padding:8px 16px;font-size:.95rem}}.ocr-review-page{width:100%;padding:2rem max(2rem,(100% - 1400px) / 2)}.review-header{margin-bottom:2rem}.review-summary{color:#6c757d;font-size:1rem;margin-top:.5rem}.needs-review-badge{display:inline-block;margin-left:1rem;padding:.25rem .75rem;background:#fff3cd;color:#856404;border-radius:12px;font-size:.9rem;font-weight:500}.review-actions-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px}.actions-right{display:flex;gap:1rem}.btn-sm{padding:.5rem 1rem;font-size:.9rem}.employee-groups{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.employee-card{background:#fff;border:2px solid #dee2e6;border-radius:8px;overflow:hidden;transition:all .2s}.employee-card.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.employee-card.needs-review{border-color:#ffc107;background:#fffbf0}.employee-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:#f8f9fa;border-bottom:1px solid #dee2e6}.employee-header-left{display:flex;gap:1rem;flex:1}.employee-checkbox{width:20px;height:20px;cursor:pointer;margin-top:.25rem}.employee-info{flex:1}.employee-info h3{margin:0 0 .5rem;font-size:1.25rem;display:flex;align-items:center;gap:.75rem}.existing-badge{display:inline-block;padding:.25rem .75rem;background:#d4edda;color:#155724;border-radius:12px;font-size:.8rem;font-weight:500}.new-badge{display:inline-block;padding:.25rem .75rem;background:#cce5ff;color:#004085;border-radius:12px;font-size:.8rem;font-weight:500}.existing-badge-small{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;background:#d4edda;color:#155724;border-radius:8px;font-size:.7rem;font-weight:500;vertical-align:middle}.new-badge-small{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;background:#cce5ff;color:#004085;border-radius:8px;font-size:.7rem;font-weight:500;vertical-align:middle}.deadline-item.existing-deadline{background:#f0fff4;border-left:3px solid #48bb78}.skipped-badge{display:inline-block;padding:.25rem .75rem;background:#e2e8f0;color:#475569;border-radius:12px;font-size:.8rem;font-weight:500}.skipped-count{color:#475569;font-weight:500}.employee-details{margin:.25rem 0;color:#6c757d;font-size:.9rem}.confidence-info{margin:.5rem 0 0;font-size:.9rem;display:flex;align-items:center;gap:1rem}.confidence{display:inline-block;padding:.25rem .5rem;border-radius:12px;font-size:.85rem;font-weight:600}.confidence.high{background:#d4edda;color:#155724}.confidence.medium{background:#fff3cd;color:#856404}.confidence.low{background:#f8d7da;color:#721c24}.review-flag{color:#856404;font-weight:500}.employee-header-right{display:flex;gap:.5rem}.employee-card-body{padding:1.5rem}.employee-card-body h4{margin:0 0 1rem;font-size:1rem;color:#495057}.deadlines-list{display:flex;flex-direction:column;gap:.75rem}.deadline-item{padding:1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.deadline-item.needs-review{background:#fff3cd;border-color:#ffc107}.deadline-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.deadline-actions{flex-shrink:0}.deadline-title{margin:0;font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.review-icon-wrapper{display:inline-flex;align-items:center;position:relative;cursor:help;margin-left:.5rem;vertical-align:middle}.review-icon-wrapper svg{vertical-align:middle}.review-tooltip{visibility:hidden;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.8rem;font-weight:400;white-space:nowrap;z-index:1000;margin-bottom:8px;box-shadow:0 2px 8px #0003}.review-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.review-icon-wrapper:hover .review-tooltip{visibility:visible}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;background:#e9ecef;border:1px solid #ced4da;border-radius:6px;color:#495057;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#dee2e6;color:#212529}.btn-icon svg{display:block}.btn-icon-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.35rem;background:#fff;border:1px solid #1e40af;border-radius:4px;color:#1e40af;cursor:pointer;transition:all .2s}.btn-icon-secondary:hover{background:#eff6ff;border-color:#1e3a8a;color:#1e3a8a}.btn-icon-secondary svg{display:block}.btn-xs{padding:.25rem .35rem;font-size:.75rem}.deadline-edit-modal{max-width:500px}.deadline-edit-modal .file-info{margin:0;padding:.5rem .75rem;background:#f8f9fa;border-radius:4px;font-size:.9rem;color:#495057;word-break:break-all}.deadline-details{margin:0;color:#6c757d;font-size:.85rem}.review-actions-bottom{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.loading-container,.error-container,.empty-container{text-align:center;padding:3rem}.error-container h2,.empty-container h2{margin-bottom:1rem}.error-message{padding:1rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;text-align:center}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}@media(max-width:768px){.ocr-review-page{padding:1rem}.review-actions-top{flex-direction:column;gap:1rem;align-items:stretch}.actions-right{flex-direction:column}.employee-card-header{flex-direction:column;gap:1rem}.employee-header-right{width:100%;justify-content:flex-end}.review-actions-bottom{flex-direction:column}}.validation-errors-banner{display:flex;gap:12px;align-items:flex-start;background-color:#f8d7da;border:2px solid #f5c6cb;border-radius:8px;padding:1rem 1.5rem;margin-bottom:1.5rem;font-size:14px;line-height:1.5}.validation-errors-banner .error-icon{font-size:24px;flex-shrink:0}.validation-errors-banner strong{color:#721c24;font-weight:600}.validation-errors-banner div{color:#721c24}.employee-card.has-errors{border-color:#dc3545;background:#fff5f5}.error-badge{display:inline-block;padding:.25rem .75rem;background:#f8d7da;color:#721c24;border-radius:12px;font-size:.8rem;font-weight:500}.employee-errors{margin-top:.75rem;padding:.75rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;font-size:.85rem}.employee-errors strong{color:#721c24;display:block;margin-bottom:.5rem}.employee-errors ul{margin:0;padding-left:1.5rem;color:#721c24}.employee-errors li{margin-bottom:.25rem}.review-actions-top{display:flex;gap:1rem;flex-wrap:wrap}.review-actions-top>button:first-child{margin-right:auto}@media(max-width:768px){.review-actions-top{flex-direction:column}.review-actions-top>button:first-child{margin-right:0}}.submission-result{margin:1.5rem 0;padding:1rem 1.5rem;border-radius:8px;border:2px solid;display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.submission-result.success{background:#d4edda;border-color:#28a745}.submission-result.partial-success{background:#fff3cd;border-color:#ffc107}.result-header{display:flex;align-items:center;gap:.5rem;margin:0}.result-header h3{margin:0;font-size:1.1rem;font-weight:600}.success-icon{font-size:1.3rem;color:#28a745;font-weight:700}.warning-icon{font-size:1.3rem;color:#ffc107;font-weight:700}.result-summary{display:flex;gap:1.5rem;margin:0;flex:1}.summary-item{margin:0;font-size:.9rem;white-space:nowrap}.summary-item strong{font-weight:600}.failed-count{color:#dc3545;font-weight:600}.result-errors{width:100%;margin-top:.5rem;padding:.75rem 1rem;background:#fff;border-radius:6px;border:1px solid #dee2e6}.result-errors h4{margin:0 0 .5rem;font-size:.95rem;color:#495057}.result-errors ul{margin:0;padding-left:1.25rem}.result-errors li{margin-bottom:.25rem;color:#721c24;font-size:.85rem}.result-actions{display:flex;gap:.75rem;align-items:center;margin-left:auto}.result-actions p{margin:0;color:#495057;font-style:italic;font-size:.85rem}.result-actions .btn{padding:.5rem 1rem;font-size:.9rem}@media(max-width:768px){.submission-result{flex-direction:column;align-items:flex-start}.result-summary{flex-direction:column;gap:.25rem}.result-actions{width:100%;justify-content:flex-end;margin-left:0;margin-top:.5rem}}.assigned-documents-section,.unassigned-documents-section{margin-bottom:2rem}.section-title{font-size:1.5rem;margin-bottom:1rem;color:#212529;font-weight:600}.section-description{color:#6c757d;margin-bottom:1rem;font-size:.95rem}.unassigned-badge{display:inline-block;margin-left:1rem;padding:.25rem .75rem;background:#f8d7da;color:#721c24;border-radius:12px;font-size:.9rem;font-weight:500}.unassigned-documents-list{display:flex;flex-direction:column;gap:1rem}.unassigned-document-card{background:#fff;border:2px solid #ffc107;border-radius:8px;padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem}.document-info{flex:1}.document-filename{margin:0 0 .75rem;font-size:1.1rem;color:#212529}.document-deadline-data{margin:.75rem 0;padding:.75rem;background:#f8f9fa;border-radius:6px}.document-deadline-data p{margin:.25rem 0;font-size:.9rem;color:#495057}.missing-fields{margin:.75rem 0 0;color:#856404;font-size:.9rem;font-style:italic}.document-actions{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.employee-actions{display:flex;gap:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;font-size:1.5rem;color:#212529}.modal-close{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f8f9fa;color:#212529}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #dee2e6}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057}.form-control{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-control.error{border-color:#dc3545}.error-message{display:block;margin-top:.5rem;color:#dc3545;font-size:.875rem}.checking-message{display:block;margin-top:.5rem;color:#6c757d;font-size:.875rem;font-style:italic}.employee-list{max-height:400px;overflow-y:auto;border:1px solid #dee2e6;border-radius:6px;margin-top:1rem}.employee-list-item{padding:1rem;border-bottom:1px solid #dee2e6;cursor:pointer;transition:background .2s;display:flex;justify-content:space-between;align-items:center}.employee-list-item:last-child{border-bottom:none}.employee-list-item:hover{background:#f8f9fa}.employee-list-item.selected{background:#e7f3ff;border-color:#007bff}.employee-list-info{display:flex;flex-direction:column;gap:.25rem}.employee-list-info strong{color:#212529;font-size:1rem}.employee-cf{color:#6c757d;font-size:.875rem}.selected-icon{color:#007bff;font-size:1.5rem;font-weight:700}.no-results{padding:2rem;text-align:center;color:#6c757d;font-style:italic}@media(max-width:768px){.unassigned-document-card{flex-direction:column}.document-actions{width:100%}.modal-content{max-width:100%;margin:0;border-radius:0;max-height:100vh}}.ocr-progress-page{width:100%;padding:2rem}.progress-container{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;padding:3rem;box-shadow:0 2px 8px #0000001a}.progress-header{text-align:center;margin-bottom:2rem}.progress-header h2{font-size:1.75rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.progress-subtitle{font-size:1rem;color:#6b7280;margin:0}.progress-bar-container{margin:2rem 0}.progress-bar{width:100%;height:24px;background-color:#e5e7eb;border-radius:12px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:12px;transition:width .5s ease-in-out;position:relative;overflow:hidden}.progress-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percentage{text-align:center;font-size:1.5rem;font-weight:600;color:#1f2937;margin-top:.75rem}.progress-stats{display:flex;flex-direction:column;gap:1rem;margin:2rem 0;padding:1.5rem;background-color:#f9fafb;border-radius:8px}.stat-item{display:flex;align-items:center;gap:1rem}.stat-item svg{color:#6b7280;flex-shrink:0}.stat-item.stat-error svg{color:#dc2626}.stat-content{flex:1}.stat-label{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.stat-value{font-size:1.25rem;font-weight:600;color:#1f2937}.stat-item.stat-error .stat-value{color:#dc2626}.status-message{text-align:center;margin:2rem 0;padding:1rem;background-color:#eff6ff;border-radius:8px;border:1px solid #bfdbfe}.status-message p{margin:0;font-size:1rem;color:#1e40af;font-weight:500}.status-message.success{background-color:#f0fdf4;border-color:#bbf7d0}.status-message p.success{color:#15803d}.info-box{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background-color:#fef3c7;border:1px solid #fde68a;border-radius:8px;margin-top:2rem}.info-box svg{color:#d97706;flex-shrink:0;margin-top:.125rem}.info-box p{margin:0;font-size:.875rem;color:#92400e;line-height:1.5}.error-state{text-align:center;padding:3rem 2rem}.error-icon{color:#dc2626;margin-bottom:1rem}.error-state h2{font-size:1.75rem;font-weight:600;color:#1f2937;margin:0 0 1rem}.error-message{font-size:1rem;color:#6b7280;margin:0 0 2rem;max-width:500px;margin-left:auto;margin-right:auto}.error-state .btn{margin-top:1rem}.error-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem}@media(max-width:768px){.ocr-progress-page{padding:1rem}.progress-container{padding:2rem 1.5rem}.progress-header h2{font-size:1.5rem}.progress-percentage{font-size:1.25rem}.stat-value{font-size:1.125rem}}#root{width:100%;min-height:100vh}.container{max-width:1280px;margin:0 auto;padding:2rem}.card{background-color:#fff;border-radius:12px;padding:2em;box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:box-shadow .3s ease,transform .3s ease}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:3px solid var(--color-primary)}.page-title{color:var(--color-text-primary);font-size:2.5rem;font-weight:700;margin:0}.button-group{display:flex;gap:1rem;align-items:center}.grid{display:grid;gap:1.5rem;margin-top:2rem}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.error-message{color:var(--color-error);background-color:#ffebee;padding:1rem;border-radius:8px;border-left:4px solid var(--color-error);margin:1rem 0}.success-message{color:var(--color-success);background-color:#e8f5e9;padding:1rem;border-radius:8px;border-left:4px solid var(--color-success);margin:1rem 0}.info-message{color:var(--color-primary);background-color:var(--color-hover);padding:1rem;border-radius:8px;border-left:4px solid var(--color-primary);margin:1rem 0}.badge{display:inline-block;padding:.35em .65em;font-size:.85em;font-weight:600;line-height:1;text-align:center;white-space:nowrap;border-radius:6px}.badge-primary{background-color:var(--color-primary);color:#fff}.badge-success{background-color:var(--color-success);color:#fff}.badge-warning{background-color:var(--color-warning);color:#fff}.badge-error{background-color:var(--color-error);color:#fff}
