.footer{text-align:center;padding:1.5rem;margin-top:auto;color:#9a9a9a}.footer-text{font-size:.875rem;margin-bottom:.5rem}.footer-credit{font-size:.75rem;color:#b0b0b0}.landing-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:linear-gradient(135deg,#f5e6f0,#f0e8f5,#f5f0e8)}.landing-content{text-align:center;max-width:500px;width:100%;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.landing-logo{max-width:100%;width:280px;height:auto;margin-bottom:2rem;display:block;margin-left:auto;margin-right:auto}.landing-subtitle{font-size:1.125rem;color:#7a7a7a;margin-bottom:2.5rem;line-height:1.6;font-weight:400}.cta-button{background:linear-gradient(135deg,#d4a5c7,#c9a8d8);color:#fff;padding:1rem 2.5rem;font-size:1.125rem;font-weight:500;border-radius:50px;box-shadow:0 4px 15px #b88ac74d;transition:transform .2s,box-shadow .2s;margin-bottom:1rem;width:100%;max-width:280px}.cta-button:active{transform:scale(.98);box-shadow:0 2px 8px #b88ac74d}.helper-text{font-size:.875rem;color:#9a9a9a;margin-top:.5rem}@media (min-width: 768px){.landing-logo{width:360px}.landing-subtitle{font-size:1.25rem}.cta-button{padding:1.125rem 3rem;font-size:1.25rem;max-width:320px}}.upload-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;padding-bottom:0;background:linear-gradient(135deg,#f5e6f0,#f0e8f5,#f5f0e8);-webkit-overflow-scrolling:touch}.upload-content{width:100%;max-width:600px;display:flex;flex-direction:column;flex:1;justify-content:center}.upload-title{font-size:1.75rem;font-weight:300;color:#8b6fa8;text-align:center;margin-bottom:2rem;letter-spacing:1px}.upload-dropzone{background:#fff;border:2px dashed #d4a5c7;border-radius:20px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;margin-bottom:2rem;min-height:250px;display:flex;align-items:center;justify-content:center}.upload-dropzone:active{border-color:#c9a8d8;background:#fafafa}.dropzone-content{width:100%}.dropzone-icon{font-size:3rem;margin-bottom:1rem}.dropzone-text{font-size:1.125rem;color:#7a7a7a;margin-bottom:.5rem;font-weight:500}.dropzone-subtext{font-size:.875rem;color:#9a9a9a;margin-bottom:.75rem}.file-size-warning{font-size:.75rem;color:#c9a8d8;margin-top:.5rem}.file-list{background:#fff;border-radius:20px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 10px #0000000d;max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch}.file-list-title{font-size:1rem;font-weight:500;color:#8b6fa8;margin-bottom:1rem}.file-item{padding:1rem;border-bottom:1px solid #f0f0f0;position:relative;display:flex;flex-direction:column;gap:.5rem}.file-item:last-child{border-bottom:none}.file-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.file-name{flex:1;color:#5a5a5a;font-size:.875rem;word-break:break-word;text-align:left}.file-size{color:#9a9a9a;font-size:.75rem;white-space:nowrap}.progress-bar-container{width:100%;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden;margin-top:.25rem}.progress-bar{height:100%;background:linear-gradient(90deg,#d4a5c7,#c9a8d8);border-radius:3px;transition:width .3s ease}.remove-file-button{position:absolute;top:.5rem;right:.5rem;background:#f5f5f5;color:#9a9a9a;width:24px;height:24px;border-radius:50%;font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-file-button:active{background:#e0e0e0;color:#7a7a7a}.upload-button{background:linear-gradient(135deg,#d4a5c7,#c9a8d8);color:#fff;padding:1rem 2rem;font-size:1.125rem;font-weight:500;border-radius:50px;box-shadow:0 4px 15px #b88ac74d;transition:transform .2s,box-shadow .2s,opacity .2s;width:100%;margin-bottom:1rem}.upload-button:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 8px #b88ac74d}.upload-button:disabled{opacity:.7;cursor:not-allowed}.back-button{background:transparent;color:#8b6fa8;padding:.75rem 1.5rem;font-size:1rem;border-radius:50px;width:100%;transition:background .2s}.back-button:active{background:#8b6fa81a}@media (min-width: 768px){.upload-title{font-size:2.25rem}.upload-dropzone{padding:4rem 3rem;min-height:300px}.dropzone-icon{font-size:4rem}.dropzone-text{font-size:1.25rem}}.success-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:linear-gradient(135deg,#f5e6f0,#f0e8f5,#f5f0e8);position:relative;overflow:hidden}.confetti{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.confetti-piece{position:absolute;width:8px;height:8px;top:-10px;animation:confetti-fall 3s ease-in forwards;border-radius:2px}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.success-content{text-align:center;max-width:500px;width:100%;position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.checkmark-container{display:flex;justify-content:center;margin-bottom:2rem}.checkmark{width:100px;height:100px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #b88ac74d;animation:checkmark-scale .5s ease-out}@keyframes checkmark-scale{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.checkmark-svg{width:60px;height:60px;transform:scale(0);animation:checkmark-draw .5s ease-out .3s forwards}@keyframes checkmark-draw{0%{transform:scale(0) rotate(45deg)}50%{transform:scale(1.1) rotate(45deg)}to{transform:scale(1) rotate(0)}}.checkmark-circle{stroke:#d4a5c7;stroke-width:2;stroke-dasharray:166;stroke-dashoffset:166;animation:circle-draw .6s ease-out .3s forwards}@keyframes circle-draw{to{stroke-dashoffset:0}}.checkmark-check{stroke:#d4a5c7;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:check-draw .3s ease-out .9s forwards}@keyframes check-draw{to{stroke-dashoffset:0}}.success-title{font-size:1.75rem;font-weight:300;color:#8b6fa8;margin-bottom:1rem;line-height:1.4;letter-spacing:.5px}.success-subtitle{font-size:1.125rem;color:#7a7a7a;margin-bottom:2.5rem;line-height:1.6}.success-buttons{display:flex;flex-direction:column;gap:1rem}.success-primary-button{background:linear-gradient(135deg,#d4a5c7,#c9a8d8);color:#fff;padding:1rem 2rem;font-size:1.125rem;font-weight:500;border-radius:50px;box-shadow:0 4px 15px #b88ac74d;transition:transform .2s,box-shadow .2s}.success-primary-button:active{transform:scale(.98);box-shadow:0 2px 8px #b88ac74d}.success-secondary-button{background:transparent;color:#8b6fa8;padding:.75rem 1.5rem;font-size:1rem;border-radius:50px;transition:background .2s}.success-secondary-button:active{background:#8b6fa81a}@media (min-width: 768px){.checkmark{width:120px;height:120px}.checkmark-svg{width:72px;height:72px}.success-title{font-size:2.25rem}.success-subtitle{font-size:1.25rem}.success-buttons{flex-direction:row;justify-content:center}.success-primary-button,.success-secondary-button{flex:1;max-width:200px}}.admin-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:linear-gradient(135deg,#f5e6f0,#f0e8f5,#f5f0e8)}.admin-content{max-width:600px;width:100%;flex:1}.admin-title{font-size:2rem;color:#4a4a4a;margin-bottom:.5rem;text-align:center;font-weight:600}.admin-subtitle{font-size:1rem;color:#7a7a7a;margin-bottom:2rem;text-align:center}.admin-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000001a}.admin-section-title{font-size:1.25rem;color:#4a4a4a;margin-bottom:1rem;font-weight:600}.admin-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.admin-status.connected{background:#e8f5e9;color:#2e7d32}.admin-status.disconnected{background:#ffebee;color:#c62828}.status-icon{font-weight:700;font-size:1.1rem}.admin-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .2s;margin-bottom:.75rem}.admin-button.primary{background:linear-gradient(135deg,#d4a5c7,#c9a8d8);color:#fff;box-shadow:0 2px 8px #b88ac74d}.admin-button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #b88ac766}.admin-button.primary:active:not(:disabled){transform:translateY(0)}.admin-button.secondary{background:#f5f5f5;color:#4a4a4a;border:1px solid #e0e0e0}.admin-button.secondary:hover:not(:disabled){background:#eee}.admin-button.back{background:transparent;color:#7a7a7a;border:1px solid #e0e0e0;margin-top:1rem}.admin-button.back:hover:not(:disabled){background:#f5f5f5}.admin-button:disabled{opacity:.6;cursor:not-allowed}.admin-input-group{margin-bottom:1rem}.admin-label{display:block;font-size:.9rem;color:#4a4a4a;margin-bottom:.5rem;font-weight:500}.admin-input{width:100%;padding:.75rem;font-size:1rem;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;transition:border-color .2s}.admin-input:focus{outline:none;border-color:#d4a5c7}.admin-input:disabled{background:#f5f5f5;cursor:not-allowed}.admin-help-text{font-size:.85rem;color:#7a7a7a;margin-top:.5rem;line-height:1.5}.admin-help-text strong{color:#4a4a4a;font-weight:600}.admin-message{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.admin-message.success{background:#e8f5e9;color:#2e7d32}.admin-message.error{background:#ffebee;color:#c62828}.admin-message-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;opacity:.7;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.admin-message-close:hover{opacity:1}.admin-loading{text-align:center;padding:2rem;color:#7a7a7a;font-size:1rem}@media (min-width: 768px){.admin-title{font-size:2.5rem}.admin-subtitle{font-size:1.125rem}.admin-section{padding:2rem}}.app-container{min-height:100vh;display:flex;flex-direction:column}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f5e6f0,#f0e8f5,#f5f0e8);min-height:100vh;color:#5a5a5a;overflow-x:hidden}html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none}input[type=file]{display:none}
