html,body{margin:0;padding:0;min-height:100vh;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;width:100%}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#1a1a1a}.app{min-height:100vh;display:flex;justify-content:center;background-color:#1a1a1a}.app-layout{display:flex;min-height:100vh;max-width:1400px;width:100%}.side-banner{width:300px;flex-shrink:0;background-size:cover;background-position:center;background-repeat:no-repeat}.app-content{flex:1;display:flex;flex-direction:column;background-color:#f5f5f5;min-width:0}.header{background-color:#d32f2f;color:#fff;padding:1rem 2rem}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header h1{margin:0;font-size:1.5rem;font-weight:600;letter-spacing:.5px}.user-header{display:flex;align-items:center;gap:1rem}.user-name{font-size:.9rem;opacity:.9}.logout-btn{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;font-size:.85rem;border-radius:4px;cursor:pointer;transition:background-color .2s}.logout-btn:hover{background-color:#ffffff4d}.main{max-width:800px;margin:0 auto;padding:2rem;width:100%}.section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.section h2{margin:0 0 1rem;font-size:1.1rem;color:#333;border-bottom:2px solid #d32f2f;padding-bottom:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#d32f2f;box-shadow:0 0 0 2px #d32f2f1a}.form-group small{display:block;margin-top:.25rem;color:#666;font-size:.85rem}.input-row{display:flex;gap:.75rem}.input-row input{flex:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}button{background-color:#d32f2f;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}button:hover{background-color:#b71c1c}button:disabled{background-color:#ccc;cursor:not-allowed}.primary-btn{width:100%;padding:1rem;font-size:1.1rem;font-weight:600}.success{color:#2e7d32;margin-top:.5rem;font-weight:500}.user-info{margin-top:.75rem;padding:.75rem;background-color:#f5f5f5;border-radius:4px}.user-info p{margin:.25rem 0}.account-balance{color:#1565c0;font-size:1.1rem}.account-balance strong{color:#2e7d32}.cards-summary{background-color:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;padding:1.5rem;text-align:center;margin-bottom:1rem}.cards-summary p{margin:.5rem 0;font-size:1.1rem}.cards-summary .summary-total{font-size:1.25rem;color:#2e7d32;font-weight:700;margin-top:.75rem}.actions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.email-section{display:flex;gap:.75rem}.email-section input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.status{padding:1rem;border-radius:4px;margin-top:1rem;font-weight:500}.status.info{background-color:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.status.error{background-color:#ffebee;color:#c62828;border:1px solid #ef9a9a}.product-info{background-color:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:1rem;margin-bottom:1rem;text-align:center}.product-name{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.5rem}.product-price{font-size:1.25rem;color:#d32f2f;font-weight:700}.total-cost{background-color:#e8f5e9;border:1px solid #a5d6a7;border-radius:4px;padding:1rem;text-align:center;font-size:1.1rem;font-weight:600;color:#2e7d32;margin-top:1rem}.product-select-row{display:flex;gap:.75rem}.product-select-row select{flex:1}.remove-btn{background-color:#757575;padding:.75rem 1rem;font-size:.9rem}.remove-btn:hover{background-color:#616161}.add-product-group{background-color:#f9f9f9;border:1px dashed #ddd;border-radius:4px;padding:1rem;margin-top:.5rem}.add-product-group label{font-size:.9rem;color:#666}@media(max-width:1200px){.side-banner{width:150px}}@media(max-width:900px){.side-banner{display:none}.app-layout{justify-content:center}}@media(max-width:600px){.main{padding:1rem}.form-row{grid-template-columns:1fr}.input-row,.email-section{flex-direction:column}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a}.login-box{background:#fff;padding:3rem;border-radius:12px;text-align:center;box-shadow:0 4px 20px #0000004d;max-width:400px;width:90%}.login-logo h1{color:#d32f2f;font-size:2.5rem;margin:0 0 .5rem;letter-spacing:2px;text-transform:uppercase}.login-logo p{color:#666;margin:0 0 2rem;font-size:1rem}.login-btn{background-color:#d32f2f;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:6px;cursor:pointer;width:100%;transition:background-color .2s}.login-btn:hover{background-color:#b71c1c}.login-note{margin-top:1.5rem;color:#999;font-size:.85rem}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a;color:#fff;font-size:1.2rem}
