/**
 * SENAR Dashboard Styles — Redesign V17
 * Identidade: Sindicato Rural de Pindamonhangaba
 * Tipografia: Barlow Condensed (títulos) + Nunito (corpo) — tudo em PX
 */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,700;0,800;1,700;1,800&family=Nunito:wght@400;600;700;800;900&display=swap');

:root {
    --srp-900:    #0d3a1c;
    --srp-800:    #1a5c2e;
    --srp-600:    #009640;
    --srp-400:    #4caf50;
    --srp-200:    #c8e6c9;
    --srp-100:    #e8f5e8;
    --srp-50:     #f4f7f4;

    --yellow:     #FCB61A;
    --yellow-lt:  #fff8e0;
    --yellow-brd: #fde68a;

    --gender-m:   #2563eb;
    --gender-f:   #ec4899;
    --gender-o:   #8b5cf6;

    --txt-900:    #1a2a1a;
    --txt-600:    #3a5a3a;
    --txt-400:    #5a7a5a;
    --txt-300:    #7a9a7a;

    --border:     #d0dbd0;
    --white:      #ffffff;

    --radius-sm:  8px;
    --radius-md:  12px;
    --radius-lg:  16px;
    --radius-xl:  20px;

    --shadow-xs:  0 1px 3px rgba(0,0,0,0.06);
    --shadow-sm:  0 2px 8px rgba(0,0,0,0.07);
    --shadow-md:  0 4px 16px rgba(0,0,0,0.09);
    --shadow-lg:  0 8px 32px rgba(0,0,0,0.12);

    /* legados mantidos para compatibilidade */
    --primary:    #009640;
    --primary-hover: #007030;
    --bg-page:    var(--srp-50);
    --bg-card:    var(--white);
    --border-old: var(--border);
    --text-main:  var(--txt-900);
    --text-muted: var(--txt-400);
    --radius:     var(--radius-md);
    --shadow-sm-old: var(--shadow-xs);
    --shadow-md-old: var(--shadow-sm);
}

/* ── RESET ── */
.senar-dashboard-wrapper,
.senar-dashboard-wrapper * { box-sizing: border-box; }
.senar-dashboard-wrapper {
    font-family: 'Nunito', 'Segoe UI', sans-serif;
    background: var(--srp-50);
    padding: 24px;
    max-width: 1400px;
    margin: 0 auto;
    min-height: 80vh;
    color: var(--txt-900);
}

/* ══ STATUS Q11 ══════════════════════════════════════════════ */
.text-status-green {
    color: #166534;
    font-weight: 800;
    background: #dcfce7;
    padding: 2px 9px;
    border-radius: 5px;
    border: 1px solid #86efac;
    font-size: 13px;
}
.text-status-yellow {
    color: #854d0e;
    font-weight: 800;
    background: #fef9c3;
    padding: 2px 9px;
    border-radius: 5px;
    border: 1px solid #fde047;
    font-size: 13px;
}
.text-status-red {
    color: #991b1b;
    font-weight: 800;
    background: #fee2e2;
    padding: 2px 9px;
    border-radius: 5px;
    border: 1px solid #fca5a5;
    font-size: 13px;
}

/* ══ LOGIN ════════════════════════════════════════════════════ */
.senar-dashboard-wrapper.login-mode {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 70vh;
    background: var(--srp-800);
    position: relative;
    overflow: hidden;
}
.senar-dashboard-wrapper.login-mode::before {
    content: '';
    position: absolute;
    top: -120px; right: -120px;
    width: 360px; height: 360px;
    background: rgba(252,182,26,0.07);
    border-radius: 50%;
    pointer-events: none;
}
.senar-dashboard-wrapper.login-mode::after {
    content: '';
    position: absolute;
    bottom: -80px; left: -80px;
    width: 240px; height: 240px;
    background: rgba(255,255,255,0.04);
    border-radius: 50%;
    pointer-events: none;
}

.custom-login-design {
    background: var(--white);
    width: 420px;
    max-width: 100%;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg), 0 24px 48px rgba(0,0,0,0.25);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    position: relative;
    z-index: 2;
    animation: srp-slideUp 0.45s cubic-bezier(0.22,0.61,0.36,1) both;
}
@keyframes srp-slideUp {
    from { opacity: 0; transform: translateY(24px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0)   scale(1); }
}

.custom-login-design .login-header {
    background: var(--srp-800);
    padding: 36px 32px 28px;
    text-align: center;
    position: relative;
}
.custom-login-design .login-header::after {
    content: '';
    position: absolute;
    bottom: -1px; left: 0; right: 0;
    height: 20px;
    background: var(--white);
    border-radius: 20px 20px 0 0;
}
.custom-login-design .login-logo-ring {
    width: 72px; height: 72px;
    background: rgba(255,255,255,0.12);
    border: 2px solid rgba(255,255,255,0.25);
    border-radius: 50%;
    margin: 0 auto 14px;
    display: flex; align-items: center; justify-content: center;
}
.custom-login-design .login-logo-text {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 26px; font-weight: 800; color: #fff; letter-spacing: 1px;
}
.custom-login-design .login-title {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 22px; font-weight: 800; color: #fff; margin: 0 0 4px;
}
.custom-login-design .login-subtitle {
    font-size: 13px; color: rgba(255,255,255,0.7);
}
.custom-login-design .login-badge {
    display: inline-block;
    background: var(--yellow); color: var(--srp-900);
    font-size: 10px; font-weight: 800;
    padding: 3px 10px; border-radius: 20px;
    margin-top: 10px; letter-spacing: 0.5px; text-transform: uppercase;
}
.custom-login-design .login-body {
    padding: 28px 32px 28px;
}
.custom-login-design .login-field-label {
    display: block; text-align: center;
    font-size: 12px; font-weight: 800; text-transform: uppercase;
    letter-spacing: 1px; color: var(--txt-600); margin-bottom: 10px;
}
.custom-login-design .login-input-wrap { position: relative; }
.custom-login-design .login-input-icon {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    font-size: 18px; color: var(--txt-300); pointer-events: none;
}
.centered-placeholder { padding-left: 44px !important; text-align: center; }
.centered-placeholder::placeholder { text-align: center; opacity: 0.55; }

/* ══ FILTROS ════════════════════════════════════════════════ */
.senar-toolbar {
    background: var(--white);
    padding: 20px 24px;
    border-radius: var(--radius-md);
    margin-bottom: 20px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
}
.senar-filter-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    align-items: end;
    margin-bottom: 16px;
}
.filter-item label {
    display: block;
    font-size: 11px; font-weight: 800;
    color: var(--txt-400); text-transform: uppercase;
    margin-bottom: 6px; letter-spacing: 0.5px;
}
.filter-item input,
.filter-item select {
    width: 100%; padding: 10px 12px;
    border: 1.5px solid var(--border); border-radius: var(--radius-sm);
    font-size: 14px; font-family: 'Nunito', sans-serif;
    background: var(--srp-50); color: var(--txt-900);
    transition: border 0.2s, box-shadow 0.2s;
    -webkit-appearance: none;
}
.filter-item input:focus,
.filter-item select:focus {
    border-color: var(--srp-600); outline: none;
    background: var(--white);
    box-shadow: 0 0 0 3px rgba(0,150,64,0.12);
}

/* ══ HEADER ═════════════════════════════════════════════════ */
.senar-dash-header {
    display: flex; justify-content: space-between; align-items: center;
    background: var(--srp-800);
    padding: 18px 24px;
    border-radius: var(--radius-md);
    margin-bottom: 20px;
    box-shadow: var(--shadow-md);
}
.senar-dash-header h1 {
    margin: 0;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 24px; color: #fff; font-weight: 800; letter-spacing: 0.2px;
}
.senar-dash-header p {
    margin: 4px 0 0; color: rgba(255,255,255,0.7); font-size: 13px;
}

/* ══ TABELA ══════════════════════════════════════════════════ */
.senar-table-responsive {
    background: var(--white); border-radius: var(--radius-md);
    overflow-x: auto; box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
}
.senar-table { width: 100%; border-collapse: collapse; min-width: 900px; }
.senar-table th {
    background: var(--srp-50); padding: 14px 12px;
    text-align: left; font-size: 11px; text-transform: uppercase;
    color: var(--txt-400); font-weight: 800; font-family: 'Nunito', sans-serif;
    border-bottom: 2px solid var(--border); letter-spacing: 0.5px;
}
.senar-table td {
    padding: 13px 12px; border-bottom: 1px solid #f0f4f0;
    vertical-align: middle; color: var(--txt-900);
    font-size: 14px; font-family: 'Nunito', sans-serif;
}
.senar-table tr:hover { background: var(--srp-100); transition: background 0.15s; }

/* ══ TIPOGRAFIA UTILITÁRIA ══════════════════════════════════ */
.fw-bold   { font-weight: 800; }
.text-dark { color: var(--txt-900) !important; }
.text-muted { color: var(--txt-400); }
.small { font-size: 12px; }

.course-pill {
    display: inline-block;
    background: var(--srp-100); color: var(--srp-800);
    padding: 3px 10px; border-radius: 20px;
    font-size: 12px; font-weight: 700;
}

/* ══ BADGES DE NOTA ══════════════════════════════════════════ */
.senar-badge-score {
    padding: 5px 10px; border-radius: var(--radius-sm);
    font-weight: 800; font-size: 14px;
    display: inline-block; min-width: 44px;
    text-align: center; color: #fff;
}
.score-0  { background: #ef4444; }
.score-1  { background: #f87171; }
.score-2  { background: #fb923c; }
.score-3  { background: #fbbf24; }
.score-4  { background: #facc15; color: #713f12; }
.score-5  { background: #fde047; color: #854d0e; }
.score-6  { background: #eab308; }
.score-7  { background: #a3e635; color: #365314; }
.score-8  { background: #84cc16; }
.score-9  { background: #4ade80; color: #064e3b; }
.score-10 { background: #22c55e; }

/* ══ BADGES DE GÊNERO ════════════════════════════════════════ */
.srp-gender-badge {
    display: inline-block;
    padding: 2px 9px; border-radius: 20px;
    font-size: 11px; font-weight: 800; letter-spacing: 0.3px;
}
.srp-gender-m { background: #dbeafe; color: #1d4ed8; }
.srp-gender-f { background: #fce7f3; color: #be185d; }
.srp-gender-o { background: #f3e8ff; color: #6d28d9; }

/* ══ BOTÕES ═════════════════════════════════════════════════ */
.senar-btn {
    border: none; cursor: pointer;
    padding: 10px 20px; border-radius: var(--radius-sm);
    font-weight: 700; text-decoration: none;
    display: inline-flex; align-items: center; justify-content: center;
    gap: 7px; font-size: 14px; font-family: 'Nunito', sans-serif;
    transition: all 0.18s; letter-spacing: 0.2px;
}
.senar-btn:active { transform: scale(0.97); }
.senar-btn.primary {
    background: var(--srp-800); color: #fff;
    box-shadow: 0 2px 8px rgba(26,92,46,0.25);
}
.senar-btn.primary:hover { background: var(--srp-900); transform: translateY(-1px); }
.senar-btn.outline {
    background: var(--white); border: 1.5px solid var(--border);
    color: var(--txt-900); padding: 8px 14px; font-size: 13px;
}
.senar-btn.outline:hover { border-color: var(--srp-600); color: var(--srp-600); background: var(--srp-100); }
.senar-btn.outline-success {
    background: var(--white); border: 1.5px solid #22c55e;
    color: #15803d; padding: 8px 14px; font-size: 13px;
}
.senar-btn.outline-success:hover { background: #dcfce7; }
.senar-btn.full { width: 100%; }
.shadow-btn { box-shadow: 0 4px 10px rgba(0,150,64,0.22); }

/* ══ MODAL ══════════════════════════════════════════════════ */
.senar-modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(13,58,28,0.80); z-index: 9999;
    display: flex; justify-content: center; align-items: center;
    backdrop-filter: blur(5px); padding: 16px;
}
.senar-modal-content {
    background: var(--white); width: 95%; max-width: 860px;
    max-height: 90vh; border-radius: var(--radius-xl);
    display: flex; flex-direction: column;
    box-shadow: 0 32px 64px rgba(0,0,0,0.3); overflow: hidden;
    animation: srp-slideUp 0.3s cubic-bezier(0.22,0.61,0.36,1) both;
}
.modal-header {
    padding: 18px 24px; border-bottom: 1px solid var(--border);
    display: flex; justify-content: space-between; align-items: center;
    background: var(--srp-50);
}
.modal-header h2 {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 22px; font-weight: 800; color: var(--srp-800); margin: 0;
}
.modal-body-scroll { padding: 24px; overflow-y: auto; background: #fff; }

.senar-grid-details {
    display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
    margin-bottom: 24px; border-bottom: 1px dashed var(--border);
    padding-bottom: 24px;
}
.detail-card h4 {
    margin: 0 0 12px; color: var(--txt-400);
    font-size: 10px; text-transform: uppercase; letter-spacing: 1px; font-weight: 800;
}
.detail-card p {
    margin: 7px 0; font-size: 14px; color: var(--txt-900);
    display: flex; justify-content: space-between;
    border-bottom: 1px solid #f0f4f0; padding-bottom: 4px;
}
.highlight-text-blue {
    background: #eff6ff; color: #1e40af;
    padding: 2px 8px; border-radius: 5px; font-weight: 700; font-size: 13px;
}

.ratings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 10px; margin-bottom: 24px;
}
.r-item {
    background: var(--srp-50); border: 1.5px solid var(--border);
    padding: 10px 8px; border-radius: 10px; text-align: center;
    display: flex; flex-direction: column; justify-content: center;
    transition: transform 0.2s, box-shadow 0.2s;
}
.r-item:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.r-item span {
    font-size: 10px; color: var(--txt-400); text-transform: uppercase;
    margin-bottom: 5px; font-weight: 700; letter-spacing: 0.3px;
}
.r-item strong { color: var(--srp-600); font-size: 22px; font-weight: 800; line-height: 1; }
.r-item.special { background: var(--srp-800); border-color: var(--srp-800); }
.r-item.special span { color: #a7f3d0; }
.r-item.special strong { color: #fff; }

.vital-box {
    padding: 16px; border-radius: var(--radius-sm); position: relative;
    border-left: 4px solid; margin-bottom: 14px;
}
.vital-box label {
    display: block; font-weight: 800; margin-bottom: 8px;
    font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px;
}
.text-obs {
    margin: 0; color: var(--txt-900); white-space: pre-wrap;
    font-size: 14px; line-height: 1.65; font-weight: 500;
}
.warning-box  { background: #fff7ed; border-left-color: #f97316; }
.warning-box label { color: #c2410c; }
.info-box     { background: #eff6ff; border-left-color: #3b82f6; }
.info-box label { color: #1e40af; }

.tech-info-box {
    background: var(--srp-900); color: #fff; padding: 16px;
    border-radius: 10px; display: flex; align-items: center;
    justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.tech-item { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.tech-item strong { color: #4ade80; }

/* ══ ABAS ════════════════════════════════════════════════════ */
.senar-nav-tabs {
    display: flex; gap: 6px; margin-bottom: 20px;
    border-bottom: 2px solid var(--border);
}
.senar-tab-btn {
    background: transparent; border: none;
    padding: 11px 18px; font-size: 14px; font-weight: 700;
    font-family: 'Nunito', sans-serif; color: var(--txt-400);
    cursor: pointer; border-bottom: 3px solid transparent;
    margin-bottom: -2px; transition: all 0.18s; border-radius: 6px 6px 0 0;
}
.senar-tab-btn:hover { color: var(--srp-600); background: var(--srp-100); }
.senar-tab-btn.active { color: var(--srp-800); border-bottom-color: var(--srp-800); }

.tab-content { display: none; animation: srp-fadeIn 0.25s ease; }
.tab-content.active { display: block; }
@keyframes srp-fadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ══ KPI GRID ════════════════════════════════════════════════ */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px; margin-bottom: 24px;
}
.stat-box {
    background: var(--white); padding: 22px 18px;
    border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
    text-align: center; position: relative; overflow: hidden;
    border: 1px solid var(--border); border-top: 4px solid var(--srp-600);
    display: flex; flex-direction: column; justify-content: center;
    min-height: 140px; transition: transform 0.2s, box-shadow 0.2s;
}
.stat-box:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.stat-value {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 44px; font-weight: 800; color: var(--srp-800);
    margin: 8px 0; line-height: 1;
}
.stat-label {
    color: var(--txt-400); font-size: 11px;
    text-transform: uppercase; font-weight: 800; letter-spacing: 1px;
}

/* Aniversariantes */
.birthday-box {
    padding: 0; overflow: hidden;
    justify-content: flex-start; border-top: 4px solid #f59e0b;
}
.bday-header {
    background: #f59e0b; color: #fff; padding: 11px;
    font-weight: 800; width: 100%; display: block; text-align: center;
    font-size: 13px; letter-spacing: 0.3px;
}
.bday-list {
    list-style: none; margin: 0; padding: 0;
    overflow-y: auto; max-height: 120px; width: 100%;
}
.bday-list li {
    border-bottom: 1px solid #f0f4f0; padding: 8px 14px;
    display: flex; justify-content: space-between;
    font-size: 13px;
}

/* ══ GRÁFICOS ════════════════════════════════════════════════ */
.senar-charts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: 20px;
}
.chart-card {
    background: var(--white); border-radius: var(--radius-md);
    padding: 20px; box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    transition: box-shadow 0.2s;
}
.chart-card:hover { box-shadow: var(--shadow-md); }
.chart-card h3 {
    margin: 0 0 16px; font-size: 13px; font-weight: 800;
    color: var(--txt-400); text-transform: uppercase; letter-spacing: 0.5px;
    border-bottom: 1px solid var(--border); padding-bottom: 10px;
    display: flex; align-items: center; gap: 8px;
}
.chart-wrap { position: relative; height: 280px; width: 100%; }

/* ══ RESPONSIVO ══════════════════════════════════════════════ */
@media (max-width: 900px) {
    .senar-filter-grid { grid-template-columns: 1fr; gap: 10px; }
    .senar-grid-details { grid-template-columns: 1fr; gap: 12px; }
    .tech-info-box { flex-direction: column; align-items: flex-start; }
    .custom-login-design { width: 90%; }
    .kpi-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .senar-dashboard-wrapper { padding: 14px; }
    .kpi-grid { grid-template-columns: 1fr; }
    .senar-charts-grid { grid-template-columns: 1fr; }
}
