/* Giri Assistance — Refonte 2026-06-03
   Esthétique Giri Académie : maison de luxe, cosmos doré, ivoire, élégance aérienne
*/

:root{
  --black:#0A0A0E;
  --black-2:#12121A;
  --black-3:#1A1A24;
  --line:#2A2A36;
  --gold:#C9A961;
  --gold-soft:#B8924F;
  --gold-pale:#E8D29A;
  --gold-deep:#8E6D2C;
  --ivory:#F4ECD8;
  --ivory-dim:#C9C2AE;
  --ivory-mute:#8A8576;
  --green:#7ee07e;
  --green-glow:rgba(126,224,126,.32);
  --shadow-lux:0 30px 80px rgba(0,0,0,.55), 0 2px 0 rgba(255,255,255,.03) inset;
  --shadow-soft:0 12px 36px rgba(0,0,0,.4);
  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-soft:cubic-bezier(0.45,0.05,0.55,0.95);
  --safe-top:env(safe-area-inset-top,0);
  --safe-bottom:env(safe-area-inset-bottom,0);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--black);color:var(--ivory);font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;overflow:hidden}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
a{color:var(--gold-pale);text-decoration:none;border-bottom:1px dotted rgba(232,210,154,.35)}
a:hover{color:var(--gold);border-bottom-color:rgba(232,210,154,.7)}
input,textarea{font-family:inherit}

/* Cosmos background */
body::before{content:"";position:fixed;inset:0;background:
  radial-gradient(ellipse 90% 70% at 50% 35%,#16151E 0%,var(--black) 60%),
  radial-gradient(circle at 18% 88%, rgba(201,169,97,.06), transparent 38%),
  radial-gradient(circle at 88% 12%, rgba(201,169,97,.05), transparent 42%),
  var(--black);
  z-index:-2}
body::after{content:"";position:fixed;inset:0;background:
  url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.4;pointer-events:none;z-index:-1;mix-blend-mode:overlay}

/* ──────── LOGIN ──────── */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 18px}
.login-card{width:100%;max-width:460px;background:linear-gradient(180deg,rgba(26,26,36,.78),rgba(18,18,26,.92));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(201,169,97,.22);border-radius:22px;padding:42px 34px;box-shadow:var(--shadow-lux);position:relative;overflow:hidden}
.login-card::after{content:"";position:absolute;left:50%;top:-160px;width:380px;height:380px;transform:translateX(-50%);background:radial-gradient(circle,rgba(201,169,97,.18),transparent 60%);pointer-events:none;filter:blur(20px)}
.brand{display:flex;align-items:center;gap:14px;margin-bottom:22px;position:relative;z-index:1}
.brand-dot{width:46px;height:46px;border-radius:50%;background:url(/giri-assistance/golden-ball.webp) center/cover no-repeat;filter:drop-shadow(0 0 14px rgba(201,169,97,.4))}
.brand-name{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;color:var(--ivory);letter-spacing:.6px}
.brand-name small{display:block;font-family:'Inter',sans-serif;font-size:9px;letter-spacing:.32em;color:var(--gold);text-transform:uppercase;margin-top:2px;font-weight:600}
.login h1{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:32px;line-height:1.15;color:var(--ivory);margin:8px 0 8px;letter-spacing:.3px;position:relative;z-index:1}
.login .lead{margin:0 0 22px;font-size:14px;color:var(--ivory-dim);line-height:1.5;position:relative;z-index:1}
.agents-strip{display:flex;align-items:center;margin-bottom:10px;padding-left:0;position:relative;z-index:1}
.agents-strip .av{width:42px;height:42px;border-radius:50%;border:2px solid rgba(244,236,216,.18);background:#1F1A12 center/cover no-repeat;box-shadow:0 8px 18px rgba(0,0,0,.45);margin-left:-12px;transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;position:relative}
.agents-strip .av:first-child{margin-left:0}
.agents-strip .av:hover{transform:translateY(-2px) scale(1.06);z-index:2}
.agents-strip .av.online{border-color:var(--green);box-shadow:0 0 0 2px var(--green-glow), 0 8px 18px rgba(0,0,0,.45)}
.agents-strip .av.online::after{content:"";position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;background:var(--green);border:2px solid var(--black-2);box-shadow:0 0 8px var(--green-glow)}
.online-pill{display:inline-flex;align-items:center;gap:8px;font-size:11px;color:var(--ivory-dim);background:rgba(126,224,126,.08);border:1px solid rgba(126,224,126,.28);padding:5px 12px;border-radius:999px;letter-spacing:.4px;text-transform:uppercase;font-weight:600}
.online-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(126,224,126,.18);animation:pulse 1.8s ease-in-out infinite}
.online-pill.idle{color:var(--ivory-mute);background:rgba(201,169,97,.06);border-color:rgba(201,169,97,.22)}
.online-pill.idle .dot{background:var(--gold-deep);box-shadow:0 0 0 3px rgba(142,109,44,.2);animation:none}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.55}}

.field{margin-bottom:14px;position:relative;z-index:1}
.field label{display:block;font-size:10px;color:var(--gold);margin-bottom:6px;font-weight:600;letter-spacing:.24em;text-transform:uppercase}
.field input{width:100%;padding:13px 14px;border:1px solid rgba(244,236,216,.14);background:rgba(10,10,14,.6);color:var(--ivory);border-radius:10px;outline:none;font-size:15px;transition:.18s}
.field input::placeholder{color:var(--ivory-mute)}
.field input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,97,.15)}
.btn-primary{width:100%;padding:14px 16px;background:linear-gradient(135deg,var(--gold-deep) 0%,var(--gold) 50%,var(--gold-deep) 100%);background-size:200% 100%;color:#1A1408;border-radius:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;font-size:12px;box-shadow:0 10px 24px rgba(142,109,44,.35);transition:.25s var(--ease);position:relative;z-index:1}
.btn-primary:hover{background-position:100% 0;transform:translateY(-1px);box-shadow:0 14px 32px rgba(142,109,44,.5)}
.btn-primary:disabled{opacity:.6;cursor:wait}
.legal{margin-top:12px;font-size:11px;color:var(--ivory-mute);line-height:1.5;position:relative;z-index:1}

/* ──────── APP — 2 COLONNES ──────── */
.app{display:grid;grid-template-columns:1fr 380px;height:100vh;width:100%;margin:0;gap:0;overflow:hidden}
@media (max-width:900px){
  .app{grid-template-columns:1fr;height:100dvh}
  .side{position:fixed;top:0;right:0;bottom:0;width:88vw;max-width:380px;transform:translateX(100%);transition:transform .35s var(--ease);z-index:50;box-shadow:-20px 0 60px rgba(0,0,0,.6)}
  .app.side-open .side{transform:translateX(0)}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);opacity:0;pointer-events:none;transition:.3s;z-index:49}
  .app.side-open .scrim{opacity:1;pointer-events:auto}
}

/* ──────── CHAT (gauche) ──────── */
.chat{display:flex;flex-direction:column;height:100vh;background:linear-gradient(180deg,rgba(18,18,26,.92),rgba(10,10,14,.95));border-right:1px solid var(--line);position:relative;min-height:0;overflow:hidden}
@media (max-width:900px){.chat{height:100dvh;border-right:0}}
.chat-header{display:flex;align-items:center;gap:14px;padding:14px 18px;padding-top:calc(14px + var(--safe-top));background:linear-gradient(180deg,rgba(26,26,36,.95),rgba(18,18,26,.75));border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
.chat-header .av{width:46px;height:46px;border-radius:50%;background:center/cover #1F1A12;border:2px solid rgba(201,169,97,.32);box-shadow:0 6px 18px rgba(0,0,0,.4);position:relative;flex:none}
.chat-header .av.online{border-color:var(--green);box-shadow:0 0 0 2px var(--green-glow), 0 6px 18px rgba(0,0,0,.4)}
.chat-header .who{flex:1;min-width:0}
.chat-header .who b{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:18px;color:var(--ivory);letter-spacing:.3px}
.chat-header .who small{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ivory-dim);text-transform:uppercase;letter-spacing:.18em;margin-top:2px}
.chat-header .who small .live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 1.8s ease-in-out infinite}
.chat-header .spacer{flex:1}
.chat-header .icon-btn{width:38px;height:38px;border-radius:10px;color:var(--ivory-dim);font-size:16px;display:flex;align-items:center;justify-content:center;transition:.18s;background:rgba(244,236,216,.05);border:1px solid transparent}
.chat-header .icon-btn:hover{background:rgba(201,169,97,.1);color:var(--ivory);border-color:rgba(201,169,97,.2)}

.messages{flex:1;min-height:0;overflow-y:auto;padding:22px 18px 8px;scrollbar-width:none;-ms-overflow-style:none;background:
  radial-gradient(circle at 50% 0%, rgba(201,169,97,.04), transparent 50%)}
.messages::-webkit-scrollbar{display:none;width:0;height:0}
.messages::-webkit-scrollbar-thumb{background:rgba(201,169,97,.22);border-radius:6px}
.messages::-webkit-scrollbar-track{background:transparent}
.msg{display:flex;margin-bottom:10px;align-items:flex-end;gap:8px}
.msg.user{justify-content:flex-end}
.msg.system{justify-content:center}
.msg .bubble{max-width:80%;padding:12px 14px;border-radius:18px;font-size:14.5px;line-height:1.45;word-wrap:break-word;position:relative}
.msg.user .bubble{background:linear-gradient(135deg,var(--gold-deep),var(--gold-soft));color:#1A1408;border-bottom-right-radius:6px;box-shadow:0 4px 14px rgba(142,109,44,.3)}
.msg.agent .bubble{background:rgba(244,236,216,.04);color:var(--ivory);border-bottom-left-radius:6px;border:1px solid rgba(244,236,216,.1);backdrop-filter:blur(4px)}
.msg.system .bubble{background:linear-gradient(135deg,rgba(142,109,44,.18),rgba(201,169,97,.1));color:var(--gold-pale);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:14px;border:1px solid rgba(201,169,97,.22);max-width:90%;text-align:center;padding:10px 18px;border-radius:14px}
.bubble .sender-name{font-size:10px;color:var(--gold);text-transform:uppercase;letter-spacing:.22em;font-weight:600;margin-bottom:4px}
.bubble .meta{font-size:10px;color:var(--ivory-mute);margin-top:4px;text-align:right;letter-spacing:.05em}
.msg.user .bubble .meta{color:rgba(26,20,8,.55)}
.bubble .body a{color:inherit;border-bottom-color:currentColor;opacity:.85}

.atts{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.att{display:flex;align-items:center;gap:10px;background:rgba(10,10,14,.4);padding:8px 10px;border-radius:10px;font-size:13px;border:1px solid rgba(201,169,97,.18);color:var(--ivory)}
.att.img{padding:0;background:transparent;border:0}
.att img,.att video{max-width:280px;border-radius:12px;display:block}
.att .ic{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex:none}
.att .fn{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.att .sz{color:var(--ivory-mute);font-size:11px}

.typing{padding:0 18px 6px;color:var(--ivory-dim);font-size:12px;font-style:italic;min-height:18px}
.typing .dots{display:inline-flex;gap:3px;margin-left:6px}
.typing .dots span{width:5px;height:5px;border-radius:50%;background:var(--gold);animation:bounce 1.4s infinite ease-in-out both}
.typing .dots span:nth-child(2){animation-delay:.2s}
.typing .dots span:nth-child(3){animation-delay:.4s}
@keyframes bounce{0%,80%,100%{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}

.composer{display:flex;align-items:flex-end;gap:10px;padding:14px 16px;padding-bottom:calc(14px + var(--safe-bottom));background:linear-gradient(180deg,rgba(18,18,26,.6),rgba(10,10,14,.95));border-top:1px solid var(--line);backdrop-filter:blur(8px)}
.composer .icon-btn{width:44px;height:44px;border-radius:50%;background:rgba(244,236,216,.05);color:var(--gold);box-shadow:0 4px 12px rgba(0,0,0,.3);flex:none;display:flex;align-items:center;justify-content:center;font-size:17px;border:1px solid rgba(201,169,97,.18);transition:.18s}
.composer .icon-btn:hover{background:rgba(201,169,97,.12);border-color:rgba(201,169,97,.4)}
.composer textarea{flex:1;resize:none;padding:12px 16px;min-height:44px;max-height:170px;border:1px solid rgba(244,236,216,.14);background:rgba(10,10,14,.6);color:var(--ivory);border-radius:22px;outline:none;line-height:1.45;font-size:15px;transition:.18s;scrollbar-width:none;-ms-overflow-style:none}
.composer textarea::-webkit-scrollbar{display:none;width:0;height:0}
.composer textarea::placeholder{color:var(--ivory-mute)}
.composer textarea:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,169,97,.12)}
.composer .send{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;border:0;box-shadow:0 6px 16px rgba(142,109,44,.4)}
.composer .send:hover{background:linear-gradient(135deg,var(--gold),var(--gold-pale))}
.composer .send:disabled{opacity:.5}

.pending-atts{display:flex;flex-wrap:wrap;gap:8px;padding:10px 16px 0;background:transparent}
.pending-atts .chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(244,236,216,.06);color:var(--ivory);font-size:12px;border:1px solid rgba(201,169,97,.22)}
.pending-atts .chip button{color:var(--ivory-mute);font-size:14px;line-height:1}
.pending-atts .chip button:hover{color:var(--gold-pale)}

.upload-progress{height:2px;background:rgba(201,169,97,.12);overflow:hidden}
.upload-progress .bar{height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-pale));width:0;transition:width .2s}
.hide{display:none !important}

/* ──────── SIDE PANEL (droite — Mon espace) ──────── */
.side{background:linear-gradient(180deg,rgba(18,18,26,.96),rgba(10,10,14,.98));overflow-y:auto;border-left:1px solid var(--line);padding:0;display:flex;flex-direction:column;scrollbar-width:none;-ms-overflow-style:none}
.side::-webkit-scrollbar{display:none;width:0;height:0}
.side::-webkit-scrollbar-thumb{background:rgba(201,169,97,.22);border-radius:6px}
.side-head{padding:22px 22px 18px;padding-top:calc(22px + var(--safe-top));border-bottom:1px solid var(--line);background:radial-gradient(circle at 50% 0%, rgba(201,169,97,.12), transparent 60%);text-align:center;position:relative}
.side-head .avatar-big{position:relative;width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:34px;margin:0 auto 12px;box-shadow:0 0 0 3px rgba(201,169,97,.14), 0 12px 30px rgba(0,0,0,.5);letter-spacing:1px;cursor:pointer;overflow:hidden;transition:transform .35s ease, box-shadow .35s ease}
.side-head .avatar-big:hover{transform:scale(1.04);box-shadow:0 0 0 3px rgba(201,169,97,.32), 0 18px 40px rgba(0,0,0,.55)}
.side-head .avatar-big img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.side-head .avatar-big.has-img{background:#1a1408}
.side-head .avatar-edit-overlay{position:absolute;right:0;bottom:0;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#1A1408;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 4px 14px rgba(0,0,0,.45),0 0 0 2px #1a1408;pointer-events:none;transform:translate(2px,2px);transition:transform .3s ease}
.side-head .avatar-big:hover .avatar-edit-overlay{transform:translate(0,0) scale(1.08)}
.side-head h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;color:var(--ivory);letter-spacing:.4px;line-height:1.1}
.side-head .em{font-size:12px;color:var(--ivory-mute);margin-top:4px;word-break:break-all}
.side-head .close-side{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(244,236,216,.06);color:var(--ivory-dim);font-size:18px;display:none;align-items:center;justify-content:center}
@media (max-width:900px){.side-head .close-side{display:flex}}
.side-head .close-side:hover{background:rgba(201,169,97,.12);color:var(--ivory)}

.side-section{padding:18px 20px 6px}
.side-section h3{font-family:'Inter',sans-serif;font-weight:600;font-size:10px;color:var(--gold);letter-spacing:.28em;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.side-section h3::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(201,169,97,.4),transparent)}

.card-item{display:flex;gap:12px;padding:12px;background:rgba(244,236,216,.03);border:1px solid rgba(244,236,216,.08);border-radius:12px;margin-bottom:10px;text-decoration:none;color:var(--ivory);transition:.2s var(--ease);position:relative;overflow:hidden}
.card-item{border-bottom:1px solid rgba(244,236,216,.08)}
.card-item:hover{background:rgba(201,169,97,.08);border-color:rgba(201,169,97,.32);transform:translateX(-2px);box-shadow:-2px 0 0 var(--gold)}
.card-item .thumb{width:54px;height:54px;border-radius:10px;background:linear-gradient(135deg,#1F1A12,#2A2418) center/cover no-repeat;flex:none;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--gold);border:1px solid rgba(201,169,97,.18)}
.card-item .meta-wrap{flex:1;min-width:0}
.card-item .title{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:15px;line-height:1.2;color:var(--ivory);margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-item .sub{font-size:11px;color:var(--ivory-mute);text-transform:uppercase;letter-spacing:.12em}
.card-item .price{font-size:12px;color:var(--gold-pale);font-weight:600;margin-top:3px;font-variant-numeric:tabular-nums}
.card-item .streak{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--gold);background:rgba(201,169,97,.1);padding:2px 8px;border-radius:999px;margin-top:4px;letter-spacing:.05em;font-weight:600}

.empty{padding:18px;text-align:center;color:var(--ivory-mute);font-size:13px;font-style:italic;font-family:'Cormorant Garamond',serif}

.side-links{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.side-link{display:flex;align-items:center;gap:12px;padding:14px 14px;border-radius:14px;text-decoration:none;background:linear-gradient(135deg,rgba(201,169,97,.07),rgba(201,169,97,.02));border:1px solid rgba(201,169,97,.18);transition:.22s ease;position:relative;overflow:hidden}
.side-link::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,169,97,.18),transparent 60%);opacity:0;transition:.22s}
.side-link:hover{transform:translateY(-1px);border-color:rgba(201,169,97,.45);box-shadow:0 6px 18px -8px rgba(201,169,97,.45)}
.side-link:hover::before{opacity:1}
.side-link>*{position:relative;z-index:1}
.side-link .sl-ico{width:40px;height:40px;flex-shrink:0;border-radius:50%;display:grid;place-items:center;font-size:22px;line-height:1;background:radial-gradient(circle at 30% 30%,rgba(255,235,180,.18),rgba(201,169,97,.04) 70%);color:var(--gold);border:1px solid rgba(201,169,97,.32);text-shadow:0 0 8px rgba(201,169,97,.45),0 1px 0 rgba(0,0,0,.4);font-family:'Cormorant Garamond','Times New Roman',serif;font-weight:400;transition:.22s}
.side-link:hover .sl-ico{border-color:rgba(201,169,97,.65);text-shadow:0 0 12px rgba(255,220,140,.7),0 1px 0 rgba(0,0,0,.4);transform:rotate(-4deg) scale(1.05)}
.side-link .sl-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.side-link .sl-body b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:15px;color:var(--ivory);letter-spacing:.01em;line-height:1.2}
.side-link .sl-body span{font-size:11.5px;color:var(--ivory-mute);letter-spacing:.02em;line-height:1.3}
.side-link .sl-chev{font-size:18px;color:var(--gold);opacity:.65;transition:.22s;flex-shrink:0}
.side-link:hover .sl-chev{opacity:1;transform:translateX(3px)}
.side-link-maha .sl-ico{background:radial-gradient(circle at 30% 30%,rgba(255,220,140,.32),rgba(139,105,20,.18) 60%,rgba(62,39,35,.4));color:#f4e4a8;text-shadow:0 0 14px rgba(255,200,100,.7),0 1px 0 rgba(0,0,0,.5)}

.side-hint{margin-top:18px;padding:14px 16px;text-align:center;color:var(--ivory-mute);font-size:12.5px;font-style:italic;font-family:'Cormorant Garamond',serif;line-height:1.5;border-top:1px solid rgba(201,169,97,.12)}

/* Modale "Ouvrir dans le navigateur" (iOS PWA fallback) */
.ext-link-back{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;padding:20px;animation:elFadeIn .22s ease}
@keyframes elFadeIn{from{opacity:0}to{opacity:1}}
.ext-link-modal{width:100%;max-width:380px;background:linear-gradient(180deg,#1a0f06,#0e0805);border:1px solid rgba(201,169,97,.35);border-radius:18px;padding:24px 22px;box-shadow:0 24px 60px -10px rgba(0,0,0,.7),0 0 0 1px rgba(201,169,97,.06);animation:elPopIn .28s cubic-bezier(.18,.9,.32,1.15)}
@keyframes elPopIn{from{opacity:0;transform:translateY(20px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}
.ext-link-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--gold);text-align:center;margin-bottom:14px;letter-spacing:.02em}
.ext-link-url{font-family:'JetBrains Mono','Courier New',monospace;font-size:11.5px;color:var(--ivory-mute);background:rgba(255,255,255,.04);border:1px solid rgba(201,169,97,.15);padding:10px 12px;border-radius:10px;word-break:break-all;text-align:center;margin-bottom:14px}
.ext-link-hint{font-family:'Cormorant Garamond',serif;font-size:13.5px;font-style:italic;color:var(--ivory-mute);text-align:center;line-height:1.55;margin-bottom:18px}
.ext-link-actions{display:flex;flex-direction:column;gap:9px}
.ext-link-btn{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;padding:13px 16px;border-radius:12px;border:1px solid rgba(201,169,97,.32);background:linear-gradient(135deg,rgba(201,169,97,.18),rgba(201,169,97,.05));color:var(--ivory);cursor:pointer;transition:.18s;letter-spacing:.01em}
.ext-link-btn:hover{transform:translateY(-1px);border-color:rgba(201,169,97,.55);background:linear-gradient(135deg,rgba(201,169,97,.28),rgba(201,169,97,.1))}
.ext-link-btn:active{transform:translateY(0)}
.ext-link-copy{background:linear-gradient(135deg,#8b6914,#624a0c);border-color:#a68227;color:#fff}
.ext-link-copy:hover{background:linear-gradient(135deg,#a68227,#7a5b10)}
.ext-link-cancel{background:transparent;border-color:rgba(255,255,255,.12);color:var(--ivory-mute);font-size:13px;padding:11px}
.ext-link-cancel:hover{border-color:rgba(255,255,255,.22);color:var(--ivory)}

[data-theme="light"] .ext-link-back{background:rgba(60,40,15,.55)}
[data-theme="light"] .ext-link-modal{background:linear-gradient(180deg,#fdfaf3,#f5ecd9);border-color:rgba(142,109,44,.32)}
[data-theme="light"] .ext-link-title{color:#8e6d2c}
[data-theme="light"] .ext-link-url{color:#5a4828;background:rgba(142,109,44,.06);border-color:rgba(142,109,44,.18)}
[data-theme="light"] .ext-link-hint{color:#6a5230}
[data-theme="light"] .ext-link-btn{color:#3a2e1a;border-color:rgba(142,109,44,.32);background:linear-gradient(135deg,rgba(142,109,44,.12),rgba(142,109,44,.03))}
[data-theme="light"] .ext-link-cancel{color:#6a5230;border-color:rgba(0,0,0,.1)}

[data-theme="light"] .side-link{background:linear-gradient(135deg,rgba(142,109,44,.08),rgba(142,109,44,.02));border-color:rgba(142,109,44,.22)}
[data-theme="light"] .side-link:hover{border-color:rgba(142,109,44,.5);box-shadow:0 6px 18px -8px rgba(142,109,44,.35)}
[data-theme="light"] .side-link .sl-ico{background:rgba(142,109,44,.12);color:#8e6d2c;border-color:rgba(142,109,44,.25)}
[data-theme="light"] .side-link .sl-body b{color:#3a2e1a}
[data-theme="light"] .side-link .sl-chev{color:#8e6d2c}
[data-theme="light"] .side-hint{border-top-color:rgba(142,109,44,.15)}

.side-foot{margin-top:auto;padding:16px 20px;padding-bottom:calc(16px + var(--safe-bottom));border-top:1px solid var(--line);text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.side-foot .update-btn{font-family:'Inter',sans-serif;font-size:11px;color:var(--gold);letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:9px 18px;background:linear-gradient(135deg,rgba(201,169,97,.12),rgba(201,169,97,.03));border:1px solid rgba(201,169,97,.3);border-radius:8px;cursor:pointer;transition:.2s;user-select:none}
.side-foot .update-btn:hover{background:linear-gradient(135deg,rgba(201,169,97,.22),rgba(201,169,97,.08));border-color:rgba(201,169,97,.55);transform:translateY(-1px);box-shadow:0 4px 12px -6px rgba(201,169,97,.4)}
/* Telecharger lappli - bouton above Mettre a jour */
.side-foot .install-app-btn{font-family:'Inter',sans-serif;font-size:11px;color:#1b1208;letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:10px 18px;background:linear-gradient(135deg,#FFD78A 0%,#F5C36A 35%,#E5A943 70%,#C9892B 100%);border:0;border-radius:8px;cursor:pointer;transition:.2s;user-select:none;box-shadow:0 6px 18px -8px rgba(201,137,43,.55),0 0 0 1px rgba(255,232,170,.45) inset}
.side-foot .install-app-btn:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(201,137,43,.7),0 0 0 1px rgba(255,232,170,.55) inset}
.side-foot .install-app-btn:active{transform:translateY(0)}

.side-foot .update-btn:active{transform:translateY(0)}
.side-foot .update-btn:disabled{opacity:.6;cursor:wait}
.side-foot .logout{font-size:11px;color:var(--ivory-mute);letter-spacing:.18em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:.18s}
.side-foot .logout:hover{color:var(--gold-pale)}
[data-theme="light"] .side-foot .update-btn{color:#8e6d2c;background:linear-gradient(135deg,rgba(142,109,44,.1),rgba(142,109,44,.02));border-color:rgba(142,109,44,.3)}
[data-theme="light"] .side-foot .update-btn:hover{background:linear-gradient(135deg,rgba(142,109,44,.2),rgba(142,109,44,.05));border-color:rgba(142,109,44,.55)}

/* Mobile toggle bouton — montrer mon espace */
.side-toggle{display:none;position:fixed;top:calc(14px + var(--safe-top));right:14px;z-index:48;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;width:42px;height:42px;border-radius:50%;align-items:center;justify-content:center;font-size:18px;box-shadow:0 6px 18px rgba(142,109,44,.45);border:0}
@media (max-width:900px){.side-toggle{display:flex}}

/* ──────── TOAST ──────── */
.toast{position:fixed;top:calc(20px + var(--safe-top));left:50%;transform:translateX(-50%);background:rgba(18,18,26,.95);color:var(--ivory);padding:11px 18px;border-radius:999px;font-size:13px;box-shadow:var(--shadow-soft);z-index:99;opacity:0;pointer-events:none;transition:.25s;border:1px solid rgba(201,169,97,.32);backdrop-filter:blur(8px)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(4px)}

/* ──────── REDUCE MOTION ──────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .online-pill .dot,.chat-header .who small .live{animation:none}
}

/* ─── Photos des agents (partout où on voit data-slug=maha|brice|didier) ─── */
.av[data-slug="maha"],.av[data-slug="brice"],.av[data-slug="didier"],.agents-strip .av[data-slug="maha"],.agents-strip .av[data-slug="brice"],.agents-strip .av[data-slug="didier"]{background-image:url(/giri-assistance/ga-logo-192.png);background-size:cover;background-position:center;background-color:transparent}

/* ── Composer enrichi : emoji + mic + voice ─────────────────────── */
.icon-btn.emoji-btn{font-size:22px;line-height:1}
.icon-btn.mic{font-size:20px;line-height:1;color:var(--gold,#C9A24A);transition:transform .15s, background .2s, color .2s}
.icon-btn.mic.recording{background:#E54B4B;color:#fff;animation:mic-pulse 1.1s ease-in-out infinite;transform:scale(1.08)}
@keyframes mic-pulse{0%,100%{box-shadow:0 0 0 0 rgba(229,75,75,.55)}50%{box-shadow:0 0 0 12px rgba(229,75,75,0)}}
.voice-timer{position:absolute;left:50%;transform:translateX(-50%);top:-32px;background:rgba(18,18,26,.95);color:#fff;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.4px;box-shadow:0 6px 16px rgba(0,0,0,.35);border:1px solid rgba(229,75,75,.5);pointer-events:none;z-index:6}
.composer{position:relative}

/* Drag & drop visual */
.messages.drag-over{background:rgba(201,162,74,.06);box-shadow:inset 0 0 0 2px var(--gold,#C9A24A);outline-offset:-2px;transition:background .15s}

/* Emoji panel */
 /* ───── EMOJI PICKER v2 ───── */
.emoji-panel{position:absolute;left:0;right:0;bottom:64px;height:340px;background:rgba(14,14,20,.97);backdrop-filter:blur(14px) saturate(120%);border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;z-index:5;box-shadow:0 -14px 38px rgba(0,0,0,.5);animation:emojiSlideUp .22s ease-out}
@keyframes emojiSlideUp{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.emoji-panel.hide{display:none}
.emoji-search-wrap{padding:10px 12px 6px;border-bottom:1px solid rgba(255,255,255,.04)}
.emoji-search{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(201,162,74,.16);color:#f4ecda;font:500 14px Inter,system-ui,sans-serif;padding:9px 14px;border-radius:10px;outline:none;transition:border-color .15s, background .15s}
.emoji-search::placeholder{color:rgba(244,236,218,.42)}
.emoji-search:focus{border-color:rgba(201,162,74,.55);background:rgba(255,255,255,.07)}
.emoji-tabs{display:flex;gap:0;padding:6px 8px;border-bottom:1px solid var(--line);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.emoji-tabs::-webkit-scrollbar{height:4px}
.emoji-tabs::-webkit-scrollbar-thumb{background:rgba(201,162,74,.3);border-radius:2px}
.emoji-tab{background:none;border:0;cursor:pointer;font-size:20px;line-height:1;padding:7px 11px;border-radius:8px;opacity:.55;transition:opacity .15s, background .15s, transform .15s;flex:0 0 auto}
.emoji-tab:hover{opacity:.9;background:rgba(201,162,74,.08)}
.emoji-tab.active{opacity:1;background:rgba(201,162,74,.18);transform:translateY(-1px);box-shadow:0 1px 0 rgba(201,162,74,.45) inset}
.emoji-grid-wrap{flex:1;overflow:hidden;display:flex}
.emoji-grid{flex:1;overflow-y:auto;padding:10px 12px 14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.emoji-grid::-webkit-scrollbar{display:none;width:0;height:0}
.emoji-grid::-webkit-scrollbar-thumb{background:rgba(201,162,74,.25);border-radius:3px}
.emoji-cell{background:none;border:0;cursor:pointer;font-size:24px;line-height:1;padding:6px;border-radius:8px;transition:background .12s, transform .12s;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;position:relative}
.emoji-cell:hover{background:rgba(201,162,74,.12);transform:scale(1.18)}
.emoji-cell:active{transform:scale(.92)}
.emoji-cell[data-tone="1"]::after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-radius:50%;background:linear-gradient(135deg,#f5d590,#c9a24a);opacity:.55}
.emoji-empty{grid-column:1/-1;text-align:center;color:rgba(244,236,218,.5);font:400 13px Inter,sans-serif;padding:30px 12px;font-style:italic}
.emoji-hint{padding:6px 14px 8px;font:400 11px Inter,sans-serif;color:rgba(244,236,218,.4);border-top:1px solid rgba(255,255,255,.04);text-align:center}
.emoji-tone-popover{position:fixed;display:flex;gap:4px;padding:6px;background:rgba(20,20,28,.98);border:1px solid rgba(201,162,74,.35);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.55);z-index:50;opacity:0;transform:translateY(4px) scale(.94);transition:opacity .15s, transform .15s;pointer-events:auto}
.emoji-tone-popover.show{opacity:1;transform:translateY(0) scale(1)}
.emoji-tone-swatch{background:rgba(255,255,255,.04);border:0;cursor:pointer;font-size:24px;line-height:1;padding:6px;border-radius:8px;transition:background .12s, transform .12s}
.emoji-tone-swatch:hover{background:rgba(201,162,74,.18);transform:scale(1.15)}
@media (max-width:480px){
  .emoji-panel{height:300px;bottom:62px}
  .emoji-cell{font-size:22px;padding:5px}
  .emoji-tone-swatch{font-size:22px;padding:5px}
  .emoji-search{font-size:16px;padding:8px 12px}
  .emoji-hint{font-size:10px;padding:5px 10px 6px}
}

/* ──────── SIDE PANEL — Synthèse + Univers + Cards formations ──────── */
.side-synth{padding:14px 20px 6px}
.side-synth .synth-row{display:flex;gap:6px;background:rgba(201,169,97,.06);border:1px solid rgba(201,169,97,.18);border-radius:14px;padding:10px 6px}
.side-synth .synth-cell{flex:1;text-align:center}
.side-synth .synth-cell b{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;color:var(--gold);line-height:1.1}
.side-synth .synth-cell span{display:block;font-size:9.5px;color:var(--ivory-mute);text-transform:uppercase;letter-spacing:.16em;margin-top:2px}

.univers-group{margin-bottom:10px;background:rgba(244,236,216,.025);border:1px solid rgba(244,236,216,.08);border-radius:14px;overflow:hidden;transition:.2s}
.univers-group.open{border-color:rgba(201,169,97,.32);background:rgba(201,169,97,.04)}
.univers-head{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;user-select:none;transition:.2s}
.univers-head:hover{background:rgba(201,169,97,.05)}
.univers-logo{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#1F1A12,#2A2418) center/cover no-repeat;flex:none;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--gold);border:1px solid rgba(201,169,97,.28)}
.univers-name{flex:1;min-width:0}
.univers-name b{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:15px;color:var(--ivory);line-height:1.15;letter-spacing:.3px}
.univers-name span{display:block;font-size:10.5px;color:var(--ivory-mute);text-transform:uppercase;letter-spacing:.12em;margin-top:2px}
.univers-chev{font-size:22px;color:var(--gold);transition:transform .3s ease;line-height:1}
.univers-group.open .univers-chev{transform:rotate(180deg)}
.univers-body{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 10px}
.univers-group.open .univers-body{max-height:6000px;padding:4px 10px 10px}

.f-card{background:rgba(10,10,14,.45);border:1px solid rgba(244,236,216,.06);border-radius:10px;margin:8px 0;overflow:hidden;transition:.2s}
.f-card.open{border-color:rgba(201,169,97,.32)}
.f-card-head{display:flex;align-items:center;gap:10px;padding:10px;cursor:pointer;position:relative}
.f-card-head:hover{background:rgba(201,169,97,.04)}
.f-thumb{width:42px;height:42px;border-radius:8px;background:linear-gradient(135deg,#1F1A12,#2A2418) center/cover no-repeat;flex:none;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold);border:1px solid rgba(201,169,97,.16)}
.f-info{flex:1;min-width:0}
.f-title{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:14px;color:var(--ivory);line-height:1.2;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.f-meta{font-size:10.5px;color:var(--ivory-mute);margin-top:3px;letter-spacing:.05em}
.f-chev{font-size:18px;color:var(--gold);transition:transform .25s;line-height:1}
.f-card.open .f-chev{transform:rotate(90deg)}
.f-pgrs{position:absolute;left:0;right:0;bottom:0;height:2px;background:rgba(201,169,97,.12)}
.f-pgrs-fill{height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-pale));transition:width .4s ease}
.f-card-body{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 12px}
.f-card.open .f-card-body{max-height:600px;padding:6px 12px 12px}
.f-desc{font-size:12.5px;color:var(--ivory-dim);line-height:1.5;margin:6px 0 8px;font-family:'Inter',sans-serif}
.f-meta2{font-size:10.5px;color:var(--ivory-mute);letter-spacing:.04em;margin-bottom:10px;line-height:1.5}
.f-cta{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:8px 14px;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border-radius:8px;transition:.2s}
.f-cta:hover{background:linear-gradient(135deg,var(--gold),var(--gold-pale));transform:translateY(-1px);box-shadow:0 6px 16px rgba(142,109,44,.4)}
.f-cta-disabled{background:rgba(244,236,216,.04);color:var(--ivory-mute);cursor:not-allowed;border:1px solid rgba(244,236,216,.08)}

.side-section-muted h3.h3-muted{color:var(--ivory-mute);cursor:pointer;user-select:none}
.side-section-muted h3.h3-muted:hover{color:var(--gold)}
.side-section-muted .side-section-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.side-section-muted.open .side-section-body{max-height:3000px}
.card-item-small .thumb{width:42px;height:42px;font-size:16px}
.card-item-small .title{font-size:13px}
.card-item-small .sub{font-size:10px}

/* ──────── MASTER DRAWER (Mes Produits) ──────── */
.master-drawer{background:linear-gradient(135deg,rgba(201,169,97,.10),rgba(201,169,97,.04));border:1px solid rgba(201,169,97,.32);border-radius:16px;overflow:hidden;transition:.25s;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.master-drawer.open{border-color:rgba(201,169,97,.55);box-shadow:0 10px 30px rgba(0,0,0,.32),0 0 0 1px rgba(201,169,97,.18)}
.master-head{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;user-select:none;transition:.2s}
.master-head:hover{background:rgba(201,169,97,.08)}
.master-icon{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;display:flex;align-items:center;justify-content:center;font-size:18px;flex:none;box-shadow:0 4px 12px rgba(142,109,44,.4)}
.master-name{flex:1;min-width:0}
.master-name b{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:18px;color:var(--ivory);line-height:1.15;letter-spacing:.6px}
.master-name span{display:block;font-size:11px;color:var(--ivory-mute);text-transform:uppercase;letter-spacing:.16em;margin-top:3px}
.master-chev{font-size:22px;color:var(--gold);transition:transform .35s ease;line-height:1}
.master-drawer.open .master-chev{transform:rotate(180deg)}
.master-body{max-height:0;overflow:hidden;transition:max-height .45s ease;padding:0 12px}
.master-drawer.open .master-body{max-height:10000px;padding:4px 12px 14px}

/* Univers nichés dans master — visuel plus discret */
.master-body .univers-group{background:rgba(10,10,14,.4);border-color:rgba(244,236,216,.06)}
.master-body .univers-group.open{background:rgba(201,169,97,.025)}

/* ───── ATTACH BUTTON — + minimaliste moderne ───── */
.icon-btn.attach-btn{display:flex;align-items:center;justify-content:center;color:#c9a24a;transition:transform .15s, color .15s, background .15s}
.icon-btn.attach-btn:hover{color:#f5d590;background:rgba(201,162,74,.12);transform:rotate(90deg)}
.icon-btn.attach-btn:active{transform:rotate(90deg) scale(.92)}
.attach-ico{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;pointer-events:none}
.attach-ico svg{display:block;width:22px;height:22px}

/* === Bandeau confirmation email === */
.verif-banner{
  margin-top:14px;
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:linear-gradient(135deg, rgba(255,200,80,.14), rgba(255,140,60,.10));
  border:1px solid rgba(255,184,0,.32);
  border-radius:12px;
  font-size:13px;color:rgba(255,246,232,.92);
  box-shadow:0 4px 18px rgba(0,0,0,.18) inset;
}
.verif-dot{
  width:26px;height:26px;flex:0 0 26px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#FFE89C,#FFB800);
  color:#1a0c03;font-weight:700;font-size:14px;
  box-shadow:0 2px 8px rgba(255,184,0,.45);
}
.verif-txt{flex:1;line-height:1.35;font-weight:500;letter-spacing:.01em}
.verif-btn{
  flex:0 0 auto;
  padding:7px 14px;border-radius:999px;border:0;cursor:pointer;
  background:linear-gradient(135deg,#FFE89C 0%,#FFB800 50%,#FF9628 100%);
  color:#1a0c03;font-weight:700;font-size:12px;letter-spacing:.02em;
  box-shadow:0 4px 14px rgba(255,184,0,.35);
  transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.verif-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(255,184,0,.5)}
.verif-btn:disabled{opacity:.6;cursor:wait;transform:none}

/* ──────── AVATAR MENU + CROP MODAL ──────── */
.av-menu{background:linear-gradient(180deg,#1F1A12,#15110A);border:1px solid rgba(201,169,97,.32);border-radius:14px;padding:6px;box-shadow:0 14px 42px rgba(0,0,0,.55);display:flex;flex-direction:column;min-width:220px;animation:av-menu-in .18s ease-out}
@keyframes av-menu-in{from{opacity:0;transform:translateX(-50%) translateY(-6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.av-menu-btn{display:block;width:100%;text-align:left;padding:10px 14px;background:transparent;color:var(--ivory);font-size:13.5px;font-family:'Inter',sans-serif;border:0;border-radius:8px;cursor:pointer;transition:.15s;letter-spacing:.2px}
.av-menu-btn:hover{background:rgba(201,169,97,.12);color:var(--gold-pale)}
.av-menu-btn-danger{color:#FF8A80}
.av-menu-btn-danger:hover{background:rgba(255,138,128,.12);color:#FFB4A8}
.av-menu-btn-cancel{color:var(--ivory-mute);font-size:12px;text-align:center}
.av-menu-btn-cancel:hover{color:var(--ivory)}

.av-crop-overlay{position:fixed;inset:0;background:rgba(8,6,2,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:av-overlay-in .25s ease-out}
@keyframes av-overlay-in{from{opacity:0}to{opacity:1}}
.av-crop-modal{background:linear-gradient(180deg,#1F1A12,#0E0A05);border:1px solid rgba(201,169,97,.4);border-radius:24px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 1px rgba(201,169,97,.12);max-width:340px;width:100%;text-align:center;animation:av-modal-in .3s ease-out}
@keyframes av-modal-in{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
.av-crop-title{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;color:var(--gold-pale);letter-spacing:.4px;margin-bottom:18px}
.av-crop-stage{margin:0 auto 18px;border-radius:50%;overflow:hidden;background:#000;box-shadow:inset 0 0 0 2px rgba(201,169,97,.4),0 8px 30px rgba(0,0,0,.5);position:relative;cursor:grab}
.av-crop-stage:active{cursor:grabbing}
.av-crop-canvas{display:block;width:100%;height:100%;touch-action:none}
.av-crop-zoom-wrap{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding:0 4px}
.av-zoom-ico{font-size:18px;color:var(--gold);font-weight:600;width:18px;text-align:center}
.av-crop-zoom{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:rgba(201,169,97,.18);border-radius:2px;outline:none}
.av-crop-zoom::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--gold-deep),var(--gold));cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.4)}
.av-crop-zoom::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--gold-deep),var(--gold));cursor:pointer;border:0;box-shadow:0 2px 6px rgba(0,0,0,.4)}
.av-crop-actions{display:flex;gap:10px}
.av-crop-btn{flex:1;padding:11px 14px;border-radius:10px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:0;transition:.2s}
.av-crop-btn-cancel{background:rgba(244,236,216,.06);color:var(--ivory-mute);border:1px solid rgba(244,236,216,.12)}
.av-crop-btn-cancel:hover{background:rgba(244,236,216,.1);color:var(--ivory)}
.av-crop-btn-save{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#1A1408;box-shadow:0 6px 16px rgba(142,109,44,.4)}
.av-crop-btn-save:hover:not(:disabled){background:linear-gradient(135deg,var(--gold),var(--gold-pale));transform:translateY(-1px)}
.av-crop-btn-save:disabled{opacity:.6;cursor:wait}

/* ════════════════════════════════════════════════════════════════════
   THÈME CLAIR — palette ivoire/or/café (signature Maha)
   ════════════════════════════════════════════════════════════════════ */
[data-theme="light"]{
  --black:#F4EEDF;
  --black-2:#FFFFFF;
  --black-3:#FAF5E8;
  --line:#D9CFB4;
  --gold:#8E6D2C;
  --gold-soft:#A47D33;
  --gold-pale:#6B5219;
  --gold-deep:#4A380F;
  --ivory:#1F1810;
  --ivory-dim:#574737;
  --ivory-mute:#8A7660;
  --green:#2D9C2D;
  --green-glow:rgba(45,156,45,.28);
  --shadow-lux:0 20px 50px rgba(74,56,15,.10), 0 1px 0 rgba(255,255,255,.6) inset;
  --shadow-soft:0 8px 24px rgba(74,56,15,.08);
}
[data-theme="light"] body::before{background:
  radial-gradient(ellipse 90% 70% at 50% 35%,#FCF8EC 0%, var(--black) 60%),
  radial-gradient(circle at 18% 88%, rgba(142,109,44,.05), transparent 38%),
  radial-gradient(circle at 88% 12%, rgba(142,109,44,.04), transparent 42%),
  var(--black) !important}
[data-theme="light"] body::after{opacity:.15}

/* Login / Gate cards */
[data-theme="light"] .login-card,
[data-theme="light"] .gate .card{
  background:linear-gradient(180deg, #FFFFFF, #FBF6E7);
  border-color:rgba(142,109,44,.28);
  box-shadow:0 24px 60px rgba(74,56,15,.16), 0 1px 0 rgba(255,255,255,.7) inset;
}
[data-theme="light"] .login-card::after,
[data-theme="light"] .gate .card::after{background:radial-gradient(circle,rgba(142,109,44,.10),transparent 60%)}
[data-theme="light"] .field input,
[data-theme="light"] .gate input,
[data-theme="light"] .gate select{
  background:#FFFFFF;
  border-color:rgba(142,109,44,.22);
  color:var(--ivory);
}
[data-theme="light"] .field input:focus,
[data-theme="light"] .gate input:focus,
[data-theme="light"] .gate select:focus{box-shadow:0 0 0 3px rgba(142,109,44,.18)}
[data-theme="light"] .agents-strip .av{background-color:#F4EBD2;border-color:rgba(142,109,44,.28)}

/* Online pills */
[data-theme="light"] .online-pill{background:rgba(45,156,45,.10);border-color:rgba(45,156,45,.32);color:var(--ivory-dim)}
[data-theme="light"] .online-pill.idle{background:rgba(142,109,44,.08);border-color:rgba(142,109,44,.28);color:var(--ivory-mute)}

/* Chat structure */
[data-theme="light"] .chat{background:linear-gradient(180deg, #FFFFFF, #FBF6E7)}
[data-theme="light"] .chat-header{background:linear-gradient(180deg, #FFFFFF, rgba(251,246,231,.85));border-bottom-color:var(--line)}
[data-theme="light"] .chat-header .icon-btn{background:rgba(142,109,44,.06);color:var(--ivory-dim);border-color:transparent}
[data-theme="light"] .chat-header .icon-btn:hover{background:rgba(142,109,44,.14);color:var(--gold);border-color:rgba(142,109,44,.3)}
[data-theme="light"] .messages{background:radial-gradient(circle at 50% 0%, rgba(142,109,44,.04), transparent 50%)}
[data-theme="light"] .messages::-webkit-scrollbar-thumb{background:rgba(142,109,44,.30)}

/* Bubbles */
[data-theme="light"] .msg.agent .bubble{
  background:#FFFFFF;
  color:var(--ivory);
  border:1px solid rgba(142,109,44,.18);
  box-shadow:0 2px 8px rgba(74,56,15,.06);
  backdrop-filter:none;
}
[data-theme="light"] .msg.system .bubble{background:linear-gradient(135deg,rgba(142,109,44,.10),rgba(201,169,97,.06));color:var(--gold-deep);border-color:rgba(142,109,44,.28)}
[data-theme="light"] .msg.user .bubble{box-shadow:0 4px 14px rgba(142,109,44,.22)}
[data-theme="light"] .bubble .sender-name{color:var(--gold)}
[data-theme="light"] .bubble .meta{color:var(--ivory-mute)}

/* Composer */
[data-theme="light"] .composer{background:#FFFFFF;border-top:1px solid var(--line)}
[data-theme="light"] .composer textarea{background:#F8F2E1;color:var(--ivory);border-color:var(--line)}
[data-theme="light"] .composer textarea::placeholder{color:var(--ivory-mute)}
[data-theme="light"] .composer .icon-btn{color:var(--ivory-dim)}
[data-theme="light"] .composer .icon-btn:hover{background:rgba(142,109,44,.10);border-color:rgba(142,109,44,.32)}
[data-theme="light"] .icon-btn.attach-btn{color:var(--gold)}
[data-theme="light"] .icon-btn.attach-btn:hover{color:var(--gold-deep);background:rgba(142,109,44,.12)}
[data-theme="light"] .upload-progress{background:rgba(142,109,44,.12)}
[data-theme="light"] .pending-atts .chip{background:rgba(142,109,44,.08);color:var(--ivory);border:1px solid rgba(142,109,44,.22)}

/* Side panel */
[data-theme="light"] .side{background:linear-gradient(180deg,#FFFFFF,#FBF6E7)}
[data-theme="light"] .side::-webkit-scrollbar-thumb{background:rgba(142,109,44,.30)}
[data-theme="light"] .side-head .avatar-big.has-img{background:#F4EBD2}
[data-theme="light"] .side-section h3::after{background:linear-gradient(90deg,rgba(142,109,44,.4),transparent)}
[data-theme="light"] .card-item{border-bottom:1px solid rgba(142,109,44,.10)}
[data-theme="light"] .side-synth .synth-row{background:rgba(142,109,44,.06);border-color:rgba(142,109,44,.20)}
[data-theme="light"] .univers-group{background:rgba(142,109,44,.025);border-color:rgba(142,109,44,.14)}
[data-theme="light"] .univers-group.open{border-color:rgba(142,109,44,.4);background:rgba(142,109,44,.06)}
[data-theme="light"] .univers-head:hover{background:rgba(142,109,44,.06)}
[data-theme="light"] .f-card{background:rgba(255,255,255,.7);border-color:rgba(142,109,44,.12)}
[data-theme="light"] .f-card.open{border-color:rgba(142,109,44,.4)}
[data-theme="light"] .f-card-head:hover{background:rgba(142,109,44,.04)}
[data-theme="light"] .f-pgrs{background:rgba(142,109,44,.14)}
[data-theme="light"] .master-head:hover{background:rgba(142,109,44,.10)}
[data-theme="light"] .master-body .univers-group{background:rgba(255,255,255,.6);border-color:rgba(142,109,44,.14)}
[data-theme="light"] .master-body .univers-group.open{background:rgba(142,109,44,.05)}

/* Emoji panel */
[data-theme="light"] .emoji-panel{background:rgba(255,253,247,.97);box-shadow:0 -10px 28px rgba(74,56,15,.12)}
[data-theme="light"] .emoji-search-wrap{border-bottom:1px solid rgba(142,109,44,.08)}
[data-theme="light"] .emoji-search{background:#F8F2E1;color:var(--ivory);border-color:rgba(142,109,44,.22)}
[data-theme="light"] .emoji-search::placeholder{color:var(--ivory-mute)}
[data-theme="light"] .emoji-search:focus{border-color:var(--gold);background:#FFFFFF}
[data-theme="light"] .emoji-tabs{border-bottom-color:var(--line)}
[data-theme="light"] .emoji-tab:hover{background:rgba(142,109,44,.08)}
[data-theme="light"] .emoji-tab.active{background:rgba(142,109,44,.18);box-shadow:0 1px 0 rgba(142,109,44,.55) inset}
[data-theme="light"] .emoji-cell:hover{background:rgba(142,109,44,.12)}
[data-theme="light"] .emoji-empty{color:var(--ivory-mute)}
[data-theme="light"] .emoji-hint{color:var(--ivory-mute);border-top-color:rgba(142,109,44,.10)}
[data-theme="light"] .emoji-tone-popover{background:#FFFFFF;border-color:rgba(142,109,44,.4);box-shadow:0 8px 24px rgba(74,56,15,.20)}
[data-theme="light"] .emoji-tone-swatch{background:rgba(142,109,44,.05)}
[data-theme="light"] .emoji-tone-swatch:hover{background:rgba(142,109,44,.18)}

/* Theme toggle button */
.theme-toggle{cursor:pointer;border:1px solid transparent;background:rgba(244,236,216,.05);color:var(--ivory-dim);width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;transition:.2s var(--ease)}
.theme-toggle:hover{background:rgba(201,169,97,.14);color:var(--gold);border-color:rgba(201,169,97,.32);transform:rotate(20deg)}
[data-theme="light"] .theme-toggle{background:rgba(142,109,44,.06);color:var(--ivory-dim)}
[data-theme="light"] .theme-toggle:hover{background:rgba(142,109,44,.14);color:var(--gold);border-color:rgba(142,109,44,.32)}

/* Scrim & overlays */
[data-theme="light"] .scrim{background:rgba(74,56,15,.35)}

/* Toast */
[data-theme="light"] .toast{background:rgba(31,24,16,.92);color:#FBF6E7}

/* Avatar menu / Crop overlay (avatar upload) */
[data-theme="light"] .av-menu-btn-danger{color:#A02838}
[data-theme="light"] .av-menu-btn-danger:hover{background:rgba(160,40,56,.10);color:#C0182E}
[data-theme="light"] .av-crop-overlay{background:rgba(74,56,15,.55)}
[data-theme="light"] .av-crop-zoom{background:rgba(142,109,44,.20)}

/* Mic recording stays red — OK on light too */

/* === FIX avatar crayon devant + overflow visible === */
.side-head .avatar-big{ overflow:visible !important }
.side-head .avatar-big img{ border-radius:50% !important; clip-path:circle(50%); }
.side-head .avatar-edit-overlay{
  z-index:3 !important;
  right:-2px !important; bottom:-2px !important;
  transform:none !important;
  width:30px !important; height:30px !important;
  box-shadow:0 4px 14px rgba(0,0,0,.55), 0 0 0 2px var(--bg, #0f0e0c) !important;
}
.side-head .avatar-big:hover .avatar-edit-overlay{ transform:scale(1.10) !important }

/* Theme toggle flottant sur page login */
.theme-toggle-floating{position:fixed;top:18px;right:18px;z-index:100;width:44px;height:44px;border-radius:12px;background:rgba(244,236,216,.08);backdrop-filter:blur(6px);border:1px solid rgba(201,169,97,.22);font-size:18px;box-shadow:0 4px 14px rgba(0,0,0,.3)}
[data-theme="light"] .theme-toggle-floating{background:rgba(255,255,255,.85);border-color:rgba(142,109,44,.28);box-shadow:0 4px 14px rgba(74,56,15,.12)}

/* === MODALE FÉLICITATION VERIFICATION EMAIL === */
.verif-modal-overlay{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center, rgba(15,12,8,.78) 0%, rgba(8,6,4,.92) 100%);
  backdrop-filter:blur(8px) saturate(120%);
  -webkit-backdrop-filter:blur(8px) saturate(120%);
  opacity:0;transition:opacity .4s ease;
  padding:24px;
}
.verif-modal-overlay.show{opacity:1}
.verif-modal-overlay.hide{opacity:0}
.verif-modal-card{
  position:relative;
  max-width:440px;width:100%;
  padding:54px 36px 36px;
  text-align:center;
  background:linear-gradient(160deg, #1a1408 0%, #2a1f10 50%, #1a1408 100%);
  border:1px solid rgba(255,200,90,.28);
  border-radius:24px;
  box-shadow:
    0 30px 80px rgba(0,0,0,.65),
    0 0 0 1px rgba(255,232,156,.08) inset,
    0 0 60px rgba(255,180,40,.18);
  color:#f6e8c8;
  font-family:'Inter',system-ui,sans-serif;
  transform:scale(.92) translateY(12px);
  opacity:0;
  transition:transform .55s cubic-bezier(.16,.84,.32,1.08), opacity .35s ease;
}
.verif-modal-overlay.show .verif-modal-card{transform:scale(1) translateY(0);opacity:1}

.verif-modal-halo{
  position:absolute;inset:-40% -20% auto -20%;height:120%;
  background:radial-gradient(ellipse at 50% 30%, rgba(255,184,0,.18) 0%, rgba(255,107,44,.10) 35%, transparent 65%);
  pointer-events:none;filter:blur(8px);
}

.verif-modal-seal{
  position:relative;
  width:96px;height:96px;
  margin:0 auto 22px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 28%, #FFF1B8 0%, #FFE89C 12%, #FFB800 50%, #C97914 100%);
  box-shadow:
    0 0 0 6px rgba(255,184,0,.14),
    0 0 0 12px rgba(255,184,0,.06),
    0 14px 38px rgba(255,140,40,.45),
    inset 0 2px 0 rgba(255,255,255,.55),
    inset 0 -8px 22px rgba(140,70,10,.45);
  animation:vm-seal-pulse 2.6s ease-in-out infinite;
}
@keyframes vm-seal-pulse{
  0%,100%{box-shadow:0 0 0 6px rgba(255,184,0,.14),0 0 0 12px rgba(255,184,0,.06),0 14px 38px rgba(255,140,40,.45),inset 0 2px 0 rgba(255,255,255,.55),inset 0 -8px 22px rgba(140,70,10,.45)}
  50%{box-shadow:0 0 0 9px rgba(255,184,0,.20),0 0 0 18px rgba(255,184,0,.10),0 18px 50px rgba(255,140,40,.6),inset 0 2px 0 rgba(255,255,255,.6),inset 0 -8px 22px rgba(140,70,10,.45)}
}
.vm-check{
  font-size:48px;line-height:1;font-weight:700;
  color:#1a0c03;
  text-shadow:0 1px 0 rgba(255,255,255,.4), 0 -1px 0 rgba(0,0,0,.2);
  transform:translateY(-2px);
  animation:vm-check-pop .6s cubic-bezier(.16,.84,.4,1.2) .2s both;
}
@keyframes vm-check-pop{from{transform:translateY(-2px) scale(.3);opacity:0}to{transform:translateY(-2px) scale(1);opacity:1}}

.vm-sparkle{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle, #fff 0%, #FFE89C 60%, transparent 100%);
  box-shadow:0 0 12px #FFE89C;
  opacity:0;
}
.vm-s1{top:-8px;left:50%;animation:vm-spark 2.4s ease-in-out .4s infinite}
.vm-s2{top:50%;right:-10px;animation:vm-spark 2.4s ease-in-out .9s infinite}
.vm-s3{bottom:-6px;left:30%;animation:vm-spark 2.4s ease-in-out 1.4s infinite}
.vm-s4{top:24%;left:-12px;animation:vm-spark 2.4s ease-in-out 1.9s infinite}
@keyframes vm-spark{
  0%,100%{opacity:0;transform:scale(.4)}
  50%{opacity:1;transform:scale(1.4)}
}

.verif-modal-eyebrow{
  font-size:11px;letter-spacing:.32em;font-weight:600;
  color:#FFD68A;
  margin-bottom:14px;
  text-transform:uppercase;
}
.verif-modal-title{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:34px;font-weight:500;line-height:1.15;
  background:linear-gradient(135deg,#FFE89C 0%,#FFB800 70%,#FF9628 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  margin:0 0 16px;letter-spacing:.005em;
}
.verif-modal-lead{
  font-size:15.5px;line-height:1.7;color:rgba(246,232,200,.86);
  margin:0 0 28px;font-weight:400;
}
.verif-modal-btn{
  display:inline-block;padding:14px 32px;border:0;cursor:pointer;
  border-radius:999px;font-size:14.5px;font-weight:700;letter-spacing:.01em;
  background:linear-gradient(135deg,#FFE89C 0%,#FFB800 50%,#FF9628 100%);
  color:#1a0c03;
  box-shadow:
    0 10px 30px rgba(255,184,0,.45),
    0 0 50px rgba(255,107,44,.22),
    inset 0 1px 0 rgba(255,246,232,.5);
  transition:transform .2s ease, box-shadow .2s ease;
  font-family:inherit;
}
.verif-modal-btn:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(255,184,0,.55),0 0 60px rgba(255,107,44,.32),inset 0 1px 0 rgba(255,246,232,.5)}
.verif-modal-btn:active{transform:translateY(0)}
.verif-modal-foot{
  margin-top:22px;
  font-size:12px;color:rgba(246,232,200,.5);
  font-style:italic;letter-spacing:.01em;
}

@media (max-width:480px){
  .verif-modal-card{padding:42px 24px 28px;border-radius:20px}
  .verif-modal-title{font-size:28px}
  .verif-modal-lead{font-size:14.5px}
  .verif-modal-seal{width:80px;height:80px;margin-bottom:18px}
  .vm-check{font-size:40px}
}
@media (prefers-reduced-motion: reduce){
  .verif-modal-seal{animation:none}
  .vm-sparkle{display:none}
  .verif-modal-card{transition:opacity .25s ease;transform:none}
}

/* Bouton primary light : or éclatant + bordure foncée + texte gras contraste max */
[data-theme="light"] .btn-primary,
[data-theme="light"] .gate button{
  background:linear-gradient(135deg,#9C7A33 0%,#E8D29A 50%,#9C7A33 100%);
  background-size:200% 100%;
  color:#1A1408;
  font-weight:800;
  font-size:13px;
  letter-spacing:1.2px;
  border:1.5px solid #6F5520;
  box-shadow:0 10px 26px rgba(111,85,32,.45), 0 2px 0 rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.5) inset;
  text-shadow:0 1px 0 rgba(255,255,255,.35);
}
[data-theme="light"] .btn-primary:hover,
[data-theme="light"] .gate button:hover{
  background-position:100% 0;
  transform:translateY(-1px);
  box-shadow:0 14px 34px rgba(111,85,32,.6), 0 2px 0 rgba(0,0,0,.22), 0 1px 0 rgba(255,255,255,.6) inset;
}

/* Bulle user reste dorée éclatante en light (pas brune) */
[data-theme="light"] .msg.user .bubble{
  background:linear-gradient(135deg,#B8924F,#E8D29A);
  color:#1F1810;
  box-shadow:0 4px 14px rgba(184,146,79,.28);
}
[data-theme="light"] .msg.user .bubble .meta{color:rgba(31,24,16,.55)}

/* Avatar conv-item gradient identique éclatant */
[data-theme="light"] .conv-item .av{
  background:linear-gradient(135deg,#B8924F,#E8D29A);
  color:#1F1810;
  box-shadow:0 4px 10px rgba(184,146,79,.30);
}
[data-theme="light"] .chat-header .av{
  background-color:#F4EBD2;
  border-color:rgba(184,146,79,.45);
  box-shadow:0 4px 12px rgba(184,146,79,.25);
  color:#1F1810;
}
[data-theme="light"] .chat-header .av.online{border-color:var(--green);box-shadow:0 0 0 2px var(--green-glow), 0 4px 12px rgba(184,146,79,.25)}


/* ─── LIGHT THEME — FIXES LISIBILITÉ (banner / avatar-big / send / mic) ─── */
[data-theme="light"] .verif-banner{
  background:linear-gradient(135deg,#FFF1C7 0%,#FFE19A 100%);
  border:1px solid rgba(184,146,79,.50);
  color:#1F1810;
  box-shadow:0 4px 14px rgba(184,146,79,.18) inset, 0 2px 10px rgba(184,146,79,.18);
}
[data-theme="light"] .verif-banner .verif-txt{color:#1F1810;font-weight:600}
[data-theme="light"] .verif-dot{
  background:linear-gradient(135deg,#FFE89C,#FFB800);
  color:#3B2A05;
  box-shadow:0 2px 8px rgba(255,184,0,.55), 0 0 0 1px rgba(255,255,255,.5) inset;
}
[data-theme="light"] .verif-btn{
  background:linear-gradient(135deg,#FFD66A 0%,#FFA225 100%);
  color:#1F1810;
  box-shadow:0 4px 14px rgba(255,162,37,.40);
}

/* Side header big avatar — gradient or éclatant en light (au lieu de brun var(--gold-deep)) */
[data-theme="light"] .side-head .avatar-big{
  background:linear-gradient(135deg,#B8924F 0%,#E8D29A 50%,#B8924F 100%);
  color:#1F1810;
  box-shadow:0 0 0 3px rgba(184,146,79,.22), 0 12px 30px rgba(74,56,15,.20);
}
[data-theme="light"] .side-head .avatar-big.has-img{background:#F4EBD2}
[data-theme="light"] .side-head .avatar-edit-overlay{
  background:linear-gradient(135deg,#E8D29A,#B8924F);
  color:#1F1810;
  box-shadow:0 4px 14px rgba(184,146,79,.40),0 0 0 2px #FFFFFF;
}

/* Send button — gradient or éclatant + SVG paper-plane plus joli */
[data-theme="light"] .composer .send{
  background:linear-gradient(135deg,#B8924F 0%,#E8D29A 50%,#B8924F 100%);
  color:#1F1810;
  box-shadow:0 6px 16px rgba(184,146,79,.40), 0 1px 0 rgba(255,255,255,.4) inset;
  border:0;
}
[data-theme="light"] .composer .send:hover{
  background:linear-gradient(135deg,#A47D33 0%,#E8D29A 50%,#A47D33 100%);
  box-shadow:0 8px 20px rgba(184,146,79,.50);
  transform:translateY(-1px);
}
[data-theme="light"] .composer .send:disabled{opacity:.5;transform:none}
[data-theme="light"] .composer .mic{color:var(--gold-deep)}
[data-theme="light"] .composer .mic:hover{background:rgba(184,146,79,.14);color:#1F1810}

/* Send SVG (remplace l'unicode ➜) */
.composer .send svg{width:20px;height:20px;display:block;transform:translateX(1px) translateY(0)}

/* ─── Splash de reconnexion (clarté cross-device) ─── */
.auth-splash{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at top, rgba(201,169,97,.10), transparent 60%), var(--bg-primary,#1A1A24)}
.auth-splash-card{max-width:420px;width:100%;background:linear-gradient(180deg,rgba(26,26,36,.85),rgba(18,18,26,.92));border:1px solid rgba(201,169,97,.22);border-radius:22px;padding:48px 32px;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.auth-splash-orb{margin:0 auto 24px;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;filter:drop-shadow(0 8px 32px rgba(201,169,97,.5));animation:splashPulse 2.4s ease-in-out infinite}
.auth-splash-orb img{width:96px;height:96px;border-radius:50%}
.auth-splash-title{margin:0 0 8px;font-size:22px;font-weight:600;color:var(--text,#F4EEDF);font-family:'Cormorant Garamond',serif;letter-spacing:.3px}
.auth-splash-sub{margin:0 0 24px;font-size:14px;color:var(--text-soft,rgba(244,238,223,.7))}
.auth-splash-dots{display:flex;gap:8px;justify-content:center}
.auth-splash-dots span{width:8px;height:8px;border-radius:50%;background:var(--gold,#c9a24a);opacity:.3;animation:splashDot 1.2s ease-in-out infinite}
.auth-splash-dots span:nth-child(2){animation-delay:.2s}
.auth-splash-dots span:nth-child(3){animation-delay:.4s}
@keyframes splashPulse{0%,100%{transform:scale(1);filter:drop-shadow(0 8px 32px rgba(201,169,97,.5))}50%{transform:scale(1.05);filter:drop-shadow(0 12px 40px rgba(201,169,97,.8))}}
@keyframes splashDot{0%,80%,100%{opacity:.3;transform:scale(1)}40%{opacity:1;transform:scale(1.3)}}
[data-theme="light"] .auth-splash{background:radial-gradient(ellipse at top, rgba(184,146,79,.18), transparent 60%), #F4EEDF}
[data-theme="light"] .auth-splash-card{background:linear-gradient(180deg,rgba(255,250,240,.96),rgba(244,238,223,.92));border-color:rgba(184,146,79,.32);box-shadow:0 30px 80px rgba(111,85,32,.18)}
[data-theme="light"] .auth-splash-title{color:#1F1810}
[data-theme="light"] .auth-splash-sub{color:rgba(31,24,16,.7)}

/* ─── Login mobile compact : tout sur un ecran ─── */
@media (max-width: 480px) {
  .login{min-height:100vh;min-height:100dvh;display:flex;align-items:flex-start;justify-content:center;padding:16px 14px;padding-top:max(14px, env(safe-area-inset-top));padding-bottom:max(14px, env(safe-area-inset-bottom))}
  .login-card{padding:22px 20px;border-radius:18px;max-width:100%}
  .login-card::after{top:-100px;width:260px;height:260px;filter:blur(28px)}
  .brand{margin-bottom:10px}
  .brand-name{font-size:18px}
  .brand-name small{font-size:8.5px;letter-spacing:.28em;margin-top:1px}
  .login h1{font-size:22px;line-height:1.18;margin:4px 0 6px}
  .login .lead{font-size:12.5px;line-height:1.42;margin:0 0 12px}
  .agents-strip{margin-bottom:6px}
  .agents-strip .av{width:34px;height:34px;margin-left:-10px}
  .agents-strip .av.online::after{width:9px;height:9px}
  .online-pill{font-size:10px;padding:4px 10px}
  .login form{margin-top:2px}
  .field{margin-bottom:10px}
  .field label{font-size:9px;margin-bottom:4px;letter-spacing:.22em}
  .field input{padding:11px 12px;font-size:14px;border-radius:9px}
  .login .btn-cta,.login button[type=submit],.login button.cta{padding:13px 16px;font-size:14px;border-radius:10px;margin-top:2px}
  .login-card p.fineprint,.login-card .fineprint{font-size:10.5px;line-height:1.4;margin-top:10px}
  .login-card p:last-child{margin-bottom:0}
}
@media (max-width: 480px) and (max-height: 720px) {
  .login-card{padding:18px 18px}
  .login h1{font-size:20px;margin:2px 0 4px}
  .login .lead{font-size:12px;margin:0 0 10px}
  .agents-strip .av{width:32px;height:32px}
  .field{margin-bottom:8px}
  .field input{padding:10px 12px}
}

/* Mot de passe — actions secondaires & flow oublié */
.login-actions{display:flex;flex-direction:column;align-items:center;gap:6px;margin:14px 0 8px;position:relative;z-index:1}
.login-link{background:transparent;border:none;cursor:pointer;color:var(--gold,#c9a961);font:500 13px/1.4 'Inter',system-ui,sans-serif;padding:6px 10px;border-radius:8px;transition:background .2s,color .2s;letter-spacing:.01em}
.login-link:hover{background:rgba(201,169,97,.08);color:#f0d68a}
.login-link-soft{color:var(--ivory-mute,#a89678);font-weight:400;font-size:12.5px}
.login-link-soft:hover{color:var(--gold,#c9a961)}
.forgot-success{text-align:center;padding:8px 4px;position:relative;z-index:1}
.forgot-success-icon{font-size:48px;margin:0 auto 12px;line-height:1}
.forgot-success h2{font:600 22px/1.3 'Cormorant Garamond','Cormorant',serif;margin:0 0 10px;color:var(--gold,#c9a961)}
.forgot-success p{font:400 14px/1.55 'Inter',system-ui,sans-serif;color:var(--ivory,#FBE8C8);margin:0 0 10px}
.forgot-success-hint{color:var(--ivory-mute,#a89678) !important;font-size:12.5px !important}
.forgot-success .btn-primary{margin-top:14px}
[data-theme="light"] .login-link{color:#8b6914}
[data-theme="light"] .login-link:hover{background:rgba(139,105,20,.08);color:#7a5a0e}
[data-theme="light"] .login-link-soft{color:#7a684f}
[data-theme="light"] .login-link-soft:hover{color:#8b6914}
[data-theme="light"] .forgot-success h2{color:#8b6914}
[data-theme="light"] .forgot-success p{color:#3a2e1f}
@media (max-width:480px){
  .login-actions{margin:10px 0 6px;gap:4px}
  .login-link{padding:4px 8px;font-size:12.5px}
}

/* === Reactions (double-click like) === */
.bubble{position:relative}
.bubble .reaction-badge{position:absolute;bottom:-10px;right:8px;background:#1a1a22;border:1px solid rgba(201,169,97,.45);border-radius:12px;padding:2px 8px;font-size:11.5px;line-height:1;color:#f4ecd8;box-shadow:0 2px 8px rgba(0,0,0,.5);display:inline-flex;gap:4px;align-items:center;user-select:none;z-index:2}
.msg.user .bubble .reaction-badge{right:auto;left:8px}
[data-theme=light] .bubble .reaction-badge{background:#FFFDF7;border-color:rgba(142,109,44,.32);color:#6a4d20}
