/* /formacion/curso-intro-okr/curso-okr.css — styles for the OKR course pages */

.okr-wrap { max-width: 880px; margin: 0 auto; padding: clamp(28px, 4vw, 56px) 24px 80px; color: var(--ink, #0a0e1a); }

.okr-crumb { font-family: var(--font-mono, monospace); font-size: 13px; color: var(--ink-3, #5a6072); margin: 0 0 24px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.okr-crumb a { color: inherit; text-decoration: none; }
.okr-crumb a:hover { color: var(--accent, #2f5d3a); }
.okr-crumb .sep { opacity: 0.45; }
.okr-crumb .here { color: var(--ink, #0a0e1a); }

.okr-eyebrow { font-family: var(--font-mono, monospace); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-3, #5a6072); margin: 0 0 14px; }

.okr-progress { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 28px; list-style: none; padding: 0; }
.okr-progress li { display: flex; }
.okr-progress a, .okr-progress span { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; font-family: var(--font-mono, monospace); font-size: 12px; font-weight: 600; text-decoration: none; border: 1.5px solid var(--line, #e6e2d8); background: #fff; color: var(--ink-3, #5a6072); transition: all 0.15s ease; }
.okr-progress a:hover { border-color: var(--accent, #2f5d3a); color: var(--accent, #2f5d3a); }
.okr-progress .is-current a, .okr-progress .is-current span { background: var(--accent, #2f5d3a); color: #fff; border-color: var(--accent, #2f5d3a); }
.okr-progress .is-visited a, .okr-progress .is-visited span { background: rgba(47, 93, 58, 0.12); color: var(--accent, #2f5d3a); border-color: rgba(47, 93, 58, 0.35); }

.okr-title { font-size: clamp(28px, 4vw, 42px); font-weight: 600; line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 24px; }

.okr-prose h2 { font-size: clamp(22px, 2.6vw, 28px); font-weight: 600; letter-spacing: -0.01em; margin: 44px 0 14px; line-height: 1.25; }
.okr-prose h3 { font-size: clamp(18px, 2vw, 21px); font-weight: 600; margin: 32px 0 12px; line-height: 1.3; }
.okr-prose h3 strong { font-weight: 600; }
.okr-prose p, .okr-prose li { font-size: 17px; line-height: 1.65; color: var(--ink-2, #2a2f3d); }
.okr-prose p { margin: 0 0 16px; }
.okr-prose ul, .okr-prose ol { margin: 0 0 18px; padding-left: 22px; }
.okr-prose li { margin-bottom: 6px; }
.okr-prose strong { color: var(--ink, #0a0e1a); }
.okr-prose a { color: var(--accent, #2f5d3a); }
.okr-prose figure { margin: 28px 0; text-align: center; }
.okr-prose figure img { max-width: 100%; height: auto; border-radius: 10px; box-shadow: 0 6px 20px -10px rgba(0,0,0,0.18); }

.okr-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 56px 0 0; padding-top: 32px; border-top: 1px solid var(--line, #e6e2d8); }
.okr-nav a { display: flex; flex-direction: column; gap: 4px; padding: 16px 18px; border: 1px solid var(--line, #e6e2d8); border-radius: 12px; text-decoration: none; color: var(--ink, #0a0e1a); transition: border-color 0.15s ease, transform 0.15s ease; background: #fff; }
.okr-nav a:hover { border-color: var(--accent, #2f5d3a); transform: translateY(-2px); }
.okr-nav .lbl { font-family: var(--font-mono, monospace); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3, #5a6072); }
.okr-nav .ttl { font-size: 15px; font-weight: 600; line-height: 1.3; }
.okr-nav .next { text-align: right; }
.okr-nav .next .ttl::after { content: ' →'; color: var(--accent, #2f5d3a); }
.okr-nav .prev .ttl::before { content: '← '; color: var(--accent, #2f5d3a); }
.okr-nav .empty { border-style: dashed; opacity: 0.4; pointer-events: none; }
@media (max-width: 600px) { .okr-nav { grid-template-columns: 1fr; } .okr-nav .next { text-align: left; } }

.okr-hero { text-align: center; margin: 0 0 48px; }
.okr-hero h1 { font-size: clamp(36px, 5vw, 56px); font-weight: 600; line-height: 1.05; letter-spacing: -0.025em; margin: 12px 0 16px; }
.okr-hero p.lede { font-size: clamp(17px, 2vw, 19px); line-height: 1.55; color: var(--ink-2, #2a2f3d); max-width: 640px; margin: 0 auto 8px; }
.okr-hero .meta { font-family: var(--font-mono, monospace); font-size: 13px; color: var(--ink-3, #5a6072); margin: 16px 0 0; }

.okr-toc { margin: 0 0 56px; border: 1px solid var(--line, #e6e2d8); border-radius: 16px; background: #fff; overflow: hidden; }
.okr-toc-header { padding: 20px 24px; background: var(--bg-soft, #f7f4ed); border-bottom: 1px solid var(--line, #e6e2d8); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.okr-toc-header .ttl { font-family: var(--font-mono, monospace); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink, #0a0e1a); }
.okr-toc-header .progress-text { font-size: 13px; color: var(--ink-3, #5a6072); }
.okr-toc ol { list-style: none; margin: 0; padding: 0; }
.okr-toc li { border-bottom: 1px solid var(--line, #e6e2d8); }
.okr-toc li:last-child { border-bottom: none; }
.okr-toc a { display: flex; align-items: center; gap: 16px; padding: 16px 20px; text-decoration: none; color: var(--ink, #0a0e1a); transition: background 0.15s ease; }
.okr-toc a:hover { background: var(--bg-soft, #f7f4ed); }
.okr-toc .num { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; background: var(--bg-soft, #f7f4ed); border: 1.5px solid var(--line, #e6e2d8); font-family: var(--font-mono, monospace); font-size: 13px; font-weight: 600; color: var(--ink-3, #5a6072); flex-shrink: 0; }
.okr-toc li.is-visited .num { background: var(--accent, #2f5d3a); color: #fff; border-color: var(--accent, #2f5d3a); }
.okr-toc li.is-visited .num::before { content: '✓'; font-size: 14px; }
.okr-toc li.is-visited .num .digit { display: none; }
.okr-toc .ttl { font-size: 16px; font-weight: 500; line-height: 1.3; flex: 1; }
.okr-toc .arrow { color: var(--ink-3, #5a6072); font-size: 18px; }

.okr-cta { margin: 56px 0 0; padding: 32px; background: var(--ink, #0a0e1a); color: #fff; border-radius: 16px; text-align: center; }
.okr-cta h3 { font-size: clamp(22px, 3vw, 28px); font-weight: 600; margin: 0 0 12px; letter-spacing: -0.01em; }
.okr-cta p { font-size: 16px; line-height: 1.55; color: rgba(255,255,255,0.85); max-width: 520px; margin: 0 auto 20px; }
.okr-cta a.btn { display: inline-flex; align-items: center; gap: 8px; background: #fff; color: var(--ink, #0a0e1a); padding: 12px 22px; border-radius: 999px; font-weight: 600; font-size: 15px; text-decoration: none; transition: transform 0.15s ease; }
.okr-cta a.btn:hover { transform: translateY(-2px); }

.okr-feedback { margin: 56px 0 0; padding: 32px; background: var(--bg-soft, #f7f4ed); border: 1px solid var(--line, #e6e2d8); border-radius: 16px; }
.okr-feedback .intro { margin: 0 0 24px; }
.okr-feedback .intro h3 { font-size: clamp(20px, 2.4vw, 24px); font-weight: 600; margin: 0 0 8px; }
.okr-feedback .intro p { font-size: 15px; line-height: 1.55; color: var(--ink-2, #2a2f3d); margin: 0; }
.okr-feedback fieldset { border: none; padding: 0; margin: 0 0 22px; }
.okr-feedback legend { font-size: 15px; font-weight: 600; margin: 0 0 12px; color: var(--ink, #0a0e1a); }
.okr-feedback .opts { display: flex; flex-direction: column; gap: 6px; }
.okr-feedback .opt { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: #fff; border: 1px solid var(--line, #e6e2d8); border-radius: 10px; font-size: 14px; cursor: pointer; transition: border-color 0.15s ease; }
.okr-feedback .opt:hover { border-color: var(--accent, #2f5d3a); }
.okr-feedback .opt input { margin: 0; accent-color: var(--accent, #2f5d3a); }
.okr-feedback .opt input:checked + span { color: var(--accent, #2f5d3a); font-weight: 500; }
.okr-feedback button[type=submit] { background: var(--accent, #2f5d3a); color: #fff; border: none; padding: 12px 24px; border-radius: 999px; font-family: inherit; font-size: 15px; font-weight: 600; cursor: pointer; }
.okr-feedback button[type=submit]:disabled { opacity: 0.5; cursor: not-allowed; }
.okr-feedback .ok, .okr-feedback .err { margin-top: 14px; font-size: 14px; font-weight: 500; }
.okr-feedback .ok { color: var(--accent, #2f5d3a); }
.okr-feedback .err { color: #c0392b; }
