@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary-50: #f0f9ff;--primary-100: #e0f2fe;--primary-200: #bae6fd;--primary-300: #7dd3fc;--primary-400: #38bdf8;--primary-500: #0ea5e9;--primary-600: #0284c7;--primary-700: #0369a1;--primary-800: #075985;--primary-900: #0c4a6e;--secondary-50: #f8fafc;--secondary-100: #f1f5f9;--secondary-200: #e2e8f0;--secondary-300: #cbd5e1;--secondary-400: #94a3b8;--secondary-500: #64748b;--secondary-600: #475569;--secondary-700: #334155;--secondary-800: #1e293b;--secondary-900: #0f172a;--success-50: #f0fdf4;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--warning-50: #fffbeb;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-500: #ef4444;--error-600: #dc2626;--gradient-primary: linear-gradient(135deg, #0ea5e9 0%, #0369a1 100%);--gradient-secondary: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);--gradient-dark: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--border-radius-sm: .375rem;--border-radius-md: .5rem;--border-radius-lg: .75rem;--border-radius-xl: 1rem;--border-radius-2xl: 1.5rem}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--secondary-800);background:var(--gradient-secondary);min-height:100vh;font-feature-settings:"cv02","cv03","cv04","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed}.app-container{min-height:100vh;background:var(--gradient-secondary);position:relative;overflow-x:hidden}.app-container:before{content:"";position:absolute;top:0;left:0;right:0;height:60vh;background:var(--gradient-primary);z-index:-1;clip-path:polygon(0 0,100% 0,100% 70%,0 100%)}.container{max-width:1200px;margin:0 auto;padding:2rem 1rem;position:relative;z-index:1}.card{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:2.5rem;box-shadow:0 25px 50px #00000026,0 0 0 1px #ffffff4d;border:1px solid rgba(255,255,255,.3);transition:all .3s ease;margin-bottom:2rem;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}.card-header{text-align:center;margin-bottom:2.5rem}.card-icon{width:100px;height:100px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;box-shadow:var(--shadow-lg);position:relative;border:2px solid rgba(255,255,255,.4)}.card-icon:after{content:"";position:absolute;inset:-2px;background:var(--gradient-primary);border-radius:50%;z-index:-1;opacity:.2;animation:pulse 2s infinite}.card-title{font-size:2.25rem;font-weight:800;color:var(--secondary-900);margin-bottom:.75rem;letter-spacing:-.025em}.card-subtitle{font-size:1.25rem;color:var(--secondary-600);font-weight:500;line-height:1.7}.btn{display:inline-flex;align-items:center;justify-content:center;padding:1.25rem 1.5rem;border:none;border-radius:16px;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none;position:relative;overflow:visible;min-height:4rem;letter-spacing:.025em;box-shadow:0 8px 32px #0000001a;text-shadow:0 1px 2px rgba(0,0,0,.1);gap:.75rem;white-space:nowrap;word-wrap:normal}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-lg)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background:var(--secondary-300);color:var(--secondary-500);cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}.btn-secondary{background:#fff;color:var(--primary-600);border:2px solid var(--primary-200);box-shadow:var(--shadow-md)}.btn-secondary:hover{background:var(--primary-50);border-color:var(--primary-300);transform:translateY(-1px)}.form-actions{display:flex;gap:1.5rem;justify-content:center;align-items:stretch;margin-top:2.5rem;flex-wrap:wrap}.form-actions .btn{flex:1;min-width:240px;max-width:320px;height:4rem;display:flex;align-items:center;justify-content:center;text-align:center}.btn svg{width:24px;height:24px;flex-shrink:0;stroke-width:2.5;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.btn-primary svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.btn-secondary svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--secondary-700);margin-bottom:.5rem;letter-spacing:.025em;text-transform:uppercase}.form-input{width:100%;padding:1rem 1.25rem;border:2px solid var(--secondary-200);border-radius:var(--border-radius-lg);font-size:1.125rem;font-weight:500;color:var(--secondary-800);background:#fff;transition:all .3s ease;box-shadow:var(--shadow-sm)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a,var(--shadow-md);transform:translateY(-1px)}.form-input::placeholder{color:var(--secondary-400);font-weight:400}.form-input.input-code{text-align:center;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:1.5rem;letter-spacing:.5rem;font-weight:700}.alert{padding:1.25rem 1.5rem;border-radius:16px;font-weight:600;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;transition:all .3s ease;position:relative;overflow:hidden}.alert:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:currentColor;opacity:.8}.alert-error{background:linear-gradient(135deg,#ff6b6b26,#ee5a5226);color:#dc2626;border-color:#ff6b6b4d;box-shadow:0 8px 32px #ff6b6b33}.alert-success{background:linear-gradient(135deg,#10b98126,#05966926);color:#059669;border-color:#10b9814d;box-shadow:0 8px 32px #10b98133}.alert-warning{background:linear-gradient(135deg,#f59e0b26,#d9770626);color:#d97706;border-color:#f59e0b4d;box-shadow:0 8px 32px #f59e0b33}.alert-icon{width:24px;height:24px;flex-shrink:0;opacity:.9;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.alert:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000026}.alert-error:hover{box-shadow:0 12px 40px #ff6b6b4d}.alert-success:hover{box-shadow:0 12px 40px #10b9814d}.alert-warning:hover{box-shadow:0 12px 40px #f59e0b4d}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:var(--border-radius-xl);font-weight:700;font-size:1.125rem;letter-spacing:.1em;text-transform:uppercase;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.1)}.status-approved{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 8px 32px #10b9814d}.status-partial{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 8px 32px #f59e0b4d}.status-rejected,.status-unknown{background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:#1e293b;border:2px solid #cbd5e1;box-shadow:0 8px 32px #47556926;animation:shimmer 2s ease-in-out infinite alternate;position:relative;overflow:hidden}.status-rejected:before,.status-unknown:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(148,163,184,.3),transparent);animation:shimmerError 3s infinite}@keyframes shimmerError{0%{left:-100%}50%{left:100%}to{left:100%}}.progress-container{margin-bottom:2rem}.progress-bar{width:100%;height:8px;background:var(--secondary-200);border-radius:var(--border-radius-sm);overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.progress-fill{height:100%;background:var(--gradient-primary);transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite;display:inline-block;margin-right:.75rem}h1{font-size:3.5em;line-height:1.1;font-weight:900;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.1)}h2{font-size:2.25rem;font-weight:700;color:var(--secondary-800);margin-bottom:1.25rem;letter-spacing:-.01em}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-4{gap:1rem}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.fade-in{animation:fadeIn .8s cubic-bezier(.4,0,.2,1)}.slide-up{animation:slideUp .6s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.2}50%{opacity:.4}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.security-badge{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background:#fffffff2;border:1px solid var(--secondary-200);border-radius:var(--border-radius-lg);font-size:.875rem;color:var(--secondary-600);font-weight:500;min-width:180px;height:48px;text-align:center;box-shadow:0 2px 4px #0000000d;transition:all .3s ease;white-space:nowrap}.security-badge-clickable{cursor:pointer;border:2px solid var(--primary-300)}.security-badge-clickable:hover{background:var(--primary-50);border-color:var(--primary-400);transform:translateY(-1px);box-shadow:var(--shadow-md)}.security-badge-clickable:active{transform:translateY(0)}.security-code-info{margin-top:1rem;padding:1.5rem;background:linear-gradient(135deg,var(--primary-50) 0%,white 100%);border:2px solid var(--primary-200);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-lg);animation:slideDown .3s ease-out}.security-code-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--primary-700)}.security-code-header h3{font-size:1.125rem;font-weight:700;margin:0}.security-code-content{display:flex;flex-direction:column;gap:1rem}.code-display{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#fff;border:2px solid var(--primary-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm)}.code-label{font-weight:600;color:var(--secondary-600)}.code-value{font-family:Courier New,monospace;font-size:1.25rem;font-weight:700;color:var(--primary-700);background:var(--primary-100);padding:.5rem 1rem;border-radius:var(--border-radius-md);letter-spacing:.1em}.expiration-info{display:flex;align-items:center;gap:.5rem;color:var(--secondary-600);font-size:.875rem}.validity-note{display:flex;align-items:center;justify-content:center;padding:.75rem;background:var(--warning-50);border:1px solid var(--warning-500);border-radius:var(--border-radius-md);color:var(--warning-600);font-weight:600;font-size:.875rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.security-badge:hover{background:#fff;border-color:var(--primary-300);box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.security-badge svg{flex-shrink:0;width:18px;height:18px}.footer-info{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--secondary-200);color:var(--secondary-500);font-size:.875rem}@media (max-width: 768px){.container{padding:1rem}.card{padding:2rem 1.5rem}.card-title{font-size:1.75rem}.card-subtitle{font-size:1rem}.btn{padding:.875rem 1.5rem;font-size:.9375rem}.security-badge{min-width:160px;height:44px;padding:.625rem 1rem;font-size:.8125rem;gap:.375rem}.security-badge svg{width:16px;height:16px}.security-code-info{padding:1rem;margin-top:.75rem}.security-code-header h3{font-size:1rem}.code-display{flex-direction:column;gap:.5rem;text-align:center;padding:.75rem}.code-value{font-size:1.125rem;padding:.375rem .75rem}.form-actions .btn{min-width:160px;max-width:none}}.result-card{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border-radius:20px;padding:2.5rem;margin:2.5rem 0;box-shadow:0 15px 35px #0000001a;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);text-align:center;position:relative;overflow:hidden;transition:all .3s ease;width:100%;box-sizing:border-box}.result-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}.result-emoji{font-size:3.5rem;margin-bottom:2rem;display:block;animation:bounce 2s infinite;line-height:1}.result-message{font-size:1.375rem;color:var(--secondary-700);margin-bottom:2.5rem;line-height:1.6;font-weight:600;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.progress-section{margin:2rem 0;padding:1.5rem;background:#ffffffb3;border-radius:12px;border:1px solid rgba(0,0,0,.05)}.progress-header{text-align:center;margin-bottom:2rem;font-weight:600;color:var(--secondary-700);font-size:1.125rem}.percentage-circle-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:2.5rem 0;transition:all .3s ease}.percentage-circle{position:relative;width:140px;height:140px;transition:all .3s ease}.percentage-svg{width:100%;height:100%;transform:rotate(-90deg);filter:drop-shadow(0 6px 12px rgba(0,0,0,.15))}.percentage-progress{transition:stroke-dasharray 1.5s cubic-bezier(.4,0,.2,1);stroke-linecap:round}.percentage-progress.progress-success{stroke:#10b981;filter:drop-shadow(0 0 4px rgba(16,185,129,.3))}.percentage-progress.progress-warning{stroke:#f59e0b;filter:drop-shadow(0 0 4px rgba(245,158,11,.3))}.percentage-progress.progress-danger{stroke:#ef4444;filter:drop-shadow(0 0 4px rgba(239,68,68,.3))}.percentage-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#1e293b;font-weight:800;transition:all .3s ease;text-shadow:0 1px 2px rgba(255,255,255,.8)}.progress-value{font-size:1.75rem;margin-bottom:.25rem;display:block;font-weight:900}.percentage-label{font-size:.875rem;opacity:.95;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.progress-bar-fallback{display:none}.progress-bar{width:100%;height:12px;background:var(--secondary-200);border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a;position:relative}.progress-fill{height:100%;border-radius:6px;transition:width 1.2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-success{background:linear-gradient(90deg,#10b981,#059669)}.progress-warning{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-danger{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0) scale(1)}40%{transform:translateY(-15px) scale(1.05)}60%{transform:translateY(-8px) scale(1.02)}}@keyframes glow{0%,to{box-shadow:0 0 20px #ffffff4d}50%{box-shadow:0 0 30px #ffffff80}}@media (max-width: 1024px){.result-card{padding:1.75rem;margin:1.25rem 0;border-radius:14px}.result-emoji{font-size:2.75rem;margin-bottom:1.25rem}.result-message{font-size:1.0625rem;margin-bottom:1.75rem;line-height:1.65}.status-badge{padding:.6875rem 1.375rem;font-size:.9375rem}.progress-section{padding:1.25rem;margin:1.75rem 0}.progress-header{margin-bottom:1.75rem;font-size:1.0625rem}.percentage-circle{width:110px;height:110px}.percentage-circle-container{margin:1.75rem 0}.alert{padding:1.125rem 1.375rem;margin-bottom:1.75rem;border-radius:14px}.alert-icon{width:22px;height:22px}.btn{padding:1.125rem 1.25rem;font-size:1.0625rem;min-height:3.75rem}.btn svg{width:22px;height:22px}.form-actions{gap:1.25rem;margin-top:2.25rem}.form-actions .btn{min-width:220px;max-width:300px;height:3.75rem}}@media (max-width: 768px){.result-card{padding:1.5rem;margin:1rem 0;border-radius:12px}.result-emoji{font-size:2.5rem;margin-bottom:1rem}.result-message{font-size:1rem;margin-bottom:1.5rem;line-height:1.6;padding:0 .5rem}.status-badge{padding:.625rem 1.25rem;font-size:.875rem;gap:.375rem}.progress-section{padding:1rem;margin:1.5rem 0;border-radius:10px}.progress-header{margin-bottom:1.5rem;font-size:1rem}.alert{padding:1rem 1.25rem;margin-bottom:1.5rem;border-radius:12px;gap:.875rem}.alert-icon{width:20px;height:20px}.btn{padding:1rem;font-size:.9375rem;min-height:3.5rem;border-radius:14px}.btn svg{width:20px;height:20px}.form-actions{gap:1rem;margin-top:2rem;flex-direction:column}.form-actions .btn{min-width:100%;max-width:100%;height:3.5rem;flex:none}.percentage-circle{width:90px;height:90px}.percentage-circle-container{margin:1.5rem 0}.progress-value{font-size:1.125rem}.percentage-label{font-size:.6875rem}.progress-bar-fallback{display:block;margin-top:1rem}.progress-value{font-size:1.25rem}.progress-bar{height:10px;border-radius:5px}}@media (max-width: 480px){.security-badge{min-width:140px;height:40px;padding:.5rem .75rem;font-size:.75rem;gap:.25rem}.security-badge svg{width:14px;height:14px}.flex.items-center.justify-center.gap-6{flex-direction:column;gap:.75rem}.result-card{padding:1rem;margin:.5rem 0;border-radius:10px}.result-emoji{font-size:2rem;margin-bottom:.75rem}.result-message{font-size:.9375rem;margin-bottom:1.25rem;line-height:1.55;padding:0 .25rem}.status-badge{padding:.5rem 1rem;font-size:.8125rem;gap:.25rem;border-radius:8px}.progress-section{padding:.75rem;margin:1rem 0;border-radius:8px}.progress-header{margin-bottom:1rem;font-size:.9375rem}.percentage-circle{width:80px;height:80px}.percentage-circle-container{margin:1.25rem 0}.progress-value{font-size:1rem}.percentage-label{font-size:.625rem}.progress-bar-fallback{display:block;margin-top:.75rem}.progress-bar{height:8px;border-radius:4px}}@media (max-width: 360px){.result-card{padding:.875rem;margin:.375rem 0;border-radius:8px}.result-emoji{font-size:1.75rem;margin-bottom:.625rem}.result-message{font-size:.875rem;margin-bottom:1rem;line-height:1.5;padding:0}.status-badge{padding:.4375rem .875rem;font-size:.75rem;gap:.1875rem;border-radius:6px}.progress-section{padding:.625rem;margin:.875rem 0;border-radius:6px}.progress-header{margin-bottom:.875rem;font-size:.875rem}.progress-bar{height:6px;border-radius:3px}.percentage-circle{width:70px;height:70px}.percentage-circle-container{margin:1rem 0}.progress-value{font-size:.9375rem}.percentage-label{font-size:.5625rem}.progress-bar-fallback{margin-top:.5rem}}
