/*
Theme Name: Vu sans se faire voir
Theme URI: https://vusanssefairevoir.fr
Author: Vu sans se faire voir
Description: Theme une page pour vusanssefairevoir.fr — design constellation (consultant SEO local Saint-Etienne) avec chat IA Sacha au centre, branche sur le plugin Chat SEO.
Version: 1.0.0
Requires at least: 5.8
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: vsf-theme
*/

:root{--bg:#ffffff;--ink:#1b1b1d;--soft:#adada9;--soft2:#797975;--line:#eceae7;--node:#e4e2dd;--online:#2bb673;--ui:"Hanken Grotesk",system-ui,sans-serif;--serif:"Cormorant",Georgia,serif;--ease:cubic-bezier(.22,.61,.36,1)}
*{box-sizing:border-box;margin:0}body{background:var(--bg);color:var(--ink);font-family:var(--ui);font-weight:300;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
button{font-family:inherit}a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:clamp(1.6rem,3vw,2.6rem) clamp(1.5rem,5vw,3.5rem) clamp(3rem,6vw,5rem)}
.intro{text-align:center;max-width:1100px;margin:0 auto}
.brand{font-family:var(--serif);font-weight:600;font-size:clamp(2.9rem,7.5vw,5.2rem);letter-spacing:.005em;color:var(--ink);margin-bottom:.35rem;line-height:1}
.brand em{font-style:italic;font-weight:400;color:var(--soft2)}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:400;letter-spacing:.26em;text-transform:uppercase;color:var(--soft2);margin-bottom:1.4rem}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--online)}
h1{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,3vw,1.9rem);line-height:1.25;letter-spacing:0;color:var(--soft2)}
h1 em{font-style:italic;color:var(--ink)}
/* SCENE constellation */
.stage{position:relative;height:820px;margin-top:clamp(.6rem,1.5vw,1.2rem)}
.links{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.links path{fill:none;stroke:#c4bdae;stroke-width:1.5;stroke-dasharray:2 6;stroke-linecap:round;opacity:0;transition:opacity 1s var(--ease)}
.links.in path{opacity:1}
/* offre = noeud typographique, sans cadre */
.o{position:absolute;width:230px;z-index:2;opacity:0;transform:translateY(10px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.o.in{opacity:1;transform:none}
.o .node{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.o .dot{width:9px;height:9px;border-radius:50%;border:1px solid var(--ink);background:#fff}
.o .num{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--soft2)}
.o h3{font-weight:500;font-size:1.18rem;line-height:1.05;margin:0 0 .2rem;letter-spacing:.005em}
.o .b{font-size:.86rem;color:var(--soft2);font-weight:300;line-height:1.4;margin:.15rem 0 .55rem}
.o .note{display:block;font-size:.72rem;color:var(--soft);font-style:italic;margin:.35rem 0 0}
.o .score{margin:.1rem 0 .7rem}
.o .score .sl{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);margin-bottom:.25rem}
.o .score .sv{font-family:var(--serif);font-size:1.7rem;line-height:1}
.o .score .sv i{font-style:normal;font-size:.78rem;color:var(--soft)}
.o .score .bar{height:3px;background:var(--line);border-radius:99px;margin-top:.45rem;overflow:hidden}
.o .score .bar span{display:block;height:100%;width:62%;background:var(--ink)}
.o .p{font-family:var(--serif);font-size:1.45rem;line-height:1}
.o .p small{font-family:var(--ui);font-size:.76rem;color:var(--soft);font-weight:300}
.o ul{list-style:none;margin:.7rem 0 0;padding:0;display:grid;gap:.3rem}
.o li{font-size:.82rem;color:var(--soft2);font-weight:300}
.o .go{display:inline-block;margin-top:.7rem;font-size:.8rem;font-weight:500;border-bottom:1px solid var(--node);padding-bottom:2px;transition:border-color .25s;cursor:pointer}
.o:hover .go{border-color:var(--ink)}
.o.feat .dot{background:var(--ink)}.o.feat .num{color:var(--ink);font-weight:500}
.o.feat .tag{font-size:.6rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--soft2);margin-left:.4rem}
/* positions */
.o1{left:0;top:30px}.o2{left:20px;top:430px}
.o3{right:0;top:30px;text-align:right}.o3 .node{flex-direction:row-reverse}
.o4{right:20px;top:398px;text-align:right}.o4 .node{flex-direction:row-reverse}
.o5{left:50%;transform:translateX(-50%);bottom:0;text-align:center;width:280px}.o5.in{transform:translateX(-50%)}.o5 .node{justify-content:center}
/* CHAT centre */
.chat{position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);width:400px;max-width:90vw;background:#fff;border:1px solid #e6e6e3;border-radius:18px;display:flex;flex-direction:column;height:440px;overflow:hidden;box-shadow:0 30px 60px -34px rgba(20,20,22,.4);z-index:3}
.ch{display:flex;align-items:center;gap:.75rem;padding:1.1rem 1.25rem;border-bottom:1px solid var(--line)}
.av{width:38px;height:38px;flex:none;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:1.05rem}
.ch strong{display:block;font-size:.94rem;font-weight:500}.ch span{font-size:.74rem;color:var(--soft);display:inline-flex;align-items:center;gap:.4rem;font-weight:300}.ch span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--online)}
.cb{flex:1 1 auto;min-height:0;padding:1.3rem 1.25rem;display:flex;flex-direction:column;gap:.65rem;overflow-y:auto}
.bot{align-self:flex-start;max-width:88%;background:#fff;border:1px solid #efeeec;padding:.7rem .95rem;border-radius:14px;border-bottom-left-radius:4px;font-size:.9rem;line-height:1.5;font-weight:400;white-space:pre-wrap}
.msg-user{align-self:flex-end;max-width:88%;background:var(--ink);color:#fff;padding:.65rem .95rem;border-radius:14px;border-bottom-right-radius:4px;font-size:.9rem;font-weight:400;white-space:pre-wrap}
.typing{align-self:flex-start;background:#fff;border:1px solid #efeeec;padding:.8rem 1rem;border-radius:14px;border-bottom-left-radius:4px;display:inline-flex;gap:5px}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--soft);animation:blink 1.3s infinite}.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}@keyframes blink{0%,60%,100%{opacity:.3}30%{opacity:1}}
.chips{display:flex;flex-wrap:wrap;gap:.4rem;padding:0 1.25rem .85rem}
.chips button{font-family:var(--ui);font-size:.78rem;font-weight:400;background:transparent;border:1px solid #e6e6e3;color:var(--ink);border-radius:99px;padding:.42rem .8rem;cursor:pointer;transition:border-color .2s}.chips button:hover{border-color:var(--soft2)}
.ci{display:flex;gap:.5rem;padding:.8rem .95rem;border-top:1px solid var(--line)}
.ci input{flex:1;font-family:var(--ui);font-weight:300;font-size:.9rem;color:var(--ink);background:#fff;border:1px solid #e6e6e3;border-radius:99px;padding:.65rem 1rem}.ci input:focus{outline:none;border-color:var(--soft2)}
.ci .s{flex:none;width:34px;height:34px;border:none;background:none;cursor:pointer;color:var(--soft2);display:grid;place-items:center;transition:color .2s var(--ease)}
.ci .s:hover{color:var(--ink)}
.ci .s[disabled]{opacity:.4;cursor:default}
.r{opacity:0;transform:translateY(10px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.r.in{opacity:1;transform:none}
/* On masque le widget flottant du plugin : ici le chat est au centre */
#vsf-wrapper{display:none!important}
@media(max-width:980px){.stage{height:auto;display:flex;flex-direction:column;gap:1.6rem;margin-top:2rem}.links{display:none}.o,.chat{position:static;transform:none;width:auto;text-align:left}.o3 .node,.o4 .node,.o5 .node{flex-direction:row;justify-content:flex-start}.chat{order:-1;height:auto;min-height:150px;max-height:66vh;max-width:none}.o5,.o5.in{transform:none;text-align:left;width:auto}.o5 .node{justify-content:flex-start}}
