*{margin:0;padding:0;box-sizing:border-box;font-family:Montserrat,sans-serif}html,body #root{height:100%;width:100%}body{position:relative;background:linear-gradient(135deg,#8072ca,#2f256b);color:#f3f4f6;display:flex;justify-content:center;align-items:center;overflow:hidden}body:before{content:"";position:absolute;inset:0;background:url(/assets/AquaGo-zvFu-D3F.png) no-repeat center;background-size:60%;opacity:.08;z-index:0;pointer-events:none}#root{position:relative;z-index:1}.app-container{width:100%;max-width:100%;padding:2rem;text-align:center}h1,h2,h3{color:#e5e7eb;margin-bottom:1rem}p{color:#d1d5db;margin-bottom:1.5rem}.btn-primary{background-color:#22d3ee;color:#1f2937;font-weight:600;padding:.75rem 1.5rem;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background-color:#0ea5e9;transform:scale(1.05)}.btn-secondary{background-color:transparent;border:2px solid #22D3EE;color:#22d3ee;font-weight:500;padding:.6rem 1.4rem;border-radius:12px;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background-color:#22d3ee1a}.input-field{width:100%;padding:.8rem;margin-bottom:1rem;border:1px solid #4B5563;border-radius:10px;background-color:#1f2937;color:#f3f4f6}.input-field::placeholder{color:#9ca3af}.loading-container{height:100vh;width:100%;display:flex;justify-content:center;align-items:center}.logo-wrapper{text-align:center;animation:fadeIn 1s ease-in-out}.logo{width:120px;height:auto;margin-bottom:1rem;animation:pulse 2s infinite ease-in-out}.loading-title{font-size:2rem;font-weight:700;color:#f8f8f8;letter-spacing:2px;animation:slideUp 1.5s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.welcome-container{display:flex;justify-content:center;align-items:center;min-height:100vh;text-align:center;padding:1.5rem;color:#f9fafb}.welcome-content{max-width:500px;width:100%}.welcome-logo{width:150px;height:150px;margin:0 auto 1rem;display:block}.welcome-title{font-size:2.2rem;font-weight:700;margin-bottom:.5rem;color:#fff}.welcome-tagline{font-size:1.2rem;font-weight:500;margin-bottom:1rem;color:#d1d5db}.welcome-description{font-size:1rem;line-height:1.5;margin-bottom:2rem;color:#e5e7eb}.welcome-bottom,.welcome-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-primary{padding:.75rem;border-radius:9999px;border:none;background-color:#22d3ee;color:#fafbff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s ease;text-decoration:none}.btn-primary:hover{background-color:#0ea5e9}.btn-secondary{padding:.75rem;border-radius:9999px;border:2px solid #22D3EE;background:transparent;color:#22d3ee;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none}.btn-secondary:hover{background-color:#22d3ee;color:#fafbff}.auth-container{display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:1.5rem;color:#f8f9fa;text-align:center}.auth-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem}.auth-subtitle{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#f6f8ff;text-align:center;line-height:1.4;letter-spacing:.5px}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form input{padding:.9rem;border-radius:8px;border:1px solid white;outline:none;font-size:1rem;background:transparent;color:#fff}.auth-form ::placeholder{color:#fff;font-size:.8rem}.btn-primary{margin-top:1rem}.auth-footer{margin-top:1.5rem;font-size:.95rem;font-weight:300}.auth-link{color:#22d3ee;font-weight:600;cursor:pointer}.btn-google{margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 15px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-weight:500;color:#333}.btn-google:hover{background:#f7f7f7}.google-icon{width:20px;height:20px}.divider{display:flex;align-items:center;text-align:center;color:#ccc;margin:20px 0}.divider:before,.divider:after{content:"""";flex:1;border-bottom:1px solid #ccc}.divider:before{margin-right:.5em}.divider:after{margin-left:.5em}.login-container p{margin-top:1rem;font-size:.9rem;color:red}.dashboard{display:flex;flex-direction:column;height:100vh;color:#fff;padding-bottom:70px;overflow-y:auto}.dashboard-content{width:90%;max-width:1200px;margin:0 auto;padding:1rem}.machine-card{background:#ffffff14;border-radius:16px;padding:16px;margin:12px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 4px 10px #37044d4d;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.machine-card:hover{transform:translateY(-3px);box-shadow:0 6px 14px #e0d3ff66}.machine-header{display:flex;justify-content:space-between;align-items:center}.machine-name{font-size:1.1rem;font-weight:600}.machine-id{font-size:.85rem;color:#d1d5db}.machine-params{display:flex;justify-content:space-between;font-size:.9rem;color:#e5e7eb}.delete-btn{background:#ef4444;border:none;color:#fff;padding:6px 12px;font-size:.8rem;border-radius:8px;cursor:pointer;transition:background .2s ease}.delete-btn:hover{background:#dc2626}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#6e5a9e;display:flex;justify-content:space-around;align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.2);z-index:100}.bottom-nav button{background:none;border:none;color:#f3f0ff;font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:color .2s ease}.bottom-nav button.active,.bottom-nav button:hover{color:#ede9fe}.bottom-nav svg{width:22px;height:22px}.logout-btn{width:70%;font-weight:500;margin:auto;display:block}.machine-card.has-warnings{border-left:5px solid #FACC15}.machine-warnings{margin-top:10px;display:flex;flex-direction:column;gap:8px}.warning-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:.85rem;font-weight:500}.warning-water{background-color:#3b82f633;color:#bfdbfe}.warning-coin{background-color:#f59e0b33;color:#fde68a}.warning-temp{background-color:#ef444433;color:#fecaca}
