/* ============================================================
   SEO CODICE — Design System Condiviso
   Estratto e sistematizzato da audit-1-4.php
   Agente Grafica — v1.0
   ============================================================ */

/* ── VARIABILI ─────────────────────────────────────────────── */
:root {
    --bg:           #0a0a0f;
    --surface:      #12121a;
    --surface2:     #1a1a26;
    --border:       #2a2a3a;
    --accent:       #00e5a0;
    --accent2:      #00c48c;
    --accent-glow:  rgba(0,229,160,.15);
    --text:         #e8e8f0;
    --text-dim:     #8888a0;
    --red:          #ff4466;
    --orange:       #ff9933;
    --blue:         #4488ff;
    --yellow:       #ffd700;
    --font-body:    system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
    --font-mono:    ui-monospace,'SF Mono','Cascadia Code','Segoe UI Mono',Consolas,'Liberation Mono',monospace;
    --radius:       12px;
    --radius-sm:    8px;
    --radius-lg:    16px;
    --transition:   .2s ease;
}

/* ── RESET & BASE ───────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
body {
    font-family: var(--font-body);
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    overflow-x: hidden;
    line-height: 1.6;
}
body::before {
    content:'';
    position:fixed; inset:0;
    background:
        linear-gradient(rgba(0,229,160,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,229,160,.03) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events:none; z-index:0;
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container { max-width:1100px; margin:0 auto; padding:40px 20px; position:relative; z-index:1 }

/* ── HEADER ─────────────────────────────────────────────────── */
.site-header { text-align:center; margin-bottom:48px }
.site-header nav { margin-bottom:16px }
.breadcrumb {
    list-style:none; display:flex; justify-content:center;
    gap:8px; font-size:.8rem; color:var(--text-dim);
}
.breadcrumb a { color:var(--text-dim); text-decoration:underline; text-decoration-color:rgba(136,136,160,.4); text-underline-offset:3px; transition:color var(--transition), text-decoration-color var(--transition) }
.breadcrumb a:hover { color:var(--accent); text-decoration-color:var(--accent) }
.breadcrumb li+li::before { content:"›"; margin-right:8px }
.header-badge {
    display:inline-block; font-family:var(--font-mono); font-size:11px;
    letter-spacing:3px; text-transform:uppercase; color:var(--accent);
    background:var(--accent-glow); border:1px solid rgba(0,229,160,.2);
    padding:6px 16px; border-radius:20px; margin-bottom:20px;
}
.site-header h1 {
    font-size:clamp(2rem,6vw,3.2rem); font-weight:900;
    letter-spacing:-1px; line-height:1.1; margin-bottom:12px;
}
.site-header h1 span { color:var(--accent) }
.subtitle { color:var(--text-dim); font-weight:300; font-size:1.1rem }

/* ── FORM / INPUT ───────────────────────────────────────────── */
.search-card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-lg); padding:40px 30px;
    text-align:center; margin-bottom:40px;
    box-shadow:0 10px 30px rgba(0,0,0,.5);
}
.search-card h2 { margin-bottom:20px; font-size:1.2rem; color:var(--text) }
.input-group { display:flex; gap:12px; max-width:650px; margin:0 auto; flex-wrap:wrap }
@media(max-width:600px){ .input-group { flex-direction:column } }
input[type=url], input[type=text] {
    flex:1; background:var(--bg); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text);
    padding:16px; font-family:var(--font-mono); font-size:1rem;
    transition:border-color var(--transition);
    min-width:0;
}
input:focus { outline:none; border-color:var(--accent) }
.submit-btn {
    background:var(--accent); color:var(--bg); border:none;
    border-radius:var(--radius-sm); padding:16px 32px;
    font-family:var(--font-body); font-size:1rem; font-weight:700;
    cursor:pointer; transition:all .3s ease; white-space:nowrap;
}
.submit-btn:hover { background:var(--accent2); box-shadow:0 0 20px rgba(0,229,160,.3) }
.error-msg {
    color:var(--red); margin-top:15px;
    background:rgba(255,68,102,.1); padding:12px;
    border-radius:var(--radius-sm); border:1px solid var(--red);
}

/* ── LOADING OVERLAY ────────────────────────────────────────── */
#loading-overlay {
    display:none; position:fixed; top:0; left:0;
    width:100%; height:100%; background:rgba(10,10,15,.95);
    z-index:999; align-items:center; justify-content:center; flex-direction:column;
}
.spinner {
    border:4px solid var(--surface); border-top:4px solid var(--accent);
    border-radius:50%; width:50px; height:50px;
    animation:spin 1s linear infinite; margin-bottom:20px;
}
@keyframes spin { to { transform:rotate(360deg) } }
#loading-text { color:var(--accent); font-size:1.2rem; font-weight:bold; font-family:var(--font-mono) }
#loading-subtext { color:var(--text-dim); font-size:.9rem; margin-top:8px }

/* ── CARDS / BOXES ──────────────────────────────────────────── */
.box {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-lg); padding:24px;
    display:flex; flex-direction:column;
}
.box h3 {
    color:var(--text-dim); text-transform:uppercase;
    letter-spacing:1px; font-size:.8rem;
    margin-bottom:20px; border-bottom:1px solid var(--border);
    padding-bottom:12px;
}

/* ── STAT ROWS ──────────────────────────────────────────────── */
.stat-row {
    display:flex; justify-content:space-between;
    margin-bottom:14px; padding-bottom:14px;
    border-bottom:1px dashed var(--border); align-items:center;
}
.stat-row:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0 }
.stat-label { color:var(--text-dim); font-size:.9rem }
.stat-val { font-weight:700; font-family:var(--font-mono); font-size:.95rem }
.val-good  { color:var(--accent) }
.val-warn  { color:var(--orange) }
.val-bad   { color:var(--red) }
.val-info  { color:var(--blue) }
.val-dim   { color:var(--text-dim) }

/* ── BADGE ──────────────────────────────────────────────────── */
.badge {
    display:inline-block; font-size:.7rem; font-weight:700;
    padding:3px 10px; border-radius:20px; font-family:var(--font-mono);
    text-transform:uppercase; letter-spacing:.05em;
}
.badge-good   { background:rgba(0,229,160,.15); color:var(--accent); border:1px solid rgba(0,229,160,.3) }
.badge-warn   { background:rgba(255,153,51,.15); color:var(--orange); border:1px solid rgba(255,153,51,.3) }
.badge-bad    { background:rgba(255,68,102,.15); color:var(--red); border:1px solid rgba(255,68,102,.3) }
.badge-info   { background:rgba(68,136,255,.15); color:var(--blue); border:1px solid rgba(68,136,255,.3) }

/* ── SCORE CIRCLE ───────────────────────────────────────────── */
.score-circle {
    width:110px; height:110px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:2.5rem; font-weight:900; margin:20px auto;
    border:6px solid; font-family:var(--font-mono);
}
.score-green  { border-color:var(--accent); color:var(--accent) }
.score-orange { border-color:var(--orange); color:var(--orange) }
.score-red    { border-color:var(--red); color:var(--red) }
.score-unknown{ border-color:var(--text-dim); color:var(--text-dim) }

/* ── TABLE ──────────────────────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; font-size:.88rem }
.data-table th {
    text-align:left; padding:10px 14px;
    color:var(--text-dim); text-transform:uppercase;
    font-size:.72rem; letter-spacing:.08em;
    border-bottom:1px solid var(--border); font-weight:600;
}
.data-table td { padding:10px 14px; border-bottom:1px solid rgba(42,42,58,.5); vertical-align:top; word-break:break-all }
.data-table tr:last-child td { border-bottom:none }
.data-table tr:hover td { background:rgba(0,229,160,.03) }
.data-table code { font-family:var(--font-mono); font-size:.82rem; color:var(--accent); background:rgba(0,229,160,.08); padding:2px 6px; border-radius:4px }

/* ── CTA / PITCH ────────────────────────────────────────────── */
.pitch-box {
    background:linear-gradient(135deg, rgba(0,229,160,.05) 0%, rgba(26,26,38,.5) 100%);
    border:1px solid rgba(0,229,160,.2); border-radius:var(--radius-lg);
    padding:40px; margin-bottom:40px;
}
.pitch-box h2 { color:var(--accent); margin-bottom:20px; font-size:1.5rem }
.pitch-box p  { margin-bottom:16px; font-size:1rem; line-height:1.7 }
.pitch-box strong { color:#fff }
.cta-duo { display:flex; gap:14px; margin-top:20px; flex-wrap:wrap }
.cta-btn {
    display:inline-flex; align-items:center; gap:8px;
    text-decoration:none; padding:14px 28px;
    border-radius:var(--radius-sm); font-weight:700;
    font-size:1rem; transition:all var(--transition);
}
.cta-mail     { background:var(--accent); color:var(--bg) }
.cta-mail:hover { background:var(--accent2); box-shadow:0 0 20px rgba(0,229,160,.3) }
.cta-services { background:transparent; color:var(--accent); border:2px solid var(--accent) }
.cta-services:hover { background:rgba(0,229,160,.1) }

/* ── FAQ ────────────────────────────────────────────────────── */
.faq-section  { margin-top:32px }
.faq-item     { background:var(--surface); border:1px solid var(--border); border-radius:10px; margin-bottom:8px; overflow:hidden }
.faq-item summary {
    padding:16px 20px; cursor:pointer; font-weight:500;
    font-size:.95rem; list-style:none;
    display:flex; justify-content:space-between; align-items:center;
    transition:background var(--transition);
}
.faq-item summary::-webkit-details-marker { display:none }
.faq-item summary::after { content:'+'; font-size:1.2rem; color:var(--accent); font-weight:700; transition:transform var(--transition) }
.faq-item[open] summary::after { transform:rotate(45deg) }
.faq-item summary:hover { background:var(--surface2) }
.faq-item summary:focus { outline:2px solid var(--accent); outline-offset:-2px }
.faq-answer   { padding:0 20px 16px; color:var(--text-dim); font-size:.9rem; line-height:1.7 }

/* ── SEO CONTENT ────────────────────────────────────────────── */
.seo-content { margin-top:48px; padding-top:40px; border-top:1px solid var(--border) }
.seo-content h2 { font-size:1.4rem; font-weight:700; margin-bottom:16px }
.seo-content h3 { font-size:1.1rem; font-weight:600; margin:20px 0 10px }
.seo-content p  { color:var(--text-dim); font-size:.92rem; line-height:1.7; margin-bottom:12px }
.seo-content code { font-family:var(--font-mono); font-size:.85rem; background:var(--surface2); padding:2px 6px; border-radius:4px; color:var(--accent) }

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer { text-align:center; margin-top:40px; padding-top:24px; border-top:1px solid var(--border); color:var(--text-dim); font-size:.8rem }
.site-footer a, .seo-content a { color:var(--accent); text-decoration:underline; text-decoration-color:rgba(0,229,160,.5); text-underline-offset:3px; transition:text-decoration-color var(--transition) }
.site-footer a:hover, .seo-content a:hover { text-decoration-color:var(--accent) }

/* ── UTILITY ─────────────────────────────────────────────────── */
.mt-0 { margin-top:0 }
.text-mono  { font-family:var(--font-mono) }
.text-dim   { color:var(--text-dim) }
.text-accent{ color:var(--accent) }
.truncate   { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:300px }
