/* Social Preview Generator — platform mockups + report shell. */

.sp-results{max-width:1100px;margin:0 auto;padding:24px;display:grid;gap:24px}
.sp-results[hidden]{display:none}

.sp-overview{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;padding:20px 24px}
.sp-target{display:flex;flex-direction:column;gap:8px;min-width:0}
.sp-target-url{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.95rem;color:var(--text-primary);word-break:break-all}
.sp-target-summary{display:flex;flex-wrap:wrap;gap:8px}

.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}
.pill-ok{color:#22c55e;border-color:rgba(34,197,94,.4)}
.pill-warn{color:#f59e0b;border-color:rgba(245,158,11,.4)}
.pill-fail{color:#ef4444;border-color:rgba(239,68,68,.4)}
.pill-info{color:#06b6d4;border-color:rgba(6,182,212,.4)}

.sp-actions{display:flex;gap:8px}
.sp-btn{appearance:none;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:.85rem}
.sp-btn:hover{border-color:var(--accent-cyan)}

.sp-tabs{display:flex;flex-wrap:wrap;gap:6px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:6px}
.sp-tab{appearance:none;border:none;background:transparent;color:var(--text-secondary);font-weight:600;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;display:inline-flex;align-items:center;gap:8px}
.sp-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}
.sp-tab[aria-selected="true"]{background:var(--bg-tertiary);color:var(--text-primary);box-shadow:inset 0 -2px 0 var(--accent-cyan)}
.sp-tab-warn{color:#f59e0b}

.sp-panels{display:block}
.sp-panel{display:none;padding:24px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px}
.sp-panel.active{display:grid;gap:18px}
.sp-panel-warnings{display:flex;flex-direction:column;gap:6px}
.sp-warn{display:flex;gap:8px;align-items:flex-start;padding:8px 12px;border-radius:8px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.25);color:#fbbf24;font-size:.85rem;line-height:1.5}
.sp-warn::before{content:"!";display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:#f59e0b;color:#000;font-weight:700;font-size:.75rem;flex-shrink:0;margin-top:1px}

.sp-sources{font-size:.78rem;color:var(--text-secondary);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;display:flex;flex-wrap:wrap;gap:10px}
.sp-sources span{padding:2px 8px;border-radius:4px;background:var(--bg-secondary)}

.sp-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;padding:20px}
.sp-card h2{margin:0 0 16px;font-size:1.2rem;color:var(--text-primary)}

.sp-image-grid{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.sp-image-thumb{width:200px;height:200px;border-radius:10px;background:var(--bg-tertiary);display:grid;place-items:center;overflow:hidden;border:1px solid var(--border-color)}
.sp-image-thumb img{max-width:100%;max-height:100%;display:block}
.sp-image-thumb-empty{color:var(--text-secondary);font-size:.85rem;text-align:center;padding:12px}
.sp-image-meta{display:grid;grid-template-columns:max-content 1fr;gap:6px 16px;font-size:.88rem}
.sp-image-meta dt{color:var(--text-secondary)}
.sp-image-meta dd{margin:0;color:var(--text-primary);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;word-break:break-all}

.sp-raw-grid{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;font-size:.85rem}
.sp-raw-grid dt{color:var(--text-secondary);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.sp-raw-grid dd{margin:0;color:var(--text-primary);word-break:break-word}
.sp-raw-empty{color:var(--text-secondary);font-style:italic}

/* ============================================================
   Platform mockups — approximate, not pixel-perfect.
   ============================================================ */

/* Google SERP card */
.mock-google{background:#fff;color:#202124;font-family:Arial,sans-serif;padding:20px 24px;border-radius:8px;max-width:600px}
[data-theme="light"] .mock-google{box-shadow:0 1px 6px rgba(32,33,36,.08)}
.mock-google-url{display:flex;align-items:center;gap:8px;font-size:14px;color:#202124;margin-bottom:4px}
.mock-google-favicon{width:18px;height:18px;border-radius:50%;background:#dadce0;display:inline-block;flex-shrink:0}
.mock-google-domain{font-size:14px;line-height:1.3;color:#202124}
.mock-google-path{font-size:12px;color:#5f6368;margin-top:2px}
.mock-google h3{color:#1a0dab;font-size:20px;line-height:1.3;font-weight:400;margin:6px 0 4px;cursor:pointer}
.mock-google h3:hover{text-decoration:underline}
.mock-google-desc{color:#4d5156;font-size:14px;line-height:1.58}

/* Twitter / X large image card */
.mock-twitter{background:#000;color:#e7e9ea;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;border:1px solid #2f3336;border-radius:16px;overflow:hidden;max-width:520px}
.mock-twitter-img{width:100%;aspect-ratio:1.91/1;background:#16181c;display:grid;place-items:center;color:#71767b;overflow:hidden}
.mock-twitter-img img{width:100%;height:100%;object-fit:cover;display:block}
.mock-twitter-img-empty{font-size:13px}
.mock-twitter-summary .mock-twitter-img{aspect-ratio:1/1;width:130px;float:left}
.mock-twitter-body{padding:12px 16px}
.mock-twitter-domain{font-size:13px;color:#71767b;margin-bottom:2px}
.mock-twitter h3{margin:0;font-size:15px;line-height:1.3;color:#e7e9ea;font-weight:400}
.mock-twitter-desc{font-size:13px;color:#71767b;margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Facebook card */
.mock-facebook{background:#f0f2f5;color:#050505;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;border-radius:8px;overflow:hidden;max-width:520px;border:1px solid #ced0d4}
.mock-facebook-img{width:100%;aspect-ratio:1.91/1;background:#dddfe2;display:grid;place-items:center;color:#65676b;overflow:hidden}
.mock-facebook-img img{width:100%;height:100%;object-fit:cover;display:block}
.mock-facebook-body{padding:10px 12px;background:#f0f2f5}
.mock-facebook-domain{font-size:12px;color:#65676b;text-transform:uppercase;line-height:1.3}
.mock-facebook h3{margin:2px 0 0;font-size:17px;line-height:1.25;color:#050505;font-weight:600}
.mock-facebook-desc{font-size:14px;color:#65676b;margin-top:2px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* LinkedIn card */
.mock-linkedin{background:#fff;color:rgba(0,0,0,.9);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;border:1px solid rgba(0,0,0,.15);border-radius:4px;overflow:hidden;max-width:560px}
.mock-linkedin-img{width:100%;aspect-ratio:1.91/1;background:#eef3f8;display:grid;place-items:center;color:rgba(0,0,0,.6);overflow:hidden}
.mock-linkedin-img img{width:100%;height:100%;object-fit:cover;display:block}
.mock-linkedin-body{padding:10px 12px;background:#eef3f8}
.mock-linkedin h3{margin:0;font-size:16px;line-height:1.25;color:rgba(0,0,0,.9);font-weight:600}
.mock-linkedin-desc{font-size:14px;color:rgba(0,0,0,.6);margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mock-linkedin-domain{font-size:12px;color:rgba(0,0,0,.6);margin-top:6px}

/* Slack unfurl */
.mock-slack{background:#fff;color:#1d1c1d;font-family:Slack-Lato,"Helvetica Neue",Helvetica,Arial,sans-serif;border-left:4px solid #ddd;padding:8px 12px;max-width:520px;border-radius:0 8px 8px 0}
.mock-slack-site{font-size:13px;color:#616061;margin-bottom:2px}
.mock-slack h3{margin:0;font-size:15px;font-weight:700;color:#1264a3;line-height:1.4}
.mock-slack-desc{font-size:14px;color:#1d1c1d;margin-top:4px;line-height:1.4;white-space:pre-wrap}
.mock-slack-img{margin-top:8px;max-width:360px;aspect-ratio:1.91/1;background:#f4f4f4;border-radius:6px;display:grid;place-items:center;color:#616061;overflow:hidden}
.mock-slack-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:6px}

/* Discord embed */
.mock-discord{background:#2b2d31;color:#dbdee1;font-family:gg sans,"Noto Sans",sans-serif;border-left:4px solid #5865f2;padding:8px 16px 16px;border-radius:4px;max-width:520px}
.mock-discord-site{font-size:12px;color:#b5bac1;margin-top:8px}
.mock-discord h3{margin:2px 0 0;font-size:16px;font-weight:600;color:#00a8fc;line-height:1.375;cursor:pointer}
.mock-discord h3:hover{text-decoration:underline}
.mock-discord-desc{font-size:14px;color:#dbdee1;margin-top:8px;line-height:1.375;white-space:pre-wrap}
.mock-discord-img{margin-top:16px;max-width:400px;aspect-ratio:1.91/1;background:#1e1f22;border-radius:4px;display:grid;place-items:center;color:#80848e;overflow:hidden}
.mock-discord-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:4px}

.mock-empty{font-size:13px;font-style:italic;opacity:.7;padding:0 12px;text-align:center}

/* Progress (matches sc.js styling) */
.sp-progress{max-width:640px;margin:18px auto 0;padding:18px 22px;border-radius:12px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08)}
.sp-progress-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.sp-progress-step{display:flex;align-items:center;gap:12px;font-size:14px;line-height:1.4;color:rgba(255,255,255,0.55);transition:color .25s ease}
.sp-progress-mark{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,0.25);flex:0 0 auto;position:relative;transition:all .25s ease}
.sp-progress-step[data-state="active"]{color:rgba(255,255,255,0.95)}
.sp-progress-step[data-state="active"] .sp-progress-mark{border-color:#6aa9ff;animation:spPulse 1.1s ease-out infinite}
.sp-progress-step[data-state="done"]{color:rgba(255,255,255,0.75)}
.sp-progress-step[data-state="done"] .sp-progress-mark{border-color:#3ecf8e;background:#3ecf8e}
.sp-progress-step[data-state="done"] .sp-progress-mark::after{content:"";position:absolute;left:3px;top:0;width:4px;height:8px;border:solid #0b0f1a;border-width:0 2px 2px 0;transform:rotate(45deg)}
@keyframes spPulse{0%{box-shadow:0 0 0 0 rgba(106,169,255,.55)}100%{box-shadow:0 0 0 8px rgba(106,169,255,0)}}

.sp-panel{opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease}
.sp-panel.sp-panel-shown{opacity:1;transform:none}

.content-section{padding:80px 24px;background:var(--bg-secondary)}
.content-section.alt{background:var(--bg-primary)}
.content-block{max-width:880px;margin:0 auto;color:var(--text-secondary);line-height:1.8;font-size:1.05rem}
.content-block h3{color:var(--text-primary);font-size:1.4rem;margin:32px 0 12px;font-weight:600}
.content-block p{margin:0 0 18px}
.content-block ul{padding-left:24px;margin:0 0 20px}
.content-block li{margin-bottom:10px}
.content-block strong{color:var(--text-primary)}
.faq-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;margin-bottom:12px;overflow:hidden}
.faq-item[open]{border-color:var(--accent-cyan)}
.faq-item summary{padding:18px 22px;cursor:pointer;color:var(--text-primary);font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;color:var(--accent-cyan);transition:transform .2s;flex-shrink:0}
.faq-item[open] summary::after{content:"−"}
.faq-item .faq-body{padding:0 22px 20px;color:var(--text-secondary);line-height:1.7}

@media (max-width:760px){
	.sp-overview{grid-template-columns:1fr}
	.sp-actions{justify-content:flex-end}
	.sp-image-grid{grid-template-columns:1fr}
	.sp-image-thumb{width:100%;height:auto;aspect-ratio:1/1;max-width:280px}
}
