/* ==========================================================================
   Equalza — Open Graph Preview CSS
   ========================================================================== */

:root{
  --bg:#f5f6f8;--surface:#fff;--border:#e2e5ea;--border2:#c8cdd6;
  --accent:#2563eb;--accent-h:#1d4ed8;--accent-light:#eff6ff;--accent-mid:#bfdbfe;
  --text:#111827;--text2:#4b5563;--text3:#9ca3af;
  --green:#059669;--green-bg:#ecfdf5;
  --red:#dc2626;--red-bg:#fef2f2;
  --yellow:#d97706;--yellow-bg:#fffbeb;
  --sh:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --r:8px;--rl:12px;--rxl:16px;
}

/* ---------- Tool Card ---------- */
.tool-card.ogp{background:var(--surface);border:1px solid var(--border);border-radius:var(--rxl);box-shadow:var(--sh);overflow:hidden}

/* ---------- Form ---------- */
.ogp-form{padding:24px 24px 8px}

.ogp-section{margin-bottom:20px}
.ogp-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}

.ogp-field{margin-bottom:14px}
.ogp-field label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px}
.ogp-field input,.ogp-field textarea,.ogp-field select{width:100%;padding:9px 12px;border:1px solid var(--border2);border-radius:var(--r);font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .15s;box-sizing:border-box}
.ogp-field input:focus,.ogp-field textarea:focus,.ogp-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.ogp-field textarea{resize:vertical;min-height:60px}
.ogp-field select{appearance:auto}

.ogp-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ---------- Tooltips ---------- */
.ogp-tooltip{position:relative;cursor:help;display:inline-flex;align-items:center}
.ogp-tooltip svg{width:14px;height:14px;stroke:var(--text3);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .15s}
.ogp-tooltip:hover svg{stroke:var(--accent)}
.ogp-tooltip::after{content:attr(data-tooltip-text);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;font-size:12px;font-weight:400;line-height:1.5;padding:8px 12px;border-radius:var(--r);white-space:normal;width:260px;pointer-events:none;opacity:0;transition:opacity .2s;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,.15);text-align:start}
.ogp-tooltip:hover::after{opacity:1}
[dir="rtl"] .ogp-tooltip::after{text-align:start}

/* ---------- Character Meter ---------- */
.ogp-meter{height:4px;background:var(--bg);border-radius:2px;margin-top:4px;overflow:hidden}
.ogp-meter-bar{height:100%;border-radius:2px;transition:width .2s,background .2s;width:0}
.ogp-meter-bar.good{background:var(--green)}
.ogp-meter-bar.warn{background:var(--yellow)}
.ogp-meter-bar.bad{background:var(--red)}

/* ---------- Hints ---------- */
.ogp-hint{font-size:11px;margin-top:3px;min-height:16px;transition:color .2s}
.ogp-hint.good{color:var(--green)}
.ogp-hint.warn{color:var(--yellow)}
.ogp-hint.bad{color:var(--red)}

/* ---------- Image Size Guide ---------- */
.ogp-size-guide{background:var(--accent-light);border:1px solid var(--accent-mid);border-radius:var(--rl);padding:14px 16px;margin-top:4px}
.ogp-size-guide-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--accent);margin-bottom:10px}
.ogp-size-guide-header svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.ogp-size-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}
.ogp-size-item{display:flex;justify-content:space-between;align-items:center;padding:5px 10px;background:var(--surface);border-radius:6px;font-size:11px}
.ogp-size-platform{font-weight:600;color:var(--text2)}
.ogp-size-val{color:var(--text3);font-family:'Fira Code','SF Mono','Consolas',monospace;font-size:10px}
.ogp-size-item.ogp-size-best{background:var(--accent);border:none}
.ogp-size-item.ogp-size-best .ogp-size-platform,.ogp-size-item.ogp-size-best .ogp-size-val{color:#fff}

/* ---------- OG Health Score ---------- */
.ogp-score-wrap{padding:20px 24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.ogp-score-header{display:flex;align-items:center;gap:6px}
.ogp-score-label{font-size:13px;font-weight:700;color:var(--text)}
.ogp-score-ring{position:relative;width:80px;height:80px;flex-shrink:0}
.ogp-score-ring svg{width:80px;height:80px;transform:rotate(-90deg)}
.ogp-ring-bg{fill:none;stroke:var(--bg);stroke-width:8}
.ogp-ring-fill{fill:none;stroke:var(--green);stroke-width:8;stroke-linecap:round;stroke-dasharray:326.73;stroke-dashoffset:326.73;transition:stroke-dashoffset .6s ease,stroke .3s}
.ogp-score-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:22px;font-weight:800;color:var(--text)}
.ogp-score-checks{flex:1;min-width:200px;display:flex;flex-direction:column;gap:4px}
.ogp-check{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;padding:3px 0}
.ogp-check svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.ogp-check.pass{color:var(--green)}
.ogp-check.fail{color:var(--red)}
.ogp-check.warn{color:var(--yellow)}

/* ---------- Preview Section ---------- */
.ogp-preview-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.ogp-preview-header{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap}
.ogp-preview-title{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap}
.ogp-tabs{display:flex;gap:4px;flex-wrap:wrap}
.ogp-tab{padding:5px 12px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.ogp-tab:hover{border-color:var(--accent);color:var(--accent)}
.ogp-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}

.ogp-panel{display:none;padding:24px}
.ogp-panel.active{display:block}

/* ---------- Google SERP Preview ---------- */
.serp-preview{max-width:600px;font-family:Arial,sans-serif}
.serp-breadcrumb{font-size:12px;color:#202124;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.serp-breadcrumb::before{content:'';display:inline-block;width:18px;height:18px;background:#f1f3f4;border-radius:50%;vertical-align:middle;margin-right:8px;margin-inline-end:8px}
.serp-title{font-size:20px;color:#1a0dab;line-height:1.3;margin-bottom:4px;cursor:pointer;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.serp-title:hover{text-decoration:underline}
.serp-desc{font-size:14px;color:#4d5156;line-height:1.58;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}

/* ---------- Facebook Preview ---------- */
.fb-preview{max-width:500px;border:1px solid #dddfe2;border-radius:3px;overflow:hidden;background:#fff;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif}
.fb-image{background:#f0f2f5;aspect-ratio:1200/630;display:flex;align-items:center;justify-content:center;overflow:hidden}
.fb-image img{width:100%;height:100%;object-fit:cover}
.fb-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:#8a8d91}
.fb-image-placeholder svg{width:40px;height:40px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.fb-image-placeholder span{font-size:11px}
.fb-body{padding:10px 12px}
.fb-domain{font-size:12px;color:#606770;text-transform:uppercase;letter-spacing:.03em}
.fb-title{font-size:16px;font-weight:600;color:#1d2129;line-height:1.35;margin:3px 0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.fb-desc{font-size:14px;color:#606770;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* ---------- Twitter / X Preview ---------- */
.tw-preview{max-width:500px;border:1px solid #cfd9de;border-radius:16px;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}
.tw-preview.tw-large .tw-image{aspect-ratio:2/1;display:flex;align-items:center;justify-content:center;background:#f7f9f9;overflow:hidden}
.tw-preview.tw-summary{display:grid;grid-template-columns:130px 1fr}
.tw-preview.tw-summary .tw-image{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:#f7f9f9;overflow:hidden}
.tw-image img{width:100%;height:100%;object-fit:cover}
.tw-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;color:#8899a6}
.tw-image-placeholder svg{width:36px;height:36px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.tw-image-placeholder span{font-size:11px}
.tw-body{padding:12px}
.tw-title{font-size:15px;font-weight:700;color:#0f1419;line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tw-desc{font-size:14px;color:#536471;line-height:1.35;margin-bottom:4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tw-domain{font-size:13px;color:#536471;display:flex;align-items:center;gap:4px}
.tw-domain::before{content:'';display:inline-block;width:14px;height:14px;border:1.5px solid #536471;border-radius:50%}

/* ---------- LinkedIn Preview ---------- */
.li-preview{max-width:500px;border:1px solid #e0e0e0;border-radius:2px;overflow:hidden;background:#fff;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}
.li-image{background:#f3f2ef;aspect-ratio:1200/627;display:flex;align-items:center;justify-content:center;overflow:hidden}
.li-image img{width:100%;height:100%;object-fit:cover}
.li-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:#666}
.li-image-placeholder svg{width:40px;height:40px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.li-image-placeholder span{font-size:11px}
.li-body{padding:10px 12px}
.li-title{font-size:14px;font-weight:600;color:#000;line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.li-domain{font-size:12px;color:#666}

/* ---------- WhatsApp Preview ---------- */
.wa-preview{max-width:360px;padding:8px}
.wa-bubble{background:#dcf8c6;border-radius:8px;padding:4px;position:relative;max-width:340px}
.wa-link-card{border-radius:6px;overflow:hidden;background:#fff;border:1px solid #e0e0e0}
.wa-image{background:#f0f0f0;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;overflow:hidden}
.wa-image img{width:100%;height:100%;object-fit:cover}
.wa-image-placeholder{color:#999}
.wa-image-placeholder svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.wa-body{padding:8px 10px}
.wa-domain{font-size:11px;color:#8696a0;text-transform:uppercase;letter-spacing:.03em;margin-bottom:2px}
.wa-title{font-size:13px;font-weight:600;color:#111b21;line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.wa-desc{font-size:12px;color:#667781;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.wa-url{padding:6px 8px;font-size:12px;color:#027eb5;word-break:break-all}

/* ---------- Telegram Preview ---------- */
.tg-preview{max-width:400px;padding:8px}
.tg-bubble{background:#eeffde;border-radius:12px;padding:6px;max-width:380px}
.tg-link-card{border-radius:8px;overflow:hidden;background:#fff;border:1px solid #d6e5d0}
.tg-image{background:#f0f5ee;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;overflow:hidden}
.tg-image img{width:100%;height:100%;object-fit:cover}
.tg-image-placeholder{color:#8fae85}
.tg-image-placeholder svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.tg-body{padding:10px 12px;border-inline-start:3px solid #59b94c}
.tg-sitename{font-size:12px;font-weight:600;color:#59b94c;margin-bottom:2px}
.tg-title{font-size:14px;font-weight:700;color:#1a1a1a;line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.tg-desc{font-size:13px;color:#555;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.tg-url{padding:6px 8px;font-size:12px;color:#168acd;word-break:break-all}

/* ---------- Discord Preview ---------- */
.dc-preview{max-width:520px;padding:8px;background:#313338;border-radius:8px}
.dc-embed{display:flex;border-radius:4px;overflow:hidden;background:#2b2d31}
.dc-accent{width:4px;background:#2563eb;flex-shrink:0}
.dc-content{padding:12px 16px;flex:1;min-width:0}
.dc-sitename{font-size:12px;font-weight:600;color:#b5bac1;margin-bottom:4px}
.dc-title{font-size:16px;font-weight:700;color:#00a8fc;line-height:1.3;margin-bottom:4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.dc-desc{font-size:14px;color:#dbdee1;line-height:1.4;margin-bottom:10px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.dc-image{border-radius:4px;overflow:hidden;background:#1e1f22;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;max-width:400px}
.dc-image img{width:100%;height:100%;object-fit:cover}
.dc-image-placeholder{color:#5c5f66}
.dc-image-placeholder svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Slack Preview ---------- */
.sl-preview{max-width:520px;padding:8px}
.sl-attachment{display:flex;border-radius:0;overflow:hidden;background:var(--surface);border:1px solid var(--border)}
.sl-accent{width:4px;background:#e01e5a;flex-shrink:0}
.sl-content{padding:12px 16px;flex:1;min-width:0}
.sl-sitename{font-size:12px;font-weight:700;color:var(--text2);margin-bottom:4px}
.sl-title{font-size:15px;font-weight:700;color:#1264a3;line-height:1.3;margin-bottom:4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.sl-desc{font-size:14px;color:var(--text2);line-height:1.4;margin-bottom:10px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.sl-image{border-radius:4px;overflow:hidden;background:var(--bg);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;max-width:360px}
.sl-image img{width:100%;height:100%;object-fit:cover}
.sl-image-placeholder{color:var(--text3)}
.sl-image-placeholder svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Code Block ---------- */
.ogp-code-wrap{padding:0}
.ogp-code-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg);border-top:1px solid var(--border);flex-wrap:wrap;gap:8px}
.ogp-code-title{font-size:13px;font-weight:700;color:var(--text)}
.ogp-code-actions{display:flex;gap:8px}
.ogp-code-block{background:#1e293b;color:#e2e8f0;padding:20px 24px;font-family:'Fira Code','SF Mono','Consolas','Monaco',monospace;font-size:12px;line-height:1.7;overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:400px;overflow-y:auto}
.ogp-code-block .tag-name{color:#7dd3fc}
.ogp-code-block .attr-name{color:#fbbf24}
.ogp-code-block .attr-val{color:#86efac}
.ogp-code-block .comment{color:#64748b}

/* ---------- Buttons ---------- */
.btn-primary{display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;font-weight:600;font-size:13px;font-family:inherit;padding:8px 18px;border-radius:var(--r);border:none;cursor:pointer;transition:all .15s}
.btn-primary:hover{opacity:.88}
.btn-primary svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:var(--bg);color:var(--text2);font-weight:600;font-size:13px;font-family:inherit;padding:8px 18px;border-radius:var(--r);border:1px solid var(--border2);cursor:pointer;transition:all .15s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--surface)}

/* ---------- Privacy ---------- */
.ogp-privacy{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;background:var(--green-bg);border-top:1px solid #bbf7d0;font-size:12px;color:var(--green);font-weight:600}
.ogp-privacy svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Copied Toast ---------- */
.ogp-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:8px 20px;border-radius:var(--r);font-size:13px;font-weight:600;z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none}
.ogp-toast.show{opacity:1}

/* ---------- RTL ---------- */
[dir="rtl"] .ogp-row-2{direction:rtl}
[dir="rtl"] .ogp-score-wrap{direction:rtl}
[dir="rtl"] .tg-body{border-inline-start:3px solid #59b94c;border-inline-end:none}

/* ---------- Responsive ---------- */
@media(max-width:680px){
  .ogp-form{padding:16px 16px 4px}
  .ogp-row-2{grid-template-columns:1fr}
  .ogp-preview-header{padding:10px 16px}
  .ogp-panel{padding:16px}
  .ogp-tabs{gap:3px}
  .ogp-tab{padding:4px 10px;font-size:11px}
  .ogp-code-header{padding:10px 16px}
  .ogp-code-block{padding:14px 16px;font-size:11px}
  .serp-preview,.fb-preview,.tw-preview,.li-preview{max-width:100%}
  .ogp-score-wrap{flex-direction:column;align-items:flex-start}
  .ogp-size-grid{grid-template-columns:1fr 1fr}
  .ogp-tooltip::after{width:200px;left:0;transform:none}
}
