:root { --fc-surface: #0f2219; --fc-surface-2: #103220; --fc-text: #e8f9f0; --fc-muted: #7dc9a5; --fc-accent: #2dd282; --fc-accent-soft: rgba(45, 210, 130, 0.18); --fc-border: rgba(125, 201, 165, 0.45); --fc-border-strong: rgba(45, 210, 130, 0.65); --fc-overlay: rgba(4, 18, 12, 0.72); } .feature-section { margin-top: 12px; display: grid; gap: 6px; } .feature-section-header { display: flex; flex-direction: column; gap: 2px; } .feature-section-header h3 { margin: 0; font-size: 1rem; } .feature-pill-group { display: flex; flex-wrap: wrap; gap: 8px; padding: 6px 0; min-height: 40px; } .feature-pill { display: inline-flex; align-items: center; gap: 4px; border-radius: 999px; border: 1px solid var(--fc-border); background: var(--fc-accent-soft); color: inherit; box-shadow: 0 1px 2px rgba(0, 0, 0, 0.07); transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease; } .feature-pill--selected { background: color-mix(in srgb, var(--fc-accent), transparent 68%); border-color: var(--fc-border-strong); box-shadow: 0 2px 6px rgba(21, 94, 50, 0.22); } .feature-pill-toggle { appearance: none; border: none; background: transparent; color: inherit; font: inherit; padding: 6px 12px; border-radius: 999px; cursor: pointer; flex: 1 1 auto; text-align: left; } .feature-pill-toggle:focus-visible, .feature-pill-info:focus-visible { outline: 2px solid color-mix(in srgb, var(--fc-accent), white 25%); outline-offset: 2px; } .feature-pill-info { appearance: none; border: none; background: transparent; color: var(--fc-muted); width: 28px; height: 28px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; margin-right: 4px; } .feature-pill-info:hover { color: var(--fc-text); background: rgba(45, 210, 130, 0.16); } .feature-pill-info span { display: inline-block; font-size: 0.9rem; font-weight: 700; } /* Modal styles */ .fc-overlay { position: fixed; inset: 0; display: grid; place-items: center; padding: clamp(12px, 2vw, 24px); background: var(--fc-overlay); z-index: 9999; } .fc-dialog { width: min(520px, 100%); max-height: 90dvh; overflow: auto; border-radius: 12px; background: linear-gradient(180deg, var(--fc-surface), var(--fc-surface-2)); color: var(--fc-text); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.45); border: 1px solid rgba(125, 201, 165, 0.35); } .fc-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 20px; border-bottom: 1px solid rgba(125, 201, 165, 0.25); position: sticky; top: 0; backdrop-filter: blur(6px); background: linear-gradient(to bottom, color-mix(in srgb, var(--fc-surface), transparent 30%), color-mix(in srgb, var(--fc-surface-2), transparent 35%)), conic-gradient(from 0.35turn at 12% -30%, color-mix(in srgb, var(--fc-accent), transparent 80%), transparent 40%); z-index: 1; } .fc-titlewrap { display: flex; align-items: center; gap: 10px; } .fc-title { margin: 0; font-size: 1.1rem; font-weight: 700; } .fc-tag { display: inline-flex; align-items: center; justify-content: center; padding: 4px 10px; border-radius: 999px; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: #06361d; background: color-mix(in srgb, var(--fc-accent), white 38%); border: 1px solid color-mix(in srgb, var(--fc-accent), black 10%); } .fc-close { appearance: none; border: 1px solid transparent; background: transparent; color: var(--fc-muted); font-size: 1.6rem; line-height: 1; border-radius: 8px; padding: 4px 8px; cursor: pointer; } .fc-close:hover { color: var(--fc-text); border-color: rgba(125, 201, 165, 0.4); background: rgba(45, 210, 130, 0.16); } .fc-body { padding: 20px; display: grid; gap: 18px; } .fc-desc { margin: 0; color: var(--fc-text); font-size: 0.95rem; line-height: 1.4; } .fc-details { display: grid; grid-template-columns: max-content 1fr; gap: 6px 12px; margin: 0; } .fc-details dt { font-weight: 600; color: var(--fc-muted); } .fc-details dd { margin: 0; font-weight: 500; }