/* ============================================================
   Checklist ISO 27001 — estilos específicos
   Tokens em /assets/css/tools-base.css (NÃO sobrescrever).
   ============================================================ */

/* ===== Layout principal ===== */
.chk-wrap { display: flex; flex-direction: column; gap: 1.5rem; }

.chk-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.5rem;
}

/* ===== Notice (flash) ===== */
.chk-notice {
    padding: 0.75rem 1rem;
    border-radius: var(--radius-xs);
    border: 1px solid var(--border);
    font-size: 0.88rem;
    font-weight: 500;
}
.chk-notice-ok  { color: var(--green); background: rgba(34,197,94,0.08); border-color: rgba(34,197,94,0.25); }
.chk-notice-err { color: var(--red);   background: rgba(239,68,68,0.08); border-color: rgba(239,68,68,0.25); }

/* ===== Painel de contexto (colapsável) ===== */
.chk-ctx-head {
    display: flex; justify-content: space-between; align-items: center;
    cursor: pointer;
    user-select: none;
}
.chk-ctx-head h2 {
    font-size: 1rem; font-weight: 700; color: var(--text);
    display: flex; align-items: center; gap: 0.5rem;
}
.chk-ctx-head h2 svg { width: 16px; height: 16px; color: var(--accent); }
.chk-ctx-toggle {
    color: var(--text-muted);
    font-size: 0.78rem;
    display: inline-flex; align-items: center; gap: 0.3rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 4px 12px;
    transition: all var(--t);
}
.chk-ctx-toggle:hover { border-color: var(--border-hover); color: var(--text); }
.chk-ctx-toggle svg { width: 12px; height: 12px; transition: transform var(--t); }
.chk-ctx-head.open .chk-ctx-toggle svg { transform: rotate(180deg); }

.chk-ctx-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1.25rem;
}
@media (max-width: 720px) {
    .chk-ctx-grid { grid-template-columns: 1fr; }
}
.chk-field {
    display: flex; flex-direction: column; gap: 0.4rem;
}
.chk-field label {
    font-size: 0.75rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--text-muted);
}
.chk-field input,
.chk-field textarea,
.chk-field select {
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 0.6rem 0.75rem;
    border-radius: var(--radius-xs);
    font-family: inherit;
    font-size: 0.9rem;
    transition: border-color var(--t), background var(--t);
}
.chk-field input:focus,
.chk-field textarea:focus,
.chk-field select:focus {
    border-color: var(--accent);
    background: rgba(255,255,255,0.05);
}
.chk-field textarea { resize: vertical; min-height: 70px; }

/* ===== Sumário (score geral + barras) ===== */
.chk-summary {
    display: grid;
    grid-template-columns: minmax(200px, 240px) 1fr;
    gap: 2rem;
    align-items: center;
}
@media (max-width: 720px) {
    .chk-summary { grid-template-columns: 1fr; gap: 1.25rem; }
}

.chk-score-block { text-align: center; }
.chk-score-num {
    font-size: 4rem; font-weight: 800; line-height: 1;
    background: linear-gradient(135deg, var(--accent), var(--hl-blue));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.chk-score-meta {
    color: var(--text-muted);
    font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em;
    margin-top: 0.25rem;
}
.chk-score-applicable {
    color: var(--text-secondary);
    font-size: 0.8rem; margin-top: 0.4rem;
}

.chk-themes-bars { display: flex; flex-direction: column; gap: 0.7rem; }
.chk-theme-bar { display: grid; grid-template-columns: 1fr auto; gap: 0.4rem 1rem; align-items: center; }
.chk-theme-bar-label {
    grid-column: 1 / -1;
    display: flex; justify-content: space-between;
    font-size: 0.78rem; color: var(--text-secondary);
}
.chk-theme-bar-label strong { color: var(--text); font-weight: 600; }
.chk-theme-bar-track {
    grid-column: 1 / -1;
    height: 6px;
    background: rgba(255,255,255,0.05);
    border-radius: 3px; overflow: hidden;
}
.chk-theme-bar-fill {
    height: 100%;
    background: var(--accent);
    transition: width 0.6s var(--t);
}

/* ===== Distribuição por status (chips) ===== */
.chk-status-chips {
    display: flex; flex-wrap: wrap; gap: 0.4rem;
    margin-top: 1rem;
}
.chk-status-chip {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 4px 10px; border-radius: 50px;
    font-size: 0.72rem; font-weight: 600;
    background: rgba(255,255,255,0.04);
    color: var(--text-secondary);
    border: 1px solid var(--border);
}
.chk-status-dot {
    width: 8px; height: 8px; border-radius: 50%;
    flex-shrink: 0;
}
.chk-status-dot.s-na              { background: #888; }
.chk-status-dot.s-not_implemented { background: var(--red); }
.chk-status-dot.s-partial         { background: var(--yellow); }
.chk-status-dot.s-implemented     { background: var(--accent); }
.chk-status-dot.s-optimized       { background: var(--green); }
.chk-status-dot.s-unanswered      { background: rgba(255,255,255,0.2); }

/* ===== Filtros ===== */
.chk-filters {
    display: grid;
    grid-template-columns: 1fr 1fr 2fr;
    gap: 0.75rem;
    align-items: end;
}
@media (max-width: 720px) {
    .chk-filters { grid-template-columns: 1fr 1fr; }
    .chk-filters .chk-field:last-child { grid-column: 1 / -1; }
}

/* ===== Ações (toolbar) ===== */
.chk-actions {
    display: flex; flex-wrap: wrap; gap: 0.6rem;
    margin-top: 0.5rem;
}
.chk-btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.55rem 1rem;
    border-radius: var(--radius-xs);
    font-family: inherit;
    font-size: 0.85rem; font-weight: 600;
    cursor: pointer;
    transition: all var(--t);
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
    color: var(--text);
}
.chk-btn:hover { border-color: var(--border-hover); background: rgba(255,255,255,0.07); }
.chk-btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.chk-btn-primary {
    background: var(--accent);
    border-color: var(--accent);
    color: white;
}
.chk-btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.chk-btn-danger { color: var(--red); }
.chk-btn-danger:hover { border-color: var(--red); background: rgba(239,68,68,0.08); }

/* ===== Tema (group) ===== */
.chk-theme-group {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}
.chk-theme-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1rem 1.25rem;
    cursor: pointer;
    user-select: none;
    background: rgba(255,255,255,0.02);
    border-bottom: 1px solid var(--border);
    transition: background var(--t);
}
.chk-theme-head:hover { background: rgba(255,255,255,0.04); }
.chk-theme-head.collapsed { border-bottom-color: transparent; }
.chk-theme-head h3 {
    font-size: 0.95rem; font-weight: 700; color: var(--text);
    display: flex; align-items: center; gap: 0.6rem;
}
.chk-theme-id {
    display: inline-block;
    background: var(--accent-soft);
    color: var(--accent);
    padding: 2px 10px; border-radius: 50px;
    font-size: 0.72rem; font-weight: 700;
    letter-spacing: 0.04em;
}
.chk-theme-meta { display: flex; align-items: center; gap: 0.75rem; }
.chk-theme-meta-score {
    font-size: 0.8rem; color: var(--text-secondary);
}
.chk-theme-meta-score strong {
    color: var(--accent);
    font-weight: 700;
}
.chk-theme-caret {
    width: 14px; height: 14px;
    color: var(--text-muted);
    transition: transform var(--t);
}
.chk-theme-head.collapsed .chk-theme-caret { transform: rotate(-90deg); }

.chk-controls-list { padding: 0.5rem 0; }

/* ===== Linha de controle ===== */
.chk-ctrl {
    border-bottom: 1px solid var(--border);
    transition: background var(--t);
}
.chk-ctrl:last-child { border-bottom: 0; }
.chk-ctrl:hover { background: rgba(255,255,255,0.015); }

.chk-ctrl-row {
    display: grid;
    grid-template-columns: 60px 1fr auto auto;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    align-items: center;
}
@media (max-width: 720px) {
    .chk-ctrl-row {
        grid-template-columns: 1fr auto;
        gap: 0.5rem;
    }
    .chk-ctrl-id-name { grid-column: 1 / -1; display: flex; gap: 0.5rem; align-items: baseline; }
    .chk-ctrl-statuses { grid-column: 1 / -1; }
}

.chk-ctrl-id {
    font-family: ui-monospace, monospace;
    font-size: 0.78rem; font-weight: 700;
    color: var(--accent);
}
.chk-ctrl-name {
    font-size: 0.9rem;
    color: var(--text);
    line-height: 1.4;
}

.chk-ctrl-statuses {
    display: flex; gap: 4px;
    flex-wrap: wrap;
}
@media (max-width: 720px) {
    .chk-ctrl-statuses { display: grid; grid-template-columns: repeat(3, 1fr); }
}

.chk-status-btn {
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    color: var(--text-muted);
    padding: 5px 10px;
    border-radius: var(--radius-xs);
    font-family: inherit;
    font-size: 0.7rem; font-weight: 600;
    cursor: pointer;
    transition: all var(--t);
    white-space: nowrap;
}
.chk-status-btn:hover { border-color: var(--border-hover); color: var(--text); }
.chk-status-btn.active.s-na              { background: rgba(136,136,136,0.18);  color: #ccc;            border-color: #888; }
.chk-status-btn.active.s-not_implemented { background: rgba(239,68,68,0.15);    color: var(--red);     border-color: var(--red); }
.chk-status-btn.active.s-partial         { background: rgba(255,235,59,0.15);   color: var(--yellow);  border-color: var(--yellow); }
.chk-status-btn.active.s-implemented     { background: var(--accent-soft);      color: var(--accent);  border-color: var(--accent); }
.chk-status-btn.active.s-optimized       { background: rgba(34,197,94,0.15);    color: var(--green);   border-color: var(--green); }

.chk-ctrl-expand-btn {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-muted);
    width: 28px; height: 28px;
    border-radius: 50%;
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1rem; line-height: 1;
    transition: all var(--t);
}
.chk-ctrl-expand-btn:hover { border-color: var(--accent); color: var(--accent); }
.chk-ctrl-expand-btn svg { width: 12px; height: 12px; transition: transform var(--t); }
.chk-ctrl.expanded .chk-ctrl-expand-btn svg { transform: rotate(45deg); }
.chk-ctrl.expanded .chk-ctrl-expand-btn { border-color: var(--accent); color: var(--accent); }

/* ===== Detalhes opcionais ===== */
.chk-ctrl-details {
    padding: 0 1.25rem 1rem;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 0.75rem;
}
@media (max-width: 720px) {
    .chk-ctrl-details { grid-template-columns: 1fr; }
}

/* ===== Empty / autosave ===== */
.chk-empty {
    padding: 2rem;
    text-align: center;
    color: var(--text-muted);
    font-size: 0.9rem;
    font-style: italic;
}
.chk-autosave {
    color: var(--text-muted);
    font-size: 0.72rem;
    text-align: right;
    margin-top: -0.4rem;
    display: flex; align-items: center; gap: 0.4rem;
    justify-content: flex-end;
}
.chk-autosave svg { width: 11px; height: 11px; color: var(--green); }

/* ===== Print (fallback caso o usuário use ctrl+P) ===== */
@media print {
    body { background: white; color: black; }
    .ft-nav, .ft-footer, .ft-privacy-badge, .chk-actions, .chk-filters, .chk-ctrl-expand-btn { display: none !important; }
    .chk-card, .chk-theme-group { background: white !important; border: 1px solid #ccc !important; color: black !important; page-break-inside: avoid; }
    .chk-score-num { color: #173A6B !important; -webkit-text-fill-color: #173A6B !important; background: none !important; }
    .chk-ctrl-name, .chk-ctrl-id { color: #000 !important; }
}
