@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
  --cyan:        #00d4ff;
  --cyan-rgb:    0, 212, 255;
  --purple:      #b855ff;
  --purple-rgb:  184, 85, 255;
  --green:       #00ff88;
  --green-rgb:   0, 255, 136;
  --amber:       #ffb800;
  --amber-rgb:   255, 184, 0;
  --pink:        #ff3d9a;
  --pink-rgb:    255, 61, 154;

  --bg:          #070710;
  --bg2:         #0d0d1e;
  --card:        #111124;
  --card-h:      #16162e;
  --input-bg:    #0a0a1c;
  --border:      rgba(255,255,255,0.07);
  --border-h:    rgba(255,255,255,0.14);
  --text:        #e8e8f8;
  --text-2:      #9090b8;
  --text-3:      #505070;
  --shadow:      rgba(0,0,0,0.45);
  --r:           12px;
  --r-sm:        8px;
  --r-lg:        20px;
  --ease:        0.2s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="light"] {
  --bg:        #f0f0fa;
  --bg2:       #e8e8f5;
  --card:      #ffffff;
  --card-h:    #f5f5ff;
  --input-bg:  #f3f3ff;
  --border:    rgba(0,0,0,0.08);
  --border-h:  rgba(0,0,0,0.18);
  --text:      #16162e;
  --text-2:    #606080;
  --text-3:    #a0a0c0;
  --shadow:    rgba(0,0,0,0.08);
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html { font-family:'Inter',-apple-system,sans-serif; -webkit-font-smoothing:antialiased; }

body {
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  transition: background var(--ease), color var(--ease);
}

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

a { color: inherit; text-decoration: none; }

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap:.4em;
  padding:.5em 1.2em; border:1px solid transparent; border-radius:var(--r-sm);
  font-family:inherit; font-size:.875rem; font-weight:500; cursor:pointer;
  transition: all var(--ease); white-space:nowrap; background:none; color:var(--text);
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0) scale(.98); }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none; }

.btn-primary {
  background: linear-gradient(135deg,rgba(var(--cyan-rgb),.15),rgba(var(--purple-rgb),.15));
  border-color: var(--cyan); color: var(--cyan);
  box-shadow: 0 0 12px rgba(var(--cyan-rgb),.15);
}
.btn-primary:hover {
  background: linear-gradient(135deg,rgba(var(--cyan-rgb),.25),rgba(var(--purple-rgb),.25));
  box-shadow: 0 0 24px rgba(var(--cyan-rgb),.3);
}

.btn-success { border-color:var(--green); color:var(--green); background:rgba(var(--green-rgb),.1); }
.btn-success:hover { background:rgba(var(--green-rgb),.2); box-shadow:0 0 18px rgba(var(--green-rgb),.2); }

.btn-warning { border-color:var(--amber); color:var(--amber); background:rgba(var(--amber-rgb),.1); }
.btn-warning:hover { background:rgba(var(--amber-rgb),.2); box-shadow:0 0 18px rgba(var(--amber-rgb),.2); }

.btn-danger { border-color:var(--pink); color:var(--pink); background:rgba(var(--pink-rgb),.1); }
.btn-danger:hover { background:rgba(var(--pink-rgb),.2); box-shadow:0 0 18px rgba(var(--pink-rgb),.2); }

.btn-ghost { border-color:var(--border); color:var(--text-2); }
.btn-ghost:hover { border-color:var(--border-h); color:var(--text); }

.btn-sm { padding:.3em .8em; font-size:.8rem; }
.btn-lg { padding:.7em 1.8em; font-size:1rem; }
.btn-full { width:100%; justify-content:center; }
.btn-icon { padding:.4em; border-radius:var(--r-sm); aspect-ratio:1; }

/* ── Forms ─────────────────────────────────────────────────────────────────── */
.form-group { margin-bottom:1.1rem; }
.form-label {
  display:block; font-size:.78rem; font-weight:600; color:var(--text-2);
  margin-bottom:.4rem; text-transform:uppercase; letter-spacing:.06em;
}
.form-input, .form-select, .form-textarea {
  width:100%; padding:.65em 1em;
  background:var(--input-bg); border:1px solid var(--border);
  border-radius:var(--r-sm); color:var(--text);
  font-family:inherit; font-size:.9rem;
  transition:border-color var(--ease), box-shadow var(--ease); outline:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--cyan); box-shadow:0 0 0 3px rgba(var(--cyan-rgb),.12);
}
.form-textarea { resize:vertical; min-height:75px; }
.form-select { cursor:pointer; }

.input-row { position:relative; }
.input-row .form-input { padding-right:2.5rem; }
.input-eye {
  position:absolute; right:.6rem; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; color:var(--text-2);
  font-size:1.1rem; padding:.2em; line-height:1;
  transition:color var(--ease);
}
.input-eye:hover { color:var(--text); }

/* ── Badges ────────────────────────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:.35em;
  padding:.22em .65em; border-radius:99px; font-size:.72rem;
  font-weight:700; border:1px solid; letter-spacing:.05em; text-transform:uppercase;
}
.badge::before { content:''; width:5px; height:5px; border-radius:50%; background:currentColor; flex-shrink:0; }

.badge-available { color:var(--cyan);   border-color:rgba(var(--cyan-rgb),.35);   background:rgba(var(--cyan-rgb),.08); }
.badge-taken     { color:var(--purple); border-color:rgba(var(--purple-rgb),.35); background:rgba(var(--purple-rgb),.08); }
.badge-pending   { color:var(--amber);  border-color:rgba(var(--amber-rgb),.35);  background:rgba(var(--amber-rgb),.08); }
.badge-done      { color:var(--green);  border-color:rgba(var(--green-rgb),.35);  background:rgba(var(--green-rgb),.08); }
.badge-admin     { color:var(--pink);   border-color:rgba(var(--pink-rgb),.35);   background:rgba(var(--pink-rgb),.08); }

/* ── Header ────────────────────────────────────────────────────────────────── */
.header {
  position:sticky; top:0; z-index:100;
  background:rgba(7,7,16,.8); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
[data-theme="light"] .header { background:rgba(240,240,250,.85); }

.header-inner {
  max-width:1200px; margin:0 auto; padding:0 1.5rem;
  height:60px; display:flex; align-items:center; justify-content:space-between; gap:1rem;
}

.logo {
  font-size:1.15rem; font-weight:700;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  white-space:nowrap; user-select:none;
}

.header-right { display:flex; align-items:center; gap:.5rem; }

.user-chip {
  display:flex; align-items:center; gap:.5rem;
  font-size:.875rem; font-weight:500;
}

/* ── Avatar ────────────────────────────────────────────────────────────────── */
.avatar {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  display:inline-flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:700; color:#fff; flex-shrink:0;
}
.avatar-md { width:40px; height:40px; font-size:.95rem; }
.avatar-lg { width:48px; height:48px; font-size:1.1rem; }

/* ── Container ─────────────────────────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:2rem 1.5rem; }

/* ── Stats bar ─────────────────────────────────────────────────────────────── */
.stats-bar { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.5rem; }

.stat-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r);
  padding:1.1rem 1.3rem; text-align:center; transition:all var(--ease);
}
.stat-card:hover { transform:translateY(-2px); box-shadow:0 8px 24px var(--shadow); }

.stat-value { font-size:2rem; font-weight:700; line-height:1; margin-bottom:.3rem; }
.stat-label { font-size:.75rem; color:var(--text-2); text-transform:uppercase; letter-spacing:.06em; }

.stat-available .stat-value { color:var(--cyan); }
.stat-taken     .stat-value { color:var(--purple); }
.stat-pending   .stat-value { color:var(--amber); }
.stat-done      .stat-value { color:var(--green); }

/* ── Progress ──────────────────────────────────────────────────────────────── */
.progress-container {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r);
  padding:1.1rem 1.5rem; margin-bottom:1.5rem;
}
.progress-label { display:flex; justify-content:space-between; font-size:.82rem; color:var(--text-2); margin-bottom:.7rem; }
.progress-track { height:6px; background:var(--border); border-radius:99px; overflow:hidden; }
.progress-fill {
  height:100%; border-radius:99px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  box-shadow:0 0 10px rgba(var(--cyan-rgb),.5);
  transition:width .7s cubic-bezier(.4,0,.2,1);
}

/* ── Filters ───────────────────────────────────────────────────────────────── */
.filters { display:flex; gap:.5rem; margin-bottom:1.5rem; flex-wrap:wrap; }

.filter-btn {
  padding:.35em .9em; border-radius:99px; border:1px solid var(--border);
  font-size:.8rem; font-weight:500; cursor:pointer; background:none; color:var(--text-2);
  font-family:inherit; transition:all var(--ease);
}
.filter-btn:hover, .filter-btn.active { border-color:var(--cyan); color:var(--cyan); }
.filter-btn.active { background:rgba(var(--cyan-rgb),.1); }

/* ── Category sections ─────────────────────────────────────────────────────── */
.category-section { margin-bottom:2rem; }

.category-header {
  display:flex; align-items:center; gap:.7rem;
  margin-bottom:.9rem; padding-bottom:.6rem; border-bottom:1px solid var(--border);
}
.cat-icon { font-size:1.3rem; }
.cat-title { font-size:.95rem; font-weight:600; }
.cat-count { font-size:.78rem; color:var(--text-2); margin-left:auto; }

.task-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:1rem; }

/* ── Task card ─────────────────────────────────────────────────────────────── */
.task-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r);
  padding:1.2rem; display:flex; flex-direction:column; gap:.7rem;
  position:relative; overflow:hidden; transition:all var(--ease);
}
.task-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  transition:opacity var(--ease);
}
.task-card:hover { border-color:var(--border-h); transform:translateY(-2px); box-shadow:0 8px 24px var(--shadow); }

.task-card.status-available::before { background:var(--cyan); opacity:.6; }
.task-card.status-taken::before     { background:var(--purple); opacity:.7; }
.task-card.status-pending::before   { background:var(--amber); opacity:.7; }
.task-card.status-done::before      { background:var(--green); opacity:.7; }

.task-card.status-taken  { border-color:rgba(var(--purple-rgb),.2); }
.task-card.status-done   { border-color:rgba(var(--green-rgb),.2); opacity:.85; }
.task-card.status-pending{ border-color:rgba(var(--amber-rgb),.2); }

.task-head { display:flex; justify-content:space-between; align-items:flex-start; gap:.5rem; }
.task-title { font-size:.95rem; font-weight:600; line-height:1.3; }

.task-desc { font-size:.82rem; color:var(--text-2); line-height:1.5; }

.badge-xs { font-size:.65rem; padding:.1rem .4rem; margin-left:auto; flex-shrink:0; }

.task-assignees { display:flex; flex-direction:column; gap:.35rem; margin:.5rem 0; }
.task-assignee { display:flex; align-items:flex-start; gap:.5rem; font-size:.83rem; font-weight:500; }
.assignee-dot {
  width:22px; height:22px; border-radius:50%; margin-top:.1rem;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  display:flex; align-items:center; justify-content:center;
  font-size:.62rem; font-weight:700; color:#fff; flex-shrink:0;
}
.assignee-info { flex:1; display:flex; flex-direction:column; gap:.1rem; min-width:0; }
.assignee-name-row { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; }
.assignee-name-row .badge-xs { margin-left:0; }
.assignee-note { font-size:.75rem; color:var(--text-2); font-style:italic; }
.note-input-row { display:flex; align-items:center; gap:.4rem; margin:.4rem 0 .1rem; }
.note-input {
  flex:1; font-size:.8rem; padding:.28rem .5rem; min-width:0;
  background:var(--input-bg); border:1px solid var(--border);
  border-radius:.4rem; color:var(--text);
}
.note-input:focus { outline:none; border-color:var(--cyan); }

.visible-xs { display:none; }
.task-actions { display:flex; gap:.4rem; flex-wrap:wrap; margin-top:auto; padding-top:.3rem; }

/* ── Modal ─────────────────────────────────────────────────────────────────── */
.overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.65); backdrop-filter:blur(4px);
  z-index:1000; display:flex; align-items:center; justify-content:center; padding:1rem;
  opacity:0; pointer-events:none; transition:opacity var(--ease);
}
.overlay.open { opacity:1; pointer-events:all; }

.modal {
  background:var(--card); border:1px solid var(--border-h); border-radius:var(--r-lg);
  padding:2rem; width:100%; max-width:500px; max-height:90vh; overflow-y:auto;
  transform:translateY(18px) scale(.96); transition:transform var(--ease);
}
.overlay.open .modal { transform:translateY(0) scale(1); }

.modal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; }
.modal-title { font-size:1.1rem; font-weight:700; }
.modal-close {
  width:30px; height:30px; border-radius:50%; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  background:none; color:var(--text-2); font-size:1.2rem; transition:all var(--ease); line-height:1;
}
.modal-close:hover { border-color:var(--pink); color:var(--pink); }

.modal-footer { display:flex; gap:.7rem; justify-content:flex-end; margin-top:1.5rem; }

/* ── Toast ─────────────────────────────────────────────────────────────────── */
.toasts {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:2000;
  display:flex; flex-direction:column; gap:.5rem; pointer-events:none;
}
.toast {
  padding:.75rem 1.1rem; border-radius:var(--r-sm); font-size:.87rem; font-weight:500;
  border:1px solid; max-width:320px; backdrop-filter:blur(10px);
  animation:toastIn .3s ease-out; pointer-events:all;
}
.toast.out { animation:toastOut .3s ease-in forwards; }

@keyframes toastIn  { from { transform:translateX(100%); opacity:0; } to { transform:none; opacity:1; } }
@keyframes toastOut { from { transform:none; opacity:1; } to { transform:translateX(110%); opacity:0; } }

.toast-success { background:rgba(var(--green-rgb),.12);  border-color:rgba(var(--green-rgb),.4);  color:var(--green); }
.toast-error   { background:rgba(var(--pink-rgb),.12);   border-color:rgba(var(--pink-rgb),.4);   color:var(--pink); }
.toast-info    { background:rgba(var(--cyan-rgb),.12);   border-color:rgba(var(--cyan-rgb),.4);   color:var(--cyan); }
.toast-warning { background:rgba(var(--amber-rgb),.12);  border-color:rgba(var(--amber-rgb),.4);  color:var(--amber); }

/* ── Login ─────────────────────────────────────────────────────────────────── */
.login-page {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:1.5rem; position:relative; overflow:hidden;
}

.blobs { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.blob {
  position:absolute; border-radius:50%; filter:blur(70px); opacity:.12;
  animation:blobFloat 10s ease-in-out infinite;
}
.blob-1 { width:480px; height:480px; background:var(--cyan);   top:-150px; left:-100px; animation-delay:0s; }
.blob-2 { width:350px; height:350px; background:var(--purple); bottom:-80px; right:-80px; animation-delay:-5s; }
.blob-3 { width:220px; height:220px; background:var(--green);  top:55%; left:55%; animation-delay:-2.5s; }

@keyframes blobFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  33%      { transform:translate(25px,-20px) scale(1.06); }
  66%      { transform:translate(-20px,25px) scale(.94); }
}

.login-card {
  background:var(--card); border:1px solid var(--border-h); border-radius:var(--r-lg);
  padding:2.5rem; width:100%; max-width:420px; position:relative; z-index:1;
  box-shadow:0 24px 64px rgba(0,0,0,.5), 0 0 0 1px rgba(var(--cyan-rgb),.06);
}

.login-icon { font-size:2.5rem; text-align:center; margin-bottom:1rem; }
.login-title {
  font-size:1.7rem; font-weight:700; text-align:center; margin-bottom:.3rem;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.login-sub { text-align:center; color:var(--text-2); font-size:.88rem; margin-bottom:2rem; }

.login-error {
  background:rgba(var(--pink-rgb),.1); border:1px solid rgba(var(--pink-rgb),.3);
  color:var(--pink); padding:.65rem 1rem; border-radius:var(--r-sm);
  font-size:.84rem; margin-bottom:1.2rem;
}
.login-footer { text-align:center; margin-top:1.2rem; }

/* ── Admin ─────────────────────────────────────────────────────────────────── */
.page-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:2rem; flex-wrap:wrap; gap:1rem; }
.page-title { font-size:1.4rem; font-weight:700; }
.breadcrumb { font-size:.82rem; color:var(--text-2); margin-bottom:.4rem; }

.tabs { display:flex; gap:.2rem; border-bottom:1px solid var(--border); margin-bottom:1.5rem; overflow-x:auto; }
.tab {
  padding:.65rem 1.2rem; font-size:.88rem; font-weight:500; cursor:pointer;
  border:none; background:none; color:var(--text-2); border-bottom:2px solid transparent;
  margin-bottom:-1px; transition:all var(--ease); white-space:nowrap; font-family:inherit;
}
.tab:hover:not(.active) { color:var(--text); }
.tab.active { color:var(--cyan); border-bottom-color:var(--cyan); }

.tab-pane { display:none; }
.tab-pane.active { display:block; }

/* ── Table ─────────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; background:var(--card); border:1px solid var(--border); border-radius:var(--r); }
.table { width:100%; border-collapse:collapse; font-size:.875rem; }
.table th {
  padding:.8rem 1rem; text-align:left; font-size:.73rem; font-weight:600;
  color:var(--text-2); text-transform:uppercase; letter-spacing:.06em;
  border-bottom:1px solid var(--border); white-space:nowrap;
}
.table td { padding:.85rem 1rem; border-bottom:1px solid var(--border); vertical-align:middle; }
.table tr:last-child td { border-bottom:none; }
.table tr:hover td { background:var(--card-h); }

/* ── Divider ───────────────────────────────────────────────────────────────── */
.divider { height:1px; background:var(--border); margin:1.5rem 0; }

/* ── Summary cards ─────────────────────────────────────────────────────────── */
.summary-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.summary-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r);
  padding:1rem 1.2rem; display:flex; align-items:center; gap:.8rem; transition:all var(--ease);
}
.summary-card:hover { border-color:var(--border-h); }
.summary-person { font-size:.9rem; font-weight:600; }
.summary-count { font-size:.78rem; color:var(--text-2); margin-top:.15rem; }

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width:900px) {
  .stats-bar { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px) {
  .container { padding:1rem; }
  .header-inner { padding:0 1rem; }
  .task-grid { grid-template-columns:1fr; }
  .login-card { padding:1.8rem 1.5rem; }
  .modal { padding:1.5rem; }
  .stats-bar { grid-template-columns:repeat(2,1fr); gap:.6rem; }
  .stat-value { font-size:1.6rem; }
  .logo { font-size:1rem; }
  .hidden-xs { display:none; }
  .visible-xs { display:inline; }
}

/* ── Utility ───────────────────────────────────────────────────────────────── */
.flex { display:flex; }
.items-center { align-items:center; }
.gap-1 { gap:.5rem; }
.gap-2 { gap:1rem; }
.mt-1 { margin-top:.5rem; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:1.5rem; }
.mb-2 { margin-bottom:1rem; }
.text-muted { color:var(--text-2); }
.text-sm { font-size:.82rem; }
.text-right { text-align:right; }

/* ── Task requests ─────────────────────────────────────────────────────────── */
.task-requests {
  margin-top:.65rem;
  border-top:1px solid var(--border);
  padding-top:.6rem;
  display:flex; flex-direction:column; gap:.35rem;
}
.task-requests-title {
  font-size:.7rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; color:var(--amber); margin-bottom:.1rem;
}
.task-request-item {
  background:rgba(var(--amber-rgb),.07);
  border:1px solid rgba(var(--amber-rgb),.18);
  border-radius:var(--r-sm);
  padding:.35rem .6rem;
  font-size:.8rem; line-height:1.4;
}
.req-author { font-weight:600; color:var(--amber); margin-right:.35rem; }
.req-meta   { font-size:.7rem; color:var(--text-3); float:right; }
.req-msg    { color:var(--text-2); }
.req-count  {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--amber); color:#000;
  font-size:.65rem; font-weight:700;
  width:16px; height:16px; border-radius:50%;
  margin-left:.3rem; vertical-align:middle;
}

/* ── Participants ──────────────────────────────────────────────────────────── */
.participants-section {
  background:var(--card);
  border:1px solid rgba(var(--purple-rgb),.2);
  border-radius:var(--r-lg);
  padding:1.2rem 1.5rem;
  margin-bottom:1.5rem;
  transition:border-color var(--ease);
}
.participants-section:hover { border-color:rgba(var(--purple-rgb),.4); }
.participants-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1rem;
}
.participants-title {
  font-size:.8rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; color:var(--purple);
}
.participants-counter {
  font-size:.78rem; color:var(--text-2);
  background:rgba(var(--purple-rgb),.1);
  padding:.2rem .65rem; border-radius:20px;
}
.presence-banner {
  display:flex; align-items:center; justify-content:space-between; gap:.6rem; flex-wrap:wrap;
  padding:.65rem 1rem; border-radius:var(--r); margin-bottom:1rem;
  font-size:.88rem; font-weight:500;
}
.presence-banner.pending {
  background:rgba(var(--amber-rgb),.08);
  border:1px solid rgba(var(--amber-rgb),.25);
  color:var(--text);
}
.presence-banner.confirmed {
  background:rgba(var(--green-rgb),.08);
  border:1px solid rgba(var(--green-rgb),.3);
  color:var(--text);
}
.presence-text { flex:1; }

.participants-group { margin-bottom:.9rem; }
.participants-group:last-child { margin-bottom:0; }
.participants-group-label {
  font-size:.68rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--text-3); margin-bottom:.55rem;
}
.participants-grid { display:flex; flex-wrap:wrap; gap:.45rem; }

.pc-chip {
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.35rem .75rem .35rem .45rem;
  border:1.5px solid var(--border);
  border-radius:50px;
  background:var(--bg2);
  cursor:pointer;
  transition:all var(--ease);
  user-select:none;
  font-size:.84rem;
  font-weight:500;
  color:var(--text);
}
.pc-chip:hover:not(.pc-disabled) {
  border-color:var(--border-h);
  transform:translateY(-1px);
}
.pc-chip.pc-present {
  border-color:var(--green);
  background:rgba(var(--green-rgb),.1);
  color:var(--text);
}
.pc-chip.pc-present .pc-avatar { background:var(--green); color:#000; }
.pc-chip.pc-disabled {
  opacity:.3; cursor:not-allowed; pointer-events:none;
}
.pc-avatar {
  width:24px; height:24px; border-radius:50%;
  background:var(--purple); color:#fff;
  font-size:.68rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:background var(--ease);
}
.pc-check {
  font-size:.75rem; color:var(--green); margin-left:.1rem; flex-shrink:0;
}

@media (max-width:640px) {
  .participants-section { padding:1rem; }
  .pc-chip { font-size:.8rem; padding:.3rem .65rem .3rem .4rem; }
}

/* ── Weather widget ────────────────────────────────────────────────────────── */
.weather-widget {
  background:var(--card);
  border:1px solid rgba(var(--cyan-rgb),.25);
  border-radius:var(--r-lg);
  padding:1.2rem 1.5rem;
  margin-bottom:1.5rem;
  position:relative;
  overflow:hidden;
  transition:border-color var(--ease);
}
.weather-widget::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(var(--cyan-rgb),.04) 0%, transparent 60%);
  pointer-events:none;
}
.weather-widget:hover { border-color:rgba(var(--cyan-rgb),.45); }

.weather-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:.8rem;
}
.weather-title {
  font-size:.8rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; color:var(--cyan);
}
.weather-refresh {
  font-size:.72rem; color:var(--text-3);
  display:flex; align-items:center; gap:.35rem;
}
.weather-refresh-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--green); display:inline-block;
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.7); }
}

.weather-body {
  display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap;
}
.weather-icon { font-size:3.5rem; line-height:1; flex-shrink:0; }
.weather-temps {
  display:flex; flex-direction:column; gap:.1rem;
}
.weather-temp-max {
  font-size:2rem; font-weight:700; color:var(--text);
  line-height:1;
}
.weather-temp-min {
  font-size:1rem; color:var(--text-2);
}
.weather-desc {
  font-size:.88rem; color:var(--text-2); margin-top:.25rem; text-transform:capitalize;
}
.weather-details {
  display:flex; flex-wrap:wrap; gap:.6rem 1.2rem; margin-left:auto;
}
.weather-detail {
  display:flex; flex-direction:column; align-items:center; gap:.1rem;
  min-width:60px;
}
.weather-detail-val {
  font-size:.95rem; font-weight:600; color:var(--text);
}
.weather-detail-lbl {
  font-size:.7rem; color:var(--text-3); text-transform:uppercase; letter-spacing:.04em;
}
.weather-error {
  color:var(--text-2); font-size:.88rem; text-align:center; padding:.5rem 0;
}
.weather-loading {
  display:flex; align-items:center; gap:.6rem; color:var(--text-2); font-size:.88rem;
}
.weather-spinner {
  width:16px; height:16px; border:2px solid var(--border);
  border-top-color:var(--cyan); border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

@media (max-width:640px) {
  .weather-body { gap:1rem; }
  .weather-details { margin-left:0; }
  .weather-icon { font-size:2.8rem; }
  .weather-temp-max { font-size:1.6rem; }
}
.hidden { display:none !important; }
