/* Shared profile button + settings panel — included on every authenticated page. */

/* Floating profile button (only shown when the page didn't already have one).
   top: 9px centers a 38px avatar inside the 56px top bars on boards.html / tasks.html.
   Pages with taller headers (e.g. estimates-preview.html with its preview banner)
   override this in their own <style> block. */
.pb-floating-user-btn {
  position: fixed; top: 9px; right: 16px; z-index: 1900;
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg, var(--blue, #2d7fc6), var(--blue-dk, #1a5fa0));
  display: flex; align-items: center; justify-content: center;
  font: 800 13px/1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: #fff; cursor: pointer; border: 2px solid var(--panel, #fff);
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(0,0,0,0.14);
  transition: transform .15s ease, box-shadow .15s ease;
}
.pb-floating-user-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,0.18); }
.pb-floating-user-btn img { width: 100%; height: 100%; object-fit: cover; }

/* Reserve room on the right side of any .top-bar so the floating avatar
   doesn't overlap right-edge action buttons (Add Column, Save, +, etc.).
   Scoped here in profile-panel.css so it ONLY applies on pages where the
   floating avatar gets injected — pages with an inline avatar in their
   own topbar (the dashboard) don't need this gutter and don't get it. */
@media (max-width: 720px) {
  .top-bar { padding-right: 72px !important; }
}

/* Backdrop + slide-in panel */
.settings-backdrop {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,.45); backdrop-filter: blur(3px);
  display: none; opacity: 0; transition: opacity .22s;
}
.settings-backdrop.open { display: block; opacity: 1; }
.settings-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 400px; max-width: 95vw;
  background: var(--panel); border-left: 1px solid var(--border);
  z-index: 2001; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 48px rgba(0,0,0,.18);
}
.settings-panel.open { transform: translateX(0); }
.settings-hdr {
  padding: 20px 20px 16px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.settings-hdr-title { font-size: 17px; font-weight: 800; color: var(--text); }
.settings-close {
  width: 32px; height: 32px; border-radius: 9px; border: 1px solid var(--border);
  background: var(--bg); cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--muted); transition: background .12s, color .12s;
}
.settings-close:hover { background: var(--red-lt); color: var(--red); border-color: var(--red); }
.settings-close svg { width: 14px; height: 14px; }
.settings-body { flex: 1; overflow-y: auto; padding: 0 0 24px; }
.settings-profile {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 20px 18px; border-bottom: 1px solid var(--border);
}
.settings-avatar {
  width: 52px; height: 52px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--blue), var(--blue-dk));
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800; color: #fff; overflow: hidden;
}
.settings-avatar img { width: 100%; height: 100%; object-fit: cover; }
.settings-profile-info { flex: 1; min-width: 0; }
.settings-profile-name { font-size: 15px; font-weight: 800; color: var(--text); }
.settings-profile-email { font-size: 12px; color: var(--muted); margin-top: 2px; }
.settings-profile-role {
  display: inline-block; margin-top: 5px;
  padding: 2px 9px; border-radius: 999px;
  background: var(--blue-lt); color: var(--blue);
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
}
.settings-section { padding: 18px 20px 0; }
.settings-section-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); margin-bottom: 10px;
}
.settings-items { display: flex; flex-direction: column; gap: 2px; margin-bottom: 18px; }
.settings-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 14px; border-radius: 11px;
  border: 1px solid transparent; cursor: pointer;
  transition: background .13s, border-color .13s;
}
.settings-item:hover { background: var(--bg); border-color: var(--border); }
.settings-item-left { display: flex; align-items: center; gap: 11px; }
.settings-item-icon {
  width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg); border: 1px solid var(--border);
}
.settings-item-icon svg { width: 15px; height: 15px; color: var(--text-2); }
.settings-item-label { font-size: 13px; font-weight: 600; color: var(--text); }
.settings-item-sub { font-size: 11px; color: var(--muted); margin-top: 1px; }
.settings-item-right { display: flex; align-items: center; gap: 8px; }
.settings-badge {
  font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 999px;
  background: var(--blue-lt); color: var(--blue);
}
.settings-badge.coming { background: var(--orange-lt); color: var(--orange); }

/* Calendar Sync: connect / remove buttons */
.sync-btn {
  font-size: 11px; font-weight: 700; padding: 5px 12px; border-radius: 7px;
  cursor: pointer; transition: all .14s; font-family: inherit;
  border: 1px solid var(--border);
}
.sync-btn.connect { background: var(--blue-lt); color: var(--blue); border-color: rgba(45,127,198,.3); }
.sync-btn.connect:hover { background: var(--blue); color: #fff; border-color: var(--blue); }
.sync-btn.remove  { background: var(--red-lt); color: var(--red); border-color: rgba(192,57,43,.3); }
.sync-btn.remove:hover { background: var(--red); color: #fff; border-color: var(--red); }

/* Calendar connect popup */
.cal-popup-backdrop {
  position: fixed; inset: 0; z-index: 2500;
  background: rgba(12,24,40,.65); backdrop-filter: blur(4px);
  display: none; opacity: 0; transition: opacity .2s;
}
.cal-popup-backdrop.open { display: flex; align-items: center; justify-content: center; opacity: 1; }
.cal-popup {
  width: 100%; max-width: 380px;
  background: #0d1f3c; border: 1px solid #1e3560; border-radius: 16px;
  padding: 22px 22px 20px;
  box-shadow: 0 32px 80px rgba(0,0,0,.5);
  transform: scale(.96); transition: transform .2s;
}
.cal-popup-backdrop.open .cal-popup { transform: scale(1); }
.cal-popup-title { color: #e0ecfa; font-size: 16px; font-weight: 800; margin-bottom: 4px; }
.cal-popup-sub   { color: #8ab4d8; font-size: 12px; margin-bottom: 18px; }
.cal-popup-btn {
  width: 100%; padding: 11px 14px; border-radius: 10px;
  background: #0f2040; border: 1px solid #1e3560; color: #e0ecfa;
  font-size: 13px; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; gap: 10px; transition: all .15s;
  margin-bottom: 8px; font-family: inherit;
}
.cal-popup-btn:hover { background: #1a3560; border-color: #2d5090; transform: translateY(-1px); }
.cal-popup-btn svg { width: 18px; height: 18px; flex-shrink: 0; }
.cal-popup-cancel {
  width: 100%; padding: 9px; border: none; background: transparent;
  color: #4a6a8a; font-size: 12px; font-weight: 600; cursor: pointer;
  margin-top: 4px; font-family: inherit;
}
.cal-popup-cancel:hover { color: #8ab4d8; }

.settings-toggle { position: relative; width: 36px; height: 20px; flex-shrink: 0; }
.settings-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.settings-toggle-track {
  position: absolute; inset: 0; border-radius: 999px;
  background: var(--border); cursor: pointer; transition: background .18s;
}
.settings-toggle-track::after {
  content: ""; position: absolute; width: 14px; height: 14px;
  border-radius: 50%; background: #fff; top: 3px; left: 3px;
  transition: transform .18s; box-shadow: 0 1px 3px rgba(0,0,0,.25);
}
.settings-toggle input:checked + .settings-toggle-track { background: var(--blue); }
.settings-toggle input:checked + .settings-toggle-track::after { transform: translateX(16px); }
.settings-divider { height: 1px; background: var(--border); margin: 4px 20px 18px; }
.settings-logout-btn {
  margin: 0 20px; width: calc(100% - 40px); padding: 11px;
  border-radius: 11px; border: 1px solid rgba(192,57,43,.3);
  background: var(--red-lt); color: var(--red);
  font-size: 13px; font-weight: 700; font-family: inherit;
  cursor: pointer; transition: background .13s, border-color .13s;
}
.settings-logout-btn:hover { background: #fbd5d2; border-color: var(--red); }
.settings-edit-row {
  display: flex; align-items: center; gap: 8px; margin-top: 10px;
}
.settings-edit-input {
  flex: 1; padding: 8px 11px; border-radius: 9px;
  border: 1px solid var(--border); background: var(--bg);
  color: var(--text); font-size: 13px; font-family: inherit; outline: none;
  transition: border-color .15s;
}
.settings-edit-input:focus { border-color: var(--blue); }
.settings-edit-save {
  padding: 8px 14px; border-radius: 9px; border: none;
  background: var(--blue); color: #fff; font-size: 12px; font-weight: 700;
  font-family: inherit; cursor: pointer; white-space: nowrap;
  transition: background .13s;
}
.settings-edit-save:hover { background: var(--blue-dk); }
.settings-edit-link {
  font-size: 11px; font-weight: 600; color: var(--blue);
  cursor: pointer; border: none; background: none; font-family: inherit;
  padding: 0; margin-top: 4px; display: inline-block;
}
.settings-edit-link:hover { text-decoration: underline; }
