/* ============================================================================
   Cloud layer — login, entity dashboard, sharing, floating bar.
   Uses the BUILDER's own design tokens (:root vars from app.css, which loads
   first) so it matches the app exactly and follows the active theme.
   ========================================================================== */
#cloudRoot, #cloudRoot * { box-sizing: border-box; }

.cloud-screen {
  position: fixed; inset: 0; z-index: 4000;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 44px 24px; overflow: auto;
  background:
    radial-gradient(120% 90% at 50% -10%, var(--accent-muted) 0%, rgba(0,0,0,0) 55%),
    var(--bg);
  font-family: var(--font-body);
  color: var(--text);
  letter-spacing: .01em;
}
.cloud-screen.center { align-items: center; }

.cloud-card {
  width: 100%; max-width: 416px;
  background: var(--paper2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 30px 28px;
}
.cloud-card.wide { max-width: 860px; }

.cloud-brand { display: flex; align-items: center; gap: 11px; color: var(--text-strong); }
.cloud-brand.lg { flex-direction: column; gap: 13px; align-items: center; text-align: center; margin-bottom: 2px; }
.cloud-logo-mark { height: 26px; width: auto; flex: none; display: block; }
.cloud-brand.lg .cloud-logo-mark { height: 54px; width: auto; }
.cloud-wordmark { font-size: var(--fs-body-lg); color: var(--text-strong); letter-spacing: .02em; font-weight: 400; white-space: nowrap; }
.cloud-wordmark b { font-weight: 700; }
.cloud-brand.lg .cloud-wordmark { font-size: 23px; }

.cloud-sub { color: var(--muted); font-size: var(--fs-meta); margin: 10px 0 22px; line-height: 1.5; }
.cloud-sub.center { text-align: center; }

.cloud-field { margin-bottom: 14px; }
.cloud-field label { display: block; font-size: var(--fs-label-sm); color: var(--muted); margin-bottom: 6px; font-weight: var(--fw-control); }
.cloud-field input, .cloud-field select {
  width: 100%; padding: 12px 14px;
  border: 1px solid var(--line2); border-radius: var(--radius-sm);
  background: var(--paper3); color: var(--text);
  font-size: var(--fs-body); font-weight: var(--fw-body); font-family: inherit;
}
.cloud-field input::placeholder { color: var(--muted2); }
.cloud-field input:focus, .cloud-field select:focus { outline: none; border-color: var(--accent-strong); background: var(--surface-dark); box-shadow: 0 0 0 3px var(--accent-muted); }

/* buttons mirror the app's .btn */
.cloud-btn {
  padding: 9px 15px; min-height: 42px;
  border: 1px solid var(--primary); border-radius: var(--radius-sm);
  background: var(--primary); color: #fff;
  font-size: 14px; font-weight: var(--fw-control); font-family: inherit;
  letter-spacing: .02em; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .15s ease, border-color .15s ease;
}
.cloud-btn.block { width: 100%; }
.cloud-btn:hover { background: var(--accent-strong); border-color: var(--accent-strong); }
.cloud-btn:active { transform: translateY(1px); }
.cloud-btn:disabled { opacity: .55; cursor: default; }
.cloud-btn.ghost { background: transparent; border-color: var(--line2); color: var(--text-soft); }
.cloud-btn.ghost:hover { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.38); color: #fff; }
.cloud-btn.sm { min-height: 32px; padding: 0 12px; font-size: var(--fs-label-sm); }
.cloud-btn.danger { background: transparent; border-color: rgba(180,35,24,.62); color: #F1C4C0; }
.cloud-btn.danger:hover { background: rgba(180,35,24,.16); border-color: rgba(180,35,24,.85); }
.cloud-btn.google { background: var(--paper3); color: var(--text-soft); border-color: var(--line2); }
.cloud-btn.google:hover { background: #262626; border-color: rgba(255,255,255,.38); }

.cloud-or { display: flex; align-items: center; gap: 12px; color: var(--muted2); font-size: var(--fs-label-sm); margin: 16px 0 8px; }
.cloud-or::before, .cloud-or::after { content: ''; flex: 1; height: 1px; background: var(--line); }

.cloud-toggle { margin-top: 18px; text-align: center; font-size: var(--fs-meta); color: var(--muted); }
.cloud-toggle button { background: none; border: none; color: var(--text-soft); cursor: pointer; font-size: var(--fs-meta); font-family: inherit; font-weight: var(--fw-control); padding: 0 2px; }
.cloud-toggle button:hover { text-decoration: underline; }

.cloud-msg { margin-top: 14px; font-size: var(--fs-meta); line-height: 1.5; padding: 10px 12px; border-radius: var(--radius-sm); }
.cloud-msg.err  { background: rgba(180,35,24,.14); border: 1px solid rgba(180,35,24,.5); color: #F1C4C0; }
.cloud-msg.ok   { background: rgba(70,185,138,.14); border: 1px solid rgba(70,185,138,.45); color: #A9E2C4; }
.cloud-msg.info { background: var(--accent-muted); border: 1px solid var(--accent); color: var(--text-soft); }

/* ---------- dashboard ---------- */
.cloud-dash-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cloud-dash-head .who { font-size: var(--fs-meta); color: var(--muted); display: flex; align-items: center; gap: 10px; }
.cloud-dash-head .who button { background: transparent; border: 1px solid var(--line2); color: var(--text-soft); border-radius: var(--radius-sm); padding: 7px 12px; font-size: var(--fs-label-sm); font-weight: var(--fw-control); cursor: pointer; font-family: inherit; white-space: nowrap; display: inline-flex; align-items: center; }
.cloud-dash-head .who button:hover { border-color: rgba(255,255,255,.38); background: rgba(255,255,255,.05); color: #fff; }

.cloud-section-title { display: flex; align-items: center; justify-content: space-between; margin: 26px 0 12px; }
.cloud-section-title h2 { font-size: var(--fs-label-sm); font-weight: 600; color: var(--muted); letter-spacing: .09em; text-transform: uppercase; margin: 0; }

.cloud-entity { border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper2); margin-bottom: 12px; overflow: hidden; }
.cloud-entity-head { display: flex; align-items: center; gap: 12px; padding: 14px 16px; cursor: pointer; }
.cloud-entity-head:hover { background: var(--paper3); }
.cloud-entity-head .caret { color: var(--muted2); transition: transform .15s ease; flex: none; }
.cloud-entity.open .cloud-entity-head .caret { transform: rotate(90deg); }
.cloud-entity-head .ent-name { font-size: var(--fs-body); font-weight: 600; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-strong); }
.cloud-entity-head .ent-count { font-size: var(--fs-label-sm); color: var(--muted2); flex: none; }
.cloud-badge { font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: var(--radius-full); flex: none; letter-spacing: .02em; }
.cloud-badge.owner  { background: var(--accent-muted); color: #9FB6E0; border: 1px solid var(--accent); }
.cloud-badge.editor { background: rgba(70,185,138,.16); color: #A9E2C4; }
.cloud-badge.viewer { background: rgba(156,163,175,.16); color: #C7CDD7; }

.cloud-entity-body { display: none; padding: 4px 12px 14px; }
.cloud-entity.open .cloud-entity-body { display: block; }
.cloud-entity-actions { display: flex; flex-wrap: wrap; gap: 8px; padding: 6px 4px 12px; }

.cloud-sop { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 13px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 7px; cursor: pointer; transition: border-color .15s ease, background .15s ease; }
.cloud-sop:hover { border-color: var(--accent-strong); background: var(--surface-dark); }
.cloud-sop .meta { min-width: 0; }
.cloud-sop .title { font-size: var(--fs-meta); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-soft); }
.cloud-sop .sub { font-size: 11.5px; color: var(--muted2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cloud-sop .row-actions { display: flex; gap: 6px; flex: none; }
.cloud-sop .row-actions button { background: transparent; border: 1px solid var(--line2); color: var(--muted); border-radius: var(--radius-sm); padding: 5px 9px; font-size: 11.5px; cursor: pointer; font-family: inherit; }
.cloud-sop .row-actions button:hover { border-color: rgba(255,255,255,.38); color: #fff; }
.cloud-sop .row-actions button.del:hover { border-color: rgba(180,35,24,.85); color: #F1C4C0; }

.cloud-empty { color: var(--muted2); font-size: var(--fs-meta); padding: 10px 6px; line-height: 1.6; }
.cloud-empty.big { text-align: center; padding: 26px 10px; }

.cloud-spinner { width: 28px; height: 28px; margin: 30px auto; border-radius: 50%; border: 3px solid var(--line2); border-top-color: var(--text-soft); animation: cloudspin .8s linear infinite; }
@keyframes cloudspin { to { transform: rotate(360deg); } }

/* ---------- modal ---------- */
.cloud-modal-back { position: fixed; inset: 0; z-index: 4200; background: rgba(0,0,0,.62); display: flex; align-items: center; justify-content: center; padding: 24px; }
.cloud-modal { width: 100%; max-width: 460px; background: var(--paper2); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 24px; }
.cloud-modal h3 { margin: 0 0 4px; font-size: var(--fs-body-lg); font-weight: 600; color: var(--text-strong); }
.cloud-modal .hint { color: var(--muted); font-size: var(--fs-meta); margin: 0 0 16px; line-height: 1.5; }
.cloud-modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }

.cloud-share-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 11px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 7px; }
.cloud-share-row .em { font-size: var(--fs-meta); min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-soft); }
.cloud-share-row .ctl { display: flex; gap: 7px; align-items: center; flex: none; }
.cloud-share-row select, .cloud-add-row select { background: var(--paper3); border: 1px solid var(--line2); color: var(--text); border-radius: var(--radius-sm); padding: 7px 8px; font-size: var(--fs-label-sm); font-family: inherit; }
.cloud-add-row { display: flex; gap: 8px; margin-top: 12px; }
.cloud-add-row input { flex: 1; padding: 10px 12px; border: 1px solid var(--line2); border-radius: var(--radius-sm); background: var(--paper3); color: var(--text); font-size: var(--fs-meta); font-family: inherit; }
.cloud-add-row input::placeholder { color: var(--muted2); }
.cloud-add-row input:focus { outline: none; border-color: var(--accent-strong); background: var(--surface-dark); }

/* ---------- approval / pending screen ---------- */
.cloud-pending { text-align: center; margin-top: 18px; }
.cloud-pending-icon { font-size: 40px; line-height: 1; margin-bottom: 12px; }
.cloud-pending h2 { font-size: var(--fs-body-lg); font-weight: 600; color: var(--text-strong); margin: 0 0 4px; }
.cloud-pending .cloud-sub { margin: 10px 0 16px; }
.cloud-pending-who { font-size: var(--fs-label-sm); color: var(--muted2); margin: 0 0 18px; }
.cloud-pending.rejected .cloud-pending-icon { filter: grayscale(.2); }

/* ---------- admin: manage users ---------- */
.cloud-dash-head .who button.admin-link { border-color: var(--accent); color: #9FB6E0; }
.cloud-dash-head .who button.admin-link:hover { background: var(--accent-muted); border-color: var(--accent-strong); color: #fff; }
.cloud-pill { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px; padding: 0 5px; margin-left: 5px; border-radius: var(--radius-full); background: #B42318; color: #fff; font-size: 11px; font-weight: 700; }

.cloud-modal.wide { max-width: 620px; }
.cloud-user-row { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 7px; }
.cloud-user-row .em { flex: 1; min-width: 0; font-size: var(--fs-meta); color: var(--text-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: center; gap: 7px; }
.cloud-user-row .st { flex: none; }
.cloud-user-row .ctl { flex: none; display: flex; gap: 7px; align-items: center; }
.cloud-self { font-size: var(--fs-label-sm); color: var(--muted2); padding: 0 4px; }
.cloud-tag { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; padding: 2px 6px; border-radius: var(--radius-full); background: var(--accent-muted); color: #9FB6E0; border: 1px solid var(--accent); }
.cloud-badge.pending { background: rgba(227,192,138,.16); color: #E3C08A; }
.cloud-badge.danger  { background: rgba(180,35,24,.16); color: #F1C4C0; }
.cloud-role { background: var(--paper3); border: 1px solid var(--line2); color: var(--text); border-radius: var(--radius-sm); padding: 6px 8px; font-size: var(--fs-label-sm); font-family: inherit; cursor: pointer; }
.cloud-role:focus { outline: none; border-color: var(--accent-strong); box-shadow: 0 0 0 3px var(--accent-muted); }

@media (max-width: 560px) {
  .cloud-user-row { flex-wrap: wrap; row-gap: 9px; }
  .cloud-user-row .em { flex-basis: 100%; }
  .cloud-user-row .ctl { margin-left: auto; flex-wrap: wrap; justify-content: flex-end; }   /* badge left, role+actions right on line 2 */
  .cloud-user-row .ctl .cloud-btn.sm { min-height: 36px; }
}

/* ---------- floating account bar ---------- */
#cloudBar { position: fixed; right: 14px; bottom: 14px; z-index: 3500; display: flex; gap: 8px; align-items: center; font-family: var(--font-body); }
#cloudBar button { display: inline-flex; align-items: center; gap: 7px; padding: 8px 13px; background: var(--toolbar); border: 1px solid var(--line2); border-radius: var(--radius-full); color: var(--text-soft); font-size: var(--fs-label-sm); font-weight: var(--fw-control); font-family: inherit; cursor: pointer; }
#cloudBar button:hover { border-color: rgba(255,255,255,.38); background: var(--paper3); color: #fff; }
#cloudBar .cloud-status { font-size: 11.5px; color: var(--muted2); padding-right: 2px; }
#cloudBar .cloud-status.saving { color: #E3C08A; }
#cloudBar .cloud-status.saved  { color: #A9E2C4; }
#cloudBar .cloud-ro { font-size: 11.5px; color: #C7CDD7; background: rgba(156,163,175,.16); padding: 7px 12px; border-radius: var(--radius-full); }

/* view-only: hide editing affordances for viewers (refined per real markup at 2.0 integration) */
body.cloud-viewonly [data-action="toggle-edit"], body.cloud-viewonly #editToggle { display: none !important; }

@media (max-width: 560px) {
  #cloudBar { right: 10px; bottom: 10px; }
  #cloudBar .label-text { display: none; }
  .cloud-card { padding: 22px 18px; }

  /* dashboard header stacks: brand row, then email + actions below */
  .cloud-dash-head { flex-direction: column; align-items: stretch; gap: 14px; }
  .cloud-dash-head .cloud-brand { justify-content: flex-start; }
  .cloud-dash-head .who { flex-wrap: wrap; gap: 8px; }
  .cloud-dash-head .who > span { flex: 1 1 100%; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .cloud-dash-head .who button { flex: 1 1 auto; justify-content: center; min-height: 40px; }

  /* section title: keep heading + action on one tidy row */
  .cloud-section-title { gap: 10px; }
  .cloud-section-title .cloud-btn.sm { flex: none; }

  /* modals fill the small screen with comfortable padding */
  .cloud-modal-back { padding: 14px; }
  .cloud-modal, .cloud-modal.wide { max-width: 100%; padding: 20px 18px; }
  .cloud-modal-actions .cloud-btn { flex: 1 1 auto; }
}
