/* ═══════════════════════════════════════════════════════════
   2DEB  —  Main Stylesheet
   Dark theme default · Light theme optional · RTL Arabic
═══════════════════════════════════════════════════════════ */

/* ── Dark theme (default) ────────────────────────────── */
:root {
  --bg:          #0d0d14;
  --bg2:         #13131e;
  --bg3:         #1a1a28;
  --bg4:         #20203050;
  --border:      #28283c;
  --border2:     #35355040;
  --focus:       #5c6bc0;

  --accent:      #6c5ce7;
  --accent-h:    #7d70e8;
  --accent-gl:   rgba(108,92,231,.14);
  --teal:        #00cec9;

  --tx1:         #eaeaf4;
  --tx2:         #8888a8;
  --tx3:         #50506a;
  --on-accent:   #fff;

  --s-draft:     #fdcb6e;
  --s-pending:   #74b9ff;
  --s-active:    #55efc4;
  --s-completed: #a29bfe;

  --sh1: 0 2px 8px  rgba(0,0,0,.45);
  --sh2: 0 4px 24px rgba(0,0,0,.55);
  --sh3: 0 8px 48px rgba(0,0,0,.65);

  --r1: 6px;
  --r2: 10px;
  --r3: 16px;
  --nav-h: 62px;
  --ease: .18s ease;
}

/* ── Light theme ─────────────────────────────────────── */
[data-theme="light"] {
  --bg:   #f2f2f8;
  --bg2:  #e8e8f2;
  --bg3:  #ffffff;
  --bg4:  rgba(0,0,0,.04);
  --border:  #d2d2e8;
  --border2: #c0c0da;
  --tx1:  #18182e;
  --tx2:  #48487a;
  --tx3:  #9090b8;
  --sh1: 0 2px 8px  rgba(0,0,0,.08);
  --sh2: 0 4px 24px rgba(0,0,0,.10);
  --sh3: 0 8px 48px rgba(0,0,0,.13);
}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg); color:var(--tx1);
  line-height:1.65; min-height:100vh;
  display:flex; flex-direction:column;
  transition:background var(--ease),color var(--ease);
}
[dir="rtl"] body{font-family:'Segoe UI','Tahoma',system-ui,sans-serif}
a{color:var(--accent);text-decoration:none;transition:color var(--ease)}
a:hover{color:var(--accent-h)}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ── Util ────────────────────────────────────────────── */
.container{max-width:1080px;margin:0 auto;padding:0 1.2rem}
.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-1{gap:.4rem}.gap-2{gap:.9rem}.gap-3{gap:1.4rem}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}
.w-full{width:100%}
.text-xs{font-size:.72rem}.text-sm{font-size:.84rem}
.text-muted{color:var(--tx3)}.text-sub{color:var(--tx2)}
.ulink{color:var(--tx2);text-decoration:none;transition:color var(--ease)}
.ulink:hover{color:var(--accent)}
h1,h2,h3,h4{font-weight:700;color:var(--tx1);line-height:1.3}
h1{font-size:clamp(1.5rem,4vw,2.2rem)}
h2{font-size:clamp(1.15rem,3vw,1.65rem)}
h3{font-size:clamp(.95rem,2.5vw,1.25rem)}

/* ── Navbar ──────────────────────────────────────────── */
.navbar{
  position:sticky;top:0;z-index:200;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  height:var(--nav-h);
  box-shadow:var(--sh1);
}
.navbar .container{height:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.nav-logo{
  font-size:1.45rem;font-weight:900;letter-spacing:-1px;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--teal));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none;flex-wrap:nowrap}
.nav-links a{
  color:var(--tx2);padding:.38rem .7rem;border-radius:var(--r1);
  font-size:.87rem;transition:all var(--ease);white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{color:var(--tx1);background:var(--accent-gl)}
.nav-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}

.hamburger{display:none;background:none;border:none;cursor:pointer;
  padding:6px;color:var(--tx1)}
.hamburger span{display:block;width:20px;height:2px;
  background:currentColor;margin:4px 0;transition:var(--ease);border-radius:2px}

/* ── Lang switcher ───────────────────────────────────── */
.lang-sw{
  display:flex;gap:2px;
  background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--r1);padding:3px;
}
.lang-btn{
  padding:3px 7px;border-radius:4px;font-size:.72rem;font-weight:700;
  text-transform:uppercase;color:var(--tx3);text-decoration:none;
  transition:all var(--ease);
}
.lang-btn:hover{color:var(--tx1)}
.lang-btn.active{background:var(--accent);color:#fff}

/* ── Theme toggle ────────────────────────────────────── */
.theme-btn{
  background:none;border:1px solid var(--border);border-radius:var(--r1);
  color:var(--tx2);cursor:pointer;padding:4px 9px;font-size:.95rem;
  transition:all var(--ease);line-height:1;
}
.theme-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── Main ────────────────────────────────────────────── */
.main-content{flex:1;padding:2rem 0}

/* ── Card ────────────────────────────────────────────── */
.card{
  background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--r2);padding:1.4rem;
  transition:border-color var(--ease),box-shadow var(--ease);
}
.card:hover{border-color:var(--accent);box-shadow:var(--sh2)}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1rem;padding-bottom:.7rem;border-bottom:1px solid var(--border);
}
.card-title{
  font-size:.82rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--tx2);
}
.card-title .icon{margin-inline-end:.35rem}

/* ── Home grid ───────────────────────────────────────── */
.home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.15rem}

/* ── Debate list item ────────────────────────────────── */
.debate-item{
  padding:.65rem 0;border-bottom:1px solid var(--border2);
  display:flex;flex-direction:column;gap:.25rem;
}
.debate-item:last-child{border-bottom:none;padding-bottom:0}
.debate-item-title{font-size:.93rem;font-weight:600;color:var(--tx1);transition:color var(--ease)}
.debate-item-title:hover{color:var(--accent)}
.debate-item-meta{font-size:.76rem;color:var(--tx3);display:flex;gap:.65rem;flex-wrap:wrap;align-items:center}

/* ── Badge ───────────────────────────────────────────── */
.badge{
  display:inline-block;padding:2px 8px;border-radius:20px;
  font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
}
.badge-draft    {background:rgba(253,203,110,.13);color:var(--s-draft)}
.badge-pending  {background:rgba(116,185,255,.13);color:var(--s-pending)}
.badge-active   {background:rgba(85,239,196,.13); color:var(--s-active)}
.badge-completed{background:rgba(162,155,254,.13);color:var(--s-completed)}
.badge-deleted  {background:rgba(255,118,117,.10);color:#ff7675}
.badge-closed   {background:rgba(253,203,110,.10);color:#fdcb6e}

/* ── Tag chip ────────────────────────────────────────── */
.tag{
  display:inline-flex;align-items:center;
  padding:2px 9px;background:var(--accent-gl);
  border:1px solid rgba(108,92,231,.28);border-radius:20px;
  font-size:.75rem;color:var(--accent);cursor:default;
  transition:all var(--ease);
}
.tag:hover{background:var(--accent);color:#fff}

/* ── Avatar ──────────────────────────────────────────── */
.av{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--teal));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.9rem;color:#fff;
}
.av.lg{width:46px;height:46px;font-size:1.1rem}
.av.sm{width:28px;height:28px;font-size:.72rem}
.av.teal{background:linear-gradient(135deg,var(--teal),#6c5ce7)}

/* ── User row ────────────────────────────────────────── */
.user-row{
  display:flex;align-items:center;gap:.7rem;
  padding:.55rem 0;border-bottom:1px solid var(--border2);
}
.user-row:last-child{border-bottom:none}
.user-info{flex:1;min-width:0}
.user-name{font-size:.88rem;font-weight:600;color:var(--tx1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-stat{font-size:.73rem;color:var(--tx3)}
.rank{font-size:.73rem;font-weight:700;color:var(--accent);min-width:22px;text-align:center}

/* ── Buttons ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.55rem 1.15rem;border-radius:var(--r1);
  font-size:.88rem;font-weight:600;cursor:pointer;
  border:none;transition:all var(--ease);text-decoration:none;white-space:nowrap;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-h);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px rgba(108,92,231,.4)}
.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--tx2)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-gl)}
.btn-ghost{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.btn-ghost:hover{background:var(--accent);color:#fff}
.btn-sm{padding:.35rem .8rem;font-size:.78rem}
.btn-lg{padding:.75rem 1.6rem;font-size:.96rem}
.btn-full{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none !important}

/* ── Forms ───────────────────────────────────────────── */
.form-group{margin-bottom:1.15rem}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--tx2);margin-bottom:.38rem}
.form-control{
  width:100%;padding:.62rem .85rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r1);
  color:var(--tx1);font-size:.88rem;font-family:inherit;
  transition:border-color var(--ease),box-shadow var(--ease);outline:none;
}
.form-control:focus{border-color:var(--focus);box-shadow:0 0 0 3px rgba(92,107,192,.2)}
.form-control::placeholder{color:var(--tx3)}
textarea.form-control{resize:vertical;min-height:96px;line-height:1.6}

/* ── Tags input autocomplete ─────────────────────────── */
.tag-input-wrap{position:relative}
.tag-dropdown{
  position:absolute;top:100%;inset-inline-start:0;width:100%;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r1);
  box-shadow:var(--sh2);z-index:60;max-height:190px;overflow-y:auto;display:none;
}
.tag-dropdown.open{display:block}
.tag-opt{padding:.45rem .85rem;cursor:pointer;font-size:.84rem;color:var(--tx1);transition:background var(--ease)}
.tag-opt:hover{background:var(--accent-gl)}

/* ── Opponent selector ───────────────────────────────── */
.opp-box{
  display:flex;align-items:center;gap:.7rem;
  background:var(--bg2);border:1px dashed var(--border);border-radius:var(--r1);
  padding:.7rem 1rem;cursor:pointer;transition:all var(--ease);
}
.opp-box:hover,.opp-box.chosen{border-style:solid;border-color:var(--accent);background:var(--accent-gl)}
.opp-placeholder{color:var(--tx3);font-size:.88rem;flex:1}
.opp-name{color:var(--tx1);font-weight:600;flex:1;font-size:.9rem}
.opp-hint{color:var(--tx3);font-size:.82rem;margin-inline-start:auto}

/* ── Form actions ────────────────────────────────────── */
.form-actions{display:flex;gap:.7rem;margin-top:1.4rem;flex-wrap:wrap}

/* ── Error ───────────────────────────────────────────── */
.error-box{
  background:rgba(255,85,85,.09);border:1px solid rgba(255,85,85,.28);
  color:#ff7675;padding:.55rem .9rem;border-radius:var(--r1);font-size:.84rem;margin-bottom:1rem;
}

/* ── Login page ──────────────────────────────────────── */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:1rem;
  background:radial-gradient(ellipse at 50% -10%,rgba(108,92,231,.18) 0%,transparent 65%),var(--bg);
}
.login-box{
  width:100%;max-width:400px;background:var(--bg3);
  border:1px solid var(--border);border-radius:var(--r3);
  padding:2.4rem;box-shadow:var(--sh3);
}
.login-logo{text-align:center;margin-bottom:2rem}
.logo-big{
  font-size:2.6rem;font-weight:900;letter-spacing:-2px;
  background:linear-gradient(135deg,var(--accent),var(--teal));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.login-tagline{font-size:.82rem;color:var(--tx3);margin-top:.2rem}
.login-lang{display:flex;justify-content:center;align-items:center;gap:.9rem;margin-top:1.4rem}
.login-lang a{font-size:.78rem;color:var(--tx3)}
.login-lang a:hover,.login-lang a.ll-active{color:var(--accent)}
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:.7rem;
  width:100%;padding:.75rem 1rem;
  background:#fff;color:#3c4043;
  border:1px solid #dadce0;border-radius:var(--r2);
  font-size:.95rem;font-weight:500;text-decoration:none;
  transition:background var(--ease),box-shadow var(--ease);
  box-shadow:0 1px 3px rgba(0,0,0,.12);
}
.btn-google:hover{background:#f8f9fa;box-shadow:0 2px 6px rgba(0,0,0,.18);color:#3c4043}

/* ── Page header ─────────────────────────────────────── */
.page-hdr{margin-bottom:1.8rem}
.page-hdr h1{margin-bottom:.2rem}
.page-hdr p{color:var(--tx2);font-size:.88rem}

/* ── Modal ───────────────────────────────────────────── */
.modal-wrap{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.72);z-index:900;
  align-items:center;justify-content:center;padding:1rem;
  backdrop-filter:blur(5px);
}
.modal-wrap.open{display:flex}
.modal{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r3);
  width:100%;max-width:460px;max-height:82vh;
  display:flex;flex-direction:column;box-shadow:var(--sh3);
  animation:mIn .18s ease;
}
@keyframes mIn{from{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:none}}
.modal-head{
  padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-head h3{font-size:.96rem}
.modal-x{background:none;border:none;cursor:pointer;color:var(--tx3);font-size:1.1rem;line-height:1;transition:color var(--ease)}
.modal-x:hover{color:var(--tx1)}
.modal-body{padding:1.1rem 1.4rem;overflow-y:auto;flex:1}
.modal-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1rem}
.modal-tab{
  padding:.45rem .9rem;font-size:.82rem;font-weight:600;color:var(--tx3);
  cursor:pointer;border-bottom:2px solid transparent;transition:all var(--ease);
}
.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.modal-panel{display:none}
.modal-panel.active{display:block}

.user-pick{
  display:flex;align-items:center;gap:.65rem;
  padding:.5rem .45rem;border-bottom:1px solid var(--border2);
  cursor:pointer;border-radius:var(--r1);transition:background var(--ease);
}
.user-pick:last-child{border-bottom:none}
.user-pick:hover{background:var(--accent-gl)}
.user-pick-name{flex:1;font-size:.88rem;font-weight:600;color:var(--tx1)}

.invite-box{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r1);
  padding:.7rem;font-size:.78rem;color:var(--tx2);word-break:break-all;
  min-height:44px;margin:.65rem 0;
}

/* ── Debate view ─────────────────────────────────────── */
.debate-head{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:1.4rem;margin-bottom:1.4rem;
}
.debate-title-big{font-size:clamp(1.05rem,3vw,1.55rem);font-weight:700;margin:.55rem 0 .9rem}
.participants{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.participant{display:flex;align-items:center;gap:.45rem;font-size:.88rem}
.vs{
  background:var(--accent-gl);border:1px solid rgba(108,92,231,.3);color:var(--accent);
  padding:2px 9px;border-radius:20px;font-size:.73rem;font-weight:700;
}

.round-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:1.35rem;margin-bottom:.9rem;position:relative;
}
.round-card.rc-creator {border-inline-start:3px solid var(--accent)}
.round-card.rc-opponent{border-inline-start:3px solid var(--teal)}
.round-head{display:flex;align-items:center;gap:.65rem;margin-bottom:1rem;justify-content:space-between;flex-wrap:wrap}
.round-num{font-size:.69rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em}
.round-field{margin-bottom:.9rem}
.round-field:last-child{margin-bottom:0}
.round-label{font-size:.72rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.28rem}
.round-val{font-size:.93rem;color:var(--tx1);line-height:1.7;white-space:pre-wrap}
.proof-a{display:inline-flex;align-items:center;gap:.3rem;font-size:.82rem;color:var(--teal)}
.proof-a:hover{color:var(--accent)}

.respond-form{
  background:var(--bg3);border:1px solid var(--accent);border-radius:var(--r2);
  padding:1.4rem;margin-top:1.4rem;
}
.respond-form h3{margin-bottom:1.2rem;font-size:.96rem;color:var(--accent);display:flex;align-items:center;gap:.4rem}
.turn-bar{
  background:linear-gradient(135deg,rgba(108,92,231,.16),rgba(0,206,201,.08));
  border:1px solid rgba(108,92,231,.35);border-radius:var(--r1);
  padding:.65rem 1rem;display:flex;align-items:center;gap:.45rem;
  font-size:.88rem;margin-bottom:1.15rem;
}
.wait-box{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:1.5rem;text-align:center;color:var(--tx2);margin-top:1.4rem;
}
.wait-box .wi{font-size:1.9rem;display:block;margin-bottom:.4rem}

/* ── My debates ──────────────────────────────────────── */
.section-lbl{
  font-size:.82rem;font-weight:700;color:var(--tx2);
  text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:.9rem;padding-bottom:.45rem;border-bottom:1px solid var(--border);
}
.dlist{display:flex;flex-direction:column;gap:.65rem}
.dcard{
  display:flex;align-items:center;gap:.9rem;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:.9rem 1.15rem;text-decoration:none;transition:all var(--ease);
  position:relative;cursor:pointer;
}
.dcard:hover{border-color:var(--accent);background:var(--bg3);transform:translateX(4px)}
[dir="rtl"] .dcard:hover{transform:translateX(-4px)}
.dcard-info{flex:1;min-width:0}
/* stretched link: the title <a> covers the whole card via ::after */
.dcard-title a{color:var(--tx1);text-decoration:none}
.dcard-title a::after{content:'';position:absolute;inset:0;z-index:0}
/* inner links (usernames, tags) sit above the stretched link */
.dcard-meta a,.dcard-meta .tag{position:relative;z-index:1}
.dcard-title{font-size:.92rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dcard-meta{font-size:.75rem;color:var(--tx3);margin-top:.22rem}
.your-turn-dot{color:var(--s-active);font-weight:700}

/* ── Pagination ──────────────────────────────────────── */
.pager{display:flex;justify-content:center;align-items:center;gap:.35rem;flex-wrap:wrap}
.page-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:2rem;height:2rem;padding:0 .55rem;
  border-radius:var(--r1);font-size:.82rem;font-weight:600;
  border:1px solid var(--border);color:var(--tx2);
  text-decoration:none;transition:all var(--ease);
}
.page-btn:hover:not(.disabled):not(.active):not(.page-gap){
  border-color:var(--accent);color:var(--accent);background:var(--accent-gl);
}
.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.page-btn.disabled{opacity:.35;cursor:default}
.page-btn.page-gap{border-color:transparent;cursor:default}

/* ── Tag cards (all_tags page) ───────────────────────── */
.tag-card{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem .9rem;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  text-decoration:none;transition:all var(--ease);
}
.tag-card:hover{border-color:var(--accent);background:var(--accent-gl)}
.tag-card-name{font-size:.88rem;font-weight:600;color:var(--accent)}
.tag-card-cnt{
  font-size:.7rem;font-weight:700;color:#fff;
  background:var(--accent);border-radius:20px;padding:1px 7px;
}

/* ── User list row ────────────────────────────────────── */
.user-list-row:hover{border-color:var(--accent);transform:translateX(3px)}
[dir="rtl"] .user-list-row:hover{transform:translateX(-3px)}

/* ── Messages inbox ──────────────────────────────────── */
.inbox-conv{
  display:flex;align-items:center;gap:.9rem;
  padding:.85rem 1.1rem;background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--r2);text-decoration:none;transition:all var(--ease);
}
.inbox-conv:hover{border-color:var(--accent);transform:translateX(3px)}
[dir="rtl"] .inbox-conv:hover{transform:translateX(-3px)}
.inbox-conv.has-unread{border-color:var(--accent);background:var(--accent-gl)}
.inbox-unread{
  background:var(--accent);color:#fff;border-radius:20px;
  font-size:.65rem;font-weight:700;padding:2px 7px;flex-shrink:0;
}

/* ── Chat messages ────────────────────────────────────── */
.msg-list{display:flex;flex-direction:column;gap:.85rem;padding:.5rem 0}
.msg-row{display:flex;gap:.55rem;align-items:flex-end}
.msg-row.mine{flex-direction:row-reverse}
.msg-bubble{
  max-width:68%;padding:.6rem .95rem;border-radius:var(--r2);
  font-size:.88rem;line-height:1.6;word-break:break-word;
}
.msg-row.mine  .msg-bubble{
  background:var(--accent);color:#fff;
  border-bottom-right-radius:3px;
}
.msg-row.theirs .msg-bubble{
  background:var(--bg3);border:1px solid var(--border);color:var(--tx1);
  border-bottom-left-radius:3px;
}
.msg-time{font-size:.66rem;color:var(--tx3);margin-top:.2rem;white-space:nowrap}

/* ── Action bar (+1 / -1 / Irrelevant / Report) ─────── */
.action-bar{
  display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;
  margin-top:.6rem;padding-top:.55rem;border-top:1px solid var(--border);
}
.ab-vote{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.18rem .55rem;font-size:.75rem;font-weight:700;
  border:1px solid var(--border);border-radius:var(--r1);
  background:transparent;color:var(--tx3);cursor:pointer;transition:all var(--ease);
  min-width:2.2rem;
}
.ab-vote:hover{border-color:var(--accent);color:var(--accent)}
.ab-vote.up.voted{background:rgba(85,239,196,.15);border-color:#55efc4;color:#55efc4}
.ab-vote.down.voted{background:rgba(255,118,117,.15);border-color:#ff7675;color:#ff7675}
.ab-cnt{
  font-size:.68rem;font-weight:800;opacity:.85;margin-inline-start:.15rem;
}
.ab-vote-ph{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:2.2rem;padding:.18rem .55rem;font-size:.75rem;font-weight:700;
  color:var(--tx3);opacity:.3;
}
.ab-sep{width:1px;height:1.1rem;background:var(--border);margin:0 .15rem;flex-shrink:0}
.ab-btn{
  display:inline-flex;align-items:center;gap:.25rem;
  padding:.18rem .6rem;font-size:.74rem;border-radius:var(--r1);
  border:1px solid var(--border);background:transparent;color:var(--tx3);
  cursor:pointer;transition:all var(--ease);
}
.ab-btn.irr:hover{border-color:#ff7675;color:#ff7675}
.ab-btn.irr.active{border-color:#ff7675;color:#ff7675;background:rgba(255,118,117,.1)}
.ab-btn.rep:hover{border-color:#fdcb6e;color:#fdcb6e}
.ab-btn.reported{color:var(--tx3);border-color:transparent;cursor:default;font-size:.74rem}
.irr-cnt{
  display:inline-flex;align-items:center;justify-content:center;
  background:#ff7675;color:#fff;border-radius:20px;
  font-size:.62rem;font-weight:700;padding:0 5px;min-width:1.1rem;
}
.penalty-badge{
  font-size:.72rem;color:#fdcb6e;
  border:1px solid rgba(253,203,110,.4);border-radius:var(--r1);
  padding:.1rem .45rem;
}
.report-form{
  margin-top:.55rem;padding:.65rem .85rem;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r1);
}
.mod-btn{
  background:transparent;border:1px solid rgba(253,203,110,.5);
  color:#fdcb6e;font-size:.75rem;
}
.mod-btn:hover{background:rgba(253,203,110,.1)}

/* ── Round vote (+/-) ────────────────────────────────── */
.round-section{border-top:1px solid var(--border);padding-top:.6rem;margin-top:.6rem}
.round-section:first-of-type{border-top:none;padding-top:0;margin-top:0}
.inline-vote-row{display:flex;align-items:center;gap:.3rem;margin-top:.55rem}
.vote-row{display:flex;align-items:center;gap:.35rem;margin-top:.85rem;padding-top:.65rem;border-top:1px solid var(--border)}
.vote-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.8rem;height:1.8rem;
  background:transparent;border:1px solid var(--border);border-radius:var(--r1);
  cursor:pointer;font-size:.78rem;color:var(--tx3);transition:all var(--ease);
}
.vote-btn:hover{border-color:var(--accent);color:var(--accent)}
.vote-btn.up.voted{background:rgba(85,239,196,.15);border-color:#55efc4;color:#55efc4}
.vote-btn.down.voted{background:rgba(255,118,117,.15);border-color:#ff7675;color:#ff7675}
.vote-btn-placeholder{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.8rem;height:1.8rem;font-size:.78rem;color:var(--tx3);opacity:.3;
}
.vote-score{
  font-size:.82rem;font-weight:700;min-width:1.8rem;text-align:center;color:var(--tx2);
}
.vote-score.pos{color:#55efc4}
.vote-score.neg{color:#ff7675}

/* ── Question vote (useful / useless) ───────────────── */
.qvote-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.55rem}
.qvote-btn{
  padding:.2rem .75rem;border-radius:var(--r1);font-size:.76rem;
  border:1px solid var(--border);background:transparent;color:var(--tx2);
  cursor:pointer;transition:all var(--ease);
}
.qvote-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.qvote-btn.useful.voted{background:rgba(85,239,196,.15);border-color:#55efc4;color:#55efc4}
.qvote-btn.useless.voted{background:rgba(255,118,117,.15);border-color:#ff7675;color:#ff7675}
.qvote-btn:disabled{opacity:.35;cursor:default}

/* ── Nav badge (notifications / messages) ────────────── */
.nav-badge{
  background:var(--accent);color:#fff;border-radius:20px;
  font-size:.6rem;font-weight:700;padding:1px 5px;line-height:1.6;
  min-width:16px;text-align:center;
}

/* ── Notification rows ───────────────────────────────── */
.notif-row{
  display:flex;align-items:flex-start;gap:.85rem;
  padding:.8rem 1rem;border-radius:var(--r2);
  border:1px solid var(--border);background:var(--bg3);
  transition:background var(--ease);
}
.notif-row.notif-unread{
  background:color-mix(in srgb,var(--accent) 6%,var(--bg3));
  border-color:color-mix(in srgb,var(--accent) 25%,var(--border));
}
.notif-av-link{display:block;text-decoration:none}

/* ── Social badges ───────────────────────────────────── */
.social-badge{
  display:inline-flex;align-items:center;
  padding:.18rem .65rem;border-radius:999px;
  font-size:.72rem;font-weight:700;text-decoration:none;
  background:color-mix(in srgb, var(--sc) 18%, transparent);
  border:1px solid color-mix(in srgb, var(--sc) 40%, transparent);
  color:var(--sc);
  transition:all var(--ease);
}
.social-badge:hover{
  background:color-mix(in srgb, var(--sc) 30%, transparent);
  color:var(--sc);
}

/* ── Admin panel ─────────────────────────────────────── */
.admin-tabs{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:1.3rem;border-bottom:1px solid var(--border);padding-bottom:.75rem}
.admin-tab{
  padding:.3rem .85rem;border-radius:var(--r1);font-size:.82rem;font-weight:600;
  color:var(--tx2);text-decoration:none;transition:all var(--ease);
  border:1px solid transparent;display:flex;align-items:center;gap:.35rem;
}
.admin-tab:hover{border-color:var(--border);color:var(--tx1)}
.admin-tab.active{background:var(--accent-gl);border-color:var(--accent);color:var(--accent)}
.admin-stats{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.85rem;
  margin-bottom:1.5rem;
}
.stat-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:1rem;text-align:center;
}
.stat-val{font-size:1.8rem;font-weight:800;line-height:1.1;color:var(--accent)}
.stat-lbl{font-size:.75rem;color:var(--tx3);margin-top:.25rem}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}
.admin-table th{
  text-align:start;padding:.55rem .8rem;
  border-bottom:2px solid var(--border);color:var(--tx3);font-weight:600;font-size:.75rem;
  text-transform:uppercase;letter-spacing:.03em;
}
.admin-table td{
  padding:.6rem .8rem;border-bottom:1px solid var(--border);vertical-align:middle;
}
.admin-table tr:hover td{background:var(--bg2)}
.row-banned td{opacity:.6}
.role-badge{
  font-size:.72rem;font-weight:700;padding:.15rem .5rem;border-radius:var(--r1);
  border:1px solid var(--border);color:var(--tx2);
}
.role-admin{border-color:var(--accent);color:var(--accent)}
.role-moderator{border-color:#fdcb6e;color:#fdcb6e}
.role-select{
  background:var(--bg2);border:1px solid var(--border);color:var(--tx1);
  border-radius:var(--r1);padding:.15rem .4rem;font-size:.78rem;cursor:pointer;
}

/* ── Footer ──────────────────────────────────────────── */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:1.8rem 0 1.2rem;margin-top:auto}
.footer-nav{display:flex;justify-content:center;gap:.35rem;flex-wrap:wrap;margin-bottom:.9rem}
.footer-nav a{color:var(--tx3);font-size:.82rem;padding:.22rem .55rem;border-radius:var(--r1);transition:all var(--ease)}
.footer-nav a:hover{color:var(--accent)}
.footer-copy{text-align:center;font-size:.75rem;color:var(--tx3)}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:768px){
  .nav-links{
    display:none;position:absolute;top:var(--nav-h);left:0;width:100%;
    background:var(--bg2);border-bottom:1px solid var(--border);
    flex-direction:column;padding:.4rem;gap:0;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:.7rem .9rem}
  .hamburger{display:block}
  .home-grid{grid-template-columns:1fr}
  .form-actions{flex-direction:column}
  .form-actions .btn{width:100%;justify-content:center}
  .participants{flex-direction:column;align-items:flex-start}
}
@media(max-width:420px){
  .login-box{padding:1.7rem 1.1rem}
  .modal{max-height:90vh}
}
