/* B2B Meetings — Public Styles */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root {
  --b2bm-blue:   #2563eb;
  --b2bm-green:  #16a34a;
  --b2bm-yellow: #d97706;
  --b2bm-red:    #dc2626;
  --b2bm-gray:   #64748b;
  --b2bm-light:  #f8fafc;
  --b2bm-border: #e2e8f0;
  --b2bm-r:      10px;
  --b2bm-shadow: 0 2px 12px rgba(0,0,0,.08);
}

.b2bm-notice {
  background:#f1f5f9; border-left:4px solid var(--b2bm-blue);
  padding:14px 18px; border-radius:var(--b2bm-r);
  font-family:'DM Sans',sans-serif;
}
.b2bm-notice--success { border-left-color:var(--b2bm-green); }
.b2bm-notice--warning { border-left-color:var(--b2bm-yellow); }
.b2bm-notice--error   { border-left-color:var(--b2bm-red); }

/* ── Calendar ────────────────────────────────────── */
.b2bm-calendar-wrap { font-family:'DM Sans',sans-serif; max-width:1100px; margin:0 auto; }
.b2bm-cal-header { display:flex; align-items:baseline; gap:12px; margin-bottom:24px; }
.b2bm-cal-header h2 { margin:0; font-size:1.6rem; color:#0f172a; }
.b2bm-cal-subtitle { color:var(--b2bm-gray); font-size:.9rem; }
.b2bm-cal-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px; }
.b2bm-cal-day { background:#fff; border:1px solid var(--b2bm-border); border-radius:var(--b2bm-r); box-shadow:var(--b2bm-shadow); overflow:hidden; }
.b2bm-cal-day-header { background:#1e293b; color:#fff; padding:14px 16px; display:flex; flex-direction:column; gap:2px; }
.b2bm-cal-day-name  { font-size:.75rem; text-transform:uppercase; letter-spacing:.08em; opacity:.7; }
.b2bm-cal-day-date  { font-size:1.1rem; font-weight:700; }
.b2bm-cal-day-label { font-size:.75rem; opacity:.6; margin-top:2px; }
.b2bm-cal-events { padding:10px; display:flex; flex-direction:column; gap:8px; }
.b2bm-cal-empty  { color:var(--b2bm-gray); font-size:.85rem; text-align:center; padding:20px 0; }
.b2bm-cal-event { border-left:10px solid var(--b2bm-blue); background:var(--b2bm-light); border-radius:6px; padding:6px 10px; }
.b2bm-event--confirmed { border-left-color:var(--b2bm-green); }
.b2bm-event--pending   { border-left-color:var(--b2bm-yellow); }
.b2bm-event--custom    { border-left-color:#7c3aed; }
.b2bm-ev-time  { font-family:'DM Mono',monospace; font-size:.78rem; color:var(--b2bm-gray); }
.b2bm-ev-title { font-weight:600; font-size:.9rem; color:#1e293b; margin:3px 0; }
.b2bm-ev-desc  { font-size:.8rem; color:var(--b2bm-gray); }
.b2bm-ev-status { display:flex; align-items:center; gap:8px; margin-top:4px; flex-wrap:wrap; }

/* ── Badges ──────────────────────────────────────── */
.b2bm-badge { display:inline-block; padding:2px 8px; border-radius:99px; font-size:.75rem; font-weight:600; }
.b2bm-badge--confirmed { background:#dcfce7; color:#166534; }
.b2bm-badge--pending   { background:#fef3c7; color:#92400e; }
.b2bm-badge--rejected  { background:#fee2e2; color:#991b1b; }
.b2bm-badge--cancelled { background:#f1f5f9; color:#475569; }

.b2bm-link-btn { background:none; border:none; color:var(--b2bm-red); cursor:pointer; font-size:.8rem; padding:0; text-decoration:underline; font-family:inherit; }

/* ── Confirm ─────────────────────────────────────── */
.b2bm-confirm-wrap { font-family:'DM Sans',sans-serif; max-width:520px; margin:40px auto; }
.b2bm-confirm-card { background:#fff; border-radius:16px; box-shadow:0 4px 32px rgba(0,0,0,.10); padding:40px; text-align:center; }
.b2bm-confirm-icon { font-size:3rem; margin-bottom:8px; }
.b2bm-confirm-card h2 { font-size:1.5rem; color:#0f172a; margin:0 0 8px; }
.b2bm-confirm-from { color:var(--b2bm-gray); margin-bottom:24px; }
.b2bm-confirm-details { background:var(--b2bm-light); border-radius:10px; padding:20px; margin-bottom:20px; display:flex; flex-direction:column; gap:12px; text-align:left; }
.b2bm-confirm-detail { display:flex; align-items:center; gap:14px; }
.b2bm-detail-icon  { font-size:1.4rem; }
.b2bm-detail-label { font-size:.75rem; color:var(--b2bm-gray); text-transform:uppercase; letter-spacing:.05em; }
.b2bm-detail-value { font-weight:600; color:#1e293b; }
.b2bm-confirm-notes { background:#fefce8; border:1px solid #fde68a; border-radius:8px; padding:12px 16px; font-size:.9rem; margin-bottom:20px; text-align:left; }
.b2bm-confirm-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.b2bm-btn { display:inline-block; padding:12px 28px; border-radius:8px; font-size:1rem; font-weight:600; cursor:pointer; border:none; font-family:'DM Sans',sans-serif; transition:opacity .15s; }
.b2bm-btn:hover { opacity:.85; }
.b2bm-btn--confirm { background:var(--b2bm-green); color:#fff; }
.b2bm-btn--reject  { background:#f1f5f9; color:var(--b2bm-red); border:2px solid var(--b2bm-red); }

/* ── Availability ────────────────────────────────── */
.b2bm-avail-wrap { font-family:'DM Sans',sans-serif; max-width:700px; }
.b2bm-avail-tabs { display:flex; gap:8px; flex-wrap:nowrap; margin-bottom:20px; overflow-x:auto; padding-bottom:4px; }
.b2bm-tab { padding:8px 18px; border-radius:99px; border:2px solid var(--b2bm-border); background:#fff; cursor:pointer; font-family:inherit; font-size:.9rem; transition:all .15s; }
.b2bm-tab.active,.b2bm-tab:hover { border-color:var(--b2bm-blue); background:var(--b2bm-blue); color:#fff; }
.b2bm-avail-panel { display:none; }
.b2bm-avail-panel.active { display:block; }
.b2bm-slots-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.b2bm-slot { display:flex; align-items:center; justify-content:center; gap:8px; padding:10px 8px; border-radius:8px; border:2px solid transparent; cursor:pointer; transition:all .15s; }
.b2bm-slot--on     { background:#dcfce7; border-color:var(--b2bm-green); }
.b2bm-slot--off    { background:#fee2e2; border-color:var(--b2bm-red); }
.b2bm-slot--locked { background:#f1f5f9; border-color:var(--b2bm-border); cursor:not-allowed; opacity:.7; }
.b2bm-slot-time { font-family:'DM Mono',monospace; font-size:.85rem; font-weight:500; }
.b2bm-muted { color:var(--b2bm-gray); }

/* ── /meet/ page ─────────────────────────────────── */
.b2bm-meet-wrap { font-family:'DM Sans',sans-serif; max-width:560px; margin:40px auto; }
.b2bm-meet-card { background:#fff; border-radius:16px; box-shadow:0 4px 32px rgba(0,0,0,.10); padding:36px; }
.b2bm-meet-icon { font-size:2.5rem; margin-bottom:8px; text-align:center; }
.b2bm-meet-card h2 { font-size:1.3rem; color:#0f172a; text-align:center; margin:0 0 6px; }
.b2bm-meet-sub { text-align:center; color:var(--b2bm-gray); margin-bottom:24px; }
.b2bm-meet-days { display:flex; flex-direction:column; gap:20px; }
.b2bm-meet-day-block {}
.b2bm-meet-day-title { font-weight:700; color:#1e293b; margin-bottom:10px; font-size:.95rem; text-transform:capitalize; }
.b2bm-slot--pick { cursor:pointer; font-family:'DM Sans',sans-serif; border:none; }
.b2bm-slot--pick:hover { transform:scale(1.03); box-shadow:0 2px 8px rgba(22,163,74,.2); }
.b2bm-spinner { color:var(--b2bm-gray); padding:20px 0; text-align:center; }
.b2bm-form-group { margin-bottom:14px; }
.b2bm-form-group label { display:block; font-size:.85rem; color:var(--b2bm-gray); margin-bottom:4px; }
.b2bm-form-row { display:flex; gap:12px; flex-wrap:wrap; }
.b2bm-input { width:100%; padding:8px 12px; border:1px solid var(--b2bm-border); border-radius:6px; font-family:'DM Sans',sans-serif; font-size:.9rem; box-sizing:border-box; }
textarea.b2bm-input { resize:vertical; }
.b2bm-modal-actions { display:flex; gap:10px; margin-top:16px; flex-wrap:wrap; }
.b2bm-btn--secondary { background:#f1f5f9; color:#374151; border:1px solid var(--b2bm-border); }
.b2bm-btn--purple { background:#7c3aed; color:#fff; }
.b2bm-btn--sm { padding:7px 16px; font-size:.85rem; }

/* ── Calendar views ──────────────────────────────── */
.b2bm-cal-app { font-family:'DM Sans',sans-serif; max-width:1100px; margin:0 auto; }
.b2bm-cal-toolbar { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:20px; flex-wrap:wrap; }
.b2bm-cal-view-btns { display:flex; flex-wrap:nowrap; gap:6px; overflow-x:auto; padding-bottom:4px; }
.b2bm-view-btn { padding:7px 14px; border-radius:99px; border:2px solid var(--b2bm-border); background:#fff; cursor:pointer; font-family:'DM Sans',sans-serif; font-size:.85rem; transition:all .15s; }
.b2bm-view-btn.active,.b2bm-view-btn:hover { border-color:var(--b2bm-blue); background:var(--b2bm-blue); color:#fff; }

/* list view */
.b2bm-cal-list { display:flex; flex-direction:column; gap:6px; }
.b2bm-list-day-header { font-weight:700; color:#1e293b; padding:12px 0 6px; border-top:2px solid var(--b2bm-border); text-transform:capitalize; font-size:1rem; }
.b2bm-list-item { margin-bottom:4px; }
.b2bm-list-empty { color:var(--b2bm-gray); font-size:.85rem; padding:4px 0 8px; }
.b2bm-event--personal { border-left-color:#7c3aed; }

/* ── Pending list ────────────────────────────────── */
.b2bm-pending-wrap { max-width:640px; margin:0 auto; font-family:'DM Sans',sans-serif; }
.b2bm-pending-wrap h2 { font-size:1.3rem; color:#0f172a; margin-bottom:20px; }
.b2bm-pending-list { display:flex; flex-direction:column; gap:12px; }
.b2bm-pending-item { background:#fff; border:1px solid #e2e8f0; border-radius:10px; padding:16px 20px; display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; box-shadow:0 1px 4px rgba(0,0,0,.05); }
.b2bm-pending-info { display:flex; flex-direction:column; gap:2px; }
.b2bm-pending-date { font-size:.78rem; color:#94a3b8; }
.b2bm-pending-actions { display:flex; gap:8px; flex-wrap:wrap; }

/* ── Stats ───────────────────────────────────────── */
.b2bm-stats-wrap { display:flex; gap:16px; flex-wrap:wrap; font-family:'DM Sans',sans-serif; }
.b2bm-stat-item { background:#fff; border:1px solid #e2e8f0; border-radius:10px; padding:20px 24px; text-align:center; min-width:140px; box-shadow:0 1px 4px rgba(0,0,0,.05); }
.b2bm-stat-number { display:block; font-size:2.2rem; font-weight:800; color:#1e293b; }
.b2bm-stat-label { display:block; font-size:.8rem; color:#64748b; margin-top:4px; }
.b2bm-stat-item--pending .b2bm-stat-number { color:#d97706; }

/* ── Buttons ─────────────────────────────────────── */
.b2bm-btn--danger { background:#dc2626; color:#fff; border:none; }
.b2bm-btn--danger:hover { background:#b91c1c; }

/* ── Badges adicionales ──────────────────────────── */
.b2bm-badge--invited  { background:#dbeafe; color:#1e40af; }
.b2bm-badge--declined { background:#fee2e2; color:#991b1b; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 480px) {
  .b2bm-slots-grid { grid-template-columns: repeat(2, 1fr); }
  .b2bm-pending-item { flex-direction: column; align-items: flex-start; }
  .b2bm-cal-grid { grid-template-columns: 1fr; }
}

/* ── Single-day full-width view ─────────────────── */
.b2bm-cal-grid.b2bm-single-day { grid-template-columns: 1fr; }

/* ── Discrete action buttons ────────────────────── */
.b2bm-link-btn { font-size:.72rem; opacity:.45; transition:opacity .15s; }
.b2bm-link-btn:hover { opacity:1; color:var(--b2bm-red); }

/* ── Calendar toolbar: keep export/add btn right aligned ─ */
.b2bm-cal-toolbar { align-items:center; }
