/* ================================================================
   JARVIS BRIEFING MANAGER v2 — CSS
   ================================================================ */
:root {
  --bg:        #0a0f1e;
  --bg2:       #111827;
  --bg3:       #1f2937;
  --border:    #2d3748;
  --text:      #f1f5f9;
  --text2:     #94a3b8;
  --text3:     #64748b;
  --btg:       #f59e0b;
  --btg-dim:   rgba(245,158,11,0.15);
  --pan:       #3b82f6;
  --pan-dim:   rgba(59,130,246,0.15);
  --green:     #22c55e;
  --yellow:    #eab308;
  --orange:    #f97316;
  --red:       #ef4444;
  --purple:    #a855f7;
  --radius:    10px;
  --radius-sm: 6px;
  --shadow:    0 4px 24px rgba(0,0,0,0.4);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; font-size: 14px; line-height: 1.5; }
.screen { min-height: 100vh; }
.hidden { display: none !important; }

/* LOGIN */
.login-wrap { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: 24px; }
.login-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 40px 36px; width: 100%; max-width: 400px; box-shadow: var(--shadow); }
.login-logo { font-size: 40px; text-align: center; margin-bottom: 8px; }
.login-title { font-size: 28px; font-weight: 700; text-align: center; background: linear-gradient(135deg, #f59e0b, #3b82f6); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: 4px; }
.login-sub { text-align: center; color: var(--text2); margin-bottom: 28px; font-size: 13px; }
.login-error { color: var(--red); font-size: 13px; margin-top: 12px; text-align: center; }
.login-hint { text-align: center; color: var(--text2); font-size: 13px; margin-top: 20px; }
.login-hint a { color: var(--pan); text-decoration: none; }

/* FORMS */
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 12px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); padding: 10px 12px; font-size: 14px; outline: none; transition: border-color 0.15s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--pan); }
.form-group textarea { resize: vertical; min-height: 72px; font-family: inherit; }
.form-group select option { background: var(--bg3); }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 24px; }

/* HEADER */
.app-header { display: flex; align-items: center; gap: 12px; padding: 0 20px; height: 54px; background: var(--bg2); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 100; }
.header-brand { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 15px; }
.header-brand.brand-home { cursor: pointer; opacity: .9; transition: opacity .15s; user-select: none; }
.header-brand.brand-home:hover { opacity: 1; }
.brand-icon { font-size: 18px; }
.header-nav { display: flex; gap: 4px; flex: 1; }
.header-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; flex-shrink: 0; }
.header-score-summary { font-size: 12px; color: var(--text2); white-space: nowrap; }

/* BUTTONS */
.btn-primary { background: linear-gradient(135deg, var(--btg), var(--pan)); color: white; border: none; border-radius: var(--radius-sm); padding: 9px 18px; font-size: 14px; font-weight: 600; cursor: pointer; transition: opacity 0.15s; }
.btn-primary:hover { opacity: 0.88; }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-full { width: 100%; }
.btn-secondary { background: var(--bg3); color: var(--text); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 7px 14px; font-size: 13px; font-weight: 500; cursor: pointer; transition: background 0.15s; white-space: nowrap; }
.btn-secondary:hover { background: var(--border); }
.btn-ghost { background: transparent; color: var(--text2); border: none; padding: 6px 10px; font-size: 13px; cursor: pointer; border-radius: var(--radius-sm); transition: color 0.15s; white-space: nowrap; }
.btn-ghost:hover { color: var(--text); }
.btn-warning { background: #7c3b00; color: #fbbf24; border: 1px solid #92400e; border-radius: var(--radius-sm); padding: 7px 14px; font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.15s; white-space: nowrap; }
.btn-warning:hover { background: #92400e; }
.btn-back { background: transparent; color: var(--text2); border: none; padding: 6px 0; font-size: 13px; cursor: pointer; white-space: nowrap; transition: color 0.15s; }
.btn-back:hover { color: var(--text); }
.btn-icon { background: transparent; border: none; padding: 6px 8px; cursor: pointer; font-size: 16px; border-radius: var(--radius-sm); transition: background 0.15s; }
.btn-icon:hover { background: var(--bg3); }
.filter-btn { background: transparent; color: var(--text2); border: 1px solid transparent; border-radius: var(--radius-sm); padding: 5px 12px; font-size: 13px; cursor: pointer; transition: all 0.15s; }
.filter-btn:hover { color: var(--text); }
.filter-btn.active { background: var(--bg3); color: var(--text); border-color: var(--border); }

/* BADGES */
.badge { font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 4px; white-space: nowrap; flex-shrink: 0; }
.badge-btg { background: var(--btg-dim); color: var(--btg); }
.badge-pan { background: var(--pan-dim); color: var(--pan); }
.badge-status { font-size: 10px; padding: 2px 6px; border-radius: 4px; font-weight: 600; }
.badge-active   { background: rgba(34,197,94,0.15);   color: var(--green); }
.badge-standby  { background: rgba(234,179,8,0.15);   color: var(--yellow); }
.badge-blocked  { background: rgba(239,68,68,0.15);   color: var(--red); }
.badge-planned  { background: rgba(100,116,139,0.15); color: var(--text2); }

/* SCORE COLORS */
.score-green  { color: var(--green); }
.score-yellow { color: var(--yellow); }
.score-orange { color: var(--orange); }
.score-red    { color: var(--red); }
.bar-green  { background: var(--green); }
.bar-yellow { background: var(--yellow); }
.bar-orange { background: var(--orange); }
.bar-red    { background: var(--red); }

/* SCORE RING */
.score-ring-wrap { position: relative; width: 72px; height: 72px; flex-shrink: 0; }
.score-ring { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.score-ring-inner { position: absolute; top: 6px; left: 6px; right: 6px; bottom: 6px; background: var(--bg2); border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.score-ring-value { font-size: 18px; font-weight: 800; line-height: 1; }
.score-ring-max { font-size: 9px; color: var(--text3); }

/* DASHBOARD */
.dashboard-main { padding: 20px 24px; max-width: 1280px; margin: 0 auto; }
.dash-title-row { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; }
.dash-title-row h2 { font-size: 18px; font-weight: 700; }
.dash-subtitle { color: var(--text2); font-size: 13px; margin-top: 2px; }
.project-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 16px; }

/* PORTFOLIO PROGRESS */
.portfolio-bar { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 14px; min-width: 200px; text-align: right; }
.portfolio-bar-label { font-size: 11px; color: var(--text2); margin-bottom: 6px; }
.portfolio-bar-track { height: 6px; background: var(--bg3); border-radius: 3px; overflow: hidden; }
.portfolio-bar-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--btg), var(--pan)); transition: width 0.8s ease; }
.portfolio-bar-pct { font-size: 20px; font-weight: 700; margin-top: 4px; }

/* PROJECT CARD */
.project-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; cursor: pointer; transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s; position: relative; overflow: hidden; }
.project-card:hover { border-color: var(--pan); transform: translateY(-2px); box-shadow: 0 8px 32px rgba(59,130,246,0.15); }
.project-card.btg:hover { border-color: var(--btg); box-shadow: 0 8px 32px rgba(245,158,11,0.15); }
.project-card.premium { border-color: var(--green); }
.project-card.premium::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--green), var(--pan)); }
.card-top { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.card-text { flex: 1; min-width: 0; }
.card-rank { font-size: 11px; color: var(--text3); font-weight: 700; margin-bottom: 3px; }
.card-name { font-size: 14px; font-weight: 600; line-height: 1.3; margin-bottom: 6px; }
.card-badges { display: flex; gap: 5px; flex-wrap: wrap; }
.card-achievements { display: flex; gap: 4px; margin-top: 10px; }
.achievement-pill { font-size: 10px; background: var(--bg3); border: 1px solid var(--border); border-radius: 20px; padding: 2px 8px; color: var(--text2); }
.achievement-pill.earned { border-color: var(--green); color: var(--green); background: rgba(34,197,94,0.08); }
.card-meta { margin-top: 12px; display: flex; flex-direction: column; gap: 4px; }
.card-meta-row { display: flex; gap: 6px; font-size: 12px; color: var(--text2); }
.card-meta-label { color: var(--text3); }
.card-geo-alert { margin-top: 10px; background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.2); border-radius: var(--radius-sm); padding: 6px 10px; font-size: 12px; color: var(--red); display: flex; align-items: center; gap: 6px; }
.card-milestone { margin-top: 8px; font-size: 11px; color: var(--text3); }
.card-milestone span { color: var(--pan); font-weight: 600; }

/* PROJECT DETAIL */
.project-main { padding: 24px; max-width: 920px; margin: 0 auto; }
.project-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; gap: 16px; flex-wrap: wrap; }
.project-title { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.project-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.project-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.project-score-big { text-align: right; flex-shrink: 0; }
.score-big-value { font-size: 44px; font-weight: 800; line-height: 1; }
.score-big-max { font-size: 14px; color: var(--text2); }
.score-big-label { font-size: 13px; font-weight: 600; margin-top: 4px; }
.blocks-section { margin-bottom: 28px; }
.section-title { font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 12px; }
.blocks-list { display: flex; flex-direction: column; gap: 6px; }
.block-row { display: flex; align-items: center; gap: 10px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 11px 14px; cursor: pointer; transition: border-color 0.15s; }
.block-row:hover { border-color: var(--pan); }
.block-num { font-size: 10px; color: var(--text3); min-width: 18px; font-weight: 700; }
.block-name { flex: 1; font-size: 13px; }
.block-bar-wrap { width: 70px; height: 4px; background: var(--bg3); border-radius: 2px; overflow: hidden; }
.block-bar { height: 100%; border-radius: 2px; transition: width 0.4s; }
.block-pts { font-size: 12px; color: var(--text2); min-width: 44px; text-align: right; font-variant-numeric: tabular-nums; }
.block-status-icon { font-size: 13px; min-width: 16px; text-align: center; }
.block-row.geo-block { border-color: rgba(239,68,68,0.3); background: rgba(239,68,68,0.04); }
.metrics-section, .geo-section { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; margin-bottom: 18px; }
.metrics-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
.metrics-template-bar { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.field-select { width: 100%; padding: 8px 10px; background: var(--bg3); border: 1px solid var(--border); border-radius: 6px; color: var(--text1); font-size: 13px; cursor: pointer; }
.field-select.confirmed { border-color: var(--green); background: rgba(34,197,94,.07); }
.metrics-table { width: 100%; border-collapse: collapse; }
.metrics-table th { text-align: left; font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.05em; padding: 0 8px 8px; }
.metrics-table td { padding: 8px; font-size: 13px; border-top: 1px solid var(--border); }
.metrics-table tr:hover .btn-row-edit,
.cron-table tr:hover .btn-row-edit { opacity: 1; }
.btn-row-edit { background: none; border: 1px solid var(--border); border-radius: 6px; color: var(--text2); cursor: pointer; font-size: 12px; padding: 2px 7px; opacity: 0; transition: opacity 0.15s, background 0.15s; }
.btn-row-edit:hover { background: var(--bg3); color: var(--text1); }
.empty-state { text-align: center; color: var(--text2); padding: 20px; font-size: 13px; }

/* BLOCK EDITOR */
.block-main { padding: 24px; max-width: 700px; margin: 0 auto; }
.block-editor-header { margin-bottom: 20px; }
.block-editor-title { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.block-editor-meta { color: var(--text2); font-size: 13px; }
.completion-preview { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 16px; margin-bottom: 18px; display: flex; align-items: center; gap: 12px; font-size: 13px; color: var(--text2); }
.completion-preview strong { color: var(--text); }
.block-mode-tabs { display: flex; gap: 8px; margin-bottom: 20px; }
.field-row { display: grid; grid-template-columns: 190px 1fr auto; gap: 12px; align-items: start; padding: 11px 0; border-bottom: 1px solid var(--border); }
.field-row:last-child { border-bottom: none; }
.field-label { font-size: 13px; font-weight: 500; color: var(--text2); padding-top: 9px; }
.field-hint { font-size: 11px; color: var(--text3); margin-top: 2px; }
.field-input { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); padding: 8px 10px; font-size: 13px; font-family: inherit; outline: none; resize: vertical; transition: border-color 0.15s; }
.field-input:focus { border-color: var(--pan); }
.field-input.confirmed { border-color: var(--green); }
.field-status { padding-top: 8px; font-size: 14px; }
.autocomplete-dropdown { position: absolute; z-index: 200; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); box-shadow: var(--shadow); min-width: 280px; max-height: 180px; overflow-y: auto; }
.autocomplete-item { padding: 8px 12px; font-size: 12px; cursor: pointer; color: var(--text2); border-bottom: 1px solid var(--border); }
.autocomplete-item:last-child { border-bottom: none; }
.autocomplete-item:hover { background: var(--bg3); color: var(--text); }
.autocomplete-label { font-size: 10px; color: var(--text3); text-transform: uppercase; padding: 6px 12px 2px; }
.field-wrapper { position: relative; }
.block-save-row { display: flex; justify-content: flex-end; gap: 10px; margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--border); }

/* QUESTIONNAIRE */
.quiz-main { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: calc(100vh - 54px); padding: 24px; }
.quiz-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 40px 36px; max-width: 600px; width: 100%; box-shadow: var(--shadow); }
.quiz-step-indicator { font-size: 12px; color: var(--text3); margin-bottom: 10px; text-align: center; font-weight: 600; }
/* Progress dots strip */
.quiz-dots { display: flex; gap: 5px; flex-wrap: wrap; justify-content: center; margin-bottom: 12px; }
.quiz-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--bg3); border: 1.5px solid var(--border); transition: all 0.2s; cursor: default; }
.quiz-dot.filled { background: var(--green); border-color: var(--green); }
.quiz-dot.active { background: var(--pan); border-color: var(--pan); transform: scale(1.35); box-shadow: 0 0 0 2px rgba(59,130,246,0.3); }
.quiz-dot.active.filled { background: var(--btg); border-color: var(--btg); }
/* Keyboard hint */
.quiz-kb-hint { font-size: 11px; color: var(--text3); margin-top: 16px; text-align: center; }
.quiz-kb-hint kbd { background: var(--bg3); border: 1px solid var(--border); border-radius: 3px; padding: 1px 5px; font-size: 10px; color: var(--text2); font-family: monospace; }
.quiz-progress-bar { height: 4px; background: var(--bg3); border-radius: 2px; overflow: hidden; margin-bottom: 32px; }
.quiz-progress-fill { height: 100%; background: linear-gradient(90deg, var(--btg), var(--pan)); border-radius: 2px; transition: width 0.4s; }
.quiz-question { font-size: 20px; font-weight: 700; margin-bottom: 8px; line-height: 1.3; }
.quiz-hint { font-size: 13px; color: var(--text2); margin-bottom: 24px; }
.quiz-input { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); padding: 14px; font-size: 15px; font-family: inherit; outline: none; resize: vertical; min-height: 90px; transition: border-color 0.15s; }
.quiz-input:focus { border-color: var(--pan); }
.quiz-actions { display: flex; gap: 10px; justify-content: space-between; margin-top: 24px; }
.quiz-progress-text { font-size: 13px; color: var(--text2); font-variant-numeric: tabular-nums; }
.quiz-summary { text-align: center; }
.quiz-summary-icon { font-size: 48px; margin-bottom: 16px; }
.quiz-summary-title { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.quiz-summary-stats { display: flex; gap: 16px; justify-content: center; margin: 20px 0; }
.quiz-stat { text-align: center; }
.quiz-stat-value { font-size: 28px; font-weight: 800; }
.quiz-stat-label { font-size: 12px; color: var(--text2); }

/* BLOCO EDITOR — Template/Import/Export */
.block-editor-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 8px; gap: 12px; }
.block-tpl-actions { display: flex; gap: 6px; flex-shrink: 0; }
.btn-icon-sm { background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; color: var(--text2); cursor: pointer; font-size: 16px; height: 34px; width: 34px; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.btn-icon-sm:hover { border-color: var(--pan); color: var(--text); }
label.btn-icon-sm { cursor: pointer; }

/* Block action buttons — Export / Import / Clear */
.block-action-group { display: flex; gap: 8px; }
.block-action-btn { display: flex; align-items: center; gap: 6px; border-radius: 8px; padding: 7px 13px; font-size: 13px; font-weight: 600; cursor: pointer; border: 1px solid transparent; transition: all 0.15s; white-space: nowrap; }
.block-action-icon { font-size: 15px; }
.block-action-label { font-size: 12px; }
.export-btn { background: #1e3a5f; color: #60a5fa; border-color: #2563eb40; }
.export-btn:hover { background: #1d4ed8; color: #fff; border-color: #3b82f6; }
.import-btn { background: #14432a; color: #4ade80; border-color: #16a34a40; cursor: pointer; }
.import-btn:hover { background: #15803d; color: #fff; border-color: #22c55e; }
.clear-btn { background: #3b1515; color: #f87171; border-color: #dc262640; }
.clear-btn:hover { background: #991b1b; color: #fff; border-color: #ef4444; }

/* Modal overlay */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.65); display: flex; align-items: center; justify-content: center; z-index: 9000; }
.modal-overlay.hidden { display: none; }
.modal-box { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 28px; min-width: 320px; max-width: 440px; width: 90%; box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.modal-title { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
.modal-sub { color: var(--text2); font-size: 13px; margin-bottom: 20px; }
.btn-danger { background: #7f1d1d; color: #fca5a5; border: 1px solid #dc2626; border-radius: var(--radius-sm); padding: 9px 18px; font-size: 14px; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.btn-danger:hover { background: #dc2626; color: #fff; }

/* Export format options */
.export-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 4px; }
.export-opt-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 16px 12px; border-radius: 10px; border: 1px solid var(--border); background: var(--bg3); cursor: pointer; transition: all 0.15s; }
.export-opt-btn:hover { border-color: var(--btg); background: #1a2540; }
.export-opt-icon { font-size: 22px; }
.export-opt-label { font-size: 14px; font-weight: 700; color: var(--text); }
.export-opt-desc { font-size: 11px; color: var(--text2); text-align: center; }

/* NOVO PROJETO — bank selector */
.new-project-main { padding: 24px; max-width: 680px; margin: 0 auto; }
.np-title { font-size: 22px; font-weight: 700; margin-bottom: 6px; }
.np-subtitle { color: var(--text2); font-size: 13px; margin-bottom: 28px; }
.bank-selector { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 8px; }
.bank-btn { background: var(--bg3); border: 2px solid var(--border); border-radius: var(--radius); padding: 14px 12px; cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 4px; transition: all 0.18s; }
.bank-btn:hover { border-color: var(--pan); }
.bank-btn.selected { background: var(--pan-dim); border-color: var(--pan); }
.bank-btn.btg-btn.selected { background: var(--btg-dim); border-color: var(--btg); }
.bank-btn-icon { font-size: 22px; }
.bank-btn-label { font-size: 14px; font-weight: 700; color: var(--text); }
.bank-btn-sub { font-size: 10px; color: var(--text3); text-align: center; line-height: 1.4; }
@media (max-width: 480px) { .bank-selector { grid-template-columns: 1fr; } }
.step-tabs { display: flex; gap: 0; margin-bottom: 28px; border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; }
.step-tab { flex: 1; padding: 10px; text-align: center; font-size: 13px; background: var(--bg3); color: var(--text2); cursor: pointer; transition: all 0.15s; }
.step-tab.active { background: var(--pan); color: white; font-weight: 600; }

/* GEO FORM */
.geo-main { padding: 24px; }
.geo-wrap { max-width: 900px; margin: 0 auto; }
.geo-card-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 24px; gap: 16px; flex-wrap: wrap; }
.geo-platform-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.geo-plat-badge { border-radius: 20px; font-size: 11px; font-weight: 700; padding: 4px 12px; }
.geo-plat-badge.chatgpt { background: rgba(16,163,127,0.15); border: 1px solid rgba(16,163,127,0.4); color: #10a37f; }
.geo-plat-badge.perplexity { background: rgba(168,85,247,0.15); border: 1px solid rgba(168,85,247,0.4); color: #a855f7; }
.geo-plat-badge.google { background: rgba(59,130,246,0.15); border: 1px solid rgba(59,130,246,0.4); color: var(--pan); }
.geo-form-grid { display: grid; grid-template-columns: 1fr 280px; gap: 20px; align-items: start; }
.geo-col-main { display: flex; flex-direction: column; gap: 0; }
.geo-col-side { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; display: flex; flex-direction: column; gap: 4px; }
.geo-mention-row { display: flex; align-items: center; gap: 10px; padding: 12px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 8px 0; }
.geo-checkbox { width: 18px; height: 18px; accent-color: var(--green); cursor: pointer; }
.geo-mention-label { font-size: 14px; color: var(--text); cursor: pointer; margin: 0; }
.geo-platform-select { height: 40px; }
.geo-side-actions { margin-top: 16px; display: flex; flex-direction: column; gap: 8px; }
.btn-full { width: 100%; }
@media (max-width: 700px) { .geo-form-grid { grid-template-columns: 1fr; } .geo-col-side { order: -1; } }

/* GEO HUB */
.geo-hub-wrap { max-width: 960px; margin: 0 auto; }
.geo-hub-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; gap: 12px; flex-wrap: wrap; }
.geo-hub-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.geo-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 20px; }
.geo-tab { background: none; border: none; border-bottom: 2px solid transparent; padding: 10px 20px; color: var(--text2); font-size: 14px; font-weight: 500; cursor: pointer; transition: all .15s; }
.geo-tab:hover { color: var(--text); }
.geo-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.geo-loading { text-align: center; padding: 40px; color: var(--text2); }
.geo-queries-list { display: flex; flex-direction: column; gap: 12px; }
.geo-query-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; }
.geo-query-top { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.geo-query-text { font-size: 15px; color: var(--text); line-height: 1.5; margin-bottom: 12px; }
.geo-query-src { font-size: 11px; color: var(--text2); }
.geo-query-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-geo-approve { background: rgba(34,197,94,.15); border: 1px solid rgba(34,197,94,.4); color: #22c55e; border-radius: 6px; padding: 5px 14px; font-size: 13px; cursor: pointer; transition: background .15s; }
.btn-geo-approve:hover { background: rgba(34,197,94,.25); }
.btn-geo-monitor { background: rgba(251,191,36,.15); border: 1px solid rgba(251,191,36,.4); color: var(--gold); border-radius: 6px; padding: 5px 14px; font-size: 13px; cursor: pointer; transition: background .15s; }
.btn-geo-monitor:hover { background: rgba(251,191,36,.25); }
.btn-geo-reject { background: rgba(239,68,68,.12); border: 1px solid rgba(239,68,68,.3); color: #ef4444; border-radius: 6px; padding: 5px 14px; font-size: 13px; cursor: pointer; transition: background .15s; }
.btn-geo-reject:hover { background: rgba(239,68,68,.22); }
.btn-geo-run-one { background: var(--bg3); border: 1px solid var(--border); color: var(--text); border-radius: 6px; padding: 5px 14px; font-size: 13px; cursor: pointer; }
.geo-cat-badge { border-radius: 20px; font-size: 11px; font-weight: 700; padding: 3px 10px; }
.geo-cat-brand { background: rgba(251,191,36,.18); color: var(--gold); }
.geo-cat-comp { background: rgba(239,68,68,.15); color: #ef4444; }
.geo-cat-prod { background: rgba(59,130,246,.15); color: var(--pan); }
.geo-cat-info { background: rgba(156,163,175,.15); color: var(--text2); }
.geo-status-badge { border-radius: 20px; font-size: 11px; font-weight: 700; padding: 3px 10px; }
.geo-status-badge.monitoring { background: rgba(251,191,36,.18); color: var(--gold); }
.geo-status-badge.approved { background: rgba(34,197,94,.15); color: #22c55e; }
.geo-hist-row { display: flex; align-items: center; gap: 6px; margin-bottom: 10px; font-size: 12px; color: var(--text2); }
.geo-hist-dot { font-size: 14px; }
.geo-mention-rate { font-size: 12px; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.geo-mention-rate.green { background: rgba(34,197,94,.15); color: #22c55e; }
.geo-mention-rate.red { background: rgba(239,68,68,.12); color: #ef4444; }
.geo-empty-state { text-align: center; padding: 48px 20px; color: var(--text2); }
.geo-summary-row { display: flex; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.geo-stat { background: var(--bg3); border-radius: 8px; padding: 10px 16px; display: flex; flex-direction: column; align-items: center; min-width: 90px; }
.geo-stat.green .geo-stat-val { color: #22c55e; }
.geo-stat.red .geo-stat-val { color: #ef4444; }
.geo-stat.orange .geo-stat-val { color: var(--gold); }
.geo-stat-val { font-size: 20px; font-weight: 700; }
.geo-stat-label { font-size: 11px; color: var(--text2); margin-top: 2px; }
.geo-plat-tag { border-radius: 4px; font-size: 11px; font-weight: 600; padding: 2px 8px; }
.geo-plat-tag.claude { background: rgba(251,191,36,.18); color: var(--gold); }
.geo-plat-tag.gemini { background: rgba(59,130,246,.15); color: var(--pan); }
.geo-plat-tag.chatgpt { background: rgba(16,163,127,.15); color: #10a37f; }
.geo-plat-tag.perplexity { background: rgba(168,85,247,.15); color: #a855f7; }
.geo-manual-form { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.btn-link { background: none; border: none; color: var(--gold); font-size: 13px; cursor: pointer; padding: 0; text-decoration: underline; }

/* INFRA — N8N config */
.infra-n8n-config { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; }
.infra-n8n-desc { font-size: 13px; color: var(--text2); line-height: 1.7; margin-bottom: 16px; }
.infra-n8n-form { display: flex; flex-direction: column; gap: 4px; }

/* INFRA SCREEN */
.infra-main { padding: 24px; max-width: 1100px; margin: 0 auto; }
.infra-title { font-size: 22px; font-weight: 700; margin-bottom: 6px; }
.infra-subtitle { color: var(--text2); font-size: 13px; margin-bottom: 28px; }
.infra-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin-bottom: 32px; }
.service-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; }
.service-card.online  { border-color: rgba(34,197,94,0.3); }
.service-card.offline { border-color: rgba(239,68,68,0.3); }
.service-card.unknown { border-color: var(--border); }
.service-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.service-icon { font-size: 24px; }
.service-name { font-size: 15px; font-weight: 600; }
.service-status-dot { width: 8px; height: 8px; border-radius: 50%; margin-left: auto; flex-shrink: 0; }
.service-status-dot.online  { background: var(--green); box-shadow: 0 0 6px var(--green); }
.service-status-dot.offline { background: var(--red); }
.service-status-dot.unknown { background: var(--text3); }
.service-desc { font-size: 12px; color: var(--text2); margin-bottom: 10px; }
.service-meta { font-size: 11px; color: var(--text3); }
.service-action { margin-top: 12px; }
.infra-section-title { font-size: 14px; font-weight: 600; color: var(--text2); margin-bottom: 14px; margin-top: 24px; text-transform: uppercase; letter-spacing: 0.05em; font-size: 11px; }
.cron-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--border); border-radius: var(--radius); }
.cron-table { width: 100%; border-collapse: collapse; background: var(--bg2); min-width: 540px; }
.cron-table th { text-align: left; font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.05em; padding: 10px 14px; border-bottom: 1px solid var(--border); }
.cron-table td { padding: 10px 14px; font-size: 13px; border-bottom: 1px solid var(--border); }
.cron-table tr:last-child td { border-bottom: none; }
@media (max-width: 640px) {
  .infra-grid { grid-template-columns: 1fr; }
  .psi-key-row { flex-direction: column; align-items: stretch !important; }
  .psi-key-row input { width: 100% !important; max-width: 100% !important; }
}
.status-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 600; }
.status-pill.active  { background: rgba(34,197,94,0.15); color: var(--green); }
.status-pill.standby { background: rgba(234,179,8,0.15);  color: var(--yellow); }
.status-pill.blocked { background: rgba(239,68,68,0.15);  color: var(--red); }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; margin-bottom: 28px; }
.stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 16px; text-align: center; }
.stat-card-value { font-size: 28px; font-weight: 800; line-height: 1; margin-bottom: 4px; }
.stat-card-label { font-size: 12px; color: var(--text2); }

/* TOAST */
.toast { position: fixed; bottom: 24px; right: 24px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 18px; font-size: 14px; z-index: 900; box-shadow: var(--shadow); transition: opacity 0.3s; max-width: 320px; }
.toast.toast-success { border-color: var(--green); color: var(--green); }
.toast.toast-error   { border-color: var(--red);   color: var(--red); }

/* ACHIEVEMENT POPUP */
.achievement-popup { position: fixed; top: 70px; right: 20px; background: var(--bg2); border: 1px solid var(--green); border-radius: var(--radius); padding: 14px 18px; display: flex; align-items: center; gap: 14px; z-index: 800; box-shadow: 0 4px 24px rgba(34,197,94,0.2); animation: slideIn 0.4s ease; max-width: 300px; }
.achievement-icon { font-size: 28px; }
.achievement-title { font-size: 14px; font-weight: 700; color: var(--green); }
.achievement-desc  { font-size: 12px; color: var(--text2); margin-top: 2px; }
@keyframes slideIn { from { transform: translateX(120%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* CHAT WIDGET */
.chat-bubble { position: fixed; bottom: 24px; right: 24px; width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(135deg, var(--btg), var(--pan)); display: flex; align-items: center; justify-content: center; font-size: 24px; cursor: pointer; box-shadow: 0 4px 20px rgba(59,130,246,0.4); z-index: 700; transition: transform 0.2s; user-select: none; }
.chat-bubble:hover { transform: scale(1.1); }
.chat-panel { position: fixed; bottom: 88px; right: 24px; width: 380px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 8px 32px rgba(0,0,0,0.5); z-index: 700; display: flex; flex-direction: column; max-height: 580px; }
.chat-header { align-items: center; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; padding: 12px 14px; }
.chat-header-info { display: flex; flex-direction: column; }
.chat-header-title { font-size: 14px; font-weight: 700; color: var(--text); }
.chat-header-sub { font-size: 11px; color: var(--text3); margin-top: 1px; }
.chat-close-btn { background: none; border: 1px solid var(--border); border-radius: 50%; color: var(--text2); cursor: pointer; font-size: 12px; height: 26px; width: 26px; display: flex; align-items: center; justify-content: center; }
.chat-close-btn:hover { border-color: var(--red); color: var(--red); }
.chat-messages { display: flex; flex-direction: column; flex: 1; gap: 8px; overflow-y: auto; padding: 12px; min-height: 180px; max-height: 260px; }
.chat-msg { max-width: 88%; padding: 9px 12px; border-radius: 12px; font-size: 13px; line-height: 1.5; word-break: break-word; }
.chat-msg.bot  { background: var(--bg3); align-self: flex-start; border-bottom-left-radius: 4px; color: var(--text); }
.chat-msg.user { background: var(--pan-dim); border: 1px solid rgba(59,130,246,0.3); color: var(--text); align-self: flex-end; border-bottom-right-radius: 4px; }
.chat-msg.loading { color: var(--text3); font-style: italic; }
.chat-confirm-area { border-top: 1px solid var(--border); max-height: 260px; overflow-y: auto; }
.chat-confirm-card { padding: 12px 14px; }
.cc-header { align-items: center; display: flex; gap: 8px; justify-content: space-between; margin-bottom: 10px; }
.cc-type-badge { background: var(--pan-dim); border: 1px solid rgba(59,130,246,0.3); border-radius: 10px; color: var(--pan); font-size: 11px; font-weight: 700; padding: 2px 8px; }
.cc-confidence { color: var(--text3); font-size: 11px; }
.cc-project-row, .cc-row { display: grid; grid-template-columns: 90px 1fr; align-items: center; gap: 6px; margin-bottom: 6px; }
.cc-label { color: var(--text3); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.cc-input { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); font-size: 12px; height: 30px; outline: none; padding: 0 8px; width: 100%; }
.cc-input:focus { border-color: var(--pan); }
textarea.cc-input { height: auto; padding: 6px 8px; resize: vertical; }
.cc-missing { color: var(--orange); font-size: 11px; margin: 4px 0; min-height: 14px; }
.cc-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 10px; border-top: 1px solid var(--border); padding-top: 10px; }
.chat-input-row { align-items: center; border-top: 1px solid var(--border); display: flex; gap: 6px; padding: 8px 10px; }
.chat-attach-btn { align-items: center; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text2); cursor: pointer; display: flex; font-size: 16px; height: 36px; justify-content: center; min-width: 36px; transition: border-color 0.15s; }
.chat-attach-btn:hover { border-color: var(--pan); color: var(--text); }
.chat-input-row input { flex: 1; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); height: 36px; padding: 0 10px; font-size: 13px; outline: none; }
.chat-input-row input:focus { border-color: var(--pan); }
.chat-send-btn { height: 36px; padding: 0 14px; font-size: 14px; border-radius: var(--radius-sm); }

/* QUIZ OPTIONS (pill buttons) */
.quiz-options { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0 8px; }
.quiz-option-btn { background: var(--bg3); border: 1.5px solid var(--border); border-radius: 20px; color: var(--text2); cursor: pointer; font-size: 13px; padding: 8px 16px; transition: all 0.15s; text-align: left; }
.quiz-option-btn:hover { border-color: var(--pan); color: var(--text); }
.quiz-option-btn.selected { background: var(--pan-dim); border-color: var(--pan); color: var(--text); font-weight: 600; animation: quiz-select-pulse 0.3s ease; }
@keyframes quiz-select-pulse { 0%{transform:scale(1)} 40%{transform:scale(1.04)} 100%{transform:scale(1)} }
.quiz-selected-note { font-size: 12px; color: var(--green); margin-top: 8px; padding: 6px 10px; background: rgba(34,197,94,0.08); border-radius: var(--radius-sm); }
.quiz-context { background: rgba(59,130,246,0.07); border-left: 3px solid var(--pan); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; color: var(--text2); font-size: 12.5px; line-height: 1.6; margin: 8px 0 12px; padding: 10px 14px; }

/* MODE TABS */
.block-mode-tabs { display: flex; gap: 8px; margin-bottom: 20px; }
.tab-active { cursor: default; opacity: 1; }

/* FILE UPLOAD */
.file-upload-area { background: var(--bg3); border: 2px dashed var(--border); border-radius: var(--radius); cursor: pointer; padding: 24px; text-align: center; transition: border-color 0.2s; }
.file-upload-area:hover { border-color: var(--pan); }

/* INSIGHTS + GAMIFICATION PANEL */
.insights-panel { background: linear-gradient(135deg, rgba(59,130,246,0.06) 0%, rgba(168,85,247,0.06) 100%); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 20px; padding: 18px 20px; }
.insights-header { align-items: flex-start; display: flex; justify-content: space-between; margin-bottom: 14px; }
.insights-title { font-size: 16px; font-weight: 700; color: var(--text); }
.insights-subtitle { color: var(--text2); font-size: 12.5px; margin-top: 3px; }
/* XP Bar */
.xp-bar-wrap { background: var(--bg3); border-radius: var(--radius-sm); margin-bottom: 14px; padding: 12px 14px; }
.xp-bar-row { align-items: center; display: flex; gap: 10px; margin-bottom: 6px; }
.xp-level-label { color: var(--text); font-size: 12.5px; font-weight: 600; flex: 1; }
.xp-total { color: var(--yellow); font-size: 12px; font-weight: 700; }
.xp-streak { color: var(--orange); font-size: 12px; font-weight: 700; }
.xp-track { background: var(--bg); border-radius: 4px; height: 6px; overflow: hidden; width: 100%; }
.xp-fill { border-radius: 4px; height: 100%; transition: width 0.5s ease; }
.xp-daily-label { color: var(--text3); font-size: 11px; flex: 1; }
.xp-daily-pct { color: var(--pan); font-size: 11px; font-weight: 600; }
/* Insight cards */
.insights-list { display: flex; flex-direction: column; gap: 8px; }
.insight-card { align-items: center; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); display: flex; gap: 12px; padding: 12px 14px; transition: border-color 0.15s; }
.insight-card:hover { border-color: var(--pan); }
.insight-icon { font-size: 22px; flex-shrink: 0; width: 28px; text-align: center; }
.insight-body { flex: 1; min-width: 0; }
.insight-title { color: var(--text); font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.insight-pts { background: rgba(34,197,94,0.12); border: 1px solid rgba(34,197,94,0.3); border-radius: 10px; color: var(--green); font-size: 11px; font-weight: 700; padding: 1px 7px; }
.insight-desc { color: var(--text2); font-size: 12px; line-height: 1.5; margin-top: 2px; }
.insight-btn { flex-shrink: 0; font-size: 12px !important; padding: 6px 12px !important; white-space: nowrap; }
.insight-empty { color: var(--green); font-size: 13px; padding: 8px 0; text-align: center; }
@media (max-width: 600px) { .insight-card { flex-wrap: wrap; } .insight-btn { width: 100%; text-align: center; } }

/* QUIZ EXAMPLE */
.quiz-example { background: rgba(34,197,94,0.06); border: 1px dashed rgba(34,197,94,0.3); border-radius: var(--radius-sm); color: var(--text2); font-size: 12px; line-height: 1.6; margin: 8px 0 4px; padding: 8px 12px; }
.quiz-example strong { color: var(--green); }
.quiz-example-label { color: var(--green); font-weight: 600; margin-right: 4px; }

/* METRICS CHAT */
.mc-container { max-width: 960px; margin: 0 auto; }
.mc-header-bar { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.mc-chat-label { font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: 0.08em; padding: 10px 16px 0; }
.mc-send-btn { padding: 0 16px; height: 40px; border-radius: 8px; flex-shrink: 0; }
.mc-panel-actions { margin-top: auto; padding-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.mc-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 16px; height: clamp(420px, calc(100vh - 220px), 600px); }
.mc-chat-col { display: flex; flex-direction: column; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.mc-messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.mc-msg { border-radius: 12px; font-size: 13px; line-height: 1.6; max-width: 85%; padding: 10px 14px; }
.mc-msg-bot { align-self: flex-start; background: var(--bg3); border-bottom-left-radius: 4px; color: var(--text); }
.mc-msg-user { align-self: flex-end; background: var(--pan-dim); border: 1px solid rgba(59,130,246,0.3); border-bottom-right-radius: 4px; color: var(--text); }
.mc-input-bar { border-top: 1px solid var(--border); display: flex; gap: 8px; padding: 10px 12px; }
.mc-attach-btn { align-items: center; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text2); cursor: pointer; display: flex; font-size: 18px; height: 40px; justify-content: center; min-width: 40px; transition: border-color 0.15s; }
.mc-attach-btn:hover { border-color: var(--pan); color: var(--text); }
.mc-text-input { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); flex: 1; font-size: 13px; outline: none; padding: 0 12px; height: 40px; }
.mc-text-input:focus { border-color: var(--pan); }
.mc-panel-col { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); display: flex; flex-direction: column; gap: 4px; overflow-y: auto; padding: 16px; }
.mc-panel-title { color: var(--text2); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; margin-bottom: 8px; text-transform: uppercase; }
.mc-field-row { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.mc-field-label { color: var(--text3); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; }
.mc-field-input { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); font-size: 13px; height: 34px; outline: none; padding: 0 10px; transition: border-color 0.15s, background 0.3s; width: 100%; }
.mc-field-input:focus { border-color: var(--pan); }
.mc-field-highlight { background: rgba(59,130,246,0.12) !important; border-color: var(--pan) !important; }
.mc-save-status { color: var(--green); font-size: 11px; margin-top: 4px; min-height: 16px; }
@media (max-width: 768px) { .mc-wrap { grid-template-columns: 1fr; height: auto; } .mc-chat-col { min-height: 340px; } }

/* MODAL OVERLAY */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center; justify-content: center; z-index: 1000; padding: 16px; backdrop-filter: blur(4px); }
.modal-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); max-height: 90vh; overflow-y: auto; padding: 24px; width: 100%; max-width: 540px; }
.modal-header { align-items: center; display: flex; justify-content: space-between; margin-bottom: 20px; }
.modal-header h3 { font-size: 18px; margin: 0; }
.modal-close { background: none; border: 1px solid var(--border); border-radius: 50%; color: var(--text2); cursor: pointer; font-size: 14px; height: 30px; width: 30px; display: flex; align-items: center; justify-content: center; }
.modal-close:hover { border-color: var(--red); color: var(--red); }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; border-top: 1px solid var(--border); padding-top: 16px; }

/* RESPONSIVE */
@media (max-width: 640px) {
  .project-grid { grid-template-columns: 1fr; }
  .dashboard-main, .project-main, .block-main, .infra-main, .new-project-main { padding: 14px; }
  .field-row { grid-template-columns: 1fr; }
  .field-label { padding-top: 0; }
  .field-status { display: none; }
  .form-row-2 { grid-template-columns: 1fr; }
  .app-header { padding: 0 12px; }
  .header-nav { display: none; }
  .project-score-big { display: none; }
  .chat-panel { width: calc(100vw - 32px); right: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .block-bar-wrap, .block-pts { display: none; }
}

/* ================================================================
   AGENTES & SKILLS
   ================================================================ */
.agents-main { padding: 24px 32px; max-width: 1400px; margin: 0 auto; }
.agents-page-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 20px; }
.agents-tabs { display: flex; gap: 8px; margin-bottom: 24px; border-bottom: 1px solid var(--border); padding-bottom: 12px; }
.agents-tab { background: none; border: none; color: var(--text3); font-size: 14px; font-weight: 500; cursor: pointer; padding: 6px 16px; border-radius: 8px; transition: all .15s; }
.agents-tab:hover { background: var(--bg2); color: var(--text1); }
.agents-tab.active { background: var(--accent); color: #fff; }
.agents-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(480px, 1fr)); gap: 16px; }
@media(max-width:900px){ .agents-list { grid-template-columns: 1fr; } }
@media(max-width:600px){ .agents-main { padding: 16px; } }

.agent-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 16px; display: flex; flex-direction: column; }
.agent-card-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; gap: 8px; }
.agent-name { font-size: 13px; font-weight: 600; color: var(--text1); font-family: monospace; }
.agent-meta { font-size: 11px; color: var(--text3); margin-top: 2px; }
.agent-card-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.agent-details { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.agent-tag { font-size: 11px; background: var(--bg3); color: var(--text2); padding: 3px 8px; border-radius: 6px; }
.agent-tag.muted { color: var(--text3); opacity: .7; }
.agent-tag code { font-size: 11px; background: none; }
.agent-skills-row { display: flex; flex-wrap: wrap; gap: 4px; width: 100%; margin-top: 4px; }
.agent-notes { font-size: 12px; color: var(--text3); width: 100%; margin-top: 6px; font-style: italic; }

.skill-chip { font-size: 10px; background: rgba(139,92,246,.15); color: #a78bfa; padding: 2px 7px; border-radius: 4px; border: 1px solid rgba(139,92,246,.25); }

.skills-flat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
@media(max-width:600px){ .skills-flat-grid { grid-template-columns: 1fr; } }
.skill-category-chip { display: inline-block; font-size: 9px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .06em; background: var(--bg3); padding: 2px 6px; border-radius: 4px; margin-bottom: 6px; }

.skills-category { margin-bottom: 24px; }
.skills-cat-label { font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.skills-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }

.skill-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 12px; }
.skill-card.deprecated { opacity: .5; }
.skill-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.skill-name { font-size: 13px; font-weight: 600; color: var(--text1); }
.skill-card-actions { display: flex; align-items: center; gap: 6px; }
.skill-status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text3); }
.skill-status-dot.active { background: var(--green); }
.skill-status-dot.draft { background: var(--yellow); }
.skill-status-dot.deprecated { background: var(--red); }
.skill-slug { margin-bottom: 4px; }
.skill-slug code { font-size: 11px; color: var(--text3); }
.skill-desc { font-size: 12px; color: var(--text2); }
.skill-notes { font-size: 11px; color: var(--text3); margin-top: 4px; font-style: italic; }

.skills-checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 6px; margin-top: 8px; }
.skill-checkbox-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text2); padding: 6px 10px; border-radius: 8px; border: 1px solid var(--border); cursor: pointer; transition: all .15s; }
.skill-checkbox-item:hover { border-color: var(--accent); }
.skill-checkbox-item.checked { border-color: var(--accent); background: rgba(139,92,246,.1); color: var(--text1); }
.skill-checkbox-item input { accent-color: var(--accent); }

.agent-section-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 12px; }
@media(max-width:640px){ .agent-section-grid { grid-template-columns: 1fr; } }
.agent-section { background: var(--bg3); border-radius: 8px; padding: 10px 12px; }
.agent-section-title { font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.agent-section-val { font-size: 12px; color: var(--text2); margin-bottom: 2px; }
.agent-section-val.muted, .agent-section-sub.muted { color: var(--text3); font-style: italic; }
.agent-section-sub { font-size: 11px; color: var(--text3); }
.agent-instructions { background: var(--bg3); border-radius: 8px; padding: 10px 12px; margin-top: 10px; }
.agent-instructions.empty { cursor: pointer; border: 1px dashed var(--border); text-align: center; padding: 10px; }
.agent-instructions-text { font-size: 12px; color: var(--text2); white-space: pre-wrap; margin-top: 6px; }
.modal-section-title { font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .06em; margin: 16px 0 8px; border-top: 1px solid var(--border); padding-top: 14px; }
.skill-prompt-details { margin-top: 8px; }
.skill-prompt-details summary { font-size: 11px; color: var(--accent); cursor: pointer; }
.skill-prompt-text { font-size: 11px; background: var(--bg3); padding: 8px; border-radius: 6px; white-space: pre-wrap; overflow-x: auto; margin-top: 6px; color: var(--text2); max-height: 200px; overflow-y: auto; }
.status-pill.active   { background: rgba(34,197,94,.15); color: #4ade80; border-color: rgba(34,197,94,.3); }
.status-pill.standby  { background: rgba(234,179,8,.15); color: #fde047; border-color: rgba(234,179,8,.3); }
.status-pill.blocked  { background: rgba(239,68,68,.15); color: #f87171; border-color: rgba(239,68,68,.3); }
.status-pill.planned  { background: var(--bg3); color: var(--text3); }

