/* =====================================================================
   Fasty Business — Design system « Atelier futuriste lumineux »
   Signature : aurore dérivante + verre dépoli + assemblage animé.
   Léger, aérien, mouvement à chaque action. Respecte prefers-reduced-motion.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
    --primary:#5B5BF0;              /* indigo (overridable par la couleur de l'entreprise) */
    --grad-a:#5B5BF0;               /* indigo */
    --grad-b:#8B5CF6;               /* violet */
    --grad-c:#22D3EE;               /* cyan   */
    --grad: linear-gradient(120deg, var(--grad-a), var(--grad-b) 55%, var(--grad-c));
    --ink:#0E1430;
    --ink-soft:#3A4163;
    --muted:#7C84A3;
    --line:rgba(14,20,48,.09);
    --line-strong:rgba(14,20,48,.16);
    --canvas:#F4F6FD;
    --glass:rgba(255,255,255,.85);
    --glass-strong:rgba(255,255,255,.93);
    --ok:#10B981;
    --err:#F43F5E;
    --warn:#F59E0B;
    --radius:20px;
    --radius-sm:14px;
    --shadow-sm:0 1px 2px rgba(14,20,48,.04), 0 4px 14px rgba(14,20,48,.06);
    --shadow:0 8px 30px rgba(40,40,120,.10), 0 2px 8px rgba(14,20,48,.05);
    --shadow-glow:0 10px 40px rgba(91,91,240,.28);
    --ease:cubic-bezier(.22,.61,.36,1);
    --ease-spring:cubic-bezier(.34,1.56,.64,1);
    font-size:17px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    color:var(--ink);background:var(--canvas);line-height:1.55;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
    min-height:100vh;overflow-x:hidden;
}

/* ---------- Aurore ambiante (signature de fond) ---------- */
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;contain:strict}
.aurora::before,.aurora::after,.aurora i{transform:translateZ(0);backface-visibility:hidden;
    content:"";position:absolute;border-radius:50%;opacity:.42;
    mix-blend-mode:multiply;will-change:transform;
}
.aurora::before{width:46vw;height:46vw;left:-8vw;top:-10vw;background:radial-gradient(circle at 30% 30%, #8B5CF6, transparent 70%);animation:drift1 22s var(--ease) infinite alternate}
.aurora::after{width:42vw;height:42vw;right:-10vw;top:6vh;background:radial-gradient(circle at 60% 40%, #22D3EE, transparent 70%);animation:drift2 26s var(--ease) infinite alternate}
.aurora i{width:40vw;height:40vw;left:25vw;bottom:-18vw;background:radial-gradient(circle at 50% 50%, #5B5BF0, transparent 70%);animation:drift3 30s var(--ease) infinite alternate;display:block}
.aurora b{position:absolute;inset:0;background:
    radial-gradient(1px 1px at 20% 30%, rgba(91,91,240,.5), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(34,211,238,.5), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(139,92,246,.5), transparent),
    radial-gradient(1px 1px at 85% 25%, rgba(91,91,240,.4), transparent);
    background-size:cover;opacity:.6;display:block}
@keyframes drift1{to{transform:translate(8vw,6vh) scale(1.15)}}
@keyframes drift2{to{transform:translate(-6vw,10vh) scale(1.1)}}
@keyframes drift3{to{transform:translate(4vw,-8vh) scale(1.2)}}

/* ---------- Typographie ---------- */
h1,h2,h3,.display{font-family:'Space Grotesk','Inter',sans-serif;letter-spacing:-.02em;line-height:1.12;color:var(--ink)}
h1{font-size:clamp(1.7rem,4.5vw,2.5rem);font-weight:600;margin:.1em 0 .25em}
h2{font-size:1.2rem;font-weight:600;margin:0}
.eyebrow{font-family:'Space Grotesk',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.18em;
    text-transform:uppercase;color:var(--primary)}
.lead{color:var(--ink-soft);font-size:1.05rem;margin:.35em 0 1.4em;max-width:46ch}
.muted{color:var(--muted)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-title{font-family:'Space Grotesk',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.16em;
    text-transform:uppercase;color:var(--muted);margin:2rem 0 .9rem;display:flex;align-items:center;gap:10px}
.section-title::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- Layout ---------- */
.container{max-width:820px;margin:0 auto;padding:22px 18px 130px;position:relative}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
    padding:14px 22px;background:var(--glass);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:8px;color:var(--ink);font-family:'Space Grotesk',sans-serif;
    font-weight:600;font-size:1.12rem}
.brand .spark{width:26px;height:26px;border-radius:8px;background:var(--grad);display:grid;place-items:center;
    color:#fff;box-shadow:var(--shadow-glow);font-size:.9rem;}
@keyframes pulseGlow{0%,100%{box-shadow:0 6px 18px rgba(91,91,240,.3)}50%{box-shadow:0 10px 30px rgba(91,91,240,.55)}}
.topnav{display:none;gap:6px}
.topnav a{color:var(--ink-soft);font-weight:500;font-size:.95rem;padding:8px 14px;border-radius:10px;
    transition:background .2s,color .2s}
.topnav a:hover{background:rgba(91,91,240,.08);color:var(--primary)}

/* ---------- Bottom tab bar (mobile) ---------- */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;justify-content:space-around;align-items:flex-end;
    padding:9px 0 calc(9px + env(safe-area-inset-bottom));background:var(--glass-strong);
    border-top:1px solid var(--line)}
.tabbar a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.7rem;color:var(--muted);
    font-weight:500;transition:color .2s}
.tabbar a .ic{font-size:1.25rem;transition:transform .25s var(--ease-spring)}
.tabbar a:active .ic{transform:scale(.85)}
.tabbar .tab-create .ic{background:var(--grad);color:#fff;width:50px;height:50px;border-radius:18px;
    display:grid;place-items:center;margin-top:-28px;box-shadow:var(--shadow-glow);font-size:1.5rem;
    transition:transform .3s var(--ease-spring)}
.tabbar .tab-create:active .ic{transform:scale(.9) rotate(90deg)}

/* ---------- Cards / glass ---------- */
.card{position:relative;background:var(--glass-strong);
    border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}
.card-glow::before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
    background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;overflow:hidden;
    border:none;border-radius:15px;padding:15px 22px;font-size:1rem;font-weight:600;font-family:inherit;
    cursor:pointer;min-height:54px;transition:transform .12s var(--ease-spring),box-shadow .25s,filter .2s;
    -webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 14px 46px rgba(91,91,240,.42)}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.btn-soft{background:rgba(91,91,240,.10);color:var(--primary)}
.btn-soft:hover{background:rgba(91,91,240,.16)}
.btn-ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-block{width:100%}
.btn-lg{min-height:60px;font-size:1.06rem}
.btn .ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.5);
    animation:ripple .6s var(--ease);pointer-events:none}
@keyframes ripple{to{transform:scale(2.6);opacity:0}}

/* ---------- Forms ---------- */
.form label{display:block;font-weight:600;font-size:.93rem;margin:16px 0 7px;color:var(--ink-soft)}
.form input,.form select,.form textarea{width:100%;padding:14px 15px;border:1.5px solid var(--line-strong);
    border-radius:13px;font-size:1rem;font-family:inherit;background:rgba(255,255,255,.8);color:var(--ink);
    transition:border-color .2s,box-shadow .2s,background .2s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(91,91,240,.14);background:#fff}
.form input[type=color]{height:54px;padding:6px;cursor:pointer}
.grid-2{display:grid;grid-template-columns:1fr;gap:0 18px}

/* ---------- Auth ---------- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:430px;background:var(--glass-strong);border:1px solid var(--line);border-radius:28px;padding:36px 28px;
    box-shadow:var(--shadow)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;font-family:'Space Grotesk',sans-serif;
    font-size:1.6rem;font-weight:600;margin:0 0 6px}
.auth-logo .spark{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center;
    color:#fff;box-shadow:var(--shadow-glow)}
.auth-sub{text-align:center;color:var(--muted);margin:0 0 22px}
.auth-foot{text-align:center;margin-top:18px;color:var(--muted);font-size:.95rem}
.auth-demo{text-align:center;margin-top:12px;font-size:.82rem;color:var(--muted)}
.auth-demo code{background:rgba(91,91,240,.1);color:var(--primary);padding:2px 7px;border-radius:7px}

/* ---------- Flash ---------- */
.flash{padding:14px 18px;border-radius:14px;margin-bottom:18px;font-weight:500;border:1px solid transparent;
    animation:dropIn .5s var(--ease-spring)}
@keyframes dropIn{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}
.flash-success{background:rgba(16,185,129,.12);color:#0a7d5c;border-color:rgba(16,185,129,.25)}
.flash-error{background:rgba(244,63,94,.1);color:#b81e3c;border-color:rgba(244,63,94,.25)}
.flash-info{background:rgba(91,91,240,.1);color:var(--primary);border-color:rgba(91,91,240,.22)}

/* ---------- Reveal (entrée échelonnée) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);
    transition:opacity .55s var(--ease),transform .55s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Route transition veil ---------- */
.route-veil{position:fixed;inset:0;z-index:90;background:var(--canvas);pointer-events:none;opacity:0;
    transform:translateY(100%)}
.route-veil.show{animation:veilIn .42s var(--ease) forwards}
@keyframes veilIn{from{opacity:0;transform:translateY(8%)}to{opacity:1;transform:translateY(0)}}

/* ---------- Hero (dashboard) ---------- */
.hero{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:6px}
.greeting .hi{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.7rem,5vw,2.3rem);font-weight:600}
.plan-badge{display:inline-flex;align-items:center;gap:6px;background:var(--glass-strong);border:1px solid var(--line);
    padding:8px 14px;border-radius:30px;font-size:.78rem;font-weight:600;color:var(--ink-soft);white-space:nowrap;
    box-shadow:var(--shadow-sm)}
.plan-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--grad)}

.completion{display:block;background:var(--glass-strong);border:1px solid var(--line);border-radius:var(--radius);
    padding:16px 18px;margin:14px 0 6px;color:var(--ink-soft);box-shadow:var(--shadow-sm);text-decoration:none;
    transition:transform .25s var(--ease),box-shadow .25s}
.completion:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.completion .bar{display:block;height:9px;background:rgba(14,20,48,.07);border-radius:6px;margin-top:10px;overflow:hidden}
.completion .bar span{display:block;height:100%;background:var(--grad);border-radius:6px;width:0;
    transition:width 1.1s var(--ease)}

/* ---------- Action grid ---------- */
.actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:13px}
.action-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:10px;
    background:var(--glass-strong);border:1px solid var(--line);border-radius:var(--radius);padding:18px 16px;
    color:var(--ink);box-shadow:var(--shadow-sm);text-decoration:none;overflow:hidden;min-height:120px;
    justify-content:space-between;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.action-card::after{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .3s;z-index:0}
.action-card>*{position:relative;z-index:1;transition:color .3s}
.action-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-glow);border-color:transparent}
.action-card:hover::after{opacity:1}
.action-card:hover .lbl,.action-card:hover .ar{color:#fff}
.action-card:hover .ico{transform:scale(1.1) rotate(-4deg)}
.action-card .ico{font-size:1.7rem;width:48px;height:48px;border-radius:14px;background:rgba(91,91,240,.1);
    display:grid;place-items:center;transition:transform .3s var(--ease-spring)}
.action-card:hover .ico{background:rgba(255,255,255,.22)}
.action-card .lbl{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.98rem;line-height:1.25}
.action-card .ar{align-self:flex-end;font-size:1.1rem;color:var(--muted);margin-top:-26px}
.action-card.soon{opacity:.6}
.action-card.soon:hover{transform:none;box-shadow:var(--shadow-sm)}
.action-card.soon:hover::after{opacity:0}
.action-card .tag{position:absolute;top:12px;right:12px;background:rgba(14,20,48,.07);color:var(--muted);
    font-size:.64rem;font-weight:600;padding:3px 8px;border-radius:10px;z-index:2}

/* ---------- Dashboard widgets ---------- */
.dash-cols{display:grid;grid-template-columns:1fr;gap:14px;margin-top:6px}
.stats{display:flex;gap:28px}
.stats .big{display:block;font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:600;
    background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums}
.stats .lbl{font-size:.84rem;color:var(--muted)}

.recent-list{display:flex;flex-direction:column;gap:11px}
.recent-item{display:grid;grid-template-columns:auto 1fr auto;gap:4px 14px;align-items:center;
    background:var(--glass-strong);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;
    color:var(--ink);text-decoration:none;box-shadow:var(--shadow-sm);
    transition:transform .25s var(--ease),box-shadow .25s}
.recent-item:hover{transform:translateX(5px);box-shadow:var(--shadow)}
.recent-item .ric{font-size:1.3rem;grid-row:1/3}
.recent-item strong{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.96rem}
.recent-item .preview{grid-column:2/3;color:var(--muted);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent-item .date{grid-row:1/3;grid-column:3/4;color:var(--muted);font-size:.8rem}

/* ===================================================================
   WIZARD — l'expérience d'assemblage (signature)
   =================================================================== */
.wizard{max-width:680px;margin:0 auto}
.wizard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-weight:500;text-decoration:none;
    transition:color .2s,transform .2s}
.back:hover{color:var(--primary);transform:translateX(-3px)}
.step-count{font-family:'Space Grotesk',sans-serif;font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums}

/* piste de construction */
.track{display:flex;gap:7px;margin-bottom:26px}
.track .seg{flex:1;height:7px;border-radius:6px;background:rgba(14,20,48,.08);overflow:hidden;position:relative}
.track .seg.done{background:var(--grad)}
.track .seg.active::after{content:"";position:absolute;inset:0;background:var(--grad);
    animation:fillSeg .5s var(--ease) forwards}
@keyframes fillSeg{from{transform:translateX(-100%)}to{transform:translateX(0)}}

.wizard-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.wizard-ico{font-size:1.7rem;width:54px;height:54px;border-radius:16px;background:var(--glass-strong);
    border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow-sm)}

/* aperçu qui se construit */
.scaffold{background:var(--glass);border:1px dashed var(--line-strong);border-radius:var(--radius);
    padding:18px;margin-bottom:22px;min-height:90px;position:relative;overflow:hidden}
.scaffold .sf-label{font-family:'Space Grotesk',sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
    color:var(--muted);margin-bottom:10px}
.sf-chips{display:flex;flex-wrap:wrap;gap:8px}
.sf-pill{background:var(--grad);color:#fff;padding:7px 13px;border-radius:11px;font-size:.85rem;font-weight:600;
    box-shadow:var(--shadow-sm);animation:snapIn .45s var(--ease-spring)}
.sf-empty{color:var(--muted);font-size:.9rem}
@keyframes snapIn{0%{opacity:0;transform:scale(.4) translateY(10px)}60%{transform:scale(1.08)}100%{opacity:1;transform:none}}

.field{margin-bottom:22px}
.field-label{display:block;font-family:'Space Grotesk',sans-serif;font-weight:600;margin-bottom:12px;font-size:1rem}

.chips{display:flex;flex-wrap:wrap;gap:11px}
.chip{position:relative;cursor:pointer}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{display:inline-flex;align-items:center;padding:13px 19px;border:1.5px solid var(--line-strong);
    border-radius:14px;background:rgba(255,255,255,.7);font-weight:600;font-size:.95rem;
    transition:all .22s var(--ease-spring)}
.chip:hover span{border-color:var(--primary);transform:translateY(-2px)}
.chip input:checked + span{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--shadow-glow);
    transform:translateY(-2px) scale(1.03)}
.chips-lg .chip span{padding:15px 24px;font-size:1rem}

.recap-intro{margin-top:0;font-size:1.05rem}
.recap-list{list-style:none;padding:0;margin:14px 0}
.recap-list li{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line)}
.recap-list li span{color:var(--muted);font-size:.9rem}
.recap-list li strong{text-align:right;max-width:62%;font-weight:600}
.recap-note{color:var(--muted);font-size:.9rem;margin:14px 0 0}

/* ---------- Generation overlay (le moment "ça se construit") ---------- */
.gen-overlay{position:fixed;inset:0;z-index:80;display:none;place-items:center;
    background:rgba(244,246,253,.7);animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.gen-box{text-align:center}
.gen-rig{width:96px;height:96px;margin:0 auto 18px;position:relative}
.gen-rig .blk{position:absolute;width:34px;height:34px;border-radius:10px;background:var(--grad);box-shadow:var(--shadow-glow)}
.gen-rig .b1{left:0;top:0;animation:assemble 1.4s var(--ease) infinite}
.gen-rig .b2{right:0;top:0;animation:assemble 1.4s var(--ease) .15s infinite}
.gen-rig .b3{left:0;bottom:0;animation:assemble 1.4s var(--ease) .3s infinite}
.gen-rig .b4{right:0;bottom:0;animation:assemble 1.4s var(--ease) .45s infinite}
@keyframes assemble{0%,100%{transform:translate(0,0) rotate(0);opacity:1}50%{transform:translate(31px,31px) rotate(45deg);opacity:.5}}
.gen-text{font-family:'Space Grotesk',sans-serif;font-weight:600;color:var(--ink);font-size:1.05rem}

/* ===================================================================
   RESULT
   =================================================================== */
.result-head{margin-bottom:12px}
.result-card{position:relative;overflow:hidden}
.result-toolbar{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.84rem;margin-bottom:14px}
.result-gen{display:inline-flex;align-items:center;gap:6px;background:rgba(91,91,240,.1);color:var(--primary);
    padding:4px 10px;border-radius:20px;font-weight:600;font-size:.78rem}
.result-text{width:100%;border:1.5px solid var(--line-strong);border-radius:14px;padding:18px;font-size:1.02rem;
    font-family:inherit;line-height:1.65;color:var(--ink);resize:vertical;background:rgba(255,255,255,.85)}
.result-text:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(91,91,240,.14)}
.result-actions{display:flex;flex-wrap:wrap;gap:11px;margin-top:16px}
.result-next{display:flex;gap:11px;flex-wrap:wrap;margin-top:4px}

/* ===================================================================
   DOCUMENTS — devis / facture
   =================================================================== */
.doc-toolbar{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center;margin-bottom:18px}
.doc-table{width:100%;border-collapse:collapse;margin-top:6px}
.doc-table th{text-align:left;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
    padding:8px 8px;font-weight:600}
.line-row{transition:opacity .3s,transform .3s}
.line-row td{padding:6px 6px;vertical-align:top}
.line-row input{padding:11px 12px;font-size:.95rem}
.line-row .col-label input{min-width:0}
.line-row .col-num input{text-align:right}
.line-row .del{background:rgba(244,63,94,.1);color:var(--err);border:none;width:40px;height:40px;border-radius:11px;
    cursor:pointer;font-size:1.1rem;transition:background .2s,transform .15s}
.line-row .del:hover{background:rgba(244,63,94,.18)}
.line-row.removing{opacity:0;transform:translateX(30px)}
.line-enter{animation:lineIn .4s var(--ease-spring)}
@keyframes lineIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.doc-totals{margin-top:18px;margin-left:auto;max-width:320px}
.doc-totals .row{display:flex;justify-content:space-between;padding:8px 0;color:var(--ink-soft)}
.doc-totals .row.total{border-top:2px solid var(--line-strong);margin-top:6px;padding-top:14px;
    font-family:'Space Grotesk',sans-serif;font-size:1.35rem;font-weight:600}
.doc-totals .row.total strong{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.doc-list{display:flex;flex-direction:column;gap:11px}
.doc-card{display:grid;grid-template-columns:auto 1fr auto auto;gap:4px 14px;align-items:center;
    background:var(--glass-strong);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px 17px;
    color:var(--ink);text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}
.doc-card:hover{transform:translateX(5px);box-shadow:var(--shadow)}
.doc-card .num{font-family:'Space Grotesk',sans-serif;font-weight:600}
.doc-card .cli{color:var(--muted);font-size:.88rem;grid-column:2}
.doc-card .amt{font-family:'Space Grotesk',sans-serif;font-weight:600;font-variant-numeric:tabular-nums}
.badge{font-size:.7rem;font-weight:600;padding:4px 10px;border-radius:20px}
.badge.draft{background:rgba(124,132,163,.16);color:var(--muted)}
.badge.sent{background:rgba(91,91,240,.12);color:var(--primary)}
.badge.accepted,.badge.paid{background:rgba(16,185,129,.14);color:#0a7d5c}
.badge.refused,.badge.overdue{background:rgba(244,63,94,.12);color:#b81e3c}

/* document imprimable */
.doc-sheet{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px;box-shadow:var(--shadow);
    color:#0E1430}
.doc-sheet .sheet-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;
    padding-bottom:22px;border-bottom:2px solid var(--line)}
.doc-sheet h1{font-size:2rem;margin:0}
.doc-sheet .sheet-table{width:100%;border-collapse:collapse;margin:24px 0}
.doc-sheet .sheet-table th{background:rgba(91,91,240,.07);text-align:left;padding:11px 12px;font-size:.8rem;
    text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.doc-sheet .sheet-table td{padding:12px;border-bottom:1px solid var(--line)}
.doc-sheet .sheet-table td.r,.doc-sheet .sheet-table th.r{text-align:right}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);
    color:#fff;padding:13px 22px;border-radius:30px;font-weight:600;font-size:.92rem;opacity:0;z-index:100;
    box-shadow:var(--shadow-glow);transition:opacity .25s,transform .25s var(--ease-spring)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- Confetti canvas ---------- */
#fx-canvas{position:fixed;inset:0;pointer-events:none;z-index:95}

/* ---------- Page head ---------- */
.page-head{margin-bottom:8px}

/* ---------- Desktop ---------- */
@media(min-width:760px){
    .topnav{display:flex}
    .tabbar{display:none}
    .container{padding-bottom:48px}
    .grid-2{grid-template-columns:1fr 1fr}
    .actions-grid{grid-template-columns:repeat(3,1fr)}
    .dash-cols{grid-template-columns:1fr 1fr;gap:16px}
}

/* ---------- Accessibilité : mouvement réduit ---------- */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
        transition-duration:.001ms !important;scroll-behavior:auto !important}
    .aurora{display:none}
    .reveal{opacity:1;transform:none;filter:none}
}

/* ---------- Impression (devis / facture) ---------- */
@media print{
    @page{margin:0}
    .aurora,.topbar,.tabbar,.no-print,.doc-toolbar,.bot,.flash{display:none !important}
    body{background:#fff;margin:0}
    .container{padding:0;max-width:none;margin:0}
    .doc-sheet{border:none;box-shadow:none;border-radius:0;padding:14mm 14mm 20mm}
    .doc-print-foot{display:block !important}
}
.doc-print-foot{display:none;position:fixed;bottom:8mm;left:0;right:0;text-align:center;font-size:.78rem;color:#6b7280}

/* =====================================================================
   DYNAMISME — curseur, magnétisme, tilt, bandeau cinétique, vitrine
   (tout est désactivé proprement sous prefers-reduced-motion / tactile)
   ===================================================================== */


/* L'aurore réagit à la souris (variables posées par le JS) */
.aurora.reactive::before{transform:translate(calc(var(--mx,0)*30px), calc(var(--my,0)*22px))}
.aurora.reactive::after{transform:translate(calc(var(--mx,0)*-26px), calc(var(--my,0)*18px))}

/* Boutons magnétiques */
.magnetic{will-change:transform;transition:transform .25s var(--ease)}

/* Parallaxe au scroll : éléments avec data-speed */
[data-speed]{will-change:transform}

/* Révélations directionnelles supplémentaires */
.reveal-l{opacity:0;transform:translateX(-32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-r{opacity:0;transform:translateX(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-l.is-in,.reveal-r.is-in{opacity:1;transform:none}

/* Texte qui se compose lettre par lettre */
.kin span{display:inline-block;opacity:0;transform:translateY(40px) rotate(6deg);
    animation:kinIn .6s var(--ease-spring) forwards}
@keyframes kinIn{to{opacity:1;transform:none}}

/* Bandeau cinétique (marquee) */
.marquee{overflow:hidden;white-space:nowrap;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee .track{display:inline-flex;gap:0;animation:marquee 26s linear infinite;will-change:transform}
.marquee .track span{padding:0 28px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.4rem;color:var(--ink-soft)}
.marquee .track .dot{color:var(--primary)}
.marquee:hover .track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}

/* Tilt 3D au survol */
.tilt{transform-style:preserve-3d;transition:transform .2s var(--ease);will-change:transform}

/* Barre de progression de lecture (guides) */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:120;transition:width .1s linear}

/* Number ticker géant (landing/stats) */
.ticker{font-family:'Space Grotesk',sans-serif;font-weight:600;font-variant-numeric:tabular-nums;
    background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

@media (prefers-reduced-motion:reduce){
    .cursor-dot,.cursor-ring{display:none}
    body.has-cursor,body.has-cursor *{cursor:auto !important}
    .marquee .track{animation:none}
    .kin span{opacity:1;transform:none;animation:none}
    .aurora.reactive::before,.aurora.reactive::after{transform:none}
}

/* ---------- Canvas 3D d'ambiance ---------- */
#scene3d{position:fixed;inset:0;z-index:-1;width:100%;height:100%;display:block;pointer-events:none}
@media (prefers-reduced-motion:reduce){ #scene3d{display:none} }

/* =====================================================================
   PAGE D'ACCUEIL (landing) — design moderne, animations légères (GPU),
   aucune dépendance lourde.
   ===================================================================== */
.landing{max-width:1180px;margin:0 auto;padding:0 22px}

/* --- Barre de navigation --- */
.lp-nav{display:flex;align-items:center;gap:18px;padding:22px 0;flex-wrap:wrap}
.lp-nav .brand{display:inline-flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;
    font-weight:700;font-size:1.15rem;color:var(--ink);text-decoration:none}
.lp-nav .brand .spark{filter:drop-shadow(0 2px 8px rgba(91,91,240,.5))}
.lp-nav .links{display:flex;align-items:center;gap:26px;margin-left:auto;margin-right:6px}
.lp-nav .links a{color:var(--muted);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s}
.lp-nav .links a:hover{color:var(--primary)}

/* --- Hero --- */
.lp-hero{text-align:center;padding:68px 0 36px}
.lp-kicker{display:inline-block;font-family:'Space Grotesk',sans-serif;font-weight:600;
    letter-spacing:.14em;text-transform:uppercase;font-size:.72rem;color:var(--primary);
    background:rgba(91,91,240,.10);padding:7px 16px;border-radius:999px;margin:0 0 22px}
.lp-hero h1{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.05;
    font-size:clamp(2.4rem,6vw,4.3rem);margin:0 0 22px;letter-spacing:-.02em;
    background:linear-gradient(100deg,#1a1f3d 0%,#5B5BF0 48%,#22D3EE 100%);
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
    background-size:220% auto;animation:hueShift 9s ease-in-out infinite}
.lp-hero > p{max-width:620px;margin:0 auto 30px;color:var(--ink-soft);font-size:1.12rem;line-height:1.6}
.lp-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.lp-scroll{display:flex;flex-direction:column;align-items:center;gap:9px;margin-top:50px;
    color:var(--muted);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase}
.lp-scroll .line{width:1.5px;height:34px;background:linear-gradient(var(--primary),transparent);
    border-radius:2px;transform-origin:top;animation:scrollPulse 1.8s ease-in-out infinite}

/* --- Bandeau défilant --- */
.marquee{margin:26px 0 6px;overflow:hidden;white-space:nowrap;
    -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
    mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:inline-flex;animation:marquee 32s linear infinite;white-space:nowrap;will-change:transform}
.marquee-track span{display:inline-flex;align-items:center;padding:0 4px;color:var(--muted);font-weight:500;font-size:.95rem}
.marquee-track span::after{content:"•";margin:0 22px;color:var(--primary);opacity:.45}

/* --- Sections --- */
.lp-section{padding:62px 0;text-align:center}
.lp-section h2{font-family:'Space Grotesk',sans-serif;font-weight:700;
    font-size:clamp(1.6rem,3.4vw,2.4rem);margin:14px auto 40px;max-width:680px;letter-spacing:-.01em;color:var(--ink)}

/* --- Grille de fonctionnalités --- */
.lp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;text-align:left}
.lp-feature{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 26px;
    box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.lp-feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(91,91,240,.32)}
.lp-feature .fic{width:54px;height:54px;display:flex;align-items:center;justify-content:center;
    font-size:1.55rem;border-radius:15px;margin-bottom:18px;
    background:linear-gradient(135deg,rgba(91,91,240,.15),rgba(34,211,238,.15))}
.lp-feature h3{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.16rem;margin:0 0 9px;color:var(--ink)}
.lp-feature p{margin:0;color:var(--muted);line-height:1.6;font-size:.97rem}

/* --- Statistiques --- */
.lp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:760px;margin:0 auto;
    background:#fff;border:1px solid var(--line);border-radius:24px;padding:38px 24px;box-shadow:var(--shadow-sm)}
.lp-stat .n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(2rem,5vw,3rem);line-height:1;
    background:linear-gradient(120deg,#5B5BF0,#22D3EE);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lp-stat .l{margin-top:10px;color:var(--muted);font-size:.92rem}

/* --- CTA final + footer --- */
.lp-final{text-align:center;padding:78px 22px 30px;max-width:1180px;margin:20px auto 0}
.lp-final h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(1.8rem,4vw,2.8rem);margin:0}
.grad-text{background:linear-gradient(100deg,#5B5BF0,#22D3EE);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lp-foot{text-align:center;padding:40px 22px 56px;color:var(--muted);font-size:.9rem;border-top:1px solid var(--line);margin-top:36px}

@media (max-width:640px){
    .lp-nav{justify-content:center}
    .lp-nav .links{gap:16px;margin:0;order:3;width:100%;justify-content:center}
    .lp-stats{grid-template-columns:1fr;gap:14px}
}

/* --- Keyframes légers (transform/opacity uniquement) --- */
@keyframes hueShift{0%,100%{background-position:0% center}50%{background-position:100% center}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* =====================================================================
   EFFETS LANDING (légers : transform/opacité uniquement)
   ===================================================================== */

/* --- Toile d'araignée : fils + points lumineux qui suivent le scroll --- */
.web{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.web-mesh{position:absolute;inset:0;width:100%;height:100%}
.web-mesh path{fill:none;stroke:rgba(91,91,240,.06);stroke-width:1;vector-effect:non-scaling-stroke}
.thread{position:absolute;top:0;height:100%;width:1px;
    background:linear-gradient(180deg,transparent,rgba(91,91,240,.10) 18%,rgba(34,211,238,.10) 82%,transparent)}
.thread::after{content:"";position:absolute;left:-2px;top:0;width:5px;height:5px;border-radius:50%;
    background:var(--primary);box-shadow:0 0 12px 2px rgba(91,91,240,.5);
    animation:flowY 7s linear infinite;will-change:transform}
@keyframes flowY{
    0%{transform:translateY(-12vh);opacity:0}
    8%{opacity:1}92%{opacity:1}
    100%{transform:translateY(102vh);opacity:0}
}
body.scroll-up .thread::after{animation-direction:reverse}

/* --- Mot "mouvement" : vibration moteur puis retour au calme --- */
.rev{display:inline-block;transform-origin:center;
    background:linear-gradient(100deg,#5B5BF0,#22D3EE 72%);
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
    animation:engine 4.6s ease-in-out infinite}
@keyframes engine{
    0%,80%,100%{transform:translate(0,0) rotate(0deg)}
    81%{transform:translate(-1.2px,1px) rotate(-.5deg)}
    83%{transform:translate(1.3px,-1px) rotate(.5deg)}
    85%{transform:translate(-1.4px,.5px) rotate(-.6deg)}
    87%{transform:translate(1.4px,1px) rotate(.6deg)}
    89%{transform:translate(-1px,-1px) rotate(-.4deg)}
    91%{transform:translate(1px,.6px) rotate(.4deg)}
    93%{transform:translate(-.6px,1px) rotate(-.2deg)}
    95%{transform:translate(.6px,-.6px) rotate(.2deg)}
    97%{transform:translate(0,.5px) rotate(0)}
}

/* --- Nuage de vignettes d'exemples au survol des cartes --- */
.lp-feature{position:relative}
.lp-feature:hover{z-index:6}
.fcloud{position:absolute;inset:0;pointer-events:none}
.fcloud .ex{position:absolute;display:inline-flex;align-items:center;gap:6px;
    padding:7px 11px;border-radius:12px;background:#fff;border:1px solid var(--line);
    box-shadow:var(--shadow);font-size:.76rem;font-weight:600;color:var(--ink);white-space:nowrap;
    opacity:0;transform:translateY(10px) scale(.82);
    transition:opacity .35s var(--ease),transform .45s var(--ease-spring)}
.fcloud .ex b{font-size:.98rem;line-height:1}
.fcloud .ex:nth-child(1){top:-18px;right:6px}
.fcloud .ex:nth-child(2){bottom:-16px;left:4px}
.fcloud .ex:nth-child(3){top:44%;right:-16px}
.lp-feature:hover .fcloud .ex{opacity:1;transform:translateY(0) scale(1)}
.lp-feature:hover .fcloud .ex:nth-child(1){animation:bob 3.2s ease-in-out .18s infinite}
.lp-feature:hover .fcloud .ex:nth-child(2){animation:bob 3.6s ease-in-out .32s infinite}
.lp-feature:hover .fcloud .ex:nth-child(3){animation:bob 3s ease-in-out .46s infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* Mouvement réduit : on calme tout */
@media (prefers-reduced-motion:reduce){
    .thread::after,.rev,.fcloud .ex{animation:none !important}
    .rev{transform:none !important}
}

/* --- Tarifs --- */
.lp-pricing .price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:22px;align-items:stretch;text-align:left}
.price-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px 28px;
    display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
    transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price-card.featured{border:1.5px solid transparent;box-shadow:var(--shadow-glow);
    background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#5B5BF0,#22D3EE) border-box}
.price-card .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
    background:linear-gradient(120deg,#5B5BF0,#22D3EE);color:#fff;font-size:.72rem;font-weight:700;
    padding:6px 14px;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-glow)}
.price-card h3{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.25rem;margin:0 0 6px;color:var(--ink)}
.price-card .price{display:flex;align-items:baseline;gap:6px;margin:6px 0 4px}
.price-card .amt{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:2.6rem;line-height:1;color:var(--ink)}
.price-card.featured .amt{background:linear-gradient(120deg,#5B5BF0,#22D3EE);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.price-card .per{color:var(--muted);font-size:.92rem}
.price-card .ptag{color:var(--primary);font-weight:600;font-size:.9rem;margin:0 0 18px}
.price-feats{list-style:none;padding:0;margin:0 0 24px;flex:1;display:flex;flex-direction:column;gap:11px}
.price-feats li{position:relative;padding-left:26px;color:var(--ink-soft);font-size:.95rem;line-height:1.45}
.price-feats li::before{content:"✓";position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;
    background:rgba(91,91,240,.12);color:var(--primary)}
.price-card .btn{width:100%}
.price-note{text-align:center;color:var(--muted);font-size:.92rem;margin:28px auto 0;max-width:540px}
@media (max-width:640px){.price-card.featured{transform:none}}

/* =====================================================================
   CARNET DE CLIENTS + nouveau client à la volée
   ===================================================================== */
.btn-sm{min-height:34px;padding:7px 14px;font-size:.85rem;border-radius:11px}

.client-list{display:flex;flex-direction:column;gap:12px}
.client-row{display:flex;align-items:center;gap:16px;padding:16px 18px}
.client-row .cl-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;text-decoration:none}
.client-row .cl-name{font-weight:600;color:var(--ink);font-size:1.02rem}
.client-row .cl-meta{color:var(--muted);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-row .cl-count{color:var(--muted);font-size:.82rem;white-space:nowrap;
    background:rgba(91,91,240,.08);padding:5px 10px;border-radius:999px}
.client-row .cl-actions{display:flex;align-items:center;gap:8px}
.client-row .cl-actions form{margin:0}
@media (max-width:560px){
    .client-row{flex-wrap:wrap}
    .client-row .cl-count{order:3}
    .client-row .cl-actions{order:4;margin-left:auto}
}

/* Bloc "nouveau client" dans le formulaire devis/facture */
.newcli{margin:8px 0 4px;padding:16px;border:1px dashed var(--line-strong);border-radius:14px;
    background:rgba(91,91,240,.03)}
.newcli[hidden]{display:none}

/* =====================================================================
   LOGO ENTREPRISE (documents + champ d'upload)
   ===================================================================== */
.doc-logo{max-height:70px;max-width:220px;object-fit:contain;display:block;margin:0 0 10px}

.logo-field{display:flex;align-items:center;gap:18px;margin:6px 0;flex-wrap:wrap}
.logo-preview{width:124px;height:86px;border:1px solid var(--line);border-radius:14px;
    display:flex;align-items:center;justify-content:center;overflow:hidden;background:#fff;flex:none}
.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}
.logo-empty{color:var(--muted);font-size:.85rem}
.logo-controls{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.logo-upload{cursor:pointer;display:inline-block;margin:0}
.logo-name{font-size:.85rem}
.logo-remove{display:flex;align-items:center;gap:7px;font-size:.88rem;color:var(--muted);cursor:pointer}

/* =====================================================================
   CALENDRIER DE PUBLICATIONS
   ===================================================================== */
.cal-nav{display:flex;align-items:center;gap:10px;margin:6px 0 14px}
.cal-title{font-size:1.15rem;margin:0;text-transform:capitalize;min-width:150px;text-align:center}
.cal-today{margin-left:auto}

.cal-grid{padding:10px}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-week + .cal-week{margin-top:6px}
.cal-wd{text-align:center;font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 0}
.cal-cell{min-height:74px;border:1px solid var(--line);border-radius:12px;padding:5px;background:#fff;
    display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.cal-cell:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.cal-cell.empty{border:none;background:transparent;cursor:default}
.cal-cell.today{border-color:var(--primary);background:rgba(91,91,240,.05)}
.cal-num{font-size:.8rem;font-weight:600;color:var(--ink-soft)}
.cal-cell.today .cal-num{color:var(--primary)}
.cal-chip{font-size:.66rem;line-height:1.3;background:rgba(91,91,240,.12);color:var(--primary);
    border-radius:6px;padding:1px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.cal-chip.done{background:rgba(16,185,129,.14);color:#0F9D6B}

.cal-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px}
.cal-row + .cal-row{border-top:1px solid var(--line)}
.cal-row-main{display:flex;align-items:center;gap:11px;min-width:0}
.cal-row-ic{font-size:1.3rem;flex:none}
.cal-row-when{margin:0;font-size:.9rem}
.cal-row-prev{margin:.1em 0 0;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:46vw}
.cal-row-act{display:flex;align-items:center;gap:6px;flex:none}

.badge.planned{background:rgba(91,91,240,.12);color:var(--primary)}
.badge.published{background:rgba(16,185,129,.14);color:#0F9D6B}
.badge.failed{background:rgba(239,68,68,.12);color:#DC2626}

.dash-up{display:flex;flex-direction:column;gap:8px;margin:.4em 0 0}
.dash-up-row{display:flex;align-items:center;gap:9px;font-size:.9rem}
.dash-up-ic{font-size:1.1rem;flex:none}
.dash-up-when{font-weight:600;flex:none}
.dash-up-prev{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Avertissement essai (partie web) */
.trial-hint{background:rgba(91,91,240,.07);border:1px solid var(--line);border-radius:12px;
    padding:10px 14px;font-size:.86rem;color:var(--ink-soft);margin:-2px 0 12px}
.trial-hint a{color:var(--primary);font-weight:600;white-space:nowrap}

/* =====================================================================
   CHATBOT D'AIDE (Fasty)
   ===================================================================== */
.bot{position:fixed;right:18px;bottom:18px;z-index:60}
@media (max-width:720px){ .bot{bottom:78px} }
.bot-launch{position:relative;width:62px;height:62px;border-radius:20px;border:none;cursor:pointer;
    background:#fff;box-shadow:var(--shadow);display:grid;place-items:center;transition:transform .25s var(--ease-spring)}
.bot-launch:hover{transform:translateY(-3px) scale(1.04)}
.bot-launch:active{transform:scale(.94)}
.bot-robot{width:42px;height:42px}
.bot-robot .bot-eye{transform-box:fill-box;transform-origin:center;animation:botBlink 4.5s infinite}
@keyframes botBlink{0%,92%,100%{transform:scaleY(1)}95%{transform:scaleY(.1)}}
.bot-ping{position:absolute;top:-3px;right:-3px;width:14px;height:14px;border-radius:50%;background:#22D3EE;border:2px solid #fff}
.bot-ping::after{content:"";position:absolute;inset:-2px;border-radius:50%;background:#22D3EE;opacity:.6;animation:botPing 1.8s ease-out infinite}
@keyframes botPing{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.4);opacity:0}}
.bot.open .bot-ping{display:none}

.bot-panel{position:absolute;right:0;bottom:74px;width:min(360px,calc(100vw - 28px));
    height:min(520px,calc(100vh - 130px));background:#fff;border:1px solid var(--line);border-radius:22px;
    box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;animation:botIn .28s var(--ease-spring)}
@keyframes botIn{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
.bot-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;background:var(--grad);color:#fff}
.bot-head-id{display:flex;align-items:center;gap:10px}
.bot-mini{width:34px;height:34px;background:rgba(255,255,255,.18);border-radius:11px;display:grid;place-items:center}
.bot-mini svg{width:26px;height:26px}
.bot-head-id strong{display:block;font-size:1rem;line-height:1.1}
.bot-status{font-size:.72rem;opacity:.92}
.bot-close{background:rgba(255,255,255,.18);border:none;color:#fff;width:30px;height:30px;border-radius:9px;cursor:pointer;font-size:.85rem}
.bot-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:var(--canvas)}
.bot-panel[hidden]{display:none!important}
.bot-panel .bot-msg{position:static!important;left:auto!important;right:auto!important;bottom:auto!important;transform:none!important}
.bot-msg{display:flex;align-items:flex-end;gap:7px;max-width:88%}
.bot-msg.user{align-self:flex-end;flex-direction:row-reverse}
.bot-av{width:26px;height:26px;border-radius:8px;flex:none;background:var(--grad)}
.bot-bubble{padding:9px 12px;border-radius:14px;font-size:.9rem;line-height:1.45;white-space:pre-wrap}
.bot-msg.bot .bot-bubble{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px;color:var(--ink)}
.bot-msg.user .bot-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:5px}
.bot-dots{display:inline-flex;gap:4px}
.bot-dots i{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:botDot 1s infinite}
.bot-dots i:nth-child(2){animation-delay:.15s}.bot-dots i:nth-child(3){animation-delay:.3s}
@keyframes botDot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.bot-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;background:var(--canvas);border-top:1px solid var(--line)}
.bot-chip{background:#fff;border:1px solid var(--line);color:var(--primary);font-weight:600;font-size:.8rem;padding:6px 11px;border-radius:999px;cursor:pointer;transition:background .15s}
.bot-chip:hover{background:rgba(91,91,240,.08)}
.bot-input{display:flex;gap:8px;padding:10px;border-top:1px solid var(--line);background:#fff}
.bot-input input{flex:1;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-size:.9rem;font-family:inherit}
.bot-input button{background:var(--primary);color:#fff;border:none;border-radius:12px;width:42px;cursor:pointer;font-size:1rem}

/* =====================================================================
   SUPPORT / TICKETS + BACK-OFFICE ADMIN
   ===================================================================== */
.tk-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:12px;text-decoration:none;color:inherit}
.tk-row:hover{background:rgba(91,91,240,.05)}
.tk-row + .tk-row{border-top:1px solid var(--line)}
.tk-subj{margin:0;font-weight:600}
.tk-meta{margin:.15em 0 0;font-size:.82rem}

.tk-thread{display:flex;flex-direction:column;gap:12px}
.tk-msg{max-width:85%;display:flex;flex-direction:column;gap:3px}
.tk-msg.me{align-self:flex-end;align-items:flex-end}
.tk-bubble{padding:10px 13px;border-radius:14px;font-size:.92rem;line-height:1.5}
.tk-msg:not(.me) .tk-bubble{background:var(--canvas);border:1px solid var(--line);border-bottom-left-radius:5px}
.tk-msg.me .tk-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:5px}
.tk-time{font-size:.72rem;color:var(--muted)}

.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.admin-stats .card{text-align:center;padding:18px 10px}
.admin-stats .big{display:block;font-size:1.9rem;font-weight:700;color:var(--primary);line-height:1}
.admin-stats .lbl{font-size:.8rem;color:var(--muted)}
@media (max-width:640px){.admin-stats{grid-template-columns:repeat(2,1fr)}}
.admin-links{display:flex;gap:10px;flex-wrap:wrap}
.admin-search{display:flex;gap:8px;margin-bottom:14px}
.admin-search input{flex:1;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-family:inherit}
.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}
.admin-table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:12px;border-bottom:1px solid var(--line)}
.admin-table td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top}
.admin-table tr:last-child td{border-bottom:none}
.admin-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chip{padding:6px 13px;border-radius:999px;border:1px solid var(--line);font-size:.85rem;color:var(--ink-soft);background:#fff;cursor:pointer;text-decoration:none;display:inline-block}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* =====================================================================
   GÉNÉRATEUR DE SITE VITRINE
   ===================================================================== */
.site-promo{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:30px 26px;border:1px solid rgba(91,91,240,.25);
    border-radius:20px;background:linear-gradient(135deg,rgba(91,91,240,.10),rgba(34,211,238,.10));
    text-decoration:none;color:inherit;margin-bottom:18px;transition:transform .2s,box-shadow .2s}
.site-promo:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(91,91,240,.18)}
.site-promo .sp-ic{font-size:2.8rem;flex:none}
.site-promo .sp-txt{display:flex;flex-direction:column;align-items:center;gap:4px}
.site-promo .sp-txt strong{font-size:1.5rem;font-weight:800}
.site-promo .sp-txt small{color:var(--muted);font-size:1rem}
.site-promo .sp-ar{color:#fff;background:var(--primary);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:1.2rem;margin-top:4px}

.site-toggles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:8px}
.site-toggle{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:14px;
    padding:12px 14px;cursor:pointer;transition:border-color .15s,background .15s}
.site-toggle input{accent-color:var(--primary);width:18px;height:18px;flex:none}
.site-toggle:has(input:checked){border-color:var(--primary);background:rgba(91,91,240,.05)}
.site-toggle .st-ic{font-size:1.2rem}
.site-toggle .st-lbl{font-weight:600;font-size:.92rem}

.site-styles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
.site-style{border:1px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;display:flex;flex-direction:column;gap:2px}
.site-style input{accent-color:var(--primary)}
.site-style span{font-weight:700}
.site-style small{color:var(--muted)}
.site-style:has(input:checked){border-color:var(--primary);background:rgba(91,91,240,.05)}

.site-themes{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.site-theme{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}
.site-theme input{display:none}
.site-theme .sw{width:54px;height:54px;border-radius:14px;border:3px solid transparent;transition:border-color .15s}
.site-theme:has(input:checked) .sw{border-color:var(--ink)}
.site-theme small{font-size:.78rem;color:var(--muted)}

.site-frame{width:100%;height:560px;border:1px solid var(--line);border-radius:14px;background:#fff;display:block}

.guide-step{margin-bottom:14px}
.guide-step h3{font-size:1.08rem;margin:0 0 8px}
.guide-step p{margin:.5em 0}
.guide-step ul{margin:.4em 0 .4em 1.1em}
.guide-step li{margin:.25em 0}
.guide-step code{background:rgba(91,91,240,.08);padding:1px 6px;border-radius:6px;font-size:.88em}

/* =====================================================================
   LANDING — grilles 3/ligne, espacement réduit, tarifs, survols
   ===================================================================== */
@media(min-width:900px){ .lp-grid{grid-template-columns:repeat(3,1fr)} }
.lp-section{padding-top:48px;padding-bottom:48px}
.lp-grid{gap:18px}

@media(min-width:780px){
    .price-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-width:820px;margin:30px auto 0;gap:22px;align-items:stretch}
    .price-grid .price-center{grid-column:1 / -1;justify-self:center;width:100%;max-width:400px}
}

/* Survols sur les "bulles" et mots clés */
.lp-kicker{transition:transform .2s, box-shadow .2s, background .2s; cursor:default}
.lp-kicker:hover{transform:translateY(-2px) scale(1.05); box-shadow:0 10px 24px rgba(91,91,240,.28)}
.rev{transition:filter .2s, transform .2s}
.rev:hover{transform:translateY(-1px); filter:drop-shadow(0 6px 16px rgba(91,91,240,.5))}
.fcloud .ex{transition:transform .18s, box-shadow .18s}
.fcloud .ex:hover{transform:translateY(-3px) rotate(-2deg); box-shadow:0 8px 18px rgba(2,8,40,.16)}
.lp-feature h3{transition:color .2s}
.lp-feature:hover h3{color:var(--primary)}
.lp-hero h1 .rev:hover{cursor:pointer}

/* =====================================================================
   AVIS — carrousel
   ===================================================================== */
.lp-reviews{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:10px 4px 18px;margin-top:26px;-webkit-overflow-scrolling:touch}
.lp-reviews::-webkit-scrollbar{height:8px}
.lp-reviews::-webkit-scrollbar-thumb{background:rgba(91,91,240,.3);border-radius:99px}
.rev-card{flex:none;width:300px;scroll-snap-align:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.rev-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.rev-card .rev-stars{color:#FBBF24;letter-spacing:2px;margin-bottom:10px}
.rev-card p{font-size:.98rem;line-height:1.55;margin:0}
.rev-card .rev-who{display:block;margin-top:12px;font-weight:700;color:var(--muted);font-size:.9rem}

/* =====================================================================
   FOOTER PRO
   ===================================================================== */
.site-foot{margin-top:40px;padding:46px 22px 26px;border-top:1px solid var(--line);background:rgba(255,255,255,.6)}
.sf-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1.4fr 1fr;gap:30px}
.sf-brand .sf-logo{font-weight:800;font-size:1.15rem;margin-bottom:10px}
.sf-brand p{color:var(--muted);font-size:.92rem;margin:6px 0}
.sf-secure{font-size:.85rem !important;color:var(--ink) !important;font-weight:600}
.sf-col h4{font-size:.95rem;margin-bottom:12px}
.sf-col a{display:block;color:var(--muted);text-decoration:none;font-size:.9rem;padding:4px 0;transition:color .15s}
.sf-col a:hover{color:var(--primary)}
.sf-bottom{max-width:1100px;margin:26px auto 0;padding-top:18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}
@media(max-width:760px){.sf-grid{grid-template-columns:1fr 1fr}.sf-brand{grid-column:1/-1}}

/* =====================================================================
   BOUTON REMONTER + BANDEAU COOKIES + FENÊTRE DE CONNEXION
   ===================================================================== */
.to-top{position:fixed;left:18px;bottom:20px;width:46px;height:46px;border-radius:50%;border:none;cursor:pointer;
    background:var(--primary);color:#fff;font-size:1.3rem;line-height:1;box-shadow:0 10px 26px rgba(91,91,240,.4);
    opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .25s,transform .25s;z-index:60}
.to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.to-top:hover{transform:translateY(-3px)}

.cookie-bar{position:fixed;left:14px;right:14px;bottom:14px;z-index:80;background:#fff;border:1px solid var(--line);
    border-radius:16px;box-shadow:0 18px 50px rgba(2,8,40,.18);padding:16px 18px;display:flex;align-items:center;gap:16px;
    flex-wrap:wrap;justify-content:space-between;opacity:0;transform:translateY(14px);transition:opacity .3s,transform .3s}
.cookie-bar.show{opacity:1;transform:translateY(0)}
.cookie-bar p{margin:0;font-size:.9rem;color:var(--ink);flex:1;min-width:240px}
.cookie-bar p a{color:var(--primary);font-weight:600}
.cookie-bar .cookie-actions{display:flex;gap:10px}
.cookie-bar .btn{padding:9px 18px;min-height:0}

.login-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;transition:opacity .25s}
.login-modal[hidden]{display:none !important}
.login-modal.show{opacity:1}
.login-modal .lm-backdrop{position:absolute;inset:0;background:rgba(8,12,32,.55)}
.lm-card{position:relative;background:#fff;border-radius:22px;max-width:420px;width:100%;padding:30px 26px;box-shadow:0 30px 80px rgba(2,8,40,.35);transform:translateY(14px) scale(.98);transition:transform .25s}
.login-modal.show .lm-card{transform:none}
.lm-close{position:absolute;top:12px;right:14px;border:none;background:none;font-size:1.3rem;cursor:pointer;color:var(--muted);line-height:1}
.lm-logo{font-weight:800;font-size:1.1rem;margin-bottom:6px}
.lm-card h3{margin:0 0 16px;font-size:1.3rem}
.lm-form{display:flex;flex-direction:column;gap:12px}
.lm-form label{display:flex;flex-direction:column;gap:5px;font-size:.85rem;font-weight:600;color:var(--muted)}
.lm-form input{padding:12px 14px;border:1px solid var(--line);border-radius:12px;font:inherit;color:var(--ink)}
.lm-err{background:rgba(220,40,60,.08);color:#b3203a;padding:10px 12px;border-radius:10px;font-size:.9rem;margin-bottom:6px}
.lm-alt{margin-top:14px;font-size:.9rem;color:var(--muted);text-align:center}
.lm-alt a{color:var(--primary);font-weight:600}

/* =====================================================================
   COMPTE (zone danger) + PAGES LÉGALES + STYLES SITE BUILDER
   ===================================================================== */
.danger-zone{border:1px solid rgba(220,40,60,.25)}
.btn-danger{background:#dc2626;color:#fff;border:none}
.btn-danger:hover{background:#b91c1c}

.legal{max-width:780px;margin:0 auto;padding:18px 4px 60px}
.legal-home{display:inline-block;margin-bottom:18px;color:var(--primary);font-weight:600;text-decoration:none}
.legal h1{font-size:2rem;margin-bottom:6px}
.legal h2{font-size:1.2rem;margin:26px 0 8px}
.legal p,.legal li{color:var(--ink);line-height:1.65}
.legal ul{margin:.4em 0 .4em 1.2em}
.legal li{margin:.3em 0}
.legal-upd{color:var(--muted);font-size:.85rem;margin-bottom:10px}
.legal-note{margin-top:24px;background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.3);padding:12px 14px;border-radius:12px;font-size:.88rem}
.refund-form{margin-top:10px}

.site-styles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}

/* ===== Grande carte "création de site" (section Visibilité & Web) ===== */
.site-hero-promo{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:30px;margin-top:22px;padding:34px 36px;border-radius:24px;
    background:linear-gradient(135deg, rgba(91,91,240,.13), rgba(34,211,238,.13));
    border:1px solid rgba(91,91,240,.25);color:inherit;position:relative;overflow:hidden}
.site-promo-badge{display:inline-block;background:var(--primary);color:#fff;font-size:.72rem;font-weight:700;
    letter-spacing:.04em;padding:4px 12px;border-radius:99px;margin-bottom:12px}
.site-promo-text h3{font-size:1.7rem;margin:0 0 10px}
.site-promo-text p{color:var(--muted);margin:0 0 18px;max-width:560px}
.site-promo-cta{font-weight:800}
/* Cluster de bulles de fonctionnalités */
.site-promo-bubbles{position:relative;min-height:230px}
.site-promo-bubbles .pb{position:absolute;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
    background:#fff;border:1px solid rgba(91,91,240,.2);border-radius:99px;padding:11px 17px;font-weight:700;font-size:.95rem;
    box-shadow:0 10px 26px rgba(2,8,40,.12);animation:pbFloat 5s ease-in-out infinite;transition:transform .25s, box-shadow .25s}
.site-promo-bubbles .pb:hover{transform:scale(1.12) translateY(-4px) !important;box-shadow:0 16px 36px rgba(91,91,240,.3);z-index:5;border-color:var(--primary)}
.site-promo-bubbles .pb1{top:6%;left:4%;animation-delay:0s}
.site-promo-bubbles .pb2{top:0;right:2%;animation-delay:.5s}
.site-promo-bubbles .pb3{top:34%;left:24%;font-size:1.05rem;animation-delay:1s}
.site-promo-bubbles .pb4{top:40%;right:6%;animation-delay:1.4s}
.site-promo-bubbles .pb5{bottom:18%;left:2%;animation-delay:.8s}
.site-promo-bubbles .pb6{bottom:4%;right:14%;animation-delay:1.8s}
.site-promo-bubbles .pb7{bottom:30%;right:34%;animation-delay:2.2s}
@keyframes pbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(prefers-reduced-motion:reduce){.site-promo-bubbles .pb{animation:none}}
@media(max-width:760px){
    .site-hero-promo{grid-template-columns:1fr;text-align:center}
    .site-promo-text p{margin-left:auto;margin-right:auto}
    .site-promo-bubbles{min-height:auto;display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
    .site-promo-bubbles .pb{position:static;animation:none}
}

/* =====================================================================
   SITE BUILDER — disposition par module, bulles de titre, articles
   ===================================================================== */
.mod-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 6px}
.mod-head{display:grid;grid-template-columns:24px 1fr 132px 108px;gap:10px;font-size:.7rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 8px}
.mod-row{display:grid;grid-template-columns:24px 1fr 132px 108px;gap:10px;align-items:center;
    background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.mod-name{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.92rem;cursor:pointer;margin:0}
.mod-name .st-ic{font-size:1.1rem}
.mod-row input[type=number],.mod-row select{padding:8px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
.mod-row select{cursor:pointer}
@media(max-width:640px){
    .mod-head{display:none}
    .mod-row{grid-template-columns:1fr 1fr;gap:8px}
    .mod-name{grid-column:1 / -1}
}

.switch-row{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.95rem;margin:4px 0 6px;cursor:pointer}

.bulle-models{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:6px}
.bmodel{display:flex;flex-direction:column;align-items:center;gap:6px;border:1px solid var(--line);border-radius:12px;padding:12px;cursor:pointer}
.bmodel input{margin-bottom:2px}
.bmodel small{color:var(--muted);font-size:.78rem}
.eb-prev{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:99px}
.eb1p{background:var(--primary);color:#fff}
.eb2p{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}
.eb3p{background:rgba(127,127,127,.16);color:var(--primary)}
.eb4p{background:linear-gradient(135deg,var(--primary),#22D3EE);color:#fff}
.eb5p{background:transparent;color:var(--primary);border-bottom:2px solid var(--primary);border-radius:0;padding-left:0;padding-right:0}
.eb6p{background:var(--primary);color:#fff;border-radius:4px;clip-path:polygon(6% 0,100% 0,94% 100%,0 100%)}
.eb7p{background:#fff;color:var(--primary);box-shadow:0 6px 16px rgba(2,8,40,.16);border-radius:99px}
.eb8p{background:transparent;color:var(--primary);font-style:italic;text-transform:none;padding-left:0}
.eb9p{background:#22D3EE;color:#0E1430;border-radius:6px}
.eb10p{background:transparent;color:var(--primary);border:1.5px dashed var(--primary);border-radius:99px}

.art-slot{border:1px dashed var(--line);border-radius:12px;padding:12px;margin-bottom:10px}

/* =====================================================================
   CRÉATEUR DE SITE — mise en page 2 colonnes + aperçu direct + drag
   ===================================================================== */
.builder-wide{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);padding:0 clamp(16px,3.5vw,72px);box-sizing:border-box}
.site-builder-layout{display:grid;grid-template-columns:1fr;gap:26px;align-items:start}
@media(min-width:1000px){ .site-builder-layout{grid-template-columns:minmax(420px,1fr) 1fr} }
@media(min-width:1500px){ .site-builder-layout{grid-template-columns:minmax(460px,560px) 1fr} }
.site-live{position:sticky;top:18px;align-self:start}
.site-live-head{font-weight:700;margin-bottom:10px;font-size:1rem;display:flex;align-items:center;justify-content:space-between;gap:10px}
.live-toggle{display:inline-flex;gap:4px;background:rgba(0,0,0,.05);border-radius:10px;padding:3px}
.live-dev{border:none;background:transparent;cursor:pointer;font-size:1rem;padding:4px 9px;border-radius:8px;line-height:1}
.live-dev.is-on{background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.site-live-framewrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;height:76vh;box-shadow:var(--shadow-sm)}
.live-frame{border:0;display:block;background:#fff}
.site-live-note{font-size:.8rem;color:var(--muted);margin-top:8px;text-align:center}
@media(max-width:1099px){ .site-live{position:static} .site-live-framewrap{height:60vh} }

/* Glisser-déposer des modules */
.mod-row{cursor:default}
.mod-grip{cursor:grab;color:var(--muted);font-size:1.15rem;line-height:1;text-align:center;user-select:none}
.mod-grip:active{cursor:grabbing}
.mod-row.dragging{opacity:.45;background:rgba(91,91,240,.06)}

/* Fiche entreprise — activités multiples */
.act-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin:4px 0 8px}
.act-chip{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.6);font-size:.92rem;cursor:pointer}
.act-chip:hover{border-color:var(--primary)}
.act-chip:has(input:checked){border-color:var(--primary);background:rgba(91,91,240,.08);font-weight:600}

/* Créateur de site : pleine largeur avec marges */
.container-wide{max-width:1700px;padding-left:clamp(18px,4vw,64px);padding-right:clamp(18px,4vw,64px)}
@media(min-width:1100px){ .container-wide .site-builder-layout{grid-template-columns:minmax(420px,1fr) 1.25fr} }
@media(min-width:1600px){ .container-wide .site-builder-layout{grid-template-columns:520px 1.4fr} }

/* Onglets Devis / Factures */
.doc-tabs{display:inline-flex;gap:4px;background:rgba(0,0,0,.05);border-radius:12px;padding:4px;margin-bottom:18px}
.doc-tab{padding:8px 18px;border-radius:9px;font-weight:600;color:var(--ink-soft,#5b6478);text-decoration:none;font-size:.95rem}
.doc-tab.is-on{background:#fff;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.1)}

/* Bandeau brouillon du créateur de site */
.draft-banner{background:rgba(91,91,240,.08);border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:.9rem;margin-bottom:16px}
.linklike{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;text-decoration:underline;font:inherit;padding:0}

/* Export d'article (page résultat) */
.export-box{margin-top:16px;padding:16px;border:1px solid var(--line);border-radius:14px;background:rgba(91,91,240,.04)}
.export-title{font-weight:700;margin:0 0 10px}
.export-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.export-sep{font-size:.85rem;color:var(--muted);margin-left:6px}

/* Actions rapides personnalisables */
.qa-edit{font-size:.8rem;font-weight:600;color:var(--primary);text-decoration:none;margin-left:10px;vertical-align:middle}
.qa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.qa-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.6);cursor:pointer}
.qa-item:has(input:checked){border-color:var(--primary);background:rgba(91,91,240,.08)}
.qa-item input{flex:none}
.qa-ic{font-size:1.2rem}
.qa-item input:disabled ~ .qa-lbl{opacity:.5}

/* Forfait mise en ligne 99 € */
.publish-promo{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin:18px 0;padding:20px 24px;border-radius:18px;background:linear-gradient(135deg,rgba(91,91,240,.12),rgba(34,211,238,.12));border:1px solid rgba(91,91,240,.25)}
.publish-promo p{margin:4px 0 0;color:var(--muted)}
.publish-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.pub-card{position:relative}
.pub-featured{border:2px solid var(--primary);box-shadow:0 18px 44px rgba(91,91,240,.18)}
.pub-tag{display:inline-block;background:var(--primary);color:#fff;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:99px;margin-bottom:10px}
.pub-tag.pub-free{background:#16a34a}
.pub-price{font-size:2.2rem;font-weight:800;color:var(--primary);margin:6px 0 12px}
.pub-price span{font-size:.9rem;font-weight:600;color:var(--muted)}
.pub-list{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:8px;line-height:1.4}
.pub-form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:10px}
.pub-form input,.pub-form textarea{width:100%;margin-top:4px}
.pub-note{font-size:.82rem;color:var(--muted);margin:10px 0 0}
@media(max-width:760px){.publish-grid{grid-template-columns:1fr}}

/* Admin — activité client */
.act-card{margin-bottom:18px}
.act-top{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}
.act-kpi{background:rgba(91,91,240,.05);border:1px solid var(--line);border-radius:12px;padding:14px 16px;text-align:center}
.act-kpi .n{display:block;font-size:1.3rem;font-weight:800;color:var(--ink)}
.act-kpi .l{display:block;font-size:.82rem;color:var(--muted);margin-top:2px}
.act-kpi.act-on{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.4)}
.act-tools{display:flex;flex-wrap:wrap;gap:8px}
.act-tool{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:99px;padding:7px 14px;font-weight:600;font-size:.9rem}
.act-tool .cnt{background:var(--primary);color:#fff;border-radius:99px;padding:1px 9px;font-size:.8rem}

/* Cartes de guides (centre d'aide) */
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}
.guide-card{display:flex;flex-direction:column;gap:10px;padding:26px;border:1px solid var(--line);border-radius:20px;background:#fff;text-decoration:none;color:inherit;min-height:210px;transition:transform .2s,box-shadow .2s}
.guide-card:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(2,8,40,.12)}
.gc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.gc-ic{font-size:2.1rem;line-height:1}
.gc-tag{background:rgba(91,91,240,.1);color:var(--primary);font-size:.72rem;font-weight:700;letter-spacing:.03em;padding:5px 12px;border-radius:99px;white-space:nowrap}
.gc-title{font-size:1.25rem;font-weight:800;margin:4px 0 0;line-height:1.25}
.gc-lede{color:var(--muted);font-size:.92rem;margin:0;line-height:1.45}
.gc-min{margin-top:auto;color:var(--primary);font-weight:700;font-size:.9rem}
