@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;line-height:1.6;min-height:100vh;background:var(--bg);color:var(--text);transition:background .2s,color .2s}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;top:-100%;left:0;z-index:9999;background:var(--primary);color:#fff;padding:9px 18px;font-weight:700;border-radius:0 0 8px 0}
.skip-link:focus{top:0}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* TOKENS */
:root,[data-theme="light"]{
  --bg:#FFFFFF;--bg2:#F8F9FA;--bg3:#EEF0F2;--card:#FFFFFF;
  --border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.14);
  --text:#0D0D0D;--text2:#4A4A5A;--muted:#8A8A9A;
  --primary:#6C47FF;--primary2:#5535DD;--primary-l:rgba(108,71,255,.10);
  --secondary:#FF4785;--secondary2:#E03570;--secondary-l:rgba(255,71,133,.10);
  --green:#22C55E;--red:#EF4444;--amber:#F59E0B;--blue:#3B82F6;
  --grad:linear-gradient(135deg,#6C47FF,#FF4785);
  --grad-r:linear-gradient(135deg,#FF4785,#6C47FF);
  --shadow:0 2px 16px rgba(0,0,0,.08);--shadow-md:0 8px 32px rgba(0,0,0,.12);
  --shadow-lg:0 16px 48px rgba(0,0,0,.16);
  --radius:10px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:32px;
  --header-h:64px;
  color-scheme:light;
}
[data-theme="dark"]{
  --bg:#0C0C12;--bg2:#14141F;--bg3:#1C1C2A;--card:#14141F;
  --border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.14);
  --text:#F4F4F8;--text2:#9090A8;--muted:#5A5A72;
  --primary:#8B6DFF;--primary2:#7055EE;--primary-l:rgba(139,109,255,.12);
  --secondary:#FF6BA0;--secondary2:#FF4785;--secondary-l:rgba(255,107,160,.12);
  --green:#4ADE80;--red:#F87171;--amber:#FBBF24;--blue:#60A5FA;
  --grad:linear-gradient(135deg,#8B6DFF,#FF6BA0);
  --grad-r:linear-gradient(135deg,#FF6BA0,#8B6DFF);
  --shadow:0 2px 16px rgba(0,0,0,.5);--shadow-md:0 8px 32px rgba(0,0,0,.6);
  --shadow-lg:0 16px 48px rgba(0,0,0,.7);
  color-scheme:dark;
}

/* SCROLLBAR */
*::-webkit-scrollbar{width:4px;height:4px}
*::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px;opacity:.5}
*::-webkit-scrollbar-track{background:transparent}

/* HEADER */
.site-header{height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:200;backdrop-filter:blur(20px)}
.logo{display:flex;align-items:center;gap:10px}
.logo-text{font-size:19px;font-weight:800;letter-spacing:-.5px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.main-nav{display:flex;gap:2px}
.nav-link{display:flex;align-items:center;gap:6px;color:var(--text2);padding:7px 13px;border-radius:8px;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none}
.nav-link:hover{background:var(--bg2);color:var(--text)}
.nav-link.active{color:var(--primary);background:var(--primary-l)}
.nav-link span{display:none}
@media(min-width:768px){.nav-link span{display:inline}}
.hdr-actions{display:flex;align-items:center;gap:8px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:var(--radius);border:none;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .18s;text-decoration:none;font-family:inherit;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 14px rgba(108,71,255,.3)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(108,71,255,.4)}
.btn-secondary-cta{background:var(--secondary);color:#fff;box-shadow:0 4px 14px rgba(255,71,133,.3)}
.btn-secondary-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,71,133,.4)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn-outline:hover{background:var(--primary-l)}
.btn-ghost{background:none;color:var(--text2);border:1px solid var(--border2)}
.btn-ghost:hover{background:var(--bg2);color:var(--text);border-color:var(--border2)}
.btn-sm{padding:7px 14px;font-size:12.5px}
.btn-lg{padding:14px 32px;font-size:15.5px;border-radius:var(--radius-lg);font-weight:700}
.btn-xl{padding:16px 40px;font-size:16px;border-radius:var(--radius-lg);font-weight:800;letter-spacing:-.2px}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.btn-icon{width:36px;height:36px;border-radius:9px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2);font-size:14px;transition:all .15s;flex-shrink:0}
.btn-icon:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-l)}
.btn-send{width:40px;height:40px;border-radius:10px;background:var(--grad);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;transition:all .15s}
.btn-send:hover{transform:scale(1.06);box-shadow:0 4px 12px rgba(108,71,255,.4)}
.inline-form{display:inline}
.w-full{width:100%;justify-content:center}
.flex-1{flex:1}
.mt-2{margin-top:8px}
.mt-4{margin-top:16px}

/* BADGE / PILL */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:30px;font-size:11.5px;font-weight:600}
.pill-primary{background:var(--primary-l);color:var(--primary)}
.pill-secondary{background:var(--secondary-l);color:var(--secondary)}
.pill-green{background:rgba(34,197,94,.1);color:var(--green)}
.pill-gray{background:var(--bg3);color:var(--muted)}

/* FORMS */
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:12.5px;font-weight:600;color:var(--text2)}
.form-group input,.form-group select,.form-group textarea{background:var(--bg2);border:1.5px solid var(--border2);color:var(--text);border-radius:var(--radius);padding:10px 13px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}
.form-group textarea{resize:vertical;min-height:80px}
.form-error{color:var(--red);font-size:12px;padding:8px 12px;background:rgba(239,68,68,.07);border-radius:8px;border-left:3px solid var(--red);display:none}
.form-error.show{display:block}
.check-row{display:flex;align-items:flex-start;gap:9px;cursor:pointer;font-size:13px;color:var(--text2);line-height:1.5}
.check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin-top:2px}
.check-row a{color:var(--primary)}
.input-row{display:flex;gap:7px;align-items:flex-end}
.char-counter{font-size:9px;color:var(--muted);flex-shrink:0;align-self:center}
.file-input{background:var(--bg2);border:1.5px solid var(--border2);border-radius:var(--radius);padding:8px;color:var(--text);width:100%}
.select-sm{background:var(--bg2);border:1px solid var(--border2);color:var(--text);border-radius:6px;padding:3px 7px;font-size:11px;cursor:pointer}

/* ALERTS */
.alert{padding:11px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alert-success{background:rgba(34,197,94,.08);color:var(--green);border:1px solid rgba(34,197,94,.2)}
.alert-error{background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.alert-warning{background:rgba(245,158,11,.08);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.alert-info{background:var(--primary-l);color:var(--primary);border:1px solid rgba(108,71,255,.2)}

/* CARD */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}
.card h2{font-size:16px;font-weight:700;margin-bottom:14px}
.card h3{font-size:14px;font-weight:600;margin-bottom:10px}

/* PAGE */
.page-wrap{max-width:1120px;margin:0 auto;padding:32px 24px 100px}
.page-header{margin-bottom:28px}
.page-header h1{font-size:clamp(24px,4vw,36px);font-weight:800;margin-bottom:6px;letter-spacing:-.5px}
.page-header p{font-size:14px;color:var(--text2);line-height:1.7}
.page-message{text-align:center;padding:80px 24px;color:var(--muted)}
.page-message i{font-size:48px;display:block;margin-bottom:14px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.text-muted{color:var(--muted);font-size:13px}

/* ═══ HERO (style Cœur&Vous adapté messagerie) ═══ */
.hero{position:relative;min-height:calc(100vh - var(--header-h));display:flex;align-items:center;overflow:hidden;background:linear-gradient(160deg,#0C0C12 0%,#13112A 55%,#1A0F2E 100%)}
[data-theme="light"] .hero{background:linear-gradient(160deg,#F0EEFF 0%,#FAF0FF 55%,#FFF0F6 100%)}
.hero-bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1611532736597-de2d4265fba3?w=1400&q=50&auto=format') center/cover;opacity:.12;z-index:0}
[data-theme="light"] .hero-bg{opacity:.06}
.hero-particles{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:1120px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:center;padding:64px 24px}
.hero-text{max-width:580px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(108,71,255,.15);border:1px solid rgba(108,71,255,.3);color:var(--primary);padding:6px 14px;border-radius:40px;font-size:12.5px;font-weight:700;margin-bottom:24px;letter-spacing:.2px}
[data-theme="light"] .hero-eyebrow{background:var(--primary-l)}
.hero h1{font-size:clamp(32px,5.5vw,64px);font-weight:900;line-height:1.06;margin-bottom:18px;letter-spacing:-1.5px}
[data-theme="dark"] .hero h1{color:#F4F4F8}
[data-theme="light"] .hero h1{color:#0D0D0D}
.hero h1 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero h1 strong{background:var(--grad-r);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:16px;color:var(--text2);max-width:460px;line-height:1.8;margin-bottom:32px}
[data-theme="dark"] .hero-sub{color:rgba(244,244,248,.6)}
.hero-ctas{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}
.trust-item{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--text2);font-weight:500}
.trust-item i{color:var(--green);font-size:13px}

/* AUTH BOX (side du hero) */
.auth-box{background:var(--card);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-lg)}
[data-theme="dark"] .auth-box{background:rgba(20,20,31,.98);border-color:rgba(255,255,255,.1)}
.auth-box-title{font-size:18px;font-weight:800;margin-bottom:4px;letter-spacing:-.3px}
.auth-box-sub{font-size:13px;color:var(--text2);margin-bottom:20px}
.auth-tabs{display:flex;gap:4px;background:var(--bg2);border-radius:var(--radius);padding:4px;margin-bottom:20px}
.auth-tab{flex:1;padding:8px;border-radius:8px;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;text-decoration:none;border:none;background:none;font-family:inherit}
.auth-tab.active{background:var(--card);color:var(--text);box-shadow:var(--shadow)}
.auth-form{display:flex;flex-direction:column;gap:12px}
.auth-note{font-size:11.5px;background:var(--primary-l);border-radius:var(--radius);padding:9px 12px;color:var(--text2);border-left:3px solid var(--primary)}
.auth-divider{text-align:center;font-size:12px;color:var(--muted);margin:4px 0;position:relative}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--border2)}
.auth-divider::before{left:0}.auth-divider::after{right:0}
.auth-profile{text-align:center}
.profile-card-hero{width:68px;height:68px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 12px;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.auth-profile h2{font-size:19px;font-weight:800;margin-bottom:4px}
.profile-sub{font-size:12px;color:var(--text2);margin-bottom:16px}

/* FIDO2 section */
.fido2-box{background:var(--bg2);border:1.5px dashed var(--primary);border-radius:var(--radius-lg);padding:20px;text-align:center;margin-top:4px}
.fido2-box i{font-size:32px;color:var(--primary);display:block;margin-bottom:10px}
.fido2-box h3{font-size:15px;font-weight:700;margin-bottom:6px}
.fido2-box p{font-size:12.5px;color:var(--text2);line-height:1.6;margin-bottom:14px}
.fido2-recovering{font-size:12px;color:var(--muted);text-align:center;margin-top:10px}
.fido2-recovering a{color:var(--primary)}

/* TRUST / PRESS BAR */
.trust-bar{padding:16px 24px;border-bottom:1px solid var(--border);background:var(--bg2)}
.trust-inner{max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.trust-items{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.trust-item-bar{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text2);font-weight:500}
.trust-item-bar i{color:var(--primary);font-size:14px}
.trust-badges{display:flex;align-items:center;gap:16px}
.trust-badge{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;opacity:.7}

/* FEATURES SECTION */
.features-section{padding:80px 24px}
.section-eyebrow{text-align:center;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:12px}
.section-title{font-size:clamp(24px,4vw,42px);font-weight:900;text-align:center;margin-bottom:12px;letter-spacing:-.8px;line-height:1.15}
.section-sub{font-size:15px;color:var(--text2);text-align:center;max-width:560px;margin:0 auto 48px;line-height:1.75}
.section-divider{width:48px;height:3px;background:var(--grad);border-radius:4px;margin:14px auto 40px}
.features-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.feat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;transition:all .22s}
.feat-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px;background:var(--primary-l)}
.feat-icon.secondary{background:var(--secondary-l)}
.feat-card h3{font-size:15px;font-weight:700;margin-bottom:7px;letter-spacing:-.2px}
.feat-card p{font-size:13px;color:var(--text2);line-height:1.65}

/* SECURITY SECTION */
.security-section{padding:60px 24px;background:var(--bg2)}
.security-inner{max-width:1120px;margin:0 auto}
.security-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:32px}
.sec-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 16px;display:flex;align-items:flex-start;gap:12px}
.sec-item i{font-size:20px;color:var(--primary);flex-shrink:0;margin-top:2px}
.sec-item-body strong{font-size:13px;font-weight:700;display:block;margin-bottom:3px}
.sec-item-body span{font-size:11.5px;color:var(--text2);line-height:1.5}
.sec-tag{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:5px;margin-top:5px}
.sec-tag.obligatoire{background:rgba(34,197,94,.1);color:var(--green)}
.sec-tag.conseille{background:var(--primary-l);color:var(--primary)}

/* TESTIMONIALS */
.testimonials-section{padding:80px 24px}
.testimonials-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:32px}
.testimonial-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px}
.testimonial-card:hover{border-color:var(--border2);box-shadow:var(--shadow)}
.test-quote{font-size:13.5px;color:var(--text2);line-height:1.75;font-style:italic;margin-bottom:16px}
.test-quote::before{content:'"';font-size:40px;line-height:0;vertical-align:-.25em;color:var(--primary);margin-right:4px;font-style:normal}
.test-author{display:flex;align-items:center;gap:10px}
.test-av{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.test-info strong{font-size:13.5px;font-weight:700;display:block}
.test-info span{font-size:12px;color:var(--muted)}
.test-hearts{color:var(--secondary);font-size:11px;margin-top:2px;display:block}

/* CTA SECTION */
.cta-section{padding:60px 24px 80px}
.cta-box{max-width:800px;margin:0 auto;background:var(--grad);border-radius:var(--radius-2xl);padding:56px 48px;text-align:center;position:relative;overflow:hidden}
.cta-box::before{content:'';position:absolute;inset:0;background:url('') center/cover;opacity:.1}
.cta-box h2{font-size:clamp(24px,4vw,40px);font-weight:900;color:#fff;margin-bottom:10px;position:relative;letter-spacing:-.5px}
.cta-box p{color:rgba(255,255,255,.75);font-size:15px;margin-bottom:28px;position:relative;line-height:1.7}
.cta-box .btn-cta-white{background:#fff;color:var(--primary);font-weight:800;padding:15px 36px;border-radius:var(--radius-lg);font-size:15px;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.cta-box .btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.cta-checks{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:18px;flex-wrap:wrap}
.cta-check{font-size:12.5px;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:5px}
.cta-check i{color:#fff}

/* FOOTER */
.site-footer{background:var(--bg2);border-top:1px solid var(--border);padding:0}
.footer-inner{max-width:1120px;margin:0 auto;padding:52px 24px 36px;display:grid;grid-template-columns:280px 1fr;gap:48px}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{display:flex;align-items:center;gap:9px;font-size:18px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.65}
.footer-social{display:flex;gap:8px;margin-top:4px}
.footer-social a{width:32px;height:32px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;transition:all .15s}
.footer-social a:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-l)}
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.footer-cols>div{display:flex;flex-direction:column;gap:7px}
.footer-cols strong{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:4px;display:block}
.footer-cols a{font-size:13px;color:var(--muted);transition:color .15s}
.footer-cols a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;max-width:1120px;margin:0 auto}
.footer-bottom span{font-size:11.5px;color:var(--muted)}
.footer-compliance{display:flex;gap:8px;flex-wrap:wrap}
.footer-comp-badge{font-size:10px;font-weight:700;background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:2px 7px;color:var(--muted)}

/* CHOPPES PILL */
.choppes-pill{display:flex;align-items:center;gap:5px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);color:var(--amber);padding:5px 11px;border-radius:20px;font-size:12px;font-weight:700;text-decoration:none;transition:all .15s}
.choppes-pill:hover{background:rgba(245,158,11,.18)}

/* USER PILL */
.user-pill{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);padding:4px 12px 4px 5px;border-radius:30px;cursor:pointer;transition:all .15s}
.user-pill:hover{border-color:var(--primary)}
.user-av{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;overflow:hidden}
.user-av img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.user-name{font-size:13px;font-weight:600}
.notif-btn{position:relative}
.badge-count{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;background:var(--red);border-radius:9px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid var(--bg);padding:0 3px}

/* STATUS */
.status-badge{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:6px}
.status-badge.admin{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.status-badge.moderator{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.status-badge.contributeur{background:var(--primary-l);color:var(--primary);border:1px solid rgba(108,71,255,.2)}
.status-badge.verifie{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.2)}
.status-badge.member{background:var(--bg2);color:var(--muted);border:1px solid var(--border)}
.badge-ver{font-size:9.5px;font-weight:700;background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.18);padding:1px 5px;border-radius:4px;margin-left:3px;vertical-align:middle}
.badge-admin{background:rgba(239,68,68,.1);color:var(--red);font-size:9px;padding:1px 5px;border-radius:4px;margin-left:3px}
.badge-mod{background:rgba(245,158,11,.1);color:var(--amber);font-size:9px;padding:1px 5px;border-radius:4px;margin-left:3px}
.odot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 6px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

/* STORIES */
.stories-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.stories-strip::-webkit-scrollbar{display:none}
.story-thumb{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0;text-decoration:none}
.story-ring{width:56px;height:56px;border-radius:50%;padding:2px;background:var(--grad);flex-shrink:0}
.story-ring.seen{background:var(--bg3)}
.story-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;background:var(--card);font-size:23px}
.story-thumb span{font-size:10.5px;color:var(--text2);max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}

/* CHAT LAYOUT */
.chat-layout{display:flex;flex:1;overflow:hidden}
.chat-sidebar{width:210px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:transform .2s}
.sidebar-head{padding:11px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sidebar-title{font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted)}
.online-count{font-size:10px;font-weight:700;background:var(--primary-l);color:var(--primary);padding:1px 7px;border-radius:10px}
.users-list{overflow-y:auto;flex:1;padding:5px}
.users-sep{font-size:9px;font-weight:800;letter-spacing:.6px;color:var(--muted);text-transform:uppercase;padding:7px 9px 2px;opacity:.7}
.user-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:9px;cursor:pointer;transition:background .12s;text-decoration:none;color:inherit}
.user-item:hover{background:var(--primary-l)}
.ui-av{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;overflow:hidden}
.ui-av img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.ui-name{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.ui-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ui-dot.online{background:var(--green)}
.ui-dot.offline{background:var(--muted);opacity:.5}
.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.chat-topbar{height:46px;border-bottom:1px solid var(--border);padding:0 14px;display:flex;align-items:center;gap:9px;flex-shrink:0;background:var(--bg)}
.chat-channel{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.chat-channel-badge{font-size:10px;font-weight:600;background:var(--primary-l);color:var(--primary);padding:2px 7px;border-radius:5px;margin-left:4px}
.chat-stories-bar{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-left:auto}
.chat-stories-bar::-webkit-scrollbar{display:none}
.cs-thumb{display:block;flex-shrink:0}
.story-ring-sm{width:36px;height:36px;border-radius:50%;padding:2px;background:var(--grad);flex-shrink:0}
.story-inner-sm{width:100%;height:100%;border-radius:50%;overflow:hidden;border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;background:var(--card);font-size:15px}
.chat-online-badge{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2);margin-left:auto;flex-shrink:0;font-weight:500}
.msgs-zone{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:2px;scroll-behavior:smooth}
.msgs-empty{text-align:center;padding:48px;color:var(--muted)}
.msgs-empty i{font-size:40px;display:block;margin-bottom:14px;opacity:.4}
.msg{display:flex;gap:9px;align-items:flex-start;padding:4px 6px;border-radius:10px;transition:background .1s;animation:msgIn .2s ease;position:relative}
@keyframes msgIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.msg:hover{background:rgba(108,71,255,.04)}
.msg:hover .msg-actions{display:flex}
.msg-av{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;cursor:pointer;overflow:hidden}
.msg-av img{width:100%;height:100%;object-fit:cover;border-radius:9px}
.msg-body{flex:1;min-width:0}
.msg-meta{display:flex;align-items:center;gap:6px;margin-bottom:2px;flex-wrap:wrap}
.msg-name{font-size:12.5px;font-weight:700;cursor:pointer;text-decoration:none;color:inherit}
.msg-name:hover{color:var(--primary)}
.msg-time{font-size:10px;color:var(--muted)}
.msg-txt{font-size:13.5px;line-height:1.65;word-break:break-word;color:var(--text)}
.msg-reply{background:linear-gradient(90deg,var(--primary) 0,var(--primary) 3px,var(--primary-l) 3px);border-radius:5px;padding:3px 9px 3px 12px;margin-bottom:4px;font-size:11px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-reply strong{color:var(--primary);margin-right:4px}
.msg-actions{display:none;align-items:center;gap:2px;margin-left:auto;flex-shrink:0}
.reply-bar{border-top:1px solid var(--border);padding:7px 14px;display:flex;align-items:center;gap:9px;background:var(--primary-l);flex-shrink:0;font-size:12.5px}
.guest-warn{background:var(--primary-l);border-top:1px solid rgba(108,71,255,.15);padding:7px 14px;font-size:12.5px;color:var(--text2)}
.guest-warn a{color:var(--primary);font-weight:700}
.input-zone{padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg)}
#msg-input{width:100%;background:var(--bg2);border:1.5px solid var(--border2);color:var(--text);border-radius:var(--radius);padding:10px 12px;font-size:13.5px;outline:none;transition:border-color .15s,box-shadow .15s;resize:none;max-height:100px;line-height:1.5;font-family:inherit}
#msg-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}
.emoji-wrap,.irc-wrap{position:relative}
.emoji-wrap summary,.irc-wrap summary{list-style:none}
.emoji-wrap summary::-webkit-details-marker,.irc-wrap summary::-webkit-details-marker{display:none}
.emoji-panel{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 10px;display:flex;flex-wrap:wrap;gap:2px;width:272px;box-shadow:var(--shadow-md);z-index:200}
.emoji-panel button{font-size:20px;padding:4px;border-radius:6px;border:none;background:none;cursor:pointer;line-height:1;transition:transform .1s}
.emoji-panel button:hover{transform:scale(1.25)}
.irc-panel{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow-md);z-index:200;width:260px;font-size:12px;color:var(--text2);line-height:2}
.irc-panel strong{color:var(--primary);display:block;margin-bottom:4px;font-size:13px}
.irc-panel code{font-family:monospace;font-size:11px;color:var(--primary);background:var(--primary-l);padding:1px 5px;border-radius:3px;margin-right:5px}
.chat-right{width:190px;flex-shrink:0;background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.cr-section{padding:12px;border-bottom:1px solid var(--border)}
.cr-title{font-size:9.5px;font-weight:800;letter-spacing:.8px;color:var(--muted);text-transform:uppercase;margin-bottom:9px;display:block}
.top-item{display:flex;align-items:center;gap:8px;padding:5px 7px;border-radius:8px;cursor:pointer;transition:background .1s;text-decoration:none;color:inherit}
.top-item:hover{background:var(--primary-l)}
.top-rank{font-size:12px;font-weight:800;width:18px;text-align:center;flex-shrink:0;color:var(--muted)}
.top-av{width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;overflow:hidden}
.top-av img{width:100%;height:100%;object-fit:cover;border-radius:7px}
.top-info{flex:1;min-width:0}
.top-name{font-size:12px;font-weight:700;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-score{font-size:9.5px;color:var(--amber);display:block}
.pm-conv-item{display:flex;align-items:center;gap:8px;padding:7px;border-radius:9px;cursor:pointer;transition:background .1s;text-decoration:none;color:inherit;border:1px solid transparent}
.pm-conv-item:hover{background:var(--primary-l);border-color:var(--border)}
.pm-av{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;overflow:hidden}
.pm-av img{width:100%;height:100%;object-fit:cover;border-radius:9px}
.pm-name{font-size:12px;font-weight:700}
.sidebar-toggle{display:none}
@media(max-width:768px){.chat-right,.chat-sidebar{display:none}.sidebar-toggle{display:flex}.chat-sidebar.open{display:flex;position:fixed;left:0;top:var(--header-h);bottom:60px;z-index:150}}
@media(max-width:1024px){.chat-right{display:none}}

/* PROFILE PAGE */
.profile-hero{padding:32px 24px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.profile-hero::before{content:"";position:absolute;inset:0;opacity:.18;background:inherit}
.profile-hero-av{width:76px;height:76px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:42px;flex-shrink:0;position:relative;z-index:1;border:2px solid rgba(255,255,255,.2);overflow:hidden}
.profile-hero-av img{width:100%;height:100%;object-fit:cover;border-radius:18px}
.profile-hero-info{flex:1;min-width:200px;position:relative;z-index:1}
.profile-hero-info h1{font-size:24px;font-weight:900;margin-bottom:6px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3);letter-spacing:-.4px}
.profile-status-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.profile-bio{font-size:13.5px;color:rgba(255,255,255,.72);line-height:1.6;margin-bottom:10px;max-width:520px}
.profile-stats-row{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:rgba(255,255,255,.65)}
.profile-stats-row strong{color:#fff}
.xp-section{padding:14px 24px;background:var(--card);border-bottom:1px solid var(--border)}
.xp-bar{height:5px;background:var(--bg3);border-radius:4px;overflow:hidden}
.xp-fill{height:100%;background:var(--grad);border-radius:4px;transition:width .5s ease}
.profile-badges{display:flex;flex-wrap:wrap;gap:7px;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--bg2)}
.badge-card{display:inline-flex;align-items:center;gap:5px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:11.5px;font-weight:700}
.profile-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);overflow-x:auto;padding:0 24px;background:var(--bg2)}
.profile-tab{padding:11px 15px;border-bottom:2px solid transparent;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;text-decoration:none;transition:all .15s;display:block}
.profile-tab:hover{color:var(--text)}
.profile-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.profile-content{padding:22px 24px 100px;max-width:900px}
.tab-panel{display:flex;flex-direction:column;gap:16px}

/* USERS PAGE */
.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.user-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center;transition:all .2s;position:relative}
.user-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.user-card-av{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 12px;overflow:hidden}
.user-card-av img{width:100%;height:100%;object-fit:cover;border-radius:16px}
.user-card-name{font-size:15px;font-weight:800;margin-bottom:4px;letter-spacing:-.2px}
.user-card-bio{font-size:12.5px;color:var(--text2);margin-bottom:12px;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-card-meta{display:flex;align-items:center;justify-content:center;gap:10px;font-size:11px;color:var(--muted);margin-bottom:14px;flex-wrap:wrap}
.user-card-actions{display:flex;gap:7px;justify-content:center}
.user-online-dot{position:absolute;top:14px;right:14px;width:9px;height:9px;border-radius:50%;background:var(--green);border:2px solid var(--card)}

/* PM MESSAGES */
.pm-msgs{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow-y:auto;padding:5px}
.pm-msg{display:flex;flex-direction:column;max-width:80%}
.pm-msg.mine{align-self:flex-end;align-items:flex-end}
.pm-msg.other{align-self:flex-start;align-items:flex-start}
.pm-bubble{padding:9px 13px;border-radius:13px;font-size:13.5px;line-height:1.55;word-break:break-word}
.pm-msg.mine .pm-bubble{background:var(--grad);color:#fff;border-bottom-right-radius:3px}
.pm-msg.other .pm-bubble{background:var(--bg2);border:1px solid var(--border);border-bottom-left-radius:3px}
.pm-time{font-size:9.5px;color:var(--muted);margin-top:3px}
.pm-form{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.pm-conv-header{display:flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:14px}

/* NOTIFS */
.notif-item{display:flex;gap:10px;padding:11px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:7px;background:var(--bg2)}
.notif-item.unread{background:var(--primary-l);border-color:var(--primary)}
.notif-icon{font-size:19px;flex-shrink:0}
.notif-body strong{display:block;font-size:13px;font-weight:700;margin-bottom:2px}
.notif-body span{display:block;font-size:11.5px;color:var(--text2);margin-bottom:2px}
.notif-body time{display:block;font-size:10px;color:var(--muted)}

/* SHOP */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:12px}
.shop-item{background:var(--bg2);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:8px;transition:all .18s}
.shop-item:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow)}
.shop-item.owned{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.04)}
.shop-item.active{border-color:var(--primary);background:var(--primary-l)}
.shop-preview{height:56px;border-radius:8px}
.shop-name{font-size:12.5px;font-weight:800}
.shop-price{font-size:11.5px;font-weight:700;color:var(--amber)}
.shop-price.free{color:var(--green)}

/* RANKING */
.ranking-list{display:flex;flex-direction:column;gap:6px}
.rank-row{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius);text-decoration:none;color:inherit;transition:all .15s;background:var(--bg2);border:1px solid var(--border)}
.rank-row:hover{border-color:var(--primary);transform:translateX(2px)}
.rank-me{border-color:var(--primary)!important;background:var(--primary-l)!important}
.rank-pos{font-size:18px;width:28px;text-align:center;flex-shrink:0;font-weight:800}
.rank-av{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0;overflow:hidden}
.rank-av img{width:100%;height:100%;object-fit:cover;border-radius:10px}
.rank-info{flex:1;min-width:0}
.rank-name{font-size:13.5px;font-weight:700;display:block}
.rank-sub{font-size:10.5px;color:var(--muted);display:block;margin-top:1px}
.rank-val{font-size:14px;font-weight:800;color:var(--amber);flex-shrink:0}

/* ADMIN */
.admin-layout{display:flex;min-height:calc(100vh - var(--header-h));overflow:hidden}
.admin-nav{width:220px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:2px;padding:14px 10px;overflow-y:auto;flex-shrink:0}
.admin-nav-item{display:flex;align-items:center;gap:10px;padding:9px 13px;border-radius:var(--radius);color:var(--text2);font-size:13px;font-weight:600;text-decoration:none;transition:all .15s}
.admin-nav-item:hover,.admin-nav-item.active{background:var(--primary-l);color:var(--primary)}
.nav-badge{margin-left:auto;min-width:18px;height:18px;background:var(--red);border-radius:9px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;padding:0 4px}
.admin-content{flex:1;overflow-y:auto;padding:24px;background:var(--bg)}
.admin-section{max-width:1100px}
.admin-section h1{font-size:21px;font-weight:800;margin-bottom:18px;display:flex;align-items:center;gap:8px;letter-spacing:-.3px}
.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:12.5px}
.admin-table th{text-align:left;padding:10px 12px;font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--border);background:var(--bg2)}
.admin-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--primary-l)}
.act-btns{display:flex;gap:5px;flex-wrap:wrap}
.act-btn{padding:4px 9px;border-radius:6px;border:none;font-size:11.5px;font-weight:700;cursor:pointer;transition:all .12s;text-decoration:none;display:inline-flex;align-items:center}
.act-btn.ban{background:rgba(239,68,68,.1);color:var(--red)}.act-btn.ban:hover{background:rgba(239,68,68,.2)}
.act-btn.unban{background:rgba(34,197,94,.1);color:var(--green)}.act-btn.unban:hover{background:rgba(34,197,94,.2)}
.act-btn.del{background:rgba(239,68,68,.05);color:rgba(239,68,68,.6)}.act-btn.del:hover{background:rgba(239,68,68,.15);color:var(--red)}
.trust-bar-sm{height:4px;background:var(--bg3);border-radius:3px;overflow:hidden;width:54px;display:inline-block}
.trust-fill{height:100%;border-radius:3px}
.search-input{background:var(--bg2);border:1.5px solid var(--border2);color:var(--text);border-radius:var(--radius);padding:7px 12px;font-size:12.5px;outline:none;min-width:200px}
.search-input:focus{border-color:var(--primary)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0}
.toggle{position:relative;display:inline-block;width:40px;height:22px;cursor:pointer}
.toggle input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:var(--bg3);border-radius:11px;transition:.25s}
.slider::before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s}
.toggle input:checked + .slider{background:var(--primary)}
.toggle input:checked + .slider::before{transform:translateX(18px)}
.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center}
.stat-num{font-size:28px;font-weight:900;color:var(--primary);display:block;letter-spacing:-1px}
.stat-lbl{font-size:11px;color:var(--muted);font-weight:600;display:block;margin-top:3px}
.stats-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stats-grid-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
.stat-card-admin{border-radius:var(--radius-lg);padding:16px;display:flex;align-items:center;gap:11px}
.stat-icon{font-size:24px;flex-shrink:0}
.tag-banned{font-size:9px;font-weight:700;background:rgba(239,68,68,.1);color:var(--red);border-radius:4px;padding:1px 5px;margin-left:5px}
.tag-ok{background:rgba(34,197,94,.1);color:var(--green);font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px}
.tag-danger{background:rgba(239,68,68,.1);color:var(--red);font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px}
.user-cell{display:flex;align-items:center;gap:9px}
.sub{font-size:10px;color:var(--muted);display:block}
.msg-preview{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.log-type{font-size:9px;padding:2px 6px;border-radius:4px;font-weight:700;background:var(--bg2);color:var(--muted)}
.log-type.login{background:rgba(34,197,94,.1);color:var(--green)}
.log-type.register{background:rgba(59,130,246,.1);color:var(--blue)}
.log-type.ban{background:rgba(239,68,68,.1);color:var(--red)}

/* MOBILE NAV */
.mobile-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--bg);border-top:1px solid var(--border);backdrop-filter:blur(20px);display:none;padding-bottom:env(safe-area-inset-bottom)}
.mnav{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--muted);font-size:10px;font-weight:600;cursor:pointer;padding:7px 10px;min-width:60px;text-decoration:none;transition:color .12s}
.mnav i{font-size:19px}
.mnav.active,.mnav:hover{color:var(--primary)}

/* COOKIE */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:1500;background:var(--card);border-top:1px solid var(--border);padding:13px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;box-shadow:0 -4px 18px rgba(0,0,0,.1)}
.cookie-banner p{flex:1;font-size:12.5px;color:var(--text2);line-height:1.6;min-width:200px;margin:0}
.cookie-banner a{color:var(--primary)}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}

/* PROFILE FILL MODAL */
.profile-fill-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:5000;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.profile-fill-modal{background:var(--card);border-radius:var(--radius-xl);padding:32px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.profile-fill-modal h2{font-size:20px;font-weight:900;margin-bottom:6px;letter-spacing:-.3px}
.profile-fill-modal .sub-txt{font-size:13px;color:var(--text2);margin-bottom:24px;line-height:1.6}
.tags-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.tag-opt{cursor:pointer}
.tag-opt input[type=checkbox]{display:none}
.tag-opt span{display:inline-flex;align-items:center;padding:6px 13px;border-radius:20px;font-size:12.5px;font-weight:600;background:var(--bg2);border:1.5px solid var(--border2);color:var(--text2);transition:all .15s;cursor:pointer}
.tag-opt input:checked + span{background:var(--primary-l);border-color:var(--primary);color:var(--primary)}
.avatar-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.avatar-opt{cursor:pointer}
.avatar-opt input[type=radio]{display:none}
.avatar-opt span{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:var(--radius);border:2px solid var(--border2);background:var(--bg2);font-size:11.5px;font-weight:600;color:var(--text2);transition:all .15s;cursor:pointer}
.avatar-opt span em{font-size:28px;font-style:normal}
.avatar-opt input:checked + span{border-color:var(--primary);background:var(--primary-l);color:var(--primary)}
.progress-steps{display:flex;gap:6px;margin-bottom:22px}
.step-dot{flex:1;height:4px;border-radius:3px;background:var(--bg3)}
.step-dot.done{background:var(--grad)}

/* RGPD/ABOUT */
.about-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.rgpd-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:10px}
.rgpd-table th,.rgpd-table td{padding:9px 12px;border:1px solid var(--border);text-align:left;vertical-align:top}
.rgpd-table th{background:var(--bg2);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.charte-list li{padding:6px 0;font-size:13px;color:var(--text2);border-bottom:1px solid var(--border)}
.charte-list li:last-child{border:none}

/* EMPTY STATE */
.empty-state{text-align:center;padding:64px 24px;color:var(--muted)}
.empty-state i{font-size:52px;display:block;margin-bottom:14px;opacity:.35}
.empty-state p{font-size:14px;line-height:1.7}

/* RESPONSIVE */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;min-height:auto;padding:40px 20px}
  .auth-box{max-width:100%}
  .footer-inner{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .admin-nav{width:54px;padding:10px 6px}
  .admin-nav-item span{display:none}
  .admin-nav-item{justify-content:center;padding:10px}
}
@media(max-width:768px){
  .mobile-nav{display:block}
  .footer-cols{grid-template-columns:1fr}
  .cfg-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .shop-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid-admin{grid-template-columns:repeat(2,1fr)}
  body{padding-bottom:60px}
  .features-grid{grid-template-columns:1fr 1fr}
  .security-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .cta-box{padding:32px 20px}
  .features-grid{grid-template-columns:1fr}
  .security-grid{grid-template-columns:1fr}
  .profile-hero{padding:20px 16px}
  .stats-grid{grid-template-columns:1fr}
  .users-grid{grid-template-columns:1fr 1fr}
}

/* ═══ EXTENSIONS v4.1 ═══ */

/* Quick actions on messages */
.qa-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:3px 7px;font-size:11px;cursor:pointer;color:var(--text2);transition:all .12s;text-decoration:none;display:inline-flex;align-items:center}
.qa-btn:hover{background:var(--primary-l);color:var(--primary);border-color:var(--primary)}
.msg-actions{display:none;gap:3px;margin-left:auto;flex-shrink:0;flex-wrap:wrap;align-items:center}
.msg:hover .msg-actions{display:flex}
@media(max-width:600px){.msg-actions{display:flex}}

/* Security badges inline */
.sec-badge{font-size:10px;cursor:help;position:relative}
.sec-badge[data-tooltip]:hover::after{content:attr(data-tooltip);position:absolute;bottom:calc(100%+4px);left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--border2);border-radius:8px;padding:5px 9px;font-size:10.5px;white-space:nowrap;z-index:500;box-shadow:var(--shadow-md);pointer-events:none;color:var(--text2)}

/* Typing indicator */
.typing-global{padding:4px 14px;font-size:11.5px;color:var(--muted);font-style:italic;height:20px;flex-shrink:0}

/* Friend system */
.friend-req-badge{position:fixed;top:70px;right:16px;background:var(--card);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:12px 16px;box-shadow:var(--shadow-md);z-index:300;display:flex;align-items:center;gap:10px;max-width:280px;animation:slideIn .3s ease}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}

/* Scroll to top button */
.scroll-top-btn{position:fixed;bottom:80px;right:16px;width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;box-shadow:var(--shadow-md);display:none;align-items:center;justify-content:center;font-size:16px;z-index:500;transition:all .2s}
.scroll-top-btn.visible{display:flex}
.scroll-top-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}

/* Mission bar (homepage) */
.mission-bar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mission-step{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:6px 12px;border-radius:20px;background:var(--bg2);border:1px solid var(--border)}
.mission-step.done{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.2);color:var(--green)}
.mission-step.current{background:var(--primary-l);border-color:var(--primary);color:var(--primary)}

/* Status availability */
.status-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}
.status-dot.available{background:var(--green)}
.status-dot.away{background:var(--amber)}
.status-dot.busy{background:var(--red)}
.status-dot.invisible{background:var(--muted)}

/* Friend button */
.btn-friend{background:var(--primary-l);color:var(--primary);border:1px solid var(--primary);border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.btn-friend:hover{background:var(--primary);color:#fff}
.btn-friend.pending{background:rgba(245,158,11,.1);color:var(--amber);border-color:var(--amber)}
.btn-friend.accepted{background:rgba(34,197,94,.1);color:var(--green);border-color:var(--green)}

/* Risk mode badge */
.risk-badge{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:10px;font-weight:700;padding:2px 7px}
.limited-badge{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.2);border-radius:6px;font-size:10px;font-weight:700;padding:2px 7px}

/* Minor mode */
.minor-warning{background:rgba(239,68,68,.06);border:1.5px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:14px}
.minor-warning h3{color:var(--red);font-size:13px;font-weight:800;margin-bottom:4px}
.minor-warning p{font-size:12px;color:var(--text2);line-height:1.6}

/* Age gate */
.age-gate-overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(8px)}
.age-gate-box{background:var(--card);border-radius:var(--radius-xl);padding:32px;max-width:480px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}
.age-gate-box h2{font-size:20px;font-weight:900;margin-bottom:8px}
.age-gate-box p{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:18px}

/* Group tag on profile */
.group-tag{display:inline-flex;align-items:center;gap:4px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:11px;font-weight:600;color:var(--text2)}
.group-tag.official{background:var(--primary-l);border-color:var(--primary);color:var(--primary)}

/* Watermark */
.watermark{position:relative;display:inline-block}
.watermark::after{content:attr(data-wm);position:absolute;bottom:4px;right:6px;font-size:8px;color:rgba(255,255,255,.5);font-weight:700;pointer-events:none;letter-spacing:.3px}

/* Activity live pulse */
.live-activity{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted)}
.live-activity .odot{width:6px;height:6px}

/* Reward popup */
.reward-popup{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:4000;background:var(--grad);color:#fff;border-radius:var(--radius-xl);padding:18px 28px;text-align:center;box-shadow:var(--shadow-lg);animation:rewardIn .4s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes rewardIn{from{transform:translateX(-50%) scale(.6);opacity:0}to{transform:translateX(-50%) scale(1);opacity:1}}
.reward-popup h3{font-size:18px;font-weight:900;margin-bottom:4px}
.reward-popup p{font-size:13px;opacity:.85}

/* Info bubble (global tooltip) */
[data-tooltip]{position:relative;cursor:help}
[data-tooltip]::before{content:attr(data-tooltip);position:absolute;bottom:calc(100%+6px);left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--border2);color:var(--text2);font-size:11.5px;font-weight:500;padding:6px 10px;border-radius:8px;white-space:nowrap;max-width:220px;white-space:normal;text-align:center;z-index:600;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .15s}
[data-tooltip]:hover::before{opacity:1}

/* Hamburger mobile */
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:6px}
.hamburger span{width:22px;height:2px;background:var(--text2);border-radius:2px;transition:all .2s}
@media(max-width:768px){
  .hamburger{display:flex}
  .main-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;padding:12px;z-index:199}
  .main-nav.open{display:flex}
  .nav-link span{display:inline!important}
}

/* Font size settings */
[data-fontsize="small"] body{font-size:13px}
[data-fontsize="large"] body{font-size:18px}

/* Blurred photo (non-connected) */
.photo-blurred{filter:blur(12px);pointer-events:none;user-select:none}
.photo-blur-wrap{position:relative;overflow:hidden;border-radius:inherit}
.photo-blur-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);color:#fff;font-size:12px;font-weight:700;text-align:center;padding:8px;cursor:pointer}

/* Bot crew hidden badge */
.bot-crew{display:none}

/* Mute badge */
.muted-badge{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:10px;font-weight:700;padding:2px 7px}

/* Presentation salon */
.presentation-banner{background:var(--primary-l);border:1px solid var(--primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:14px;font-size:13px;color:var(--text2)}

/* Live last message bar */
.last-msg-bar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:6px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}

/* Profile ID */
.profile-uid{font-size:10px;font-weight:700;color:var(--muted);font-family:monospace;letter-spacing:.5px}

/* Signature Ed25519 */
.ed25519-sig{display:inline-flex;align-items:center;gap:4px;font-size:9.5px;color:var(--muted);background:var(--bg2);border:1px solid var(--border);border-radius:5px;padding:1px 7px;font-family:monospace}

/* Cron backup indicator */
.backup-status{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}

/* Back to top */
@media(max-width:768px){.scroll-top-btn{bottom:72px}}

/* ══════════════════════════════════════════════
   EXTENSIONS SEO + UI v4.2
   ══════════════════════════════════════════════ */

/* Police Inter partout */
body,input,textarea,select,button{font-family:'Inter',system-ui,-apple-system,sans-serif}

/* Footer trust */
.footer-trust{display:flex;flex-direction:column;gap:5px;margin-top:10px}
.footer-trust-item{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px;font-weight:500}

/* Recherche globale */
.global-search-wrap{position:relative}
.global-search-box{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius-lg);padding:10px;box-shadow:var(--shadow-lg);z-index:400;flex-direction:column;gap:8px}
.search-form{display:flex;gap:6px;align-items:center}
.global-search-input{flex:1;background:var(--bg2);border:1.5px solid var(--border2);color:var(--text);border-radius:var(--radius);padding:8px 12px;font-size:13.5px;outline:none;transition:border-color .15s;font-family:inherit}
.global-search-input:focus{border-color:var(--primary)}
.search-hints{display:flex;flex-direction:column;gap:2px;max-height:220px;overflow-y:auto}
.search-hint-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;text-decoration:none;color:var(--text);transition:background .1s;font-size:13px}
.search-hint-item:hover{background:var(--primary-l)}
.search-hint-item span:first-child{font-size:18px;flex-shrink:0}
.search-hint-item small{margin-left:auto;font-size:10.5px;color:var(--muted);flex-shrink:0}
.search-no-result{font-size:12.5px;color:var(--muted);text-align:center;padding:10px}
@media(max-width:480px){.global-search-box{width:calc(100vw - 32px);right:-16px}}

/* ── ONBOARDING / DIDACTICIEL ── */
.tutorial-overlay{position:fixed;inset:0;z-index:8000;pointer-events:none}
.tutorial-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:8001;backdrop-filter:blur(3px)}
.tutorial-modal{position:fixed;bottom:32px;left:50%;transform:translateX(-50%);z-index:8002;background:var(--card);border:1px solid var(--border2);border-radius:24px;padding:28px 28px 22px;max-width:420px;width:calc(100% - 32px);box-shadow:0 24px 80px rgba(0,0,0,.5);pointer-events:all;animation:tutorialIn .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes tutorialIn{from{transform:translateX(-50%) translateY(30px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.tutorial-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.tutorial-logo img{width:52px;height:52px}
.tutorial-logo span{font-size:14px;font-weight:700;color:var(--primary)}
.tutorial-steps{display:flex;gap:5px;margin-bottom:16px}
.tutorial-step-dot{flex:1;height:3px;border-radius:2px;background:var(--bg3);transition:background .3s}
.tutorial-step-dot.done{background:var(--grad)}
.tutorial-modal h2{font-size:18px;font-weight:900;margin-bottom:6px;letter-spacing:-.3px}
.tutorial-modal p{font-size:13.5px;color:var(--text2);line-height:1.7;margin-bottom:18px}
.tutorial-btns{display:flex;gap:8px;justify-content:flex-end}
.tutorial-highlight{position:fixed;z-index:8003;border-radius:12px;box-shadow:0 0 0 4px var(--primary),0 0 0 8px rgba(108,71,255,.3);pointer-events:none;transition:all .4s cubic-bezier(.4,0,.2,1);animation:highlightPulse 2s ease-in-out infinite}
@keyframes highlightPulse{0%,100%{box-shadow:0 0 0 4px var(--primary),0 0 0 8px rgba(108,71,255,.3)}50%{box-shadow:0 0 0 4px var(--primary),0 0 0 12px rgba(108,71,255,.15)}}
.tutorial-arrow{position:fixed;z-index:8004;pointer-events:none;font-size:28px;animation:arrowBounce 1s ease-in-out infinite}
@keyframes arrowBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ── PM ACTIONS (archiver, favoris, extraire) ── */
.pm-action-bar{display:flex;gap:6px;padding:8px 0;border-top:1px solid var(--border);margin-top:8px;flex-wrap:wrap}
.pm-action-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:8px;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);font-size:11.5px;font-weight:600;cursor:pointer;transition:all .14s;font-family:inherit}
.pm-action-btn:hover{background:var(--primary-l);color:var(--primary);border-color:var(--primary)}
.pm-action-btn.danger:hover{background:rgba(239,68,68,.08);color:var(--red);border-color:rgba(239,68,68,.3)}

/* ── TAGS HERO SEO ── */
.hero-seo-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;justify-content:center}
.hero-seo-tag{font-size:11.5px;padding:4px 12px;border-radius:20px;background:rgba(108,71,255,.1);border:1px solid rgba(108,71,255,.2);color:var(--primary);font-weight:600;text-decoration:none;transition:all .15s}
.hero-seo-tag:hover{background:var(--primary);color:#fff}

/* ── SHARE BUTTON ── */
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:8px;border:1px solid var(--border2);background:var(--card);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.share-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-l)}

/* ── NOTIFICATIONS INTELLIGENTES ── */
.notif-smart{display:flex;align-items:flex-start;gap:10px}
.notif-smart .notif-icon-wrap{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;background:var(--primary-l)}
.notif-smart-msg{font-size:13px;font-weight:600;line-height:1.5}
.notif-smart-sub{font-size:11.5px;color:var(--muted);margin-top:2px}

/* ── JOURNAL UTILISATEUR ── */
.journal-entry{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.journal-entry:last-child{border:none}
.journal-icon{width:32px;height:32px;border-radius:9px;background:var(--primary-l);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.journal-body{flex:1;min-width:0}
.journal-body strong{font-size:13px;display:block}
.journal-body span{font-size:11.5px;color:var(--muted)}
.journal-time{font-size:10.5px;color:var(--muted);flex-shrink:0;margin-top:2px}

/* ── DÉCONNEXION GLOBALE ── */
.devices-list{display:flex;flex-direction:column;gap:8px}
.device-item{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.device-item.current{border-color:var(--primary);background:var(--primary-l)}
.device-icon{font-size:22px;flex-shrink:0}
.device-info{flex:1;min-width:0}
.device-info strong{font-size:13px;display:block}
.device-info span{font-size:11.5px;color:var(--muted)}
.device-current-badge{font-size:10px;font-weight:800;background:var(--primary);color:#fff;padding:2px 7px;border-radius:5px}

/* ── ALERTE SÉCURITÉ ── */
.security-alert{background:rgba(245,158,11,.06);border:1.5px solid rgba(245,158,11,.3);border-radius:var(--radius-lg);padding:14px 16px;display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.security-alert-icon{font-size:22px;flex-shrink:0}
.security-alert strong{font-size:13px;display:block;color:var(--amber);margin-bottom:2px}
.security-alert p{font-size:12.5px;color:var(--text2);margin:0;line-height:1.55}

/* ── STATUS PAGE ── */
.status-bar{height:32px;display:flex;gap:2px;align-items:center;border-radius:6px;overflow:hidden}
.status-bar-day{flex:1;height:100%;background:rgba(34,197,94,.35);border-radius:2px;cursor:default;transition:background .15s}
.status-bar-day:hover{background:rgba(34,197,94,.7)}
.status-bar-day.incident{background:rgba(239,68,68,.5)}
.status-bar-day.incident:hover{background:rgba(239,68,68,.8)}

/* ── SEO HEADING CLASSES ── */
.seo-h1{font-size:clamp(28px,5vw,56px);font-weight:900;line-height:1.08;letter-spacing:-1.5px}
.seo-h2{font-size:clamp(20px,3.5vw,38px);font-weight:800;line-height:1.15;letter-spacing:-.8px}
.seo-h2 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── GUIDES / ARTICLES ── */
.guide-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s}
.guide-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.guide-card-img{height:140px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:52px}
.guide-card-body{padding:16px}
.guide-card-tag{font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--primary);margin-bottom:6px;display:block}
.guide-card h3{font-size:14.5px;font-weight:800;margin-bottom:5px;line-height:1.4}
.guide-card p{font-size:12.5px;color:var(--text2);line-height:1.6}
.guide-card-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);font-size:11.5px;color:var(--muted)}

/* ── ROBOT TAV' CHAT ── */
.tav-chat-bubble{position:fixed;bottom:90px;right:20px;z-index:900;cursor:pointer;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.tav-bubble-trigger{width:52px;height:52px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(108,71,255,.4);transition:transform .2s}
.tav-bubble-trigger:hover{transform:scale(1.08)}
.tav-bubble-trigger img{width:38px;height:38px}
.tav-bubble-popup{background:var(--card);border:1px solid var(--border2);border-radius:16px 16px 4px 16px;padding:12px 14px;max-width:240px;box-shadow:var(--shadow-md);animation:bubbleAppear .25s ease;font-size:13px;line-height:1.5;display:none}
.tav-bubble-popup.show{display:block}
@keyframes bubbleAppear{from{transform:scale(.8) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}

/* ── IMAGE PIPELINE BADGE ── */
.img-pipeline{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.img-pipeline-step{display:flex;align-items:center;gap:0}
.img-pipeline-step span{font-size:11px;font-weight:700;background:var(--bg2);border:1px solid var(--border);padding:4px 9px;border-radius:6px;color:var(--text2)}
.img-pipeline-step::after{content:'→';font-size:11px;color:var(--muted);padding:0 4px}
.img-pipeline-step:last-child::after{display:none}

/* ── RECHERCHE RÉSULTATS ── */
.search-results{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all .15s}
.search-result-item:hover{border-color:var(--primary);background:var(--primary-l)}
.search-result-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;background:var(--bg2)}
.search-result-body{flex:1;min-width:0}
.search-result-body strong{font-size:14px;font-weight:700;display:block}
.search-result-body span{font-size:12px;color:var(--muted)}
.search-result-type{font-size:10px;font-weight:800;padding:2px 8px;border-radius:5px;background:var(--primary-l);color:var(--primary);flex-shrink:0}

/* ── DARK/LIGHT/AUTO THEME SWITCHER ── */
.theme-switcher{display:flex;gap:4px;background:var(--bg2);border-radius:9px;padding:3px;border:1px solid var(--border)}
.theme-opt{padding:5px 10px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);border:none;background:none;font-family:inherit;transition:all .15s}
.theme-opt.active,.theme-opt:hover{background:var(--card);color:var(--text);box-shadow:var(--shadow)}

/* Corrections Inter font */
code,pre,kbd{font-family:'Fira Code','Cascadia Code',monospace}
