/* SEO Text Drafts — extracted from the inline <style> blocks in
   index/edit/new.html.haml, prompt_rules.css pattern. Page-scoped:
   .drafts-index (list), .seo-drafts-chat (edit), .drafts-new (wizard). */

/* ── index page ── */
.drafts-index { max-width: 800px; margin: 2rem auto; padding: 0 1.5rem; font-family: system-ui, -apple-system, sans-serif; }
.drafts-index .drafts-index__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.drafts-index .drafts-index__header h1 { font-size: 1.5rem; font-weight: 700; }
.drafts-index .drafts-new-btn { padding: 0.6rem 1.25rem; background: #1a1a1a; color: #fff; border: none; border-radius: 8px; font-size: 0.9rem; font-weight: 600; cursor: pointer; text-decoration: none; font-family: inherit; }
.drafts-index .drafts-new-btn:hover { background: #333; }
.drafts-index .drafts-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.drafts-index .drafts-table th { text-align: left; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: #888; padding: 0.5rem 0.75rem; border-bottom: 1px solid #e5e5e5; }
.drafts-index .drafts-table td { padding: 0.75rem 0.75rem; border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
.drafts-index .drafts-table tbody tr { cursor: pointer; }
.drafts-index .drafts-table tbody tr:hover td { background: #fafafa; }
.drafts-index .brand-badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.drafts-index .brand-badge--duotone { background: #000; color: #fff; }
.drafts-index .brand-badge--ion { background: #E20B14; color: #fff; }
.drafts-index .brand-badge--sqlab { background: #F2A93C; color: #1a1a1a; }
.drafts-index .draft-link { color: #1a1a1a; text-decoration: none; font-weight: 500; }
.drafts-index .draft-link:hover { text-decoration: underline; }
.drafts-index .predecessor-text { font-size: 0.82rem; color: #666; }
.drafts-index .date-text { font-size: 0.82rem; color: #999; white-space: nowrap; }
.drafts-index .empty-state { text-align: center; padding: 4rem 2rem; color: #888; }
.drafts-index .empty-state p { margin-top: 0.5rem; font-size: 0.95rem; }
.drafts-index nav.pagy { position: static; top: auto; left: auto; right: auto; z-index: auto; background: none; box-shadow: none; border-radius: 0; margin-top: 1.25rem; display: flex; gap: 0.25rem; justify-content: center; flex-wrap: wrap; }
.drafts-index nav.pagy a,
.drafts-index nav.pagy span { display: inline-block; padding: 0.375rem 0.625rem; font-size: 0.875rem; border-radius: 6px; text-decoration: none; color: #374151; border: 1px solid #d1d5db; }
.drafts-index nav.pagy a:hover { background: #f3f4f6; }
.drafts-index nav.pagy .current { background: #465A64; color: #fff; border-color: #465A64; font-weight: 600; pointer-events: none; }
.drafts-index nav.pagy .gap,
.drafts-index nav.pagy [aria-disabled="true"] { color: #9ca3af; background: #f9fafb; }

/* ── edit page ── */
/* the page-local universal reset also reached <body> */
body:has(.seo-drafts-chat) { margin: 0; padding: 0; }
.seo-drafts-chat,
.seo-drafts-chat *,
.seo-drafts-chat *::before,
.seo-drafts-chat *::after { box-sizing: border-box; margin: 0; padding: 0; }
.seo-drafts-chat { display: flex; flex-direction: column; height: calc(100vh - 80px); font-family: system-ui, -apple-system, sans-serif; background: #f7f7f7; }
.seo-drafts-chat .drafts-header { flex-shrink: 0; padding: 0.85rem 1.5rem; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(0,0,0,0.1); background: #fff; }
.seo-drafts-chat .drafts-header__left { display: flex; align-items: center; gap: 0.75rem; }
.seo-drafts-chat .drafts-header__brand { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; }
.seo-drafts-chat .brand-badge--duotone { background: #000; color: #fff; }
.seo-drafts-chat .brand-badge--ion { background: #E20B14; color: #fff; }
.seo-drafts-chat .brand-badge--sqlab { background: #F2A93C; color: #1a1a1a; }
.seo-drafts-chat .drafts-header__product { font-weight: 600; font-size: 1rem; }
.seo-drafts-chat .drafts-header__sub { font-size: 0.72rem; color: #888; letter-spacing: 0.08em; text-transform: uppercase; }
.seo-drafts-chat .drafts-header__back { font-size: 0.82rem; color: #888; text-decoration: none; }
.seo-drafts-chat .drafts-header__back:hover { color: #333; }
.seo-drafts-chat .seo-messages { flex: 1; overflow-y: auto; padding: 1.5rem 1.5rem 1rem; display: flex; flex-direction: column; gap: 1rem; }
.seo-drafts-chat .message-row { display: flex; align-items: flex-end; gap: 0.6rem; }
.seo-drafts-chat .message-row--user { flex-direction: row-reverse; }
.seo-drafts-chat .bubble { max-width: 78%; padding: 0.85rem 1.1rem; border-radius: 16px; line-height: 1.65; font-size: 1rem; }
.seo-drafts-chat .bubble--claude { background: #fff; border: 1px solid #e5e5e5; border-bottom-left-radius: 4px; }
.seo-drafts-chat .bubble--user { background: #1a1a1a; color: #fff; border-bottom-right-radius: 4px; white-space: pre-wrap; }
.seo-drafts-chat .bubble--error { background: #fee2e2; border: 1px solid #fca5a5; color: #991b1b; }
.seo-drafts-chat .bubble-content h1,
.seo-drafts-chat .bubble-content h2,
.seo-drafts-chat .bubble-content h3 { margin: 0.8em 0 0.4em; font-weight: 600; line-height: 1.3; }
.seo-drafts-chat .bubble-content h1 { font-size: 1.1rem; }
.seo-drafts-chat .bubble-content h2 { font-size: 1rem; }
.seo-drafts-chat .bubble-content h3 { font-size: 0.95rem; }
.seo-drafts-chat .bubble-content p { margin: 0.5em 0; }
.seo-drafts-chat .bubble-content ul,
.seo-drafts-chat .bubble-content ol { margin: 0.5em 0 0.5em 1.4em; }
.seo-drafts-chat .bubble-content li { margin: 0.2em 0; }
.seo-drafts-chat .bubble-content strong { font-weight: 600; }
.seo-drafts-chat .bubble-content em { font-style: italic; }
.seo-drafts-chat .bubble-content code { background: #f0f0f0; padding: 0.1em 0.3em; border-radius: 3px; font-size: 0.9em; font-family: monospace; }
.seo-drafts-chat .bubble-content pre { background: #f0f0f0; padding: 0.75rem; border-radius: 6px; overflow-x: auto; margin: 0.5em 0; }
.seo-drafts-chat .bubble-content pre code { background: none; padding: 0; }
.seo-drafts-chat .bubble-content blockquote { border-left: 3px solid #ccc; padding-left: 0.8em; color: #666; margin: 0.5em 0; }
.seo-drafts-chat .copy-card { border: 1px solid #e0e0e0; border-radius: 10px; margin: 0.6rem 0; overflow: hidden; background: #fafafa; }
.seo-drafts-chat .copy-card-header { display: flex; justify-content: space-between; align-items: center; padding: 0.5rem 0.9rem; background: #f0f0f0; border-bottom: 1px solid #e0e0e0; gap: 1rem; }
.seo-drafts-chat .copy-card-title { font-size: 0.78rem; font-weight: 700; color: #333; letter-spacing: 0.02em; }
.seo-drafts-chat .copy-btn { display: inline-flex; align-items: center; gap: 0.3rem; padding: 0.22rem 0.65rem; font-size: 0.72rem; font-family: inherit; background: #fff; border: 1px solid #ccc; border-radius: 5px; cursor: pointer; color: #555; white-space: nowrap; flex-shrink: 0; transition: background 0.12s; }
.seo-drafts-chat .copy-btn:hover { background: #e8e8e8; }
.seo-drafts-chat .copy-btn.copied { color: #2a7a2a; border-color: #2a7a2a; background: #f0faf0; }
.seo-drafts-chat .copy-card-body { padding: 0.85rem 0.9rem; font-size: 0.95rem; line-height: 1.7; color: #222; }
.seo-drafts-chat .copy-card-body p { margin: 0.4em 0; }
.seo-drafts-chat .copy-card-body ul,
.seo-drafts-chat .copy-card-body ol { margin: 0.4em 0 0.4em 1.3em; }
.seo-drafts-chat .copy-card-body li { margin: 0.15em 0; }
.seo-drafts-chat .copy-card-body strong { font-weight: 600; }
.seo-drafts-chat .debug-warn { font-size: 0.8rem; color: #92400e; padding: 2px 8px; opacity: 0.8; }
.seo-drafts-chat .debug-thinking { margin: 0.4rem 0; border-left: 3px solid #e6a817; background: #fffbea; border-radius: 4px; font-size: 0.82rem; }
.seo-drafts-chat .debug-thinking summary { padding: 0.35rem 0.75rem; cursor: pointer; font-style: italic; color: #888; user-select: none; }
.seo-drafts-chat .debug-thinking pre { margin: 0; padding: 0.5rem 0.75rem 0.6rem; white-space: pre-wrap; word-break: break-word; color: #555; border-top: 1px solid #f0e0a0; font-family: system-ui, sans-serif; font-size: 0.82rem; line-height: 1.5; }
.seo-drafts-chat .debug-tool { margin: 0.4rem 0; padding: 0.35rem 0.75rem; background: #f0f4ff; border-left: 3px solid #4a6fa5; border-radius: 4px; font-size: 0.82rem; font-family: monospace; color: #444; }
.seo-drafts-chat .bubble-spinner { display: flex; gap: 5px; align-items: center; padding: 0.2rem 0; }
.seo-drafts-chat .bubble-spinner span { width: 7px; height: 7px; border-radius: 50%; background: #ccc; animation: bounce 1.2s infinite ease-in-out; }
.seo-drafts-chat .bubble-spinner span:nth-child(2) { animation-delay: 0.2s; }
.seo-drafts-chat .bubble-spinner span:nth-child(3) { animation-delay: 0.4s; }
.seo-drafts-chat .seo-input-bar { flex-shrink: 0; background: #fff; border-radius: 12px; box-shadow: 0 -4px 16px rgba(0,0,0,.08); margin: 0 12px 12px; padding: 0.5rem 1.5rem 1rem; }
.seo-drafts-chat .seo-status { padding: 0.3rem 0 0; font-size: 0.76rem; color: #aaa; min-height: 1.4rem; }
.seo-drafts-chat .seo-input-bar form { display: flex; gap: 0.65rem; align-items: flex-end; }
.seo-drafts-chat .seo-input-bar textarea { flex: 1; padding: 0.85rem 1rem; font-size: 1.05rem; border: 1.5px solid #d0d0d0; border-radius: 10px; resize: vertical; font-family: inherit; line-height: 1.6; outline: none; min-height: 80px; }
.seo-drafts-chat .seo-input-bar textarea:focus { border-color: #1a1a1a; }
.seo-drafts-chat .seo-input-bar input[type="submit"] { padding: 0.85rem 1.4rem; background: #1a1a1a; color: #fff; border: none; border-radius: 10px; font-size: 1rem; font-weight: 600; cursor: pointer; flex-shrink: 0; align-self: flex-end; letter-spacing: 0.02em; transition: background 0.12s; }
.seo-drafts-chat .seo-input-bar input[type="submit"]:hover:not(:disabled) { background: #333; }
.seo-drafts-chat .seo-input-bar input[type="submit"]:disabled { opacity: 0.35; cursor: default; }
.seo-drafts-chat .quick-replies { display: flex; flex-wrap: wrap; gap: 0.5rem; padding: 0.25rem 0 0.5rem; }
.seo-drafts-chat .quick-replies-label { width: 100%; font-size: 0.75rem; font-weight: 600; color: #6b7280; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 0.1rem; }
.seo-drafts-chat .quick-reply-btn { padding: 0.45rem 1rem; background: #fff; border: 1.5px solid #d1d5db; border-radius: 999px; font-size: 0.82rem; color: #374151; cursor: pointer; font-family: inherit; line-height: 1.4; transition: background 0.1s, border-color 0.1s; }
.seo-drafts-chat .quick-reply-btn:hover { background: #f3f4f6; border-color: #9ca3af; }
.seo-drafts-chat .quick-reply-btn--knowledge { border-style: dashed; color: #6b7280; }
.seo-drafts-chat .quick-reply-btn--knowledge:hover { border-color: #6b7280; color: #374151; }
/* identical to the bounce in seo_text_drafting.css — kept for self-containment */
@keyframes bounce { 0%,80%,100% { transform: translateY(0); opacity: 0.4; } 40% { transform: translateY(-5px); opacity: 1; } }

/* ── new page ── */
/* the page-local universal reset also reached <body> */
body:has(.drafts-new) { margin: 0; padding: 0; }
.drafts-new,
.drafts-new *,
.drafts-new *::before,
.drafts-new *::after { box-sizing: border-box; margin: 0; padding: 0; }
.drafts-new .drafts-wizard { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: calc(100vh - 80px); background: #141414; font-family: system-ui, -apple-system, sans-serif; padding: 2.5rem 2rem; }
.drafts-new .drafts-wizard__inner { width: 100%; max-width: 640px; display: flex; flex-direction: column; gap: 1.5rem; }
.drafts-new .wizard-step { display: none; flex-direction: column; gap: 14px; }
.drafts-new .wizard-step.is-active { display: flex; }
.drafts-new .wizard-headline { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: #666; margin-bottom: 0.25rem; }
.drafts-new .wizard-question { font-size: 1.1rem; font-weight: 600; color: #fff; line-height: 1.4; }
.drafts-new .wizard-question em { font-style: normal; color: #f0c040; }
.drafts-new .brand-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.drafts-new .brand-btn { display: flex; align-items: center; justify-content: center; padding: 1.75rem 1.25rem; min-height: 140px; border: 1.5px solid transparent; border-radius: 14px; cursor: pointer; font-family: inherit; transition: transform 0.12s, box-shadow 0.12s, border-color 0.15s; }
.drafts-new .brand-btn:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,0.35); }
.drafts-new .brand-btn--duotone { background: #000; border-color: #333; }
.drafts-new .brand-btn--duotone:hover { border-color: #555; }
.drafts-new .brand-btn--ion { background: #fff; border-color: #e8e8e8; }
.drafts-new .brand-btn--ion:hover { border-color: #E20B14; }
.drafts-new .brand-btn--sqlab { background: #fff; border-color: #e8e8e8; }
.drafts-new .brand-btn--sqlab:hover { border-color: #F2A93C; }
.drafts-new .wizard-brand-header { display: flex; align-items: center; }
.drafts-new .wbh-brand { display: inline-flex; align-items: center; padding: 7px 16px; border-radius: 8px; }
.drafts-new .wbh-brand--duotone { background: #000; color: #fff; }
.drafts-new .wbh-brand--ion { background: #fff; color: #111; }
.drafts-new .wbh-brand--sqlab { background: #fff; color: #141416; }
.drafts-new .wizard-input,
.drafts-new .wizard-textarea { width: 100%; padding: 0.85rem 1rem; font-size: 1rem; border: 1.5px solid #333; border-radius: 10px; background: #1e1e1e; color: #fff; font-family: inherit; line-height: 1.6; outline: none; }
.drafts-new .wizard-input:focus,
.drafts-new .wizard-textarea:focus { border-color: #666; }
.drafts-new .wizard-textarea { resize: vertical; }
.drafts-new .wizard-btn { align-self: flex-start; padding: 0.75rem 1.75rem; background: #fff; color: #1a1a1a; border: none; border-radius: 10px; font-size: 1rem; font-weight: 600; cursor: pointer; font-family: inherit; transition: background 0.12s; }
.drafts-new .wizard-btn:hover:not(:disabled) { background: #e8e8e8; }
.drafts-new .wizard-btn:disabled { opacity: 0.35; cursor: default; }
.drafts-new .wizard-btn--generate { padding: 0.85rem 2rem; background: #4ade80; color: #052e16; }
.drafts-new .wizard-btn--generate:hover:not(:disabled) { background: #22c55e; }
.drafts-new .wizard-back { background: none; border: none; color: #666; cursor: pointer; font-size: 0.875rem; font-family: inherit; padding: 0; align-self: flex-start; transition: color 0.12s; }
.drafts-new .wizard-back:hover { color: #aaa; }
.drafts-new .wizard-skip { background: none; border: 1.5px solid #444; color: #888; cursor: pointer; font-size: 0.875rem; font-family: inherit; padding: 0.5rem 1.25rem; border-radius: 8px; transition: border-color 0.12s, color 0.12s; }
.drafts-new .wizard-skip:hover { border-color: #888; color: #ddd; }
.drafts-new .hint-text { font-size: 0.8rem; color: #666; }
.drafts-new .autocomplete-wrap { position: relative; }
.drafts-new .autocomplete-list { position: absolute; top: 100%; left: 0; right: 0; background: #2a2a2a; border: 1px solid #444; border-radius: 8px; z-index: 100; list-style: none; margin: 4px 0 0; padding: 4px 0; max-height: 240px; overflow-y: auto; }
.drafts-new .autocomplete-list li { padding: 8px 14px; cursor: pointer; font-size: 0.9rem; color: #ddd; line-height: 1.4; }
.drafts-new .autocomplete-list li:hover,
.drafts-new .autocomplete-list li.active { background: #3a3a3a; color: #fff; }
.drafts-new .predecessor-badge { border: 1.5px solid #444; border-radius: 10px; padding: 12px 14px; background: #1e1e1e; }
.drafts-new .predecessor-badge__header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.drafts-new .predecessor-badge__header strong { color: #fff; font-size: 0.95rem; }
.drafts-new .brand-label { font-size: 0.72rem; color: #aaa; background: #2e2e2e; border-radius: 4px; padding: 2px 7px; }
.drafts-new .muted { font-size: 0.82rem; color: #666; }
.drafts-new .clear-btn { margin-left: auto; background: none; border: none; color: #666; cursor: pointer; font-size: 0.9rem; padding: 0 4px; }
.drafts-new .clear-btn:hover { color: #aaa; }
.drafts-new .predecessor-badge details summary { font-size: 0.8rem; color: #888; cursor: pointer; margin-top: 8px; user-select: none; }
.drafts-new .predecessor-badge details p { font-size: 0.82rem; color: #aaa; margin-top: 6px; line-height: 1.55; max-height: 160px; overflow-y: auto; }
.drafts-new .style-level__label { font-size: 0.875rem; color: #aaa; margin-bottom: 8px; }
.drafts-new .style-level__track { display: flex; border: 1.5px solid #444; border-radius: 10px; overflow: hidden; }
.drafts-new .style-level__btn { flex: 1; padding: 0.5rem 0.25rem; font-size: 0.72rem; background: #1e1e1e; color: #aaa; border: none; border-right: 1px solid #444; cursor: pointer; font-family: inherit; transition: background 0.12s, color 0.12s; text-align: center; line-height: 1.3; }
.drafts-new .style-level__btn:last-child { border-right: none; }
.drafts-new .style-level__btn:hover { background: #2a2a2a; color: #ddd; }
.drafts-new .style-level__btn--active { background: #fff; color: #1a1a1a; font-weight: 600; }
.drafts-new .style-level__desc { font-size: 0.8rem; color: #666; margin-top: 8px; min-height: 2.4em; }
.drafts-new .brand-error { color: #f87171; font-size: 0.875rem; }
.drafts-new .hidden { display: none !important; }
