/* ========== CMEDIA AUDIT SEO TOOL · CSS v3 (avec email gate) ========== */
.cm-audit-app, .cm-audit-app *{box-sizing:border-box}
.cm-audit-app{--cm-bg:#06060E;--cm-surface:#0D0D1C;--cm-text:#E8ECF8;--cm-muted:#B8BCC8;--cm-accent:#FF5C00;--cm-ice:#7DEBFF;--cm-green:#00D97E;--cm-magenta:#FF2255;--cm-border:rgba(255,255,255,0.08);font-family:'Exo 2',Inter,sans-serif;color:var(--cm-text)}
.cm-audit-app code{font-family:'Fira Code',Menlo,monospace;background:rgba(125,235,255,0.08);color:var(--cm-ice);padding:2px 7px;border-radius:4px;font-size:0.88em}

/* HERO */
.cm-audit-hero{background:linear-gradient(180deg,#06060E 0%,rgba(255,92,0,0.04) 100%);padding:60px 24px 40px;text-align:center;border-bottom:1px solid var(--cm-border)}
.cm-audit-hero-inner{max-width:820px;margin:0 auto}
.cm-audit-badge{display:inline-block;font-family:'Fira Code',monospace;font-size:0.72rem;color:var(--cm-accent);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:20px;padding:6px 14px;border:1px solid rgba(255,92,0,0.3);border-radius:20px}
.cm-audit-title{font-family:'Russo One',sans-serif !important;font-size:clamp(1.8rem,4.4vw,3.2rem) !important;font-weight:400 !important;line-height:1.1 !important;letter-spacing:-0.015em;margin:0 0 20px !important;color:var(--cm-text) !important}
.cm-audit-app .cm-accent{color:var(--cm-accent)}
.cm-audit-sub{font-size:1.1rem;line-height:1.65;color:var(--cm-muted);max-width:720px;margin:0 auto}

/* TOOL WRAPPER */
.cm-tool{padding:60px 24px;border-top:1px solid var(--cm-border)}
.cm-tool-inner{max-width:980px;margin:0 auto}
.cm-tool-label{font-family:'Fira Code',monospace;color:var(--cm-accent);font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;margin-bottom:20px}

/* AUDIT FORM */
.cm-audit-form{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.cm-audit-form input[type="url"]{flex:1;min-width:260px;padding:18px 22px;font-size:1.05rem;background:var(--cm-surface);border:1px solid var(--cm-border);color:var(--cm-text);border-radius:10px;font-family:'Fira Code',monospace;outline:none;transition:border-color 0.2s ease}
.cm-audit-form input[type="url"]:focus{border-color:var(--cm-accent)}
.cm-audit-form button{padding:18px 30px;background:var(--cm-accent);color:var(--cm-bg);border:none;border-radius:10px;font-family:'Russo One',sans-serif;font-size:0.95rem;letter-spacing:0.03em;cursor:pointer;transition:all 0.2s ease;font-weight:400}
.cm-audit-form button:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(255,92,0,0.3)}
.cm-audit-form button:disabled{opacity:0.5;cursor:wait;transform:none}
.cm-audit-examples{margin-top:14px;color:rgba(184,188,200,0.7);font-size:0.88rem}
.cm-audit-examples a{color:var(--cm-ice);text-decoration:none;margin:0 4px;cursor:pointer}
.cm-audit-examples a:hover{color:var(--cm-accent)}

/* AUDIT STATUS */
.cm-audit-status{margin-top:24px;font-family:'Fira Code',monospace;font-size:0.9rem;color:var(--cm-ice);display:none}
.cm-audit-status.is-visible{display:block}
.cm-audit-status.is-error{color:var(--cm-magenta)}
.cm-audit-status .cm-pulse{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--cm-accent);margin-right:10px;vertical-align:middle;animation:cmPulse 1.2s ease-in-out infinite}
@keyframes cmPulse{0%,100%{opacity:0.3}50%{opacity:1}}

/* AUDIT RESULTS */
.cm-audit-results{margin-top:32px;display:none}
.cm-audit-results.is-visible{display:block}
.cm-overall-score{background:var(--cm-surface);border:1px solid var(--cm-border);border-radius:14px;padding:30px 28px;text-align:center;margin-bottom:28px}
.cm-overall-score-num{font-family:'Russo One',sans-serif;font-size:4.5rem;line-height:1;margin:0;font-weight:400}
.cm-overall-score-num.good{color:var(--cm-green)}
.cm-overall-score-num.ok{color:var(--cm-accent)}
.cm-overall-score-num.bad{color:var(--cm-magenta)}
.cm-overall-score-label{font-family:'Fira Code',monospace;font-size:0.85rem;color:var(--cm-muted);letter-spacing:0.12em;text-transform:uppercase;margin-top:6px}
.cm-overall-summary{margin-top:14px;color:var(--cm-muted);font-size:0.98rem}

.cm-cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px;margin-bottom:28px}
.cm-cat{background:var(--cm-surface);border:1px solid var(--cm-border);border-radius:12px;padding:22px}
.cm-cat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cm-cat-title{font-family:'Russo One',sans-serif;font-size:1.05rem;margin:0;font-weight:400}
.cm-cat-score{font-family:'Fira Code',monospace;font-size:0.92rem;padding:3px 11px;border-radius:12px;font-weight:700}
.cm-cat-score.good{background:rgba(0,217,126,0.15);color:var(--cm-green)}
.cm-cat-score.ok{background:rgba(255,92,0,0.15);color:var(--cm-accent)}
.cm-cat-score.bad{background:rgba(255,34,85,0.15);color:var(--cm-magenta)}
.cm-checks{list-style:none;padding:0;margin:0;font-size:0.9rem}
.cm-checks li{padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.04);display:flex;align-items:flex-start;gap:10px}
.cm-checks li:last-child{border-bottom:none}
.cm-check-icon{flex-shrink:0;font-size:1rem;line-height:1.4;font-weight:700}
.cm-check-icon.pass{color:var(--cm-green)}
.cm-check-icon.warn{color:var(--cm-accent)}
.cm-check-icon.fail{color:var(--cm-magenta)}
.cm-check-txt{flex:1;color:var(--cm-muted);line-height:1.5}
.cm-check-txt strong{color:var(--cm-text)}
.cm-check-value{display:block;font-family:'Fira Code',monospace;font-size:0.8rem;color:rgba(184,188,200,0.65);margin-top:3px;word-break:break-all}

/* TABS */
.cm-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-top:20px;margin-bottom:24px;border-bottom:1px solid var(--cm-border);padding-bottom:0}
.cm-tab{background:none;border:1px solid transparent;color:var(--cm-muted);padding:12px 18px;cursor:pointer;font-family:'Fira Code',monospace;font-size:0.88rem;border-bottom:none;border-radius:8px 8px 0 0;transition:all 0.2s ease;margin-bottom:-1px}
.cm-tab:hover{color:var(--cm-text);background:rgba(255,255,255,0.03)}
.cm-tab.is-active{background:var(--cm-surface);border-color:var(--cm-border);color:var(--cm-accent);border-bottom-color:var(--cm-surface)}
.cm-tab-panel{display:none;background:var(--cm-surface);border:1px solid var(--cm-border);border-radius:0 12px 12px 12px;padding:28px}
.cm-tab-panel.is-active{display:block}
.cm-panel-title{font-family:'Russo One',sans-serif !important;font-size:1.3rem !important;font-weight:400 !important;margin:0 0 8px !important;color:var(--cm-text) !important}
.cm-panel-desc{color:var(--cm-muted);margin:0 0 22px;font-size:0.95rem;line-height:1.6}

/* FORM GRID */
.cm-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-bottom:20px}
.cm-form-grid label{display:flex;flex-direction:column;gap:6px}
.cm-form-grid label > span{font-family:'Fira Code',monospace;font-size:0.78rem;color:var(--cm-muted);letter-spacing:0.05em;text-transform:uppercase}
.cm-form-grid input[type="text"],.cm-form-grid input[type="url"],.cm-form-grid input[type="number"],.cm-form-grid textarea,.cm-form-grid select{padding:12px 14px;background:var(--cm-bg);border:1px solid var(--cm-border);color:var(--cm-text);border-radius:8px;font-family:'Fira Code',monospace;font-size:0.92rem;outline:none;transition:border-color 0.2s ease;width:100%}
.cm-form-grid input:focus,.cm-form-grid textarea:focus,.cm-form-grid select:focus{border-color:var(--cm-accent)}
.cm-form-grid textarea{min-height:80px;resize:vertical;font-family:inherit}
.cm-field-hint{color:rgba(184,188,200,0.6);font-size:0.75rem;font-family:'Fira Code',monospace;margin-top:3px}

.cm-generate-btn{background:var(--cm-accent);color:var(--cm-bg);border:none;padding:14px 24px;border-radius:8px;font-family:'Russo One',sans-serif;font-size:0.9rem;letter-spacing:0.03em;cursor:pointer;transition:all 0.2s ease}
.cm-generate-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(255,92,0,0.25)}

.cm-code-output{margin-top:20px;display:none;position:relative}
.cm-code-output.is-visible{display:block}
.cm-code-output pre{background:var(--cm-bg);border:1px solid var(--cm-border);border-radius:10px;padding:20px 22px;font-family:'Fira Code',monospace;font-size:0.85rem;line-height:1.5;color:var(--cm-ice);overflow-x:auto;margin:0;max-height:500px;white-space:pre-wrap;word-break:break-word}
.cm-code-output .cm-copy-corner{position:absolute;top:12px;right:12px;background:var(--cm-accent);color:var(--cm-bg);border:none;padding:7px 14px;border-radius:6px;font-size:0.78rem;cursor:pointer;font-family:'Fira Code',monospace;font-weight:700}

.cm-copy-btn{background:var(--cm-surface);color:var(--cm-ice);border:1px solid var(--cm-ice);padding:10px 18px;border-radius:8px;font-family:'Fira Code',monospace;font-size:0.85rem;cursor:pointer;transition:all 0.2s ease;white-space:nowrap}
.cm-copy-btn:hover{background:var(--cm-ice);color:var(--cm-bg)}
.cm-slug-result{display:flex;gap:10px;align-items:flex-end}
.cm-slug-result label{flex:1;display:flex;flex-direction:column;gap:6px}

/* DENSITY */
.cm-density-output{margin-top:24px;display:none}
.cm-density-output.is-visible{display:block}
.cm-density-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:22px}
.cm-density-stat{background:var(--cm-bg);border:1px solid var(--cm-border);border-radius:10px;padding:14px;text-align:center}
.cm-density-stat-num{font-family:'Russo One',sans-serif;font-size:1.8rem;font-weight:400;color:var(--cm-ice);line-height:1}
.cm-density-stat-label{font-family:'Fira Code',monospace;font-size:0.7rem;color:var(--cm-muted);letter-spacing:0.05em;text-transform:uppercase;margin-top:6px}
.cm-density-table{background:var(--cm-bg);border:1px solid var(--cm-border);border-radius:10px;padding:0;overflow:hidden}
.cm-density-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;padding:11px 18px;border-bottom:1px solid rgba(255,255,255,0.04);font-family:'Fira Code',monospace;font-size:0.88rem;align-items:center}
.cm-density-row:last-child{border-bottom:none}
.cm-density-row strong{color:var(--cm-text);font-weight:700}
.cm-density-row span{color:var(--cm-muted)}
.cm-density-row .bar{height:6px;background:rgba(125,235,255,0.12);border-radius:3px;overflow:hidden;min-width:80px}
.cm-density-row .bar-fill{height:100%;background:var(--cm-ice);border-radius:3px}

/* FINAL CTA */
.cm-final-cta{background:linear-gradient(180deg,rgba(255,92,0,0.04) 0%,rgba(255,92,0,0.09) 100%)}
.cm-final-cta h2{font-family:'Russo One',sans-serif !important;font-size:2rem;margin:0 0 16px;color:#E8ECF8 !important;font-weight:400 !important}
.cm-final-cta p{color:#B8BCC8;margin:0 0 24px;font-size:1.05rem}
.cm-final-btn{display:inline-block;background:#FF5C00;color:#06060E !important;padding:16px 32px;border-radius:30px;font-family:'Russo One',sans-serif;font-weight:400;letter-spacing:0.03em;text-decoration:none !important;transition:all 0.25s ease;font-size:1rem}
.cm-final-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(255,92,0,0.35)}

/* ================================
   LEAD CAPTURE MODAL (v3)
   ================================ */
.cm-lead-modal{position:fixed;inset:0;z-index:999999;display:flex;align-items:center;justify-content:center;padding:20px;animation:cmFadeIn 0.25s ease}
.cm-lead-modal-backdrop{position:absolute;inset:0;background:rgba(6,6,14,0.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer}
.cm-lead-modal-box{position:relative;background:#0D0D1C;border:1px solid rgba(255,92,0,0.25);border-radius:16px;padding:44px 38px 34px;max-width:460px;width:100%;color:#E8ECF8;font-family:'Exo 2',Inter,sans-serif;box-shadow:0 40px 120px rgba(255,92,0,0.15),0 0 0 1px rgba(255,92,0,0.06);animation:cmSlideUp 0.35s cubic-bezier(0.2,1,0.3,1)}
.cm-lead-modal-box::before{content:'';position:absolute;top:0;left:24px;right:24px;height:3px;background:linear-gradient(90deg,#FF5C00 0%,rgba(255,92,0,0) 100%);border-radius:0 0 3px 3px}
.cm-lead-modal-close{position:absolute;top:12px;right:14px;background:transparent;border:none;color:#B8BCC8;font-size:28px;line-height:1;cursor:pointer;padding:6px 10px;border-radius:8px;transition:all 0.2s ease}
.cm-lead-modal-close:hover{background:rgba(255,255,255,0.05);color:#FF5C00}
.cm-lead-modal-badge{font-family:'Fira Code',monospace;font-size:0.7rem;color:#FF5C00;letter-spacing:0.18em;text-transform:uppercase;margin:0 0 16px;padding:5px 12px;border:1px solid rgba(255,92,0,0.35);border-radius:20px;display:inline-block}
.cm-lead-modal-title{font-family:'Russo One',sans-serif !important;font-size:1.6rem !important;line-height:1.15 !important;margin:0 0 10px !important;color:#E8ECF8 !important;font-weight:400 !important;letter-spacing:-0.01em}
.cm-lead-modal-desc{color:#B8BCC8;font-size:0.95rem;line-height:1.55;margin:0 0 26px}
.cm-lead-form{display:flex;flex-direction:column;gap:14px}
.cm-lead-field{display:flex;flex-direction:column;gap:6px}
.cm-lead-field > span{font-family:'Fira Code',monospace;font-size:0.72rem;color:#B8BCC8;letter-spacing:0.1em}
.cm-lead-field input{padding:14px 16px;background:#06060E;border:1px solid rgba(255,255,255,0.1);color:#E8ECF8;border-radius:10px;font-family:'Fira Code',monospace;font-size:0.95rem;outline:none;transition:border-color 0.2s ease}
.cm-lead-field input:focus{border-color:#FF5C00}
.cm-lead-error{background:rgba(255,34,85,0.1);border:1px solid rgba(255,34,85,0.3);color:#FF2255;padding:10px 14px;border-radius:8px;font-size:0.88rem;font-family:'Fira Code',monospace}
.cm-lead-submit{margin-top:8px;background:#FF5C00;color:#06060E;border:none;padding:16px 24px;border-radius:10px;font-family:'Russo One',sans-serif;font-size:1rem;font-weight:400;letter-spacing:0.03em;cursor:pointer;transition:all 0.2s ease;width:100%}
.cm-lead-submit:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(255,92,0,0.35)}
.cm-lead-submit:disabled{opacity:0.6;cursor:wait;transform:none}
.cm-lead-privacy{color:rgba(184,188,200,0.65);font-size:0.78rem;line-height:1.5;margin:14px 0 0;text-align:center}

@keyframes cmFadeIn{from{opacity:0}to{opacity:1}}
@keyframes cmSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:640px){
    .cm-audit-form{flex-direction:column}
    .cm-audit-form input[type="url"],.cm-audit-form button{width:100%}
    .cm-tabs{overflow-x:auto;flex-wrap:nowrap}
    .cm-tab{white-space:nowrap;font-size:0.8rem;padding:10px 14px}
    .cm-slug-result{flex-direction:column;align-items:stretch}
    .cm-lead-modal-box{padding:34px 24px 26px}
    .cm-lead-modal-title{font-size:1.35rem !important}
}
