/* ════════════════════════════════════════════════════════════════════════════
   announcements.css  —  Announcements page specific styles
   Cal-picker CSS is in shared.css — not duplicated here.
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Card (page override — adds glass shine) ── */
.card {
  background: var(--card-bg); border: 1px solid var(--glass-border);
  border-radius: var(--radius); padding: 1.4rem 1.6rem; margin-bottom: 1rem;
  position: relative; overflow: hidden;
  backdrop-filter: blur(40px) saturate(150%); -webkit-backdrop-filter: blur(40px) saturate(150%);
  box-shadow: var(--shadow-card);
}
.card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent); }
.card::after  { content:''; position:absolute; inset:0; background:var(--glass-shine); pointer-events:none; border-radius:var(--radius); }

/* ── Send button ── */
.btn-send {
  width:100%; padding:0.85rem; border-radius:12px; border:none;
  background:linear-gradient(135deg,#7c5cfc,#5a3de0); color:var(--text);
  font-size:0.95rem; font-weight:800; cursor:pointer; font-family:inherit;
  transition:all 0.2s; margin-top:0.5rem;
}
.btn-send:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 24px rgba(124,92,252,0.4); }
.btn-send:disabled { opacity:0.4; cursor:not-allowed; }
.btn-schedule      { background:rgba(251,191,36,0.1); border-color:rgba(251,191,36,0.3); color:var(--amber); }
.btn-schedule:hover{ background:rgba(251,191,36,0.18); }

/* ── Compose ── */
.compose-wrap { position:relative; z-index:1; }
.compose-textarea {
  width:100%; min-height:120px; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1); border-radius:10px;
  padding:0.75rem 0.9rem; color:var(--text); font-size:0.9rem;
  font-family:inherit; outline:none; resize:vertical; transition:border-color 0.2s; line-height:1.6;
}
.compose-textarea:focus       { border-color:rgba(124,92,252,0.5); background:rgba(124,92,252,0.04); }
.compose-textarea::placeholder{ color:var(--text-muted); font-style:italic; }
.char-count { font-size:0.7rem; color:var(--text-muted); text-align:right; margin-top:0.3rem; }

/* ── Channel pills ── */
.channel-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:1rem; position:relative; z-index:1; }
.channel-pill {
  display:flex; align-items:center; gap:0.4rem; padding:0.35rem 0.85rem;
  border-radius:20px; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.04);
  font-size:0.78rem; font-weight:600; cursor:pointer; transition:all 0.15s; user-select:none;
}
.channel-pill input[type=checkbox]{ position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
.channel-pill.active { background:rgba(124,92,252,0.12); border-color:rgba(124,92,252,0.4); color:var(--accent2); }

/* ── Templates ── */
.templates-row { display:flex; gap:0.4rem; flex-wrap:wrap; margin-bottom:1rem; position:relative; z-index:1; }
.tpl-btn {
  padding:0.22rem 0.65rem; border-radius:20px; font-size:0.72rem; font-weight:600;
  cursor:pointer; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.04);
  color:var(--text-dim); transition:all 0.15s; font-family:inherit;
}
.tpl-btn:hover { border-color:rgba(124,92,252,0.35); color:var(--accent2); background:rgba(124,92,252,0.08); }

/* ── Send result ── */
.send-result { display:none; padding:0.75rem 1rem; border-radius:10px; margin-top:0.75rem; font-size:0.84rem; font-weight:600; position:relative; z-index:1; animation:vcrise 0.2s cubic-bezier(0.16,1,0.3,1); }
.send-result.ok    { display:block; background:rgba(52,211,153,0.1);  border:1px solid rgba(52,211,153,0.3);  color:var(--green); }
.send-result.error { display:block; background:rgba(248,113,113,0.1); border:1px solid rgba(248,113,113,0.3); color:var(--red); }

/* ── Config status ── */
.config-status-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:1rem; position:relative; z-index:1; }
.config-chip { display:flex; align-items:center; gap:0.35rem; padding:0.25rem 0.75rem; border-radius:20px; font-size:0.74rem; font-weight:600; border:1px solid; background:rgba(255,255,255,0.03); }
.config-chip.ok    { border-color:rgba(52,211,153,0.3);  color:var(--green); }
.config-chip.miss  { border-color:rgba(248,113,113,0.3); color:var(--red); }
.config-chip.blank { border-color:rgba(255,255,255,0.1); color:var(--text-muted); }

/* ── History list ── */
.history-list    { display:flex; flex-direction:column; gap:0.4rem; position:relative; z-index:1; }
.history-row     { padding:0.65rem 0.85rem; border-radius:10px; background:rgba(255,255,255,0.025); border:1px solid rgba(255,255,255,0.05); }
.history-row-head{ display:flex; align-items:center; gap:0.5rem; margin-bottom:0.25rem; }
.history-ts      { font-size:0.7rem; color:var(--text-dim); font-family:'DM Mono',monospace; }
.history-ch      { display:flex; gap:0.25rem; }
.history-ch-tag  { font-size:0.66rem; font-weight:700; padding:0.1rem 0.4rem; border-radius:20px; }
.ch-matrix       { background:rgba(0,190,150,0.12); border:1px solid rgba(0,190,150,0.3); color:#00be96; }
.ch-pages        { background:rgba(124,92,252,0.12); border:1px solid rgba(124,92,252,0.3); color:var(--accent2); }
.history-ok      { font-size:0.7rem; margin-left:auto; }
.history-ok.sent { color:var(--green); }
.history-ok.fail { color:var(--red); }
.history-msg     { font-size:0.84rem; color:var(--text); word-break:break-word; }
.empty-state     { padding:2.5rem 1rem; text-align:center; color:var(--text-muted); font-size:0.88rem; }

/* ── My templates ── */
.my-templates-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.5rem; position:relative; z-index:1; }
.my-templates-label  { font-size:0.67rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-dim); }
.my-tpl-list  { display:flex; flex-direction:column; gap:0.3rem; margin-bottom:0.75rem; position:relative; z-index:1; }
.my-tpl-row   { display:flex; align-items:center; gap:0.4rem; padding:0.4rem 0.6rem; border-radius:8px; background:rgba(255,255,255,0.025); border:1px solid rgba(255,255,255,0.06); transition:border-color 0.15s; }
.my-tpl-row:hover { border-color:rgba(124,92,252,0.25); }
.my-tpl-name    { flex:1; font-size:0.8rem; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; cursor:pointer; }
.my-tpl-name:hover  { color:var(--accent2); }
.my-tpl-preview     { font-size:0.7rem; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:200px; }
.save-tpl-row       { display:flex; gap:0.4rem; position:relative; z-index:1; }
.save-tpl-input     { flex:1; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:8px; padding:0.38rem 0.65rem; color:var(--text); font-size:0.8rem; font-family:inherit; outline:none; transition:border-color 0.2s; }
.save-tpl-input:focus       { border-color:rgba(124,92,252,0.45); }
.save-tpl-input::placeholder{ color:var(--text-muted); }

/* ── Custom checkbox ── */
.vc-cb-wrap { display:inline-flex; align-items:center; gap:0.55rem; cursor:pointer; user-select:none; position:relative; }
.vc-cb-wrap input[type=checkbox] { position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
.vc-cb-box  { width:17px; height:17px; flex-shrink:0; border-radius:5px; border:1.5px solid rgba(255,255,255,0.18); background:rgba(0,0,0,0.35); display:flex; align-items:center; justify-content:center; transition:all 0.15s; }
.vc-cb-wrap input:checked + .vc-cb-box { background:var(--accent); border-color:var(--accent); box-shadow:0 0 8px rgba(124,92,252,0.45); }
.vc-cb-wrap input:checked + .vc-cb-box::after { content:''; width:9px; height:5px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg) translateY(-1px); display:block; }
.vc-cb-wrap:hover .vc-cb-box { border-color:rgba(124,92,252,0.55); }

/* ── Schedule fields ── */
.schedule-toggle-row { display:flex; align-items:center; gap:0.65rem; margin-top:0.75rem; position:relative; z-index:1; flex-wrap:wrap; }
.schedule-fields     { display:none; align-items:center; gap:0.5rem; flex-wrap:wrap; }
.schedule-fields.open{ display:flex; }
.schedule-dt-input   {
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1);
  border-radius:8px; padding:0.38rem 0.65rem; color:var(--text-dim);
  font-size:0.8rem; font-family:inherit; outline:none; transition:border-color 0.2s;
  cursor:pointer; text-align:left; min-width:160px;
}
.schedule-dt-input:hover,
.schedule-dt-input:focus { border-color:rgba(124,92,252,0.5); }
.schedule-dt-input.has-value { color:var(--text); }
