* { 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, #667eea 0%, #764ba2 100%); min-height: 100vh; color: #333; } /* Home Component Styles */ .home-container { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; } .content { background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); border-radius: 24px; padding: 40px 30px; text-align: center; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); max-width: 500px; width: 100%; } .title { font-size: 2.5rem; font-weight: 700; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: 12px; line-height: 1.2; } .subtitle { font-size: 1.1rem; color: #666; margin-bottom: 40px; line-height: 1.5; } .button-container { display: flex; flex-direction: column; gap: 16px; } .action-button { padding: 16px 32px; border: none; border-radius: 12px; font-size: 1.1rem; font-weight: 600; cursor: pointer; transition: all 0.3s ease; text-decoration: none; display: inline-block; position: relative; overflow: hidden; } .action-button.primary { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white; box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3); } .action-button.primary:hover { transform: translateY(-2px); box-shadow: 0 12px 35px rgba(102, 126, 234, 0.4); } .action-button.secondary { background: white; color: #667eea; border: 2px solid #667eea; } .action-button.secondary:hover { background: #667eea; color: white; transform: translateY(-2px); box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3); } /* Create Station Component Styles */ .create-station { min-height: 100vh; padding: 20px; display: flex; flex-direction: column; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); } .create-station-header { text-align: center; margin-bottom: 40px; padding-top: 40px; } .create-station-header h1 { font-size: 2.2rem; font-weight: 700; color: white; margin-bottom: 20px; text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); } .create-station-content { flex: 1; max-width: 600px; margin: 0 auto; width: 100%; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); border-radius: 24px; padding: 40px 30px; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); } .join-method-section h2 { font-size: 1.4rem; font-weight: 600; color: #333; margin-bottom: 30px; line-height: 1.4; } .radio-option { margin-bottom: 24px; } .radio-option label { display: flex; align-items: center; font-size: 1.1rem; font-weight: 500; cursor: pointer; padding: 16px 20px; border: 2px solid #e9ecef; border-radius: 12px; transition: all 0.3s ease; background: white; } .radio-option label:hover { border-color: #667eea; background: #f8f9ff; } .radio-option input[type="radio"]:checked + label, .radio-option label:has(input[type="radio"]:checked) { border-color: #667eea; background: linear-gradient(135deg, rgba(102, 126, 234, 0.1) 0%, rgba(118, 75, 162, 0.1) 100%); color: #667eea; } .radio-option input[type="radio"] { margin-right: 12px; transform: scale(1.3); accent-color: #667eea; } .password-input-section { margin-top: 30px; animation: slideIn 0.3s ease; } @keyframes slideIn { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } } .password-input-section label { display: block; font-size: 1rem; font-weight: 600; color: #333; margin-bottom: 12px; } .password-input-section input { width: 100%; padding: 16px 20px; border: 2px solid #e9ecef; border-radius: 12px; font-size: 1rem; transition: all 0.3s ease; background: white; } .password-input-section input:focus { outline: none; border-color: #667eea; box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1); } .create-station-final-btn { width: 100%; background: linear-gradient(135deg, #28a745 0%, #20c997 100%); color: white; border: none; padding: 18px 32px; font-size: 1.1rem; font-weight: 600; border-radius: 12px; cursor: pointer; margin-top: 40px; transition: all 0.3s ease; box-shadow: 0 8px 25px rgba(40, 167, 69, 0.3); } .create-station-final-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 12px 35px rgba(40, 167, 69, 0.4); } .create-station-final-btn:disabled { background: #ccc; cursor: not-allowed; transform: none; box-shadow: none; } /* Join Station Component Styles */ .join-station { min-height: 100vh; padding: 20px; display: flex; flex-direction: column; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); } .join-station-header { text-align: center; margin-bottom: 40px; padding-top: 40px; } .join-station-header h1 { font-size: 2.2rem; font-weight: 700; color: white; margin-bottom: 20px; text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); } .join-station-content { flex: 1; max-width: 600px; margin: 0 auto; width: 100%; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); border-radius: 24px; padding: 40px 30px; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); } .verify-method-section h2 { font-size: 1.4rem; font-weight: 600; color: #333; margin-bottom: 30px; line-height: 1.4; } .join-station-final-btn { width: 100%; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white; border: none; padding: 18px 32px; font-size: 1.1rem; font-weight: 600; border-radius: 12px; cursor: pointer; margin-top: 40px; transition: all 0.3s ease; box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3); } .join-station-final-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 12px 35px rgba(102, 126, 234, 0.4); } .join-station-final-btn:disabled { background: #ccc; cursor: not-allowed; transform: none; box-shadow: none; } /* Mobile Responsive Design */ @media (max-width: 768px) { .content { padding: 30px 20px; margin: 10px; border-radius: 20px; } .title { font-size: 2rem; } .subtitle { font-size: 1rem; margin-bottom: 30px; } .create-station-header { padding-top: 20px; margin-bottom: 30px; } .create-station-header h1 { font-size: 1.8rem; } .create-station-content { padding: 30px 20px; border-radius: 20px; margin: 10px; } .join-method-section h2 { font-size: 1.2rem; } .radio-option label { padding: 14px 16px; font-size: 1rem; } .password-input-section input { padding: 14px 16px; } .create-station-final-btn { padding: 16px 24px; font-size: 1rem; } .join-station-header { padding-top: 20px; margin-bottom: 30px; } .join-station-header h1 { font-size: 1.8rem; } .join-station-content { padding: 30px 20px; border-radius: 20px; margin: 10px; } .verify-method-section h2 { font-size: 1.2rem; } .join-station-final-btn { padding: 16px 24px; font-size: 1rem; } } @media (max-width: 480px) { .home-container { padding: 15px; } .content { padding: 25px 15px; } .title { font-size: 1.8rem; } .create-station { padding: 15px; } .create-station-content { padding: 25px 15px; } .join-station { padding: 15px; } .join-station-content { padding: 25px 15px; } } /* Larger screens */ @media (min-width: 1024px) { .title { font-size: 3rem; } .subtitle { font-size: 1.2rem; } .create-station-header h1 { font-size: 2.5rem; } .button-container { flex-direction: row; justify-content: center; gap: 20px; } .action-button { min-width: 200px; } .join-station-header h1 { font-size: 2.5rem; } }