@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  --font:'Plus Jakarta Sans',sans-serif;
  --tr:0.2s cubic-bezier(0.4,0,0.2,1);
  --sb:env(safe-area-inset-bottom,0px);
  --st:env(safe-area-inset-top,0px);
  --p:#7B2FFF;
  --p2:#FF2D8A;
  --p3:#FF6B35;
  --t1:#1A0A3D;
  --t2:rgba(60,30,100,0.5);
  --t3:rgba(60,30,100,0.3);
  --card:rgba(255,255,255,0.65);
  --cardb:rgba(255,255,255,0.9);
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;font-family:var(--font);overflow:hidden;-webkit-font-smoothing:antialiased;}
button{font-family:var(--font);cursor:pointer;border:none;background:none;}
input,textarea{font-family:var(--font);outline:none;border:none;}
::-webkit-scrollbar{width:2px;}
::-webkit-scrollbar-thumb{background:rgba(123,47,255,0.2);border-radius:2px;}

body{
  background:
    radial-gradient(ellipse 100% 70% at 0% 0%,#FFD6F0 0%,transparent 55%),
    radial-gradient(ellipse 80% 80% at 100% 0%,#D6E8FF 0%,transparent 50%),
    radial-gradient(ellipse 90% 90% at 50% 100%,#E8D6FF 0%,transparent 55%),
    #F5F0FF;
}

.page{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden;z-index:1;background:transparent;}

/* AUTH */
#pg-auth{justify-content:center;}
.auth-glow{display:none;}
.auth-box{
  position:relative;z-index:1;width:100%;max-width:420px;
  padding:48px 24px 36px;margin:0 auto;overflow-y:auto;max-height:100vh;
}

.logo-row{display:flex;align-items:center;gap:14px;margin-bottom:6px;}
.logo-icon{
  width:56px;height:56px;border-radius:18px;
  background:linear-gradient(135deg,var(--p),var(--p2),var(--p3));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(123,47,255,0.4);
}
.logo-name{
  font-size:2.4rem;font-weight:800;letter-spacing:-0.04em;
  background:linear-gradient(135deg,var(--p),var(--p2),var(--p3));
  background-size:200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:grad 5s ease-in-out infinite;
}
@keyframes grad{0%,100%{background-position:0%;}50%{background-position:100%;}}
.logo-sub{font-size:0.82rem;color:var(--t3);margin-bottom:32px;letter-spacing:0.06em;text-transform:uppercase;}

.tabs{
  display:flex;background:rgba(255,255,255,0.6);backdrop-filter:blur(20px);
  border:1.5px solid rgba(255,255,255,0.9);border-radius:14px;
  padding:4px;gap:3px;margin-bottom:24px;
}
.tab{flex:1;padding:12px;border-radius:11px;font-size:0.875rem;font-weight:700;color:var(--t2);transition:var(--tr);}
.tab.active{background:linear-gradient(135deg,var(--p),var(--p2));color:#fff;box-shadow:0 4px 16px rgba(123,47,255,0.4);}

.field-wrap{display:flex;flex-direction:column;gap:12px;}

.inp-row{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.7);backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,0.9);border-radius:13px;
  padding:0 14px;transition:var(--tr);color:var(--t3);
}
.inp-row:focus-within{border-color:rgba(123,47,255,0.4);box-shadow:0 0 0 3px rgba(123,47,255,0.08);color:var(--p);background:rgba(255,255,255,0.9);}
.inp-row.ok{border-color:rgba(0,200,120,0.5);}
.inp-row.err{border-color:rgba(255,45,138,0.5);}
.inp-ic{font-size:0.95rem;flex-shrink:0;opacity:0.6;}
.inp-row input{flex:1;background:transparent;font-size:0.95rem;padding:13px 0;color:var(--t1);font-weight:500;}
.inp-row input::placeholder{color:var(--t3);}
.st-ic{font-size:0.85rem;flex-shrink:0;}
.eye{color:var(--t3);font-size:0.85rem;padding:4px;transition:var(--tr);}
.eye:hover{color:var(--p);}

.fhint{font-size:0.775rem;padding-left:2px;color:var(--t3);min-height:14px;}
.fhint.ok{color:#00C878;}
.fhint.err{color:var(--p2);}
.fhint.warn{color:#FF8C00;}

.strength-bar{height:3px;background:rgba(123,47,255,0.08);border-radius:2px;margin-top:-4px;overflow:hidden;}
.strength-bar div{height:100%;width:0;border-radius:2px;transition:width 0.4s,background 0.3s;}

.err-box{background:rgba(255,45,138,0.07);border:1px solid rgba(255,45,138,0.2);border-radius:11px;padding:10px 14px;color:#B0006A;font-size:0.825rem;font-weight:500;}

.cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:15px;margin-top:4px;
  background:linear-gradient(135deg,var(--p),var(--p2));
  background-size:200%;
  border-radius:13px;color:#fff;font-size:0.95rem;font-weight:800;
  letter-spacing:0.03em;
  box-shadow:0 6px 28px rgba(123,47,255,0.45);
  transition:var(--tr);position:relative;overflow:hidden;
  animation:grad 4s ease-in-out infinite;
}
.cta::before{
  content:'';position:absolute;top:-50%;left:-100%;
  width:50%;height:200%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);
  transform:skewX(-20deg);
  animation:shine 3s ease-in-out infinite;
}
@keyframes shine{0%{left:-100%;}50%,100%{left:150%;}}
.cta:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(123,47,255,0.55);}
.cta:active{transform:scale(0.97);}

.spin-row{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--t2);font-size:0.875rem;padding:16px 0;}
.spinner{width:20px;height:20px;border:2px solid rgba(123,47,255,0.15);border-top-color:var(--p);border-radius:50%;animation:spin 0.7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* TOPBAR */
.topbar{
  display:flex;align-items:center;gap:8px;
  padding:12px 14px 11px;
  padding-top:calc(12px + var(--st));
  background:rgba(255,255,255,0.75);
  backdrop-filter:blur(30px);
  border-bottom:1.5px solid rgba(255,255,255,0.9);
  box-shadow:0 2px 16px rgba(123,47,255,0.06);
  flex-shrink:0;z-index:10;position:relative;
}
.topbar::after{
  content:'';position:absolute;bottom:-1px;left:8%;right:8%;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--p),var(--p2),transparent);opacity:0.35;
}
.topbar-l{display:flex;align-items:center;gap:10px;flex:1;}
.topbar-title{
  font-size:1.3rem;font-weight:800;letter-spacing:-0.03em;
  background:linear-gradient(135deg,var(--p),var(--p2));
  background-size:200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:grad 4s ease-in-out infinite;
}
.topbar-c{display:flex;align-items:center;gap:10px;flex:1;min-width:0;cursor:pointer;}
.topbar-r{display:flex;gap:2px;}

.icbtn{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  color:var(--t2);transition:var(--tr);flex-shrink:0;
}
.icbtn:hover{background:rgba(123,47,255,0.08);color:var(--p);}
.icbtn:active{transform:scale(0.86);}

/* AVATARS — carrés arrondis propres */
.ava{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;
  border-radius:14px;
}
.ava40{width:40px;height:40px;font-size:0.95rem;border-radius:13px;}
.ava38{width:38px;height:38px;font-size:0.9rem;border-radius:12px;}
.ava48{width:48px;height:48px;font-size:1.1rem;border-radius:15px;}
.ava64{width:64px;height:64px;font-size:1.5rem;border-radius:20px;}

.mr-ava{
  width:30px;height:30px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:0.7rem;font-weight:800;color:#fff;
  margin-bottom:18px;
}
.mr.out .mr-ava{display:none;}

/* SEARCH */
.searchbar{
  display:flex;align-items:center;gap:9px;
  margin:10px 12px 6px;
  background:rgba(255,255,255,0.6);backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,0.9);border-radius:13px;
  padding:10px 14px;flex-shrink:0;transition:var(--tr);color:var(--t3);
}
.searchbar:focus-within{border-color:rgba(123,47,255,0.3);}
.searchbar input{flex:1;background:transparent;font-size:0.875rem;color:var(--t1);font-weight:500;}
.searchbar input::placeholder{color:var(--t3);}

/* ROOMS LIST */
.rooms-list{flex:1;overflow-y:auto;padding:4px 0 12px;}
.empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:64px 24px;text-align:center;}
.empty-icon{font-size:3rem;opacity:0.3;}
.empty p{font-size:0.9rem;color:var(--t2);}
.ghost-btn{padding:11px 24px;border-radius:12px;border:1.5px solid rgba(123,47,255,0.25);color:var(--p);font-size:0.875rem;font-weight:700;background:rgba(123,47,255,0.05);transition:var(--tr);}
.ghost-btn:hover{background:rgba(123,47,255,0.1);}

/* Room item */
.ri{
  display:flex;align-items:center;gap:12px;
  padding:13px 16px;cursor:pointer;transition:var(--tr);position:relative;
}
.ri:active{background:rgba(123,47,255,0.04);}
.ri.active{background:linear-gradient(90deg,rgba(123,47,255,0.07),transparent);}
.ri.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:36px;
  background:linear-gradient(180deg,var(--p),var(--p2));
  border-radius:0 3px 3px 0;
}
.ri-info{flex:1;min-width:0;}
.ri-name{font-size:0.95rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--t1);}
.ri-last{font-size:0.8rem;color:var(--t3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ri-last.new{color:var(--t2);font-weight:500;}
.ri-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0;}
.ri-time{font-size:0.71rem;color:var(--t3);font-weight:500;}
.ri-time.new{color:var(--p);}
.ri-badge{background:linear-gradient(135deg,var(--p),var(--p2));color:#fff;font-size:0.68rem;font-weight:800;padding:2px 7px;border-radius:10px;min-width:20px;text-align:center;}

/* CHAT */
.chat-title{font-size:0.96rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--t1);}
.chat-sub{font-size:0.73rem;color:var(--p);margin-top:1px;font-weight:600;}

.msgs{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 12px 8px;display:flex;flex-direction:column;gap:4px;}

.dsep{display:flex;align-items:center;gap:10px;color:var(--t3);font-size:0.7rem;font-weight:700;margin:12px 0;letter-spacing:0.07em;text-transform:uppercase;}
.dsep::before,.dsep::after{content:'';flex:1;height:1px;background:rgba(123,47,255,0.1);}

/* Messages */
.mr{display:flex;align-items:flex-end;gap:8px;}
.mr.in{animation:mIn 0.25s cubic-bezier(0.34,1.56,0.64,1);}
.mr.out{flex-direction:row-reverse;animation:mOut 0.25s cubic-bezier(0.34,1.56,0.64,1);}
@keyframes mIn{from{opacity:0;transform:translateX(-14px) scale(0.93);}to{opacity:1;transform:none;}}
@keyframes mOut{from{opacity:0;transform:translateX(14px) scale(0.93);}to{opacity:1;transform:none;}}

.mr-group{display:flex;flex-direction:column;max-width:80%;gap:2px;}
.mr.out .mr-group{align-items:flex-end;}

.mb{padding:10px 14px;line-height:1.6;font-size:0.9rem;word-break:break-word;font-weight:500;}
.mr.in .mb{
  background:rgba(255,255,255,0.75);backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,0.95);
  border-radius:18px 18px 18px 4px;color:var(--t1);
  box-shadow:0 2px 12px rgba(123,47,255,0.06);
}
.mr.out .mb{
  background:linear-gradient(135deg,var(--p),#C040FF);
  border-radius:18px 18px 4px 18px;color:#fff;
  box-shadow:0 4px 20px rgba(123,47,255,0.35);
}
.mb img{max-width:100%;max-height:260px;border-radius:12px;display:block;cursor:pointer;}
.mb video{max-width:100%;max-height:300px;border-radius:12px;display:block;background:#000;}
.mb audio{width:100%;border-radius:8px;margin-top:4px;}

.mf{display:flex;align-items:center;gap:9px;padding:10px 13px;background:rgba(255,255,255,0.6);border:1.5px solid rgba(255,255,255,0.9);border-radius:12px;cursor:pointer;transition:var(--tr);}
.mf:hover{background:rgba(123,47,255,0.07);}
.mf-ic{font-size:1.5rem;}
.mf-name{font-size:0.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px;color:var(--t1);}
.mf-sz{font-size:0.7rem;color:var(--t3);}

.mm{display:flex;align-items:center;gap:5px;padding:0 3px;margin-top:2px;}
.mr.out .mm{flex-direction:row-reverse;}
.mt{font-size:0.67rem;color:var(--t3);font-weight:500;}
.mc{font-size:0.68rem;color:var(--p);font-weight:700;}

/* Réactions */
.reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;}
.rxn-item{
  display:inline-flex;align-items:center;gap:3px;
  background:rgba(255,255,255,0.8);backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,0.95);
  border-radius:20px;padding:3px 8px;font-size:0.85rem;cursor:pointer;
  transition:var(--tr);box-shadow:0 2px 8px rgba(123,47,255,0.08);
  color:var(--t1);font-weight:600;
}
.rxn-item:hover{transform:scale(1.1);}
.rxn-item.mine{background:rgba(123,47,255,0.1);border-color:rgba(123,47,255,0.25);}

.reaction-picker{
  position:absolute;z-index:100;
  display:flex;gap:3px;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(20px);
  border:1.5px solid rgba(255,255,255,1);
  border-radius:50px;padding:7px 11px;
  box-shadow:0 8px 40px rgba(123,47,255,0.25);
  animation:rxnPop 0.2s cubic-bezier(0.34,1.56,0.64,1);
  bottom:calc(100% + 8px);left:0;
}
.mr.out .reaction-picker{left:auto;right:0;}
@keyframes rxnPop{from{opacity:0;transform:scale(0.7) translateY(8px);}to{opacity:1;transform:none;}}
.rxn-btn{background:transparent;border-radius:50%;width:36px;height:36px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr);}
.rxn-btn:hover{transform:scale(1.4);background:rgba(123,47,255,0.08);}

/* Typing */
.typing-row{padding:4px 14px 6px;flex-shrink:0;}
.typing-dots{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(255,255,255,0.75);backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,0.95);
  padding:10px 14px;border-radius:18px 18px 18px 4px;
  box-shadow:0 2px 10px rgba(123,47,255,0.06);
}
.typing-dots span{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--p),var(--p2));animation:td 1.3s ease-in-out infinite;}
.typing-dots span:nth-child(2){animation-delay:.18s;}
.typing-dots span:nth-child(3){animation-delay:.36s;}
@keyframes td{0%,60%,100%{transform:translateY(0);opacity:0.35;}30%{transform:translateY(-6px);opacity:1;}}

/* Input */
.input-zone{
  display:flex;align-items:flex-end;gap:6px;
  padding:10px 11px;padding-bottom:calc(10px + var(--sb));
  background:rgba(255,255,255,0.8);backdrop-filter:blur(30px);
  border-top:1.5px solid rgba(255,255,255,0.9);
  box-shadow:0 -2px 16px rgba(123,47,255,0.05);
  flex-shrink:0;
}
.msg-wrap{
  flex:1;background:rgba(255,255,255,0.7);backdrop-filter:blur(16px);
  border:1.5px solid rgba(255,255,255,0.9);border-radius:15px;
  padding:10px 13px;transition:var(--tr);
}
.msg-wrap:focus-within{border-color:rgba(123,47,255,0.35);box-shadow:0 0 0 3px rgba(123,47,255,0.07);}
.msg-wrap textarea{width:100%;background:transparent;font-size:0.925rem;resize:none;max-height:110px;line-height:1.5;color:var(--t1);font-weight:500;}
.msg-wrap textarea::placeholder{color:var(--t3);}

.send-btn{
  width:44px;height:44px;border-radius:13px;flex-shrink:0;
  background:linear-gradient(135deg,var(--p),var(--p2));
  display:flex;align-items:center;justify-content:center;
  color:#fff;box-shadow:0 4px 18px rgba(123,47,255,0.45);transition:var(--tr);
  position:relative;overflow:hidden;
}
.send-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);}
.send-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(123,47,255,0.55);}
.send-btn:active{transform:scale(0.9);}

/* Emoji */
.emoji-box{
  position:absolute;bottom:74px;right:10px;
  width:min(288px,calc(100vw - 20px));
  background:rgba(255,255,255,0.95);backdrop-filter:blur(24px);
  border:1.5px solid rgba(255,255,255,1);border-radius:18px;padding:12px;
  box-shadow:0 10px 40px rgba(123,47,255,0.18);z-index:50;
}
#emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;max-height:170px;overflow-y:auto;}
.ej{background:transparent;border-radius:8px;padding:7px;font-size:1.05rem;display:flex;align-items:center;justify-content:center;transition:var(--tr);}
.ej:hover{background:rgba(123,47,255,0.07);transform:scale(1.25);}

/* Modals */
.modal-bg{position:fixed;inset:0;z-index:200;background:rgba(60,20,100,0.2);backdrop-filter:blur(20px);display:flex;align-items:flex-end;justify-content:center;}
.modal-sheet{
  background:rgba(255,255,255,0.95);backdrop-filter:blur(30px);
  border:1.5px solid rgba(255,255,255,1);border-radius:26px 26px 0 0;
  width:100%;max-width:500px;padding:20px 20px calc(26px + var(--sb));
  display:flex;flex-direction:column;gap:14px;
  animation:sheetUp 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 -8px 50px rgba(123,47,255,0.12);
}
@keyframes sheetUp{from{transform:translateY(100%);}to{transform:none;}}
.sheet-handle{width:38px;height:4px;border-radius:2px;margin:0 auto 6px;background:linear-gradient(90deg,var(--p),var(--p2));}
.modal-sheet h3{font-size:1rem;font-weight:800;background:linear-gradient(135deg,var(--p),var(--p2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.profile-card{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 0 6px;}
.s-name{font-size:1.05rem;font-weight:700;color:var(--t1);}
.s-id{font-size:0.78rem;color:var(--t3);}
.slabel{font-size:0.72rem;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:0.07em;}
.danger-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;border-radius:12px;background:rgba(255,45,138,0.07);border:1px solid rgba(255,45,138,0.2);color:#B0006A;font-size:0.9rem;font-weight:700;transition:var(--tr);}
.danger-btn:hover{background:rgba(255,45,138,0.12);}

/* Toast */
.toast{
  position:fixed;bottom:calc(30px + var(--sb));left:50%;transform:translateX(-50%);
  background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);
  border:1.5px solid rgba(255,255,255,1);border-radius:13px;
  padding:11px 20px;font-size:0.875rem;white-space:nowrap;font-weight:600;color:var(--t1);
  box-shadow:0 8px 36px rgba(123,47,255,0.18);z-index:400;
  animation:tIn 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes tIn{from{opacity:0;transform:translateX(-50%) translateY(12px) scale(0.9);}to{opacity:1;transform:translateX(-50%) scale(1);}}

/* Desktop */
@media(min-width:768px){
  body{display:flex;}
  #pg-list{position:relative;width:340px;flex-shrink:0;border-right:1.5px solid rgba(123,47,255,0.08);}
  #pg-chat{position:relative;flex:1;}
  .emoji-box{bottom:78px;}
  .modal-bg{align-items:center;}
  .modal-sheet{border-radius:22px;max-width:420px;padding:28px 24px;}
  @keyframes sheetUp{from{opacity:0;transform:scale(0.93);}to{opacity:1;transform:scale(1);}}
}

/* ═══ EMOJI PICKER AVANCÉ ═══ */
.emoji-box{
  position:absolute;bottom:80px;right:10px;
  width:min(320px,calc(100vw - 20px));
  background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);
  border:1.5px solid rgba(255,255,255,1);border-radius:18px;
  box-shadow:0 10px 40px rgba(123,47,255,0.18);z-index:50;
  overflow:hidden;
}
#emoji-grid{display:flex;flex-direction:column;}
.emoji-cats{
  display:flex;gap:2px;padding:8px 8px 0;overflow-x:auto;
  scrollbar-width:none;border-bottom:1px solid rgba(123,47,255,0.08);
}
.emoji-cats::-webkit-scrollbar{display:none;}
.ecat{
  flex-shrink:0;padding:6px 8px;border-radius:8px;
  font-size:1.1rem;cursor:pointer;transition:all 0.15s;background:transparent;
}
.ecat.active,.ecat:hover{background:rgba(123,47,255,0.1);}
.emoji-content{
  display:grid;grid-template-columns:repeat(8,1fr);
  gap:2px;padding:8px;max-height:200px;overflow-y:auto;
}
.ej{background:transparent;border-radius:8px;padding:6px;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;transition:all 0.15s;cursor:pointer;}
.ej:hover{background:rgba(123,47,255,0.08);transform:scale(1.25);}

/* ═══ GIF PICKER ═══ */
.gif-box{
  position:absolute;bottom:80px;right:10px;
  width:min(320px,calc(100vw - 20px));
  max-height:320px;overflow:hidden;
  background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);
  border:1.5px solid rgba(255,255,255,1);border-radius:18px;
  box-shadow:0 10px 40px rgba(123,47,255,0.18);z-index:50;
  display:flex;flex-direction:column;
}
.gif-search-row{
  display:flex;gap:6px;padding:10px 10px 6px;border-bottom:1px solid rgba(123,47,255,0.08);
}
.gif-search-row input{
  flex:1;background:rgba(123,47,255,0.06);border:none;border-radius:8px;
  padding:8px 12px;font-size:0.875rem;color:var(--t1);font-family:var(--font);
}
.gif-search-row button{
  padding:8px 10px;border-radius:8px;
  background:linear-gradient(135deg,var(--p),var(--p2));color:#fff;font-size:0.85rem;
}
.gif-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:4px;
  padding:6px;overflow-y:auto;flex:1;
}
.gif-item{width:100%;height:100px;object-fit:cover;border-radius:8px;cursor:pointer;transition:all 0.15s;}
.gif-item:hover{transform:scale(1.02);opacity:0.9;}

/* ═══ INPUT ACTIONS ═══ */
.input-actions{display:flex;flex-direction:column;gap:2px;}

/* ═══ ÉPHÉMÈRE ═══ */
.ephemeral-bar{
  padding:6px 12px;
  background:rgba(255,255,255,0.6);
  border-top:1px solid rgba(123,47,255,0.06);
  flex-shrink:0;
}
.eph-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:0.78rem;color:var(--p2);font-weight:600;}
.eph-label input{accent-color:var(--p2);}
.ephemeral-badge{
  position:absolute;top:8px;left:8px;
  background:rgba(255,45,138,0.85);color:#fff;
  font-size:0.65rem;font-weight:700;padding:2px 7px;border-radius:8px;
  backdrop-filter:blur(4px);
}

/* ═══ RÉACTIONS ═══ */
.reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;}
.rxn-item{
  display:inline-flex;align-items:center;gap:3px;
  background:rgba(255,255,255,0.85);backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,0.95);
  border-radius:20px;padding:3px 8px;font-size:0.9rem;cursor:pointer;
  transition:all 0.15s;font-weight:600;color:var(--t1);
  box-shadow:0 2px 8px rgba(123,47,255,0.08);
}
.rxn-item:hover{transform:scale(1.1);}
.rxn-item.mine{background:rgba(123,47,255,0.1);border-color:rgba(123,47,255,0.25);}
.rxn-count{font-size:0.75rem;color:var(--t2);}

.reaction-picker{
  position:absolute;z-index:100;
  display:flex;gap:2px;
  background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);
  border:1.5px solid rgba(255,255,255,1);
  border-radius:50px;padding:6px 10px;
  box-shadow:0 8px 40px rgba(123,47,255,0.25);
  animation:rxnPop 0.2s cubic-bezier(0.34,1.56,0.64,1);
  bottom:calc(100% + 8px);left:0;
}
.mr.out .reaction-picker{left:auto;right:0;}
@keyframes rxnPop{from{opacity:0;transform:scale(0.7) translateY(8px);}to{opacity:1;transform:none;}}
.rxn-btn{
  background:transparent;border-radius:50%;width:36px;height:36px;
  font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all 0.15s;
}
.rxn-btn:hover{transform:scale(1.45);background:rgba(123,47,255,0.08);}

/* ═══ VOCAL ═══ */
.voice-msg{display:flex;align-items:center;gap:10px;padding:4px 0;min-width:180px;}
.voice-play{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--p),var(--p2));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1rem;cursor:pointer;flex-shrink:0;
  box-shadow:0 4px 12px rgba(123,47,255,0.35);transition:all 0.15s;border:none;
}
.voice-play:hover{transform:scale(1.08);}
.voice-wave{
  flex:1;height:28px;position:relative;overflow:hidden;border-radius:4px;
  background:rgba(123,47,255,0.06);
}
.voice-wave::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,
    rgba(123,47,255,0.15) 0px,rgba(123,47,255,0.15) 2px,
    transparent 2px,transparent 5px,
    rgba(123,47,255,0.25) 5px,rgba(123,47,255,0.25) 6px,
    transparent 6px,transparent 9px,
    rgba(123,47,255,0.1) 9px,rgba(123,47,255,0.1) 11px,
    transparent 11px,transparent 14px
  );
  animation:waveMove 1.5s linear infinite;
}
@keyframes waveMove{from{transform:translateX(0);}to{transform:translateX(-50px);}}
.voice-dur{font-size:0.75rem;color:var(--t2);font-weight:600;flex-shrink:0;}

/* ═══ ÉPHÉMÈRE AMÉLIORÉ ═══ */
.eph-blurred{ filter:blur(20px) brightness(0.7) !important; }
.eph-wrap{ overflow:hidden;border-radius:12px; }
.eph-overlay{
  position:absolute;inset:0;border-radius:12px;
  background:rgba(123,47,255,0.35);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  transition:opacity 0.3s;
}
.eph-tap-hint{
  color:#fff;font-size:0.8rem;font-weight:700;
  background:rgba(0,0,0,0.4);padding:6px 14px;border-radius:20px;
  letter-spacing:0.03em;
}
.eph-icon{ font-size:1.8rem; }
.eph-timer{
  position:absolute;top:8px;right:8px;
  background:rgba(123,47,255,0.85);color:#fff;
  font-size:0.72rem;font-weight:800;
  padding:3px 8px;border-radius:10px;
  backdrop-filter:blur(4px);transition:background 0.3s;
}
.eph-expired{
  padding:10px 14px !important;
  color:rgba(123,47,255,0.5) !important;
  font-size:0.85rem !important;font-style:italic;
  background:rgba(123,47,255,0.05) !important;
  border:1px dashed rgba(123,47,255,0.2) !important;
  cursor:default !important;
}

/* Cache la barre éphémère */
.ephemeral-bar{ display:none !important; }

/* ═══ SÉCURITÉ — BLOCAGE TÉLÉCHARGEMENT ═══ */
img { -webkit-touch-callout: none !important; pointer-events:none; }
.eph-wrap img, .eph-wrap video { pointer-events:auto; }
video::-webkit-media-controls-enclosure { overflow:hidden; }
video::-webkit-media-controls-panel { width:calc(100% + 30px); }

/* Screen capture CSS overlay - rend les screenshots illisibles */
#pg-chat::after {
  content:'';
  position:fixed;inset:0;z-index:0;
  background:transparent;
  pointer-events:none;
  mix-blend-mode:difference;
}

/* ═══ VIDEO ÉPHÉMÈRE OVERLAY ═══ */
.eph-video{ cursor:pointer; }
