/* Aapla Zinble — site styles */

:root {
    --az-primary: #0d6553;
    --az-primary-dark: #084b3d;
    --az-accent: #25d366;
    --az-bg: #f4f6f8;
    --az-sidebar-bg: #0f2a25;
    --az-sidebar-fg: #cfe9df;
    --az-sidebar-fg-active: #ffffff;
    --az-card-shadow: 0 2px 6px rgba(0,0,0,.06);
}

body.az-app {
    background: var(--az-bg);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.az-topbar {
    background: var(--az-primary);
    height: 56px;
}

.az-shell {
    display: flex;
    min-height: calc(100vh - 56px);
}

.az-sidebar {
    width: 232px;
    background: var(--az-sidebar-bg);
    color: var(--az-sidebar-fg);
    padding: 16px 0;
    flex-shrink: 0;
}

.az-sidebar .nav-link {
    color: var(--az-sidebar-fg);
    padding: 10px 18px;
    border-left: 3px solid transparent;
    font-size: 14px;
}

.az-sidebar .nav-link i {
    margin-right: 8px;
    width: 18px;
    text-align: center;
}

.az-sidebar .nav-link:hover,
.az-sidebar .nav-link.active {
    background: rgba(255,255,255,0.06);
    color: var(--az-sidebar-fg-active);
    border-left-color: var(--az-accent);
}

.az-sidebar-section {
    margin-top: 16px;
    padding: 4px 18px;
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.06em;
    color: rgba(207,233,223,.6);
}

.az-main {
    flex: 1;
    min-width: 0;
}

.az-page-title {
    margin: 0 0 16px;
    font-size: 22px;
    font-weight: 600;
}

.az-card {
    background: #fff;
    border-radius: 8px;
    padding: 16px 18px;
    box-shadow: var(--az-card-shadow);
}

.az-metric {
    background: #fff;
    border-radius: 10px;
    padding: 16px;
    box-shadow: var(--az-card-shadow);
    border-left: 4px solid var(--az-primary);
}

.az-metric .label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #6c757d;
    margin-bottom: 4px;
}

.az-metric .value {
    font-size: 28px;
    font-weight: 600;
    color: #1a2a2a;
}

.az-metric.accent { border-left-color: var(--az-accent); }
.az-metric.warn   { border-left-color: #f0ad4e; }
.az-metric.danger { border-left-color: #dc3545; }
.az-metric.info   { border-left-color: #0dcaf0; }

/* Auth pages */
.az-auth-body {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--az-primary) 0%, var(--az-primary-dark) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.az-auth-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px 32px;
    width: 100%;
    max-width: 380px;
    box-shadow: 0 12px 30px rgba(0,0,0,.18);
}

.az-auth-brand {
    font-size: 24px;
    font-weight: 700;
    color: var(--az-primary);
}

.az-auth-brand i { margin-right: 6px; }

.btn-primary {
    background: var(--az-primary);
    border-color: var(--az-primary);
}
.btn-primary:hover,
.btn-primary:focus {
    background: var(--az-primary-dark);
    border-color: var(--az-primary-dark);
}

/* Contact category groups (form) */
.az-cat-group {
    border: 1px solid #dee2e6;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}

.az-cat-group-header {
    background: var(--az-primary);
    color: #fff;
    padding: 6px 12px;
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.az-cat-group-body {
    padding: 8px 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px 12px;
}

@media (max-width: 576px) {
    .az-cat-group-body { grid-template-columns: 1fr; }
}

.az-cat-group-body .form-check { margin-bottom: 0; }

/* Blocked-contact row highlight */
.az-row-blocked {
    background-color: rgba(220, 53, 69, 0.07) !important;
}
.az-row-blocked a { color: #842029; }

/* Tree view for category admin */
.az-cat-tree { list-style: none; padding-left: 0; margin-bottom: 0; }
.az-cat-tree > li {
    padding: 8px 12px;
    border-bottom: 1px solid #f1f3f5;
}
.az-cat-tree > li:last-child { border-bottom: 0; }
.az-cat-tree ul { list-style: none; padding-left: 24px; margin-top: 6px; }
.az-cat-tree ul li {
    padding: 4px 0;
    color: #495057;
    font-size: 14px;
}
.az-cat-tree .az-cat-name { font-weight: 600; }
.az-cat-tree .az-cat-actions a {
    font-size: 12px;
    margin-left: 8px;
}
