/* PTT Live - Styles composants principaux */ .app { width: 100%; height: 100%; display: flex; flex-direction: column; background-color: var(--color-bg); } /* === Login === */ .login-container { flex: 1; display: flex; align-items: center; justify-content: center; padding: var(--spacing-lg); } .login-card { width: 100%; max-width: 400px; padding: var(--spacing-xl); background: var(--color-surface); border-radius: 16px; border: 1px solid var(--color-border); } .app-title { font-size: 2.5rem; font-weight: 700; text-align: center; margin-bottom: var(--spacing-xs); background: linear-gradient(135deg, var(--color-primary), var(--color-success)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .app-subtitle { text-align: center; color: var(--color-text-secondary); margin-bottom: var(--spacing-xl); font-size: 0.9rem; } .error-message { padding: var(--spacing-md); background: rgba(239, 68, 68, 0.1); border: 1px solid var(--color-danger); border-radius: 8px; color: var(--color-danger); margin-bottom: var(--spacing-lg); font-size: 0.9rem; } .form-group { margin-bottom: var(--spacing-lg); } .form-group label { display: block; margin-bottom: var(--spacing-sm); color: var(--color-text-secondary); font-size: 0.9rem; font-weight: 500; } .form-group input, .form-group select { width: 100%; padding: var(--spacing-md); background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 8px; color: var(--color-text); font-size: 1rem; transition: border-color 0.2s; } .form-group input:focus, .form-group select:focus { outline: none; border-color: var(--color-primary); } .form-group input:disabled, .form-group select:disabled { opacity: 0.5; cursor: not-allowed; } .btn-primary { width: 100%; padding: var(--spacing-md); background: var(--color-primary); color: white; border-radius: 8px; font-weight: 600; font-size: 1rem; } .btn-primary:hover:not(:disabled) { background: var(--color-primary-hover); } /* === Header === */ .app-header { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-md) var(--spacing-lg); background: var(--color-surface); border-bottom: 1px solid var(--color-border); } .header-info h2 { font-size: 1.2rem; font-weight: 600; margin-bottom: var(--spacing-xs); } .text-secondary { color: var(--color-text-secondary); font-size: 0.85rem; } .btn-disconnect { padding: var(--spacing-sm) var(--spacing-md); background: var(--color-surface-hover); color: var(--color-text-secondary); border-radius: 6px; font-size: 0.9rem; } .btn-disconnect:hover { background: var(--color-border); } /* === Main === */ .app-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; } /* === Responsive === */ @media (max-width: 640px) { .login-card { padding: var(--spacing-lg); } .app-title { font-size: 2rem; } } /* Mode paysage mobile */ @media (max-height: 500px) and (orientation: landscape) { .login-card { max-width: 600px; padding: var(--spacing-md); } .app-title { font-size: 1.5rem; } .form-group { margin-bottom: var(--spacing-md); } }