/* /var/www/seoapp/static/css/from_serp_to_sale.css */

/* ── Layout ── */
.fts-wrap{max-width:1100px;margin:0 auto;padding:24px 18px}
.fts-scene{margin:18px 0;border:1px solid rgba(255,255,255,.10);border-radius:16px;overflow:hidden}
.fts-scene--public{background:linear-gradient(135deg, rgba(0,255,255,.08), rgba(255,0,221,.06))}
.fts-scene--tool{background:rgba(255,255,255,.03)}

/* ── Shared header (Launch Pad + Tool) ── */
.fts-tool-header{margin-bottom:12px}
.fts-launch-title{margin:0;font-weight:700;font-size:18px;line-height:1.15;letter-spacing:.2px;display:inline-flex;align-items:center;gap:10px}
.fts-launch-title .tool-icon{font-size:18px;line-height:1}
.fts-launch-subtitle{margin:4px 0 0 0;color:rgba(255,255,255,.70);font-size:12px;max-width:860px}

/* ── Launchpad ── */
.fts-launch{margin-top:6px}
.fts-launch-wrap{max-width:1040px;margin:0 auto}
.fts-launch-panel{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:18px}
.fts-launch-h2{margin:0 0 .6rem 0;font-weight:700;font-size:16px;line-height:1.25;letter-spacing:.2px;color:rgba(255,255,255,.92)}
.fts-launch-copy{margin-top:16px;color:rgba(255,255,255,.86);font-size:13px;line-height:1.55}
.fts-launch-copy p{margin:10px 0}
.fts-launch-list{margin:10px 0 0 0;padding-left:18px}
.fts-launch-list li{margin:8px 0}
.fts-launch-cta{display:flex;justify-content:flex-end;margin-top:12px}
.fts-btn.fts-launch-open-btn{background:#3b82f6;border-color:#3b82f6;color:#fff;font-weight:600;letter-spacing:.2px;padding:10px 14px}
.fts-btn.fts-launch-open-btn:hover{background:#2563eb;border-color:#2563eb;color:#fff;text-decoration:none;opacity:1}

/* ── Hero (legacy, kept for backwards compat) ── */
.fts-hero{padding:22px}
.fts-hero__kicker{opacity:.75;font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.fts-hero__title{margin:10px 0 6px;font-size:34px;line-height:1.1}
.fts-hero__sub{opacity:.86;max-width:70ch}
.fts-hero__meta{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}

/* ── Pills ── */
.fts-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-size:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}
.fts-pill--admin{background:rgba(255,0,221,.10);border-color:rgba(255,0,221,.25)}
.fts-pill--ok{background:rgba(0,255,128,.10);border-color:rgba(0,255,128,.25)}
.fts-pill--warn{background:rgba(255,200,0,.10);border-color:rgba(255,200,0,.25)}

/* ── Public card ── */
.fts-public-card{padding:18px 22px;border-top:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.15)}
.fts-h2{margin:0 0 10px;font-size:18px}
.fts-list{margin:0;padding-left:18px;opacity:.9}

/* ── Tool / grid ── */
.fts-tool{padding:18px 22px}
.fts-tool__top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.fts-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.fts-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:inherit;text-decoration:none;cursor:pointer;font-size:13px;transition:opacity .15s}
.fts-btn:disabled{opacity:.5;cursor:not-allowed}
.fts-btn--ghost{background:transparent}
.fts-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:14px;margin-top:14px}
@media (max-width:900px){.fts-grid{grid-template-columns:1fr}}
.fts-panel{border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:14px;background:rgba(0,0,0,.18)}
.fts-panel__title{font-weight:700;margin-bottom:4px}
.fts-panel__sub{opacity:.75;font-size:13px;margin-bottom:12px}
.fts-empty{opacity:.75;padding:10px;border:1px dashed rgba(255,255,255,.18);border-radius:12px}

/* ── KV status rows ── */
.fts-kv__row{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.fts-kv__row:last-child{border-bottom:0}
.fts-kv__k{opacity:.75}

/* ── Alerts ── */
.fts-alert{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,80,80,.35);background:rgba(255,80,80,.10)}
.fts-alert--danger{border-color:rgba(255,80,80,.35);background:rgba(255,80,80,.10)}

/* ── Locked state ── */
.fts-tool-locked{padding:18px 22px}
.fts-lock{border:1px dashed rgba(255,255,255,.18);border-radius:14px;padding:16px;background:rgba(0,0,0,.18)}
.fts-lock__title{font-weight:800;margin-bottom:4px}
.fts-lock__sub{opacity:.8;margin-bottom:10px}

/* ── Selection card ── */
.fts-selectcard{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;background:rgba(0,0,0,.10);margin-bottom:14px}
.fts-selectcard__head{margin-bottom:12px}
.fts-selectcard__title{font-weight:700;font-size:15px}
.fts-selectcard__sub{opacity:.7;font-size:12px;margin-top:2px}

/* ── Form elements ── */
.fts-form__row{margin-bottom:12px}
.fts-form__row--actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:0}
.fts-label{display:block;font-size:13px;font-weight:600;margin-bottom:4px}
.fts-select,.fts-input{display:block;width:100%;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25);color:inherit;font-size:13px;font-family:inherit}
.fts-select:focus,.fts-input:focus{outline:none;border-color:rgba(0,255,255,.4)}
.fts-help{font-size:11px;opacity:.6;margin-top:3px}
.fts-help--warn{color:#ffc800;opacity:.9}
.fts-inline{display:flex;gap:10px}
.fts-field{flex:1}
.fts-field__lbl{font-size:11px;opacity:.7;margin-bottom:2px}

/* ── Status messages ── */
.fts-msg{padding:8px 0;font-size:13px;min-height:1em}
.fts-msg--info{color:rgba(0,200,255,.9)}
.fts-msg--ok{color:rgba(0,255,128,.9)}
.fts-msg--warn{color:rgba(255,200,0,.9)}

/* ── Insight cards ── */
.fts-cards{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.fts-card{border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 14px;background:rgba(0,0,0,.12)}
.fts-card--info{border-left:3px solid rgba(0,180,255,.5)}
.fts-card--good{border-left:3px solid rgba(0,255,128,.5)}
.fts-card--warn{border-left:3px solid rgba(255,200,0,.5)}
.fts-card--neutral{border-left:3px solid rgba(255,255,255,.15)}
.fts-card__title{font-weight:700;font-size:14px;margin-bottom:6px}
.fts-card__source{font-weight:400;font-size:11px;opacity:.5;margin-left:6px}
.fts-card__body{margin:0;font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-word;opacity:.9;font-family:inherit}
.fts-note{margin-top:12px;opacity:.7;font-size:12px;font-style:italic}

/* ── Chat with your data ── */
.fts-chat{margin-top:18px;border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:14px;background:rgba(0,0,0,.15)}
.fts-chat__head{margin-bottom:12px}
.fts-chat__title{font-weight:700;font-size:15px}
.fts-chat__sub{opacity:.7;font-size:12px;margin-top:2px}
.fts-chat__log{max-height:400px;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column;gap:8px}
.fts-chat__welcome{opacity:.5;font-size:13px;font-style:italic;padding:10px;border:1px dashed rgba(255,255,255,.12);border-radius:10px}
.fts-chat__bubble{padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6;max-width:90%;word-break:break-word}
.fts-chat__bubble p{margin:0 0 8px}
.fts-chat__bubble p:last-child{margin-bottom:0}
.fts-chat__bubble--user{background:rgba(0,180,255,.12);border:1px solid rgba(0,180,255,.2);align-self:flex-end}
.fts-chat__bubble--assistant{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);align-self:flex-start}
.fts-chat__bubble--thinking{opacity:.5;font-style:italic}
@keyframes fts-pulse{0%,100%{opacity:.5}50%{opacity:.9}}
.fts-chat__bubble--thinking{animation:fts-pulse 1.5s ease-in-out infinite}
.fts-chat__input-row{display:flex;gap:8px;margin-top:10px}
.fts-chat__input{flex:1;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25);color:inherit;font-size:13px;font-family:inherit}
.fts-chat__input:focus{outline:none;border-color:rgba(0,255,255,.4)}
.fts-chat__input::placeholder{opacity:.4}
