@import url('tokens.css');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body.layout-auth {
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--color-text);
    background: var(--color-bg);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-container {
    width: 100%;
    max-width: 380px;
    padding: var(--space-4);
}

.auth-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    box-shadow: var(--shadow-lg);
}

.auth-header {
    text-align: center;
    margin-bottom: var(--space-8);
}

.auth-logo {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}

.logo-dot {
    width: 10px; height: 10px;
    border-radius: var(--radius-full);
    background: var(--color-accent);
}

.logo-text {
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: -.4px;
}

.auth-subtitle {
    font-size: var(--text-sm);
    color: var(--color-muted);
}

.alert {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    margin-bottom: var(--space-5);
}

.alert-danger {
    background: rgba(239,68,68,.08);
    color: #DC2626;
    border: 1px solid rgba(239,68,68,.2);
}

.alert-info {
    background: rgba(37,99,235,.07);
    color: #1D4ED8;
    border: 1px solid rgba(37,99,235,.2);
}

.auth-form { display: flex; flex-direction: column; gap: var(--space-5); }

.form-group { display: flex; flex-direction: column; gap: var(--space-2); }

.form-label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
}

.form-input {
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    color: var(--color-text);
    background: var(--color-surface);
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
}

.form-input:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}

.form-row-inline { display: flex; align-items: center; }

.checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: var(--color-muted);
    cursor: pointer;
}

.btn-primary {
    padding: var(--space-3) var(--space-5);
    background: var(--color-accent);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-weight: 600;
    cursor: pointer;
    transition: background .15s;
}

.btn-primary:hover { background: #1D4ED8; }
.btn-full { width: 100%; }
