/**
 * Ganz Security Portal — components
 *
 * Buttons, inputs, cards, badges, modals, tabs — wszystko w stylu Genstar.
 */

/* ─── Card ───────────────────────────────────────────────────────────── */

.ganz-card {
    background: var(--ganz-color-surface);
    border-radius: var(--ganz-radius-card);
    box-shadow: var(--ganz-shadow-card);
    padding: var(--ganz-sp-32);
    width: 100%;
}
.ganz-card--login {
    max-width: 440px;
    padding: var(--ganz-sp-40) var(--ganz-sp-32);
}
.ganz-card__header { margin-bottom: var(--ganz-sp-24); }
.ganz-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px; height: 48px;
    border-radius: var(--ganz-radius-md);
    background: var(--ganz-color-slate-100);
    margin-bottom: var(--ganz-sp-16);
    color: var(--ganz-color-slate-700);
}
.ganz-card__title {
    font-size: var(--ganz-fs-24);
    font-weight: var(--ganz-fw-bold);
    margin: 0 0 var(--ganz-sp-4);
    color: var(--ganz-color-slate-900);
}
.ganz-card__title em {
    font-style: normal;
    font-weight: var(--ganz-fw-normal);
}
.ganz-card__subtitle {
    font-size: var(--ganz-fs-14);
    color: var(--ganz-color-text-muted);
    margin: 0;
}

/* ─── Inputs ─────────────────────────────────────────────────────────── */

.ganz-field {
    display: flex;
    flex-direction: column;
    gap: var(--ganz-sp-6);
    margin-bottom: var(--ganz-sp-16);
}
.ganz-field__label {
    font-size: var(--ganz-fs-14);
    font-weight: var(--ganz-fw-medium);
    color: var(--ganz-color-slate-700);
}

.ganz-input,
.ganz-select,
.ganz-textarea {
    width: 100%;
    padding: var(--ganz-sp-12) var(--ganz-sp-16);
    font: inherit;
    color: var(--ganz-color-text);
    background: var(--ganz-color-input-bg);
    border: 1px solid var(--ganz-color-input-border);
    border-radius: var(--ganz-radius-input);
    transition: border-color var(--ganz-transition-fast), box-shadow var(--ganz-transition-fast);
}
.ganz-input:focus,
.ganz-select:focus,
.ganz-textarea:focus {
    outline: none;
    border-color: var(--ganz-color-input-focus);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.18);
}
.ganz-input::placeholder { color: var(--ganz-color-slate-400); }

.ganz-input-group {
    position: relative;
}
.ganz-input-group .ganz-input {
    padding-left: 44px;
}
.ganz-input-group__icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--ganz-color-slate-400);
    pointer-events: none;
    width: 20px; height: 20px;
}

/* ─── Buttons ────────────────────────────────────────────────────────── */

.ganz-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ganz-sp-8);
    padding: var(--ganz-sp-12) var(--ganz-sp-20);
    font-family: inherit;
    font-size: var(--ganz-fs-14);
    font-weight: var(--ganz-fw-semibold);
    line-height: 1;
    color: var(--ganz-color-text);
    background: var(--ganz-color-slate-100);
    border: 1px solid transparent;
    border-radius: var(--ganz-radius-input);
    cursor: pointer;
    text-decoration: none;
    transition: background var(--ganz-transition-fast), color var(--ganz-transition-fast), box-shadow var(--ganz-transition-fast);
}
.ganz-btn:hover { background: var(--ganz-color-slate-200); }
.ganz-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.ganz-btn--primary {
    background: var(--ganz-color-primary);
    color: var(--ganz-color-white);
}
.ganz-btn--primary:hover { background: var(--ganz-color-primary-hover); }

.ganz-btn--accent {
    background: var(--ganz-color-accent);
    color: var(--ganz-color-white);
}
.ganz-btn--accent:hover { background: var(--ganz-color-teal-700); }

.ganz-btn--ghost {
    background: transparent;
    color: var(--ganz-color-text-muted);
}
.ganz-btn--ghost:hover { background: var(--ganz-color-slate-100); color: var(--ganz-color-text); }

.ganz-btn--block {
    width: 100%;
    padding-top: var(--ganz-sp-16);
    padding-bottom: var(--ganz-sp-16);
}

.ganz-btn--lg {
    font-size: var(--ganz-fs-16);
    padding: var(--ganz-sp-16) var(--ganz-sp-24);
}

/* ─── Alerts / status messages ───────────────────────────────────────── */

.ganz-alert {
    padding: var(--ganz-sp-12) var(--ganz-sp-16);
    border-radius: var(--ganz-radius-md);
    font-size: var(--ganz-fs-14);
    margin-bottom: var(--ganz-sp-16);
}
.ganz-alert--info    { background: #ECFEFF; color: #155E75; border: 1px solid #A5F3FC; }
.ganz-alert--success { background: #ECFDF5; color: #065F46; border: 1px solid #A7F3D0; }
.ganz-alert--warning { background: #FFFBEB; color: #92400E; border: 1px solid #FCD34D; }
.ganz-alert--danger  { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }

/* ─── Badges ─────────────────────────────────────────────────────────── */

.ganz-badge {
    display: inline-flex;
    align-items: center;
    padding: var(--ganz-sp-4) var(--ganz-sp-12);
    border-radius: var(--ganz-radius-full);
    font-size: var(--ganz-fs-12);
    font-weight: var(--ganz-fw-medium);
    line-height: 1.4;
    background: var(--ganz-color-slate-100);
    color: var(--ganz-color-slate-700);
}

/* ─── Topbar / sidebar (app shell) ───────────────────────────────────── */

.ganz-shell {
    min-height: 100vh;
    background: var(--ganz-color-bg);
    display: grid;
    grid-template-columns: var(--ganz-sidebar-width) 1fr;
    grid-template-rows:    var(--ganz-topbar-height) 1fr;
    grid-template-areas:
        "sidebar topbar"
        "sidebar main";
}
.ganz-shell__sidebar {
    grid-area: sidebar;
    background: var(--ganz-color-navy-900);
    color: var(--ganz-color-white);
    padding: var(--ganz-sp-24) var(--ganz-sp-16);
}
.ganz-shell__topbar {
    grid-area: topbar;
    background: var(--ganz-color-surface);
    border-bottom: 1px solid var(--ganz-color-border);
    padding: 0 var(--ganz-sp-24);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.ganz-shell__main {
    grid-area: main;
    padding: var(--ganz-sp-32);
    overflow: auto;
}
@media (max-width: 768px) {
    .ganz-shell {
        grid-template-columns: 1fr;
        grid-template-rows: var(--ganz-topbar-height) 1fr;
        grid-template-areas: "topbar" "main";
    }
    .ganz-shell__sidebar { display: none; }
}

/* ─── Footer ─────────────────────────────────────────────────────────── */

.ganz-footer {
    padding: var(--ganz-sp-24);
    text-align: center;
    color: var(--ganz-color-slate-400);
    font-size: var(--ganz-fs-12);
}
