*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:Poppins,Roboto,Helvetica,Arial,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.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}.w-full{width:100%}.h-full{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.hidden{display:none}.block{display:block}@media (max-width:768px){.hidden-mobile{display:none!important}.block-mobile{display:block!important}}@media (min-width:769px){.hidden-desktop{display:none!important}.block-desktop{display:block!important}}.App{display:flex;flex-direction:column;min-height:100vh}.App-header{background:linear-gradient(135deg,#2e7d32,#4caf50);color:#fff;padding:2rem;text-align:center}.App-main{flex:1 1;padding:2rem}.App-footer{background-color:#2e7d32;color:#fff;padding:2rem;text-align:center}.loading-spinner{align-items:center;display:flex;height:200px;justify-content:center}.error-message{background-color:#ffebee;border-left:4px solid #d32f2f;color:#d32f2f}.error-message,.success-message{border-radius:8px;margin:1rem 0;padding:1rem}.success-message{background-color:#e8f5e8;border-left:4px solid #2e7d32;color:#2e7d32}.btn-primary{background:linear-gradient(45deg,#2e7d32,#4caf50);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary:hover{background:linear-gradient(45deg,#1b5e20,#2e7d32);box-shadow:0 4px 12px #2e7d324d;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(45deg,#d32f2f,#f44336);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary:hover{background:linear-gradient(45deg,#c62828,#d32f2f);box-shadow:0 4px 12px #d32f2f4d;transform:translateY(-2px)}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:1rem 0;padding:1.5rem;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.card-header{border-bottom:1px solid #e0e0e0;margin-bottom:1rem;padding-bottom:1rem}.card-title{color:#212121;font-size:1.25rem;font-weight:600;margin:0}.card-subtitle{color:#757575;font-size:.875rem;margin-top:.25rem}.card-body{color:#424242}.card-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem}.form-group{margin-bottom:1.5rem}.form-label{color:#212121;display:block;font-weight:500;margin-bottom:.5rem}.form-control{border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-control:focus{border-color:#2e7d32;box-shadow:0 0 0 2px #2e7d321a;outline:none}.form-control.error{border-color:#d32f2f}.form-error{color:#d32f2f;font-size:.875rem;margin-top:.25rem}@media (max-width:768px){.App-main,.card{padding:1rem}.btn-primary,.btn-secondary{margin-bottom:.5rem;width:100%}}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}.pulse{animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}