/* ============================================================
   GiDM Live Booking — Frontend Wizard CSS
   Compatibile con qualsiasi tema WP (tutto scoped a .gslb-fe)
   ============================================================ */

/* TEMI */
.gslb-fe-theme-warm-salon   { --fe-accent:#c4845a; --fe-accent2:#a06b42; --fe-bg:#fdf6f0; --fe-surface:#fff; --fe-surface2:#faf0e8; --fe-border:#e8d0bb; --fe-text:#2d1a10; --fe-sub:#8a6558; --fe-radius:14px; --fe-radius-sm:8px; }
.gslb-fe-theme-blue-night   { --fe-accent:#58a6ff; --fe-accent2:#1f6feb; --fe-bg:#0d1117; --fe-surface:#161b22; --fe-surface2:#21262d; --fe-border:#30363d; --fe-text:#e6edf3; --fe-sub:#8b949e; --fe-radius:14px; --fe-radius-sm:8px; }
.gslb-fe-theme-modern-white { --fe-accent:#5c6bc0; --fe-accent2:#3949ab; --fe-bg:#f8f9fa; --fe-surface:#fff; --fe-surface2:#f0f2f5; --fe-border:#dde1e7; --fe-text:#1a1a2e; --fe-sub:#6b7280; --fe-radius:14px; --fe-radius-sm:8px; }
.gslb-fe-theme-glass        { --fe-accent:#8c98ad; --fe-accent2:#6f7f95; --fe-bg:linear-gradient(180deg,#f8fafc 0%,#eef2f6 52%,#e6edf3 100%); --fe-surface:rgba(255,255,255,.68); --fe-surface2:rgba(255,255,255,.54); --fe-border:rgba(129,146,168,.22); --fe-text:#101923; --fe-sub:rgba(30,41,59,.82); --fe-radius:18px; --fe-radius-sm:12px; }
.gslb-fe-theme-super-glass { --fe-accent:#a7b2c2; --fe-accent2:#8f9daf; --fe-bg:radial-gradient(circle at top left, rgba(255,255,255,.62), transparent 24%), radial-gradient(circle at top right, rgba(255,255,255,.22), transparent 20%), linear-gradient(180deg,#e8edf2 0%,#dbe3ea 50%,#cfd9e2 100%); --fe-surface:rgba(255,255,255,.28); --fe-surface2:rgba(255,255,255,.36); --fe-border:rgba(240,246,252,.52); --fe-text:#0f1724; --fe-sub:rgba(30,41,59,.84); --fe-radius:24px; --fe-radius-sm:16px; }
.gslb-fe-theme-green-nature-glass { --fe-accent:#245a35; --fe-accent2:#d9a441; --fe-bg:radial-gradient(circle at top left, rgba(255,255,255,.7), transparent 24%), radial-gradient(circle at 85% 10%, rgba(217,238,243,.7), transparent 22%), linear-gradient(180deg,#f7f6ee 0%,#edf5ee 46%,#dfeee3 100%); --fe-surface:rgba(255,255,255,.44); --fe-surface2:rgba(255,255,255,.58); --fe-border:rgba(36,90,53,.16); --fe-text:#18231b; --fe-sub:rgba(66,88,74,.86); --fe-radius:24px; --fe-radius-sm:16px; }
.gslb-fe-theme-black-glass { --fe-accent:#7fd6ff; --fe-accent2:#63a7ff; --fe-bg:radial-gradient(circle at top left, rgba(76,122,255,.14), transparent 24%), radial-gradient(circle at 88% 14%, rgba(143,92,255,.12), transparent 20%), linear-gradient(180deg,#090d15 0%,#0f1520 48%,#121924 100%); --fe-surface:rgba(16,22,34,.78); --fe-surface2:rgba(22,30,44,.72); --fe-border:rgba(138,167,215,.18); --fe-text:#eef4ff; --fe-sub:rgba(198,212,235,.72); --fe-radius:24px; --fe-radius-sm:16px; }

/* BASE WIDGET */
.gslb-fe { all:initial; display:block; width:min(100%, 720px); max-width:100%; min-width:0; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; font-size:16px; line-height:1.5; color:var(--fe-text); background:var(--fe-bg); border-radius:var(--fe-radius); overflow:hidden; box-shadow:0 4px 32px rgba(0,0,0,.12); margin:0 auto; }
.gslb-fe-theme-glass,
.gslb-fe-theme-glass .gslb-fe__header,
.gslb-fe-theme-glass .gslb-fe__svc-card,
.gslb-fe-theme-glass .gslb-fe__panel,
.gslb-fe-theme-glass .gslb-fe__summary-card,
.gslb-fe-theme-glass .gslb-fe__service-summary,
.gslb-fe-theme-glass .gslb-fe__operator-card,
.gslb-fe-theme-glass .gslb-fe__slot,
.gslb-fe-theme-glass .gslb-fe__login-card,
.gslb-fe-theme-glass .gslb-fe__register-card {
  backdrop-filter: blur(24px) saturate(150%);
  -webkit-backdrop-filter: blur(24px) saturate(150%);
}
.gslb-fe-theme-super-glass,
.gslb-fe-theme-super-glass .gslb-fe__header,
.gslb-fe-theme-super-glass .gslb-fe__svc-card,
.gslb-fe-theme-super-glass .gslb-fe__panel,
.gslb-fe-theme-super-glass .gslb-fe__summary-card,
.gslb-fe-theme-super-glass .gslb-fe__service-summary,
.gslb-fe-theme-super-glass .gslb-fe__operator-card,
.gslb-fe-theme-super-glass .gslb-fe__slot,
.gslb-fe-theme-super-glass .gslb-fe__login-card,
.gslb-fe-theme-super-glass .gslb-fe__register-card,
.gslb-fe-theme-green-nature-glass,
.gslb-fe-theme-green-nature-glass .gslb-fe__header,
.gslb-fe-theme-green-nature-glass .gslb-fe__svc-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__panel,
.gslb-fe-theme-green-nature-glass .gslb-fe__summary-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__service-summary,
.gslb-fe-theme-green-nature-glass .gslb-fe__operator-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__slot,
.gslb-fe-theme-green-nature-glass .gslb-fe__login-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__register-card,
.gslb-fe__modal-backdrop {
  backdrop-filter: blur(28px) saturate(165%);
  -webkit-backdrop-filter: blur(28px) saturate(165%);
}
.gslb-fe-theme-black-glass,
.gslb-fe-theme-black-glass .gslb-fe__header,
.gslb-fe-theme-black-glass .gslb-fe__svc-card,
.gslb-fe-theme-black-glass .gslb-fe__panel,
.gslb-fe-theme-black-glass .gslb-fe__summary-card,
.gslb-fe-theme-black-glass .gslb-fe__service-summary,
.gslb-fe-theme-black-glass .gslb-fe__operator-card,
.gslb-fe-theme-black-glass .gslb-fe__slot,
.gslb-fe-theme-black-glass .gslb-fe__login-card,
.gslb-fe-theme-black-glass .gslb-fe__register-card,
.gslb-fe-theme-black-glass .gslb-fe__modal-backdrop {
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
}
.gslb-fe-theme-super-glass {
  box-shadow: 0 24px 80px rgba(98, 113, 132, .22);
  position: relative;
}
.gslb-fe-theme-green-nature-glass {
  box-shadow: 0 24px 80px rgba(18, 51, 31, .18);
  position: relative;
}
.gslb-fe-theme-super-glass::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--fe-radius) + 2px);
  pointer-events: none;
  border: 1px solid rgba(255,255,255,.68);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.58), 0 0 0 1px rgba(255,255,255,.12);
}
.gslb-fe-theme-green-nature-glass::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--fe-radius) + 2px);
  pointer-events: none;
  border: 1px solid rgba(255,255,255,.58);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.54), 0 0 0 1px rgba(217,164,65,.08);
}
.gslb-fe-theme-black-glass {
  box-shadow: 0 24px 80px rgba(4, 8, 18, .5);
  position: relative;
}
.gslb-fe-theme-black-glass::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--fe-radius) + 2px);
  pointer-events: none;
  border: 1px solid rgba(165, 195, 245, .18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 0 0 1px rgba(104, 143, 255, .08);
}
.gslb-fe-theme-super-glass .gslb-fe__header,
.gslb-fe-theme-super-glass .gslb-fe__panel,
.gslb-fe-theme-super-glass .gslb-fe__svc-card,
.gslb-fe-theme-super-glass .gslb-fe__summary-card,
.gslb-fe-theme-super-glass .gslb-fe__service-summary,
.gslb-fe-theme-super-glass .gslb-fe__operator-card,
.gslb-fe-theme-super-glass .gslb-fe__slot,
.gslb-fe-theme-super-glass .gslb-fe__login-card,
.gslb-fe-theme-super-glass .gslb-fe__register-card,
.gslb-fe-theme-super-glass .gslb-fe__modal,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card,
.gslb-fe-theme-super-glass .gslb-fe__service-choice,
.gslb-fe-theme-super-glass .gslb-fe__service-edit-row {
  background:
    linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.18)),
    radial-gradient(circle at top left, rgba(255,255,255,.28), transparent 34%);
  border-color: rgba(255,255,255,.46);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    0 16px 40px rgba(86, 97, 114, .18);
}
.gslb-fe-theme-green-nature-glass .gslb-fe__header,
.gslb-fe-theme-green-nature-glass .gslb-fe__panel,
.gslb-fe-theme-green-nature-glass .gslb-fe__svc-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__summary-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__service-summary,
.gslb-fe-theme-green-nature-glass .gslb-fe__operator-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__slot,
.gslb-fe-theme-green-nature-glass .gslb-fe__login-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__register-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__modal,
.gslb-fe-theme-green-nature-glass .gslb-fe__add-svc-card,
.gslb-fe-theme-green-nature-glass .gslb-fe__service-choice,
.gslb-fe-theme-green-nature-glass .gslb-fe__service-edit-row {
  background:
    linear-gradient(180deg, rgba(255,255,255,.46), rgba(255,255,255,.28)),
    radial-gradient(circle at top left, rgba(217,238,243,.34), transparent 38%);
  border-color: rgba(36,90,53,.16);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.56),
    0 16px 40px rgba(18, 51, 31, .12);
}
.gslb-fe-theme-black-glass .gslb-fe__header,
.gslb-fe-theme-black-glass .gslb-fe__panel,
.gslb-fe-theme-black-glass .gslb-fe__svc-card,
.gslb-fe-theme-black-glass .gslb-fe__summary-card,
.gslb-fe-theme-black-glass .gslb-fe__service-summary,
.gslb-fe-theme-black-glass .gslb-fe__operator-card,
.gslb-fe-theme-black-glass .gslb-fe__slot,
.gslb-fe-theme-black-glass .gslb-fe__login-card,
.gslb-fe-theme-black-glass .gslb-fe__register-card,
.gslb-fe-theme-black-glass .gslb-fe__modal,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card,
.gslb-fe-theme-black-glass .gslb-fe__service-choice,
.gslb-fe-theme-black-glass .gslb-fe__service-edit-row {
  background:
    linear-gradient(180deg, rgba(23,31,48,.88), rgba(13,19,31,.82)),
    radial-gradient(circle at top left, rgba(122,172,255,.12), transparent 38%);
  border-color: rgba(123, 154, 214, .24);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 18px 42px rgba(0,0,0,.32);
}
.gslb-fe-theme-black-glass .gslb-fe__title,
.gslb-fe-theme-black-glass .gslb-fe__panel-title,
.gslb-fe-theme-black-glass .gslb-fe__svc-cat-title {
  color: #f4f7ff;
}
.gslb-fe-theme-black-glass .gslb-fe__btn--primary,
.gslb-fe-theme-black-glass .gslb-fe__cat-chip.active,
.gslb-fe-theme-black-glass .gslb-fe__step.active span,
.gslb-fe-theme-black-glass .gslb-fe__step.done span,
.gslb-fe-theme-black-glass .gslb-fe__slot.selected {
  background: linear-gradient(135deg, rgba(94,149,255,.95), rgba(127,110,255,.94));
  border-color: rgba(163, 197, 255, .58);
  color: #f7fbff;
  box-shadow: 0 10px 26px rgba(63, 108, 214, .34);
}
.gslb-fe-theme-black-glass .gslb-fe__btn--ghost,
.gslb-fe-theme-black-glass .gslb-fe__auth-input,
.gslb-fe-theme-black-glass .gslb-fe__field input,
.gslb-fe-theme-black-glass .gslb-fe__field textarea {
  background: rgba(17,24,37,.86);
  border-color: rgba(126, 155, 209, .24);
  color: var(--fe-text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.gslb-fe-theme-black-glass .gslb-fe__btn--ghost:hover,
.gslb-fe-theme-black-glass .gslb-fe__svc-card:hover,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card:hover,
.gslb-fe-theme-black-glass .gslb-fe__att-card:hover,
.gslb-fe-theme-black-glass .gslb-fe__slot:hover {
  border-color: rgba(148, 182, 245, .4);
  box-shadow: 0 12px 28px rgba(16,22,36,.36);
}
.gslb-fe-theme-black-glass .gslb-fe__modal-head {
  background: linear-gradient(180deg, rgba(27,36,54,.92), rgba(18,24,37,.86));
  border-bottom-color: rgba(126, 155, 209, .22);
}
.gslb-fe-theme-black-glass .gslb-fe__modal {
  box-shadow: 0 30px 70px rgba(0,0,0,.4);
}
.gslb-fe-theme-black-glass .gslb-fe__btn--ghost {
  color: #dce8ff;
}
.gslb-fe-theme-black-glass .gslb-fe__field label,
.gslb-fe-theme-black-glass .gslb-fe__auth-desc,
.gslb-fe-theme-black-glass .gslb-fe__svc-card__meta,
.gslb-fe-theme-black-glass .gslb-fe__slot,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card-meta,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card-subtitle {
  color: rgba(206, 220, 244, .76);
}
.gslb-fe-theme-black-glass .gslb-fe__svc-card__desc,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card-desc {
  color: rgba(234, 241, 255, .84);
  opacity: 1;
}
.gslb-fe-theme-black-glass .gslb-fe__svc-card__name,
.gslb-fe-theme-black-glass .gslb-fe__att-name,
.gslb-fe-theme-black-glass .gslb-fe__add-svc-card-title,
.gslb-fe-theme-black-glass .gslb-fe__cal-month {
  color: #f5f8ff;
}
.gslb-fe-theme-black-glass .gslb-fe__steps {
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(22,30,45,.78), rgba(12,18,30,.72));
  border: 1px solid rgba(118, 148, 207, .2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.gslb-fe-theme-black-glass .gslb-fe__step-line {
  background: rgba(124, 145, 181, .3);
}
.gslb-fe-theme-black-glass .gslb-fe__step small {
  color: rgba(214, 226, 247, .72);
  font-weight: 700;
}
.gslb-fe-theme-super-glass .gslb-fe__title,
.gslb-fe-theme-super-glass .gslb-fe__panel-title,
.gslb-fe-theme-super-glass .gslb-fe__svc-cat-title {
  color: #17212f;
  text-shadow: 0 1px 0 rgba(255,255,255,.3);
}
.gslb-fe-theme-super-glass .gslb-fe__btn--primary,
.gslb-fe-theme-super-glass .gslb-fe__cat-chip.active,
.gslb-fe-theme-super-glass .gslb-fe__step.active span,
.gslb-fe-theme-super-glass .gslb-fe__step.done span,
.gslb-fe-theme-super-glass .gslb-fe__slot.selected {
  background: linear-gradient(135deg, rgba(182,192,206,.96), rgba(148,160,178,.96));
  border-color: rgba(255,255,255,.72);
  color: #fff;
  box-shadow: 0 8px 20px rgba(109, 121, 139, .22);
}
.gslb-fe-theme-super-glass .gslb-fe__btn--ghost,
.gslb-fe-theme-super-glass .gslb-fe__auth-input,
.gslb-fe-theme-super-glass .gslb-fe__field input,
.gslb-fe-theme-super-glass .gslb-fe__field textarea {
  background: rgba(255,255,255,.4);
  border-color: rgba(255,255,255,.54);
  color: var(--fe-text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.52);
}
.gslb-fe-theme-super-glass .gslb-fe__btn--ghost:hover,
.gslb-fe-theme-super-glass .gslb-fe__svc-card:hover,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card:hover,
.gslb-fe-theme-super-glass .gslb-fe__att-card:hover,
.gslb-fe-theme-super-glass .gslb-fe__slot:hover {
  border-color: rgba(255,255,255,.76);
  box-shadow: 0 12px 28px rgba(109, 121, 139, .18);
}
.gslb-fe-theme-super-glass .gslb-fe__modal-head {
  background: linear-gradient(180deg, rgba(255,255,255,.4), rgba(255,255,255,.22));
  border-bottom-color: rgba(255,255,255,.4);
}
.gslb-fe-theme-super-glass .gslb-fe__modal {
  box-shadow: 0 28px 68px rgba(72, 83, 99, .22);
}
.gslb-fe-theme-super-glass .gslb-fe__btn--primary,
.gslb-fe-theme-super-glass .gslb-fe__step.active span,
.gslb-fe-theme-super-glass .gslb-fe__step.done span,
.gslb-fe-theme-super-glass .gslb-fe__slot.selected,
.gslb-fe-theme-super-glass .gslb-fe__cat-chip.active {
  color: #15202d;
  text-shadow: none;
}
.gslb-fe-theme-super-glass .gslb-fe__btn--primary:hover:not(:disabled) {
  background: linear-gradient(135deg, rgba(190,199,211,.98), rgba(161,172,188,.98));
  border-color: rgba(255,255,255,.82);
  color: #15202d;
}
.gslb-fe-theme-super-glass .gslb-fe__btn--ghost {
  color: #233042;
}
.gslb-fe-theme-super-glass .gslb-fe__field label,
.gslb-fe-theme-super-glass .gslb-fe__auth-desc,
.gslb-fe-theme-super-glass .gslb-fe__svc-card__meta,
.gslb-fe-theme-super-glass .gslb-fe__slot,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card-meta,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card-subtitle {
  color: rgba(30, 41, 59, .76);
}
.gslb-fe-theme-super-glass .gslb-fe__svc-card__desc,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card-desc {
  color: rgba(17, 24, 39, .82);
  opacity: 1;
}
.gslb-fe-theme-super-glass .gslb-fe__svc-card__name,
.gslb-fe-theme-super-glass .gslb-fe__att-name,
.gslb-fe-theme-super-glass .gslb-fe__add-svc-card-title,
.gslb-fe-theme-super-glass .gslb-fe__cal-month {
  color: #16202d;
}
.gslb-fe-theme-super-glass .gslb-fe__steps {
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,.26), rgba(255,255,255,.14));
  border: 1px solid rgba(255,255,255,.45);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.46);
}
.gslb-fe-theme-super-glass .gslb-fe__step-line {
  background: rgba(148, 163, 184, .34);
}
.gslb-fe-theme-super-glass .gslb-fe__step small {
  color: rgba(30, 41, 59, .72);
  font-weight: 700;
}
.gslb-fe *, .gslb-fe *::before, .gslb-fe *::after { box-sizing:border-box; margin:0; padding:0; }

/* HEADER + STEPS */
.gslb-fe__header { background:var(--fe-surface); border-bottom:1px solid var(--fe-border); padding:24px 28px 20px; }
.gslb-fe__title  { font-size:22px; font-weight:800; color:var(--fe-accent); margin-bottom:20px; text-align:center; }
.gslb-fe--reschedule .gslb-fe__title { text-align:center; }
.gslb-fe__steps  { display:flex; align-items:center; gap:0; }
.gslb-fe__step   { display:flex; flex-direction:column; align-items:center; gap:4px; flex:0 0 auto; }
.gslb-fe__step span { width:32px; height:32px; border-radius:50%; background:var(--fe-surface2); border:2px solid var(--fe-border); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:var(--fe-sub); transition:all .25s; }
.gslb-fe__step small { font-size:10px; color:var(--fe-sub); white-space:nowrap; }
.gslb-fe__step.active span, .gslb-fe__step.done span { background:var(--fe-accent); border-color:var(--fe-accent); color:#fff; }
.gslb-fe__step.done span::after { content:'\2713'; font-size:14px; }
.gslb-fe__step.done span { font-size:0; }
.gslb-fe__step-line { flex:1; height:2px; background:var(--fe-border); margin:0 6px; margin-bottom:16px; transition:background .25s; min-width:16px; }
.gslb-fe__step.done + .gslb-fe__step-line { background:var(--fe-accent); }
.gslb-fe__push-banner {
    --fe-accent:#8c98ad;
    --fe-accent2:#6f7f95;
    --fe-surface:#fff;
    --fe-border:rgba(129,146,168,.28);
    --fe-text:#101923;
    --fe-sub:rgba(30,41,59,.82);
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    margin: 16px auto 0;
    padding: 12px 52px 12px 18px;
    border: 1px solid var(--fe-border);
    border-radius: 16px;
    background: var(--fe-surface);
    box-shadow: 0 18px 54px rgba(15, 23, 42, .13);
}
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-warm-salon { --fe-accent:#c4845a; --fe-accent2:#a06b42; --fe-bg:#fdf6f0; --fe-surface:#fff; --fe-surface2:#faf0e8; --fe-border:#e8d0bb; --fe-text:#2d1a10; --fe-sub:#8a6558; }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-blue-night { --fe-accent:#58a6ff; --fe-accent2:#1f6feb; --fe-bg:#0d1117; --fe-surface:#161b22; --fe-surface2:#21262d; --fe-border:#30363d; --fe-text:#e6edf3; --fe-sub:#8b949e; }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-modern-white { --fe-accent:#5c6bc0; --fe-accent2:#3949ab; --fe-bg:#f8f9fa; --fe-surface:#fff; --fe-surface2:#f0f2f5; --fe-border:#dde1e7; --fe-text:#1a1a2e; --fe-sub:#6b7280; }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-glass { --fe-accent:#8c98ad; --fe-accent2:#6f7f95; --fe-bg:linear-gradient(180deg,#f8fafc 0%,#eef2f6 52%,#e6edf3 100%); --fe-surface:rgba(255,255,255,.68); --fe-surface2:rgba(255,255,255,.54); --fe-border:rgba(129,146,168,.22); --fe-text:#101923; --fe-sub:rgba(30,41,59,.82); }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-super-glass { --fe-accent:#a7b2c2; --fe-accent2:#8f9daf; --fe-bg:radial-gradient(circle at top left, rgba(255,255,255,.62), transparent 24%), radial-gradient(circle at top right, rgba(255,255,255,.22), transparent 20%), linear-gradient(180deg,#e8edf2 0%,#dbe3ea 50%,#cfd9e2 100%); --fe-surface:rgba(255,255,255,.28); --fe-surface2:rgba(255,255,255,.36); --fe-border:rgba(240,246,252,.52); --fe-text:#0f1724; --fe-sub:rgba(30,41,59,.84); }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-green-nature-glass { --fe-accent:#245a35; --fe-accent2:#d9a441; --fe-bg:radial-gradient(circle at top left, rgba(255,255,255,.7), transparent 24%), radial-gradient(circle at 85% 10%, rgba(217,238,243,.7), transparent 22%), linear-gradient(180deg,#f7f6ee 0%,#edf5ee 46%,#dfeee3 100%); --fe-surface:rgba(255,255,255,.44); --fe-surface2:rgba(255,255,255,.58); --fe-border:rgba(36,90,53,.16); --fe-text:#18231b; --fe-sub:rgba(66,88,74,.86); }
.gslb-fe__push-banner.gslb-fe__push-banner--design-theme.gslb-fe-theme-black-glass { --fe-accent:#7fd6ff; --fe-accent2:#63a7ff; --fe-bg:radial-gradient(circle at top left, rgba(76,122,255,.14), transparent 24%), radial-gradient(circle at 88% 14%, rgba(143,92,255,.12), transparent 20%), linear-gradient(180deg,#090d15 0%,#0f1520 48%,#121924 100%); --fe-surface:rgba(16,22,34,.78); --fe-surface2:rgba(22,30,44,.72); --fe-border:rgba(138,167,215,.18); --fe-text:#eef4ff; --fe-sub:rgba(198,212,235,.72); }
.gslb-fe__push-banner--floating {
    position: fixed;
    z-index: 999990;
    left: 50%;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 18px);
    width: min(900px, calc(100vw - 38px));
    margin: 0;
    transform: translateX(-50%);
    backdrop-filter: blur(10px) saturate(135%);
    -webkit-backdrop-filter: blur(10px) saturate(135%);
    box-shadow: 0 24px 72px rgba(15, 23, 42, .22);
}
.gslb-fe__push-banner--inline {
    margin: 0;
}
.gslb-fe__push-banner-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}
.gslb-fe__push-banner-copy strong {
    color: var(--fe-text);
    font-size: 16px;
    font-weight: 900;
    line-height: 1.25;
}
.gslb-fe__push-banner-copy span,
.gslb-fe__push-banner-result {
    color: var(--fe-sub);
    font-size: 13px;
    line-height: 1.35;
}
.gslb-fe__push-banner-actions {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    align-items: center;
    gap: 14px;
}
.gslb-fe__push-banner-actions .gslb-fe__btn {
    min-height: 40px;
    padding: 9px 24px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 900;
    white-space: nowrap;
}
.gslb-fe__push-banner-actions .gslb-fe__push-banner-hide {
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    color: var(--fe-sub);
    font-size: 14px;
    font-weight: 500;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.gslb-fe__push-banner-actions .gslb-fe__push-banner-hide:hover {
    color: var(--fe-text);
    background: transparent;
    box-shadow: none;
}
.gslb-fe__push-banner-close {
    position: absolute;
    top: 8px;
    right: 10px;
    width: 28px;
    height: 28px;
    border: 1px solid rgba(129,146,168,.24);
    border-radius: 999px;
    background: #fff;
    color: var(--fe-text);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
}
.gslb-fe__push-banner-result {
    grid-column: 1 / -1;
}
.gslb-fe__push-banner--design-neutral {
    --fe-accent:#64748b;
    --fe-accent2:#475569;
    --fe-surface:#fff;
    --fe-border:rgba(129,146,168,.28);
    --fe-text:#101923;
    --fe-sub:#475569;
    background:#fff;
    color:#101923;
}
.gslb-fe__push-banner--design-custom {
    --fe-accent:var(--gslb-push-accent,#64748b);
    --fe-accent2:var(--gslb-push-accent,#64748b);
    --fe-surface:var(--gslb-push-bg,#fff);
    --fe-border:rgba(129,146,168,.28);
    --fe-text:var(--gslb-push-text,#101923);
    --fe-sub:var(--gslb-push-sub,#475569);
    background:var(--gslb-push-bg,#fff);
    color:var(--gslb-push-text,#101923);
}
.gslb-fe__push-banner--design-custom .gslb-fe__btn--primary {
    background:var(--gslb-push-accent,#64748b);
    border-color:var(--gslb-push-accent,#64748b);
    color:var(--gslb-push-button-text,#fff);
}
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-close,
.gslb-fe__push-banner--design-custom .gslb-fe__btn--ghost,
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-close,
.gslb-fe__push-banner--design-neutral .gslb-fe__btn--ghost {
    background:rgba(255,255,255,.94);
    border-color:rgba(129,146,168,.28);
    color:var(--fe-text,#101923);
}
.gslb-fe-theme-glass .gslb-fe__push-banner,
.gslb-fe-theme-super-glass .gslb-fe__push-banner,
.gslb-fe__push-banner.gslb-fe-theme-glass.gslb-fe__push-banner--design-theme,
.gslb-fe__push-banner.gslb-fe-theme-super-glass.gslb-fe__push-banner--design-theme {
    background: rgba(255, 255, 255, .95);
    border-color: rgba(71, 85, 105, .28);
    color: #101923;
    box-shadow: 0 24px 70px rgba(15, 23, 42, .22);
}
.gslb-fe-theme-glass .gslb-fe__push-banner-copy strong,
.gslb-fe-theme-super-glass .gslb-fe__push-banner-copy strong,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__push-banner-copy strong,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__push-banner-copy strong {
    color: #07111f;
    text-shadow: 0 1px 0 rgba(255, 255, 255, .55);
}
.gslb-fe-theme-glass .gslb-fe__push-banner-copy span,
.gslb-fe-theme-super-glass .gslb-fe__push-banner-copy span,
.gslb-fe-theme-glass .gslb-fe__push-banner-result,
.gslb-fe-theme-super-glass .gslb-fe__push-banner-result,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__push-banner-result,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__push-banner-result {
    color: #243244;
}
.gslb-fe-theme-glass .gslb-fe__push-banner .gslb-fe__btn--primary,
.gslb-fe-theme-super-glass .gslb-fe__push-banner .gslb-fe__btn--primary,
.gslb-fe-theme-glass .gslb-fe__install-help .gslb-fe__btn--primary,
.gslb-fe-theme-super-glass .gslb-fe__install-help .gslb-fe__btn--primary,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__btn--primary,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__btn--primary,
.gslb-fe__install-help.gslb-fe-theme-glass .gslb-fe__btn--primary,
.gslb-fe__install-help.gslb-fe-theme-super-glass .gslb-fe__btn--primary {
    background: #64748b;
    border-color: #64748b;
    color: #fff;
    box-shadow: 0 12px 28px rgba(51, 65, 85, .22);
}
.gslb-fe-theme-glass .gslb-fe__push-banner .gslb-fe__btn--ghost,
.gslb-fe-theme-super-glass .gslb-fe__push-banner .gslb-fe__btn--ghost,
.gslb-fe-theme-glass .gslb-fe__install-help .gslb-fe__btn--ghost,
.gslb-fe-theme-super-glass .gslb-fe__install-help .gslb-fe__btn--ghost,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__btn--ghost,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__btn--ghost,
.gslb-fe__install-help.gslb-fe-theme-glass .gslb-fe__btn--ghost,
.gslb-fe__install-help.gslb-fe-theme-super-glass .gslb-fe__btn--ghost {
    background: rgba(255, 255, 255, .92);
    border-color: rgba(71, 85, 105, .28);
    color: #101923;
}
.gslb-fe-theme-glass .gslb-fe__push-banner-close,
.gslb-fe-theme-super-glass .gslb-fe__push-banner-close,
.gslb-fe__push-banner.gslb-fe-theme-glass .gslb-fe__push-banner-close,
.gslb-fe__push-banner.gslb-fe-theme-super-glass .gslb-fe__push-banner-close {
    background: #fff;
    border-color: rgba(71, 85, 105, .26);
    color: #101923;
}
.gslb-fe__push-banner.gslb-fe__push-banner--design-neutral,
.gslb-fe-theme-glass .gslb-fe__push-banner.gslb-fe__push-banner--design-neutral,
.gslb-fe-theme-super-glass .gslb-fe__push-banner.gslb-fe__push-banner--design-neutral {
    background:#fff;
    border-color:rgba(129,146,168,.28);
    color:#101923;
}
.gslb-fe__push-banner.gslb-fe__push-banner--design-custom,
.gslb-fe-theme-glass .gslb-fe__push-banner.gslb-fe__push-banner--design-custom,
.gslb-fe-theme-super-glass .gslb-fe__push-banner.gslb-fe__push-banner--design-custom {
    background:var(--gslb-push-bg,#fff);
    border-color:rgba(129,146,168,.28);
    color:var(--gslb-push-text,#101923);
}
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-copy strong,
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-result,
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-copy strong,
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-result {
    color:var(--fe-text,#101923);
    text-shadow:none;
}
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner--design-neutral .gslb-fe__push-banner-result {
    color:#475569;
}
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-copy span,
.gslb-fe__push-banner--design-custom .gslb-fe__push-banner-result {
    color:var(--gslb-push-sub,#475569);
}
.gslb-fe__push-banner--design-custom .gslb-fe__btn--primary {
    background:var(--gslb-push-accent,#64748b);
    border-color:var(--gslb-push-accent,#64748b);
    color:var(--gslb-push-button-text,#fff);
}
.gslb-fe__push-banner--design-neutral .gslb-fe__btn--primary {
    background:#64748b;
    border-color:#64748b;
    color:#fff;
}
.gslb-fe--push-banner-only {
    max-width: 960px;
    margin: 18px auto;
    background: transparent;
    border: 0;
    box-shadow: none;
}
.gslb-fe--push-banner-only .gslb-fe__push-banner {
    margin: 0;
}
.gslb-fe__push-banner-host:empty {
    display: none;
}
@media (max-width: 640px) {
    .gslb-fe__push-banner {
        grid-template-columns: 1fr;
        gap: 9px;
        padding: 12px 42px 12px 14px;
        width: min(100%, calc(100vw - 24px));
    }
    .gslb-fe__push-banner-copy {
        gap: 2px;
    }
    .gslb-fe__push-banner-copy strong {
        font-size: 14px;
        line-height: 1.2;
    }
    .gslb-fe__push-banner-copy span,
    .gslb-fe__push-banner-result {
        font-size: 12px;
        line-height: 1.25;
    }
    .gslb-fe__push-banner-actions {
        justify-content: flex-start;
        flex-wrap: nowrap;
        gap: 8px;
    }
    .gslb-fe__push-banner-actions .gslb-fe__btn {
        flex: 0 0 auto;
        min-height: 36px;
        padding: 8px 14px;
        font-size: 13px;
        justify-content: center;
    }
    .gslb-fe__push-banner-actions .gslb-fe__push-banner-hide {
        padding: 0;
        min-height: 0;
        font-size: 12px;
        white-space: nowrap;
    }
    .gslb-fe__push-banner-copy span {
        display: none;
    }
    .gslb-fe__push-banner-close {
        top: 7px;
        right: 8px;
        width: 26px;
        height: 26px;
    }
}

/* BODY + PANELS */
.gslb-fe__body    { padding:24px 28px; }
.gslb-fe__panel   { display:none; }
.gslb-fe__panel.active { display:block; animation:feSlideIn .25s ease; }
@keyframes feSlideIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.gslb-fe__panel-title { font-size:17px; font-weight:700; margin-bottom:18px; color:var(--fe-text); text-align:center; }
.gslb-fe__panel-footer { display:flex; justify-content:flex-end; gap:10px; margin-top:24px; padding-top:16px; border-top:1px solid var(--fe-border); }

/* SERVIZI */
.gslb-fe__services-grid { display:block; }
.gslb-fe__svc-cat-title { grid-column:1/-1; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--fe-accent); padding:4px 0; margin-top:6px; border-left:3px solid var(--fe-accent); padding-left:8px; }
.gslb-fe__svc-card { background:var(--fe-surface); border:2px solid var(--fe-border); border-radius:var(--fe-radius-sm); padding:14px; cursor:pointer; transition:border-color .15s,background .15s,transform .1s; user-select:none; }
.gslb-fe__svc-card:hover { border-color:var(--fe-accent); background:var(--fe-surface2); transform:translateY(-2px); }
.gslb-fe__svc-card.selected { border-color:var(--fe-accent); background:var(--fe-surface2); box-shadow:0 0 0 3px color-mix(in srgb, var(--fe-accent) 20%, transparent); }
.gslb-fe__svc-card.is-pending-select { border-color:var(--fe-accent); background:var(--fe-surface2); box-shadow:0 0 0 3px color-mix(in srgb, var(--fe-accent) 18%, transparent); }
.gslb-fe__svc-card.is-disabled { opacity:.72; cursor:not-allowed; border-style:dashed; }
.gslb-fe__svc-card.is-disabled:hover { transform:none; border-color:var(--fe-border); background:var(--fe-surface); }
.gslb-fe__svc-card__name { font-size:15px; font-weight:700; margin-bottom:4px; }
.gslb-fe__svc-card__desc { font-size:12px; line-height:1.45; color:var(--fe-text); opacity:.78; margin-bottom:6px; }
.gslb-fe__svc-card__meta { font-size:12px; color:var(--fe-sub); display:flex; gap:10px; }
.gslb-fe__svc-card__warning { margin-top:8px; padding:8px 10px; border-radius:10px; background:rgba(201,111,89,.1); border:1px solid rgba(201,111,89,.22); color:var(--fe-text); font-size:11px; line-height:1.4; }
.gslb-fe__svc-card__cover {
    width: calc(100% + 28px);
    margin: -14px -14px 12px;
    height: 118px;
    background-size: cover;
    background-position: center;
    border-radius: 18px 18px 0 0;
    border-bottom: 1px solid rgba(0,0,0,.05);
}
.gslb-fe__svc-card__body {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: start;
}
.gslb-fe__svc-card__profile {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    overflow: hidden;
    background: rgba(255,255,255,.9);
    border: 1px solid var(--fe-border);
    box-shadow: 0 8px 24px rgba(15, 23, 42, .08);
    flex-shrink: 0;
}
.gslb-fe__svc-card__profile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.gslb-fe__svc-card__content {
    min-width: 0;
}
.gslb-fe__svc-card--centered .gslb-fe__svc-card__body {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
}
.gslb-fe__svc-card--centered .gslb-fe__svc-card__content {
    text-align: center;
}
.gslb-fe__svc-card--centered .gslb-fe__svc-card__meta {
    justify-content: center;
}
.gslb-fe__svc-card__footer { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:10px; }
.gslb-fe__svc-qty { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--fe-border); border-radius:999px; padding:4px 8px; background:var(--fe-surface0,rgba(255,255,255,.7)); }
.gslb-fe__svc-qty-btn { width:28px; height:28px; border-radius:50%; border:1px solid var(--fe-border); background:var(--fe-surface); color:var(--fe-text); font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.gslb-fe__svc-qty-btn:hover { border-color:var(--fe-accent); color:var(--fe-accent); }
.gslb-fe__svc-qty-btn:disabled { opacity:.45; cursor:not-allowed; }
.gslb-fe__svc-qty-value { min-width:18px; text-align:center; font-weight:700; }
.gslb-fe__svc-card__hint { font-size:11px; color:var(--fe-sub); }
.gslb-fe__selection-feasibility-hint {
    margin: 0 0 16px;
    min-height: 74px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid transparent;
    background: transparent;
    font-size: 14px;
    line-height: 1.45;
    transition: opacity .16s ease, border-color .16s ease, background .16s ease;
}
.gslb-fe__selection-feasibility-hint.is-idle {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}
.gslb-fe__selection-feasibility-hint.is-loading {
    opacity: 1;
    visibility: visible;
    border-color: rgba(111,123,247,.20);
    background: rgba(111,123,247,.05);
}
.gslb-fe__selection-feasibility-hint.is-error {
    opacity: 1;
    visibility: visible;
    border-color: rgba(220,53,69,.40);
    background: rgba(220,53,69,.08);
}
.gslb-fe__selection-feasibility-title {
    display: block;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--fe-text);
}
.gslb-fe__selection-feasibility-copy {
    color: var(--fe-sub);
}
.gslb-fe__selection-feasibility-copy strong {
    color: var(--fe-text);
}
.gslb-fe__booking-mode-hint {
    margin: 0 0 16px;
    padding: 0;
    font-size: 14px;
    line-height: 1.45;
}
.gslb-fe__booking-mode-hint:empty {
    display: none;
}
.gslb-fe__booking-mode-hint--info,
.gslb-fe__booking-mode-hint--error {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid transparent;
}
.gslb-fe__booking-mode-hint--info {
    border-color: rgba(111,123,247,.20);
    background: rgba(111,123,247,.05);
    color: var(--fe-sub);
}
.gslb-fe__booking-mode-hint--error {
    border-color: rgba(220,53,69,.40);
    background: rgba(220,53,69,.08);
    color: var(--fe-sub);
}
.gslb-fe__booking-mode-hint strong {
    color: var(--fe-text);
}
.gslb-fe,
.gslb-fe__body,
.gslb-fe__panel,
.gslb-fe__services-grid,
.gslb-fe__accordion,
.gslb-fe__accordion-body,
.gslb-fe__service-choice-list,
.gslb-fe__add-svc-grid,
.gslb-customer-shell,
.gslb-customer-bookings,
.gslb-customer-shell__hero,
.gslb-customer-bookings__section,
.gslb-portal__hero,
.gslb-portal__nav {
    max-width: 100%;
    min-width: 0;
}
.gslb-fe__services-grid,
.gslb-fe__accordion-body,
.gslb-fe__add-svc-grid,
.gslb-fe__service-choice-list,
.gslb-customer-bookings,
.gslb-customer-shell__content {
    overflow-x: hidden;
}
.gslb-fe__selection-feasibility-loading {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: center;
    min-height: 48px;
}
.gslb-fe__selection-feasibility-loading-copy {
    display: grid;
    gap: 2px;
}
.gslb-fe__selection-feasibility-loading-copy span {
    color: var(--fe-sub);
}
.gslb-fe__mini-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid rgba(111,123,247,.18);
    border-top-color: var(--fe-accent);
    border-radius: 50%;
    animation: feSpin .7s linear infinite;
}

/* OPERATORI */
.gslb-fe__attendants-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px, max-content)); gap:10px; justify-content:start; }
.gslb-fe__att-card { min-width:180px; max-width:240px; background:var(--fe-surface); border:2px solid var(--fe-border); border-radius:var(--fe-radius-sm); padding:16px 12px; cursor:pointer; text-align:center; transition:border-color .15s,transform .1s; }
.gslb-fe__att-card:hover { border-color:var(--fe-accent); transform:translateY(-2px); }
.gslb-fe__att-card.selected { border-color:var(--fe-accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--fe-accent) 20%, transparent); }
.gslb-fe__att-avatar { width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:700; color:#fff; margin:0 auto 8px; }
.gslb-fe__att-name { font-size:14px; font-weight:600; line-height:1.25; overflow-wrap:anywhere; word-break:normal; }
.gslb-fe__att-name small {
    display: block;
    margin-top: 2px;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.35;
    color: var(--fe-sub);
}
.gslb-fe__att-any-desc {
    margin-top: 2px;
    font-size: var(--gslb-fe-font-small);
    line-height: 1.3;
    color: var(--fe-sub);
    text-align: center;
}

/* CALENDARIO */
.gslb-fe__date-row { display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; }
@media (max-width:560px) { .gslb-fe__date-row { grid-template-columns:1fr; } }
.gslb-fe__panel[data-panel="4"] .gslb-fe__panel-title,
.gslb-fe__panel[data-panel="4"] .gslb-fe__first-avail-loading {
    text-align: center;
}
.gslb-fe__panel[data-panel="4"] .gslb-fe__first-avail-banner,
.gslb-fe__panel[data-panel="4"] .gslb-fe__date-row {
    max-width: 840px;
    margin-left: auto;
    margin-right: auto;
}
.gslb-fe__panel[data-panel="4"] .gslb-fe__slots-wrap {
    min-width: 0;
}
.gslb-fe__search-mode {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
    max-width: 840px;
    margin: 0 auto;
}
.gslb-fe__search-mode-card {
    appearance: none;
    border: 1.5px solid var(--fe-border);
    background: var(--fe-surface);
    color: var(--fe-text);
    border-radius: var(--fe-radius-sm);
    padding: 18px;
    text-align: left;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.gslb-fe__search-mode-card:hover {
    transform: translateY(-1px);
    border-color: var(--fe-accent);
    background: var(--fe-surface2);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fe-accent) 12%, transparent);
}
.gslb-fe__search-mode-card strong {
    display: block;
    font-size: 16px;
    margin-bottom: 6px;
}
.gslb-fe__search-mode-card span {
    display: block;
    font-size: 13px;
    color: var(--fe-sub);
}
.gslb-fe__first-avail-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
@media (max-width: 640px) {
    .gslb-fe__search-mode {
        grid-template-columns: 1fr;
    }
}

.gslb-fe__calendar { background:var(--fe-surface); border:1px solid var(--fe-border); border-radius:var(--fe-radius-sm); overflow:hidden; flex-shrink:0; position:relative; }
.gslb-fe__cal-nav  { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; border-bottom:1px solid var(--fe-border); }
.gslb-fe__cal-nav button { background:none; border:none; cursor:pointer; color:var(--fe-sub); font-size:18px; padding:4px 8px; border-radius:6px; transition:background .15s; }
.gslb-fe__cal-nav button:hover { background:var(--fe-surface2); }
.gslb-fe__cal-month { font-size:14px; font-weight:700; color:var(--fe-text); }
.gslb-fe__cal-grid  { display:grid; grid-template-columns:repeat(7,1fr); padding:8px; gap:3px; }
.gslb-fe__cal-day-name { text-align:center; font-size:11px; font-weight:700; color:var(--fe-sub); padding:4px 0; }
.gslb-fe__cal-day { text-align:center; font-size:13px; padding:7px 4px; border-radius:6px; cursor:pointer; transition:background .12s; color:var(--fe-text); }
.gslb-fe__cal-day:hover:not(.disabled):not(.empty) { background:var(--fe-surface2); }
.gslb-fe__cal-day.today { font-weight:700; color:var(--fe-accent); }
.gslb-fe__cal-day.selected { background:var(--fe-accent); color:#fff; font-weight:700; }
.gslb-fe__cal-day.disabled,.gslb-fe__cal-day.empty { color:var(--fe-border); cursor:default; pointer-events:none; }
.gslb-fe__cal-day.empty { pointer-events:none; }
.gslb-fe__calendar-loading {
    position:absolute;
    inset:0;
    z-index:5;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:14px;
    background:color-mix(in srgb, var(--fe-surface) 78%, transparent);
    color:var(--fe-text);
    font-size:13px;
    font-weight:700;
    text-align:center;
    backdrop-filter:blur(3px);
    -webkit-backdrop-filter:blur(3px);
    pointer-events:auto;
}

/* SLOTS */
.gslb-fe__slots-wrap { min-height:120px; }
.gslb-fe__slots-hint { font-size:13px; color:var(--fe-sub); padding:20px 0; }
.gslb-fe__slots-grid {
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:8px;
    align-items:stretch;
}
.gslb-fe__slots-wrap > .gslb-fe__waitlist-cta-wrap {
    margin:0 0 12px;
}
.gslb-fe__slot {
    width:100%;
    min-height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    background:var(--fe-surface);
    border:2px solid var(--fe-border);
    border-radius:var(--fe-radius-sm);
    padding:8px 6px;
    font-size:13px;
    font-weight:700;
    line-height:1;
    cursor:pointer;
    transition:all .12s;
}
.gslb-fe__slot:hover { border-color:var(--fe-accent); background:var(--fe-surface2); }
.gslb-fe__slot.selected { background:var(--fe-accent); border-color:var(--fe-accent); color:#fff; }
.gslb-fe__waitlist-cta-wrap { display:flex; flex-direction:column; gap:8px; width:100%; }
.gslb-fe__waitlist-cta-copy {
    font-size:13px;
    line-height:1.45;
    color:var(--fe-sub);
    text-align:center;
    width:100%;
}
.gslb-fe__slot--waitlist-global { width:100%; text-align:center; border-color:#d04949; background:#fff1f1; color:#b72d2d; }
.gslb-fe__slot--waitlist-global:hover { border-color:#b72d2d; background:#ffe2e2; }
.gslb-fe__slots-loading {
    grid-column: 1 / -1;
    width:100%;
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--fe-sub);
    font-size:13px;
    padding:12px 0;
}
.gslb-fe__slots-loading--detailed { align-items:flex-start; }
.gslb-fe__slots-loading-copy {
    display:grid;
    gap:4px;
    width:100%;
    min-width:0;
}
.gslb-fe__slots-loading-copy strong { color:var(--fe-text); }
.gslb-fe__slots-loading-copy span,
.gslb-fe__slots-loading-copy small { color:var(--fe-sub); }
.gslb-fe__slots-progress { height:8px; background:#e8ebf1; border-radius:999px; overflow:hidden; margin-top:2px; }
.gslb-fe__slots-progress-bar { height:100%; background:linear-gradient(90deg,#6f7bf7,#91a0ff); border-radius:999px; transition:width .35s ease; }
@media (max-width:560px) {
    .gslb-fe__slots-loading {
        align-items:flex-start;
    }
    .gslb-fe__slots-loading-copy strong,
    .gslb-fe__slots-loading-copy span,
    .gslb-fe__slots-loading-copy small {
        line-height:1.35;
    }
}

/* FORM DATI */
.gslb-fe__form { display:flex; flex-direction:column; gap:14px; }
.gslb-fe__row   { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:480px) { .gslb-fe__row { grid-template-columns:1fr; } }
.gslb-fe__field { display:flex; flex-direction:column; gap:5px; }
.gslb-fe__field--full { grid-column:1/-1; }
.gslb-fe__field--check { flex-direction:column; align-items:stretch; gap:8px; padding-top:4px; }
.gslb-fe__field--check label {
    display:grid;
    grid-template-columns:20px minmax(0,1fr);
    align-items:flex-start;
    gap:10px;
    cursor:pointer;
    font-size:14px;
    color:var(--fe-sub);
    line-height:1.5;
}
.gslb-fe__field--check input[type="checkbox"] {
    width:18px;
    height:18px;
    flex-shrink:0;
    margin:2px 0 0;
    accent-color:var(--fe-accent);
    cursor:pointer;
}
.gslb-fe__check-copy {
    display:block;
    min-width:0;
}
.gslb-fe__check-required {
    color:#c43b31;
    font-weight:800;
    margin-right:2px;
}
.gslb-fe__field--check a { color:var(--fe-accent); }
.gslb-fe__field--check .gslb-fe__field-err {
    padding-left:30px;
}
@media (max-width:640px) {
    .gslb-fe__field--check {
        gap:6px;
    }
    .gslb-fe__field--check label {
        font-size:15px;
        gap:12px;
    }
    .gslb-fe__field--check input[type="checkbox"] {
        width:20px;
        height:20px;
        margin-top:1px;
    }
    .gslb-fe__field--check .gslb-fe__field-err {
        padding-left:32px;
    }
}
@media (min-width: 641px) {
    .gslb-fe__slots-grid {
        grid-template-columns:repeat(5, minmax(0, 1fr));
    }
}
.gslb-fe__field label { font-size:13px; font-weight:600; color:var(--fe-sub); }
.gslb-fe__field input, .gslb-fe__field textarea {
    background:var(--fe-surface); border:1.5px solid var(--fe-border);
    border-radius:var(--fe-radius-sm); color:var(--fe-text); font-size:15px;
    padding:10px 12px; outline:none; font-family:inherit;
    transition:border-color .2s;
    width:100%;
}
.gslb-fe__field input:focus, .gslb-fe__field textarea:focus { border-color:var(--fe-accent); }
.gslb-fe__field input[readonly] { opacity:.7; cursor:default; }
.gslb-fe__field textarea { resize:vertical; min-height:72px; }
.gslb-fe__field-err { font-size:12px; color:#e53935; min-height:16px; }
.gslb-fe__field.has-error input, .gslb-fe__field.has-error textarea { border-color:#e53935; }

/* BOTTONI */
.gslb-fe__btn { display:inline-flex; align-items:center; gap:6px; padding:11px 22px; border:2px solid transparent; border-radius:var(--fe-radius-sm); font-size:15px; font-weight:700; cursor:pointer; font-family:inherit; transition:all .15s; text-decoration:none; }
.gslb-fe__btn:disabled { opacity:.5; cursor:not-allowed; }
.gslb-fe__btn--primary { background:var(--fe-accent); border-color:var(--fe-accent); color:#fff; }
.gslb-fe__btn--primary:hover:not(:disabled) { background:var(--fe-accent2); border-color:var(--fe-accent2); }
.gslb-fe__btn--ghost { background:transparent; border-color:var(--fe-border); color:var(--fe-text); }
.gslb-fe__btn--ghost:hover { background:var(--fe-surface2); }

/* SPINNER */
.gslb-fe__spinner { width:28px; height:28px; border:3px solid var(--fe-border); border-top-color:var(--fe-accent); border-radius:50%; animation:feSpin .7s linear infinite; margin:30px auto; display:block; }
@keyframes feSpin { to { transform:rotate(360deg); } }

/* SUCCESSO */
.gslb-fe__success { text-align:center; padding:32px 0; }
.gslb-fe__success-icon { font-size:56px; margin-bottom:12px; }
.gslb-fe__success h3 { font-size:22px; font-weight:800; color:var(--fe-text); margin-bottom:8px; }
.gslb-fe__success-msg { color:var(--fe-sub); margin-bottom:20px; }
.gslb-fe__success-recap { background:var(--fe-surface); border:1px solid var(--fe-border); border-radius:var(--fe-radius-sm); padding:16px 20px; text-align:left; display:inline-block; min-width:240px; max-width:360px; font-size:14px; line-height:1.8; color:var(--fe-text); }
.gslb-fe__panel--payment .gslb-fe__success { max-width:720px; margin:0 auto; }
.gslb-fe__inline-payment { margin:20px auto 0; max-width:560px; padding:18px; border-radius:18px; border:1px solid var(--fe-border); background:color-mix(in srgb, var(--fe-surface) 92%, transparent); text-align:left; box-shadow:0 14px 40px rgba(0,0,0,.08); }
.gslb-fe__inline-payment--modal { max-width:none; margin-top:0; }
.gslb-fe__inline-payment-summary { margin-bottom:14px; }
.gslb-fe__inline-payment-kicker { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--fe-sub); font-weight:800; }
.gslb-fe__inline-payment-amount { font-size:30px; line-height:1.1; font-weight:800; color:var(--fe-text); margin-top:6px; }
.gslb-fe__inline-payment-note { color:var(--fe-sub); font-size:14px; line-height:1.55; margin-top:6px; }
.gslb-fe__inline-payment-deadline { color:var(--fe-accent); font-size:13px; line-height:1.45; margin-top:8px; font-weight:700; }
.gslb-fe__inline-payment-element { padding:14px; border:1px solid var(--fe-border); border-radius:14px; background:rgba(255,255,255,.7); }
.gslb-fe__inline-payment-error { margin-top:12px; padding:12px 14px; border-radius:12px; background:#fff1ef; border:1px solid #efc2be; color:#98372d; font-size:14px; line-height:1.5; }
.gslb-fe__inline-payment-submit { width:100%; margin-top:14px; }

/* ERRORE GLOBALE */
.gslb-fe__error-global { background:#fdecea; border:1.5px solid #f44336; border-radius:var(--fe-radius-sm); padding:12px 16px; font-size:14px; color:#c62828; margin:0 28px 20px; }
.gslb-payment-notice { margin:0 0 18px; border-radius:12px; padding:14px 16px; font-size:14px; line-height:1.5; border:1px solid transparent; }
.gslb-payment-notice--success { background:#edf8f0; color:#1f6b38; border-color:#b7e0c1; }
.gslb-payment-notice--warning { background:#fff5e8; color:#8a5a15; border-color:#f0d0a5; }

/* WIDGET CLIENTE */
.gslb-cliente-widget { background:var(--fe-surface,#fff); border:1px solid var(--fe-border,#e5e7eb); border-radius:12px; overflow:hidden; }
.gslb-cliente-widget__row { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; border-bottom:1px solid var(--fe-border,#e5e7eb); font-size:15px; }
.gslb-cliente-widget__row:last-child { border-bottom:none; }
.gslb-cliente-widget__row--warning { color:#c62828; }
.gslb-cliente-widget__row--action {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}
.gslb-cliente-widget__row--action:hover {
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 7%, #fff);
}
.gslb-portal {
    --gslb-portal-font-body: 16px;
    --gslb-portal-font-meta: 15px;
    --gslb-portal-font-small: 14px;
    --gslb-portal-font-tab: 15px;
    --gslb-portal-font-card-label: 14px;
    --gslb-portal-font-card-value: 29px;
    --gslb-portal-font-section: 22px;
    --gslb-portal-font-status: 14px;
    --gslb-portal-font-hero: 35px;
}
.gslb-portal--font-medium {
    --gslb-portal-font-body: 18px;
    --gslb-portal-font-meta: 17px;
    --gslb-portal-font-small: 16px;
    --gslb-portal-font-tab: 17px;
    --gslb-portal-font-card-label: 16px;
    --gslb-portal-font-card-value: 32px;
    --gslb-portal-font-section: 25px;
    --gslb-portal-font-status: 16px;
    --gslb-portal-font-hero: 40px;
}
.gslb-portal--font-large {
    --gslb-portal-font-body: 20px;
    --gslb-portal-font-meta: 18px;
    --gslb-portal-font-small: 17px;
    --gslb-portal-font-tab: 18px;
    --gslb-portal-font-card-label: 17px;
    --gslb-portal-font-card-value: 36px;
    --gslb-portal-font-section: 28px;
    --gslb-portal-font-status: 17px;
    --gslb-portal-font-hero: 44px;
}
.gslb-portal--font-xlarge {
    --gslb-portal-font-body: 22px;
    --gslb-portal-font-meta: 20px;
    --gslb-portal-font-small: 18px;
    --gslb-portal-font-tab: 20px;
    --gslb-portal-font-card-label: 18px;
    --gslb-portal-font-card-value: 40px;
    --gslb-portal-font-section: 31px;
    --gslb-portal-font-status: 18px;
    --gslb-portal-font-hero: 48px;
}
.gslb-fe {
    --gslb-fe-font-body: 16px;
    --gslb-fe-font-title: 24px;
    --gslb-fe-font-panel-title: 19px;
    --gslb-fe-font-step: 14px;
    --gslb-fe-font-step-label: 11px;
    --gslb-fe-font-category: 13px;
    --gslb-fe-font-service-name: 16px;
    --gslb-fe-font-service-desc: 13px;
    --gslb-fe-font-meta: 13px;
    --gslb-fe-font-small: 12px;
    --gslb-fe-font-attendant: 15px;
    --gslb-fe-font-input: 16px;
    --gslb-fe-font-button: 16px;
    --gslb-fe-font-slot: 14px;
    --gslb-fe-font-calendar: 14px;
    --gslb-fe-font-special-banner-title: 13px;
    --gslb-fe-font-special-banner-body: 13px;
    --gslb-fe-font-special-banner-item-title: 15px;
    font-size: var(--gslb-fe-font-body);
}
.gslb-fe--font-medium {
    --gslb-fe-font-body: 18px;
    --gslb-fe-font-title: 27px;
    --gslb-fe-font-panel-title: 21px;
    --gslb-fe-font-step: 15px;
    --gslb-fe-font-step-label: 12px;
    --gslb-fe-font-category: 14px;
    --gslb-fe-font-service-name: 18px;
    --gslb-fe-font-service-desc: 15px;
    --gslb-fe-font-meta: 15px;
    --gslb-fe-font-small: 14px;
    --gslb-fe-font-attendant: 17px;
    --gslb-fe-font-input: 18px;
    --gslb-fe-font-button: 18px;
    --gslb-fe-font-slot: 16px;
    --gslb-fe-font-calendar: 16px;
    --gslb-fe-font-special-banner-title: 14px;
    --gslb-fe-font-special-banner-body: 14px;
    --gslb-fe-font-special-banner-item-title: 16px;
}
.gslb-fe--font-large {
    --gslb-fe-font-body: 20px;
    --gslb-fe-font-title: 30px;
    --gslb-fe-font-panel-title: 24px;
    --gslb-fe-font-step: 17px;
    --gslb-fe-font-step-label: 13px;
    --gslb-fe-font-category: 16px;
    --gslb-fe-font-service-name: 20px;
    --gslb-fe-font-service-desc: 17px;
    --gslb-fe-font-meta: 17px;
    --gslb-fe-font-small: 15px;
    --gslb-fe-font-attendant: 19px;
    --gslb-fe-font-input: 20px;
    --gslb-fe-font-button: 20px;
    --gslb-fe-font-slot: 18px;
    --gslb-fe-font-calendar: 18px;
    --gslb-fe-font-special-banner-title: 16px;
    --gslb-fe-font-special-banner-body: 16px;
    --gslb-fe-font-special-banner-item-title: 18px;
}
.gslb-fe--font-xlarge {
    --gslb-fe-font-body: 22px;
    --gslb-fe-font-title: 34px;
    --gslb-fe-font-panel-title: 27px;
    --gslb-fe-font-step: 18px;
    --gslb-fe-font-step-label: 14px;
    --gslb-fe-font-category: 17px;
    --gslb-fe-font-service-name: 22px;
    --gslb-fe-font-service-desc: 18px;
    --gslb-fe-font-meta: 18px;
    --gslb-fe-font-small: 16px;
    --gslb-fe-font-attendant: 21px;
    --gslb-fe-font-input: 22px;
    --gslb-fe-font-button: 22px;
    --gslb-fe-font-slot: 20px;
    --gslb-fe-font-calendar: 20px;
    --gslb-fe-font-special-banner-title: 17px;
    --gslb-fe-font-special-banner-body: 17px;
    --gslb-fe-font-special-banner-item-title: 20px;
}
.gslb-fe__title { font-size: var(--gslb-fe-font-title); }
.gslb-fe__step span { font-size: var(--gslb-fe-font-step); }
.gslb-fe__step small { font-size: var(--gslb-fe-font-step-label); }
.gslb-fe__step.done span::after { font-size: var(--gslb-fe-font-step); }
.gslb-fe__panel-title { font-size: var(--gslb-fe-font-panel-title); }
.gslb-fe__svc-cat-title { font-size: var(--gslb-fe-font-category); }
.gslb-fe__svc-card__name { font-size: var(--gslb-fe-font-service-name); }
.gslb-fe__svc-card__desc { font-size: var(--gslb-fe-font-service-desc); }
.gslb-fe__svc-card__meta,
.gslb-fe__booking-mode-hint,
.gslb-fe__selection-feasibility-hint { font-size: var(--gslb-fe-font-meta); }
.gslb-fe__svc-card__warning,
.gslb-fe__svc-card__hint,
.gslb-fe__field-err,
.gslb-fe__att-name small,
.gslb-fe__cal-day-name { font-size: var(--gslb-fe-font-small); }
.gslb-fe__att-name,
.gslb-fe__att-card--sm .gslb-fe__att-name { font-size: var(--gslb-fe-font-attendant); }
.gslb-fe__field label,
.gslb-fe__slots-hint,
.gslb-fe__slots-loading,
.gslb-fe__waitlist-cta-copy,
.gslb-fe__inline-payment-deadline { font-size: var(--gslb-fe-font-meta); }
.gslb-fe__field input,
.gslb-fe__field textarea,
.gslb-fe__field--check label,
.gslb-fe__inline-payment-note,
.gslb-fe__error-global,
.gslb-payment-notice,
.gslb-fe__success-recap { font-size: var(--gslb-fe-font-input); }
.gslb-fe__btn { font-size: var(--gslb-fe-font-button); }
.gslb-fe__slot { font-size: var(--gslb-fe-font-slot); }
.gslb-fe__cal-month,
.gslb-fe__cal-day { font-size: var(--gslb-fe-font-calendar); }
.gslb-fe__search-mode-card strong { font-size: var(--gslb-fe-font-service-name); }
.gslb-fe__search-mode-card span { font-size: var(--gslb-fe-font-meta); }
.gslb-fe__success h3 { font-size: var(--gslb-fe-font-title); }
.gslb-fe__inline-payment-kicker { font-size: var(--gslb-fe-font-small); }
.gslb-fe__inline-payment-amount { font-size: calc(var(--gslb-fe-font-title) + 8px); }
.gslb-fe__special-rules-note-title { font-size: var(--gslb-fe-font-special-banner-title); }
.gslb-fe__special-rule,
.gslb-fe__special-rule-line,
.gslb-fe__special-rules-note-empty { font-size: var(--gslb-fe-font-special-banner-body); }
.gslb-fe__special-rule-title { font-size: var(--gslb-fe-font-special-banner-item-title); }
.gslb-customer-summary { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:12px; }
.gslb-customer-summary__card { background:var(--fe-surface,#fff); border:1px solid var(--fe-border,#e5e7eb); border-radius:12px; padding:14px 16px; display:flex; flex-direction:column; gap:8px; }
.gslb-customer-summary__card span { font-size:var(--gslb-portal-font-card-label); color:var(--fe-sub,#6b7280); }
.gslb-customer-summary__card strong { font-size:var(--gslb-portal-font-card-value); line-height:1.1; color:var(--fe-text,#111827); }
.gslb-customer-summary__card--warning strong { color:#c62828; }
.gslb-customer-summary__card--action { cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.gslb-customer-summary__card--action:hover { transform:translateY(-1px); border-color:color-mix(in srgb, var(--fe-accent,#5b6bd5) 35%, var(--fe-border,#e5e7eb)); box-shadow:0 12px 24px rgba(17,24,39,.06); }
.gslb-customer-summary__shortcuts {
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:-4px;
}
.gslb-customer-shortcut {
    border:1px solid var(--fe-border,#e5e7eb);
    background:var(--fe-surface,#fff);
    color:var(--fe-text,#111827);
    border-radius:999px;
    padding:10px 14px;
    display:inline-flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    transition:all .18s ease;
}
.gslb-customer-shortcut:hover {
    border-color:var(--fe-accent,#5b6bd5);
    color:var(--fe-accent,#5b6bd5);
}
.gslb-customer-shortcut__label {
    font-size:var(--gslb-portal-font-small);
    color:inherit;
}
.gslb-customer-shortcut__count {
    font-size:var(--gslb-portal-font-small);
    font-weight:800;
    color:inherit;
}
.gslb-customer-shortcut--warning {
    border-color:color-mix(in srgb, #c62828 22%, var(--fe-border,#e5e7eb));
    color:#b42318;
}
.gslb-customer-manage-tabs {
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:22px 0 16px;
}
.gslb-customer-manage-tab {
    border:1px solid var(--fe-border,#e5e7eb);
    background:var(--fe-surface,#fff);
    color:var(--fe-text,#111827);
    border-radius:999px;
    padding:10px 14px;
    font-size:var(--gslb-portal-font-tab);
    font-weight:700;
    cursor:pointer;
    transition:all .18s ease;
}
.gslb-customer-manage-tab:hover {
    border-color:var(--fe-accent,#5b6bd5);
    color:var(--fe-accent,#5b6bd5);
}
.gslb-customer-manage-tab.is-active {
    background:var(--fe-accent,#5b6bd5);
    border-color:var(--fe-accent,#5b6bd5);
    color:#fff;
    box-shadow:0 12px 24px rgba(91,107,213,.18);
}
.gslb-customer-manage-panel { display:none; }
.gslb-customer-manage-panel.is-active { display:block; }
.gslb-customer-log-summary {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:16px;
    flex-wrap:wrap;
}
.gslb-customer-log-summary__value {
    font-size:28px;
    font-weight:800;
    line-height:1;
    color:var(--fe-text,#111827);
}
.gslb-customer-log-summary__note {
    font-size:13px;
    color:var(--fe-sub,#6b7280);
    margin-top:8px;
}
.gslb-customer-log-table {
    width:100%;
    border-collapse:collapse;
    font-size:13px;
}
.gslb-customer-log-table th,
.gslb-customer-log-table td {
    padding:10px 12px;
    border-bottom:1px solid var(--fe-border,#e5e7eb);
    text-align:left;
    vertical-align:top;
}
.gslb-customer-log-table th {
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--fe-sub,#6b7280);
}
.gslb-customer-log-table td:last-child,
.gslb-customer-log-table th:last-child {
    text-align:right;
}
.gslb-customer-log-delta {
    font-weight:800;
    white-space:nowrap;
}
.gslb-customer-log-delta--positive { color:#2e8b57; }
.gslb-customer-log-delta--negative { color:#c62828; }
.gslb-customer-area {
    display: grid;
    gap: 18px;
    max-width: 860px;
    margin: 0 auto;
    font-size: var(--gslb-portal-font-body);
}
.gslb-portal {
    display: grid;
    gap: 18px;
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    min-width: 0;
    overflow-x: clip;
}
.gslb-portal__hero {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 22px 24px;
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 18px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--fe-accent) 11%, var(--fe-surface,#fff)) 0%, var(--fe-surface,#fff) 100%);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--fe-accent) 10%, transparent);
}
.gslb-portal__hero h2 {
    margin: 0 0 6px;
    font-size: var(--gslb-portal-font-hero);
    line-height: 1.05;
    color: var(--fe-text,#111827);
}
.gslb-portal__hero p {
    max-width: 620px;
    color: var(--fe-sub,#6b7280);
    font-size: var(--gslb-portal-font-body);
}
.gslb-portal__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-content: flex-start;
    gap: 8px;
    min-width: 260px;
}
.gslb-portal__tab {
    appearance: none;
    border: 1px solid var(--fe-border,#e5e7eb);
    background: color-mix(in srgb, var(--fe-surface2,#f9fafb) 78%, transparent);
    color: var(--fe-text,#111827);
    border-radius: 999px;
    min-height: 42px;
    padding: 0 16px;
    font-size: var(--gslb-portal-font-tab);
    font-weight: 700;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}
.gslb-portal__tab:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--fe-accent) 45%, var(--fe-border,#e5e7eb));
}
.gslb-portal__tab.is-active {
    background: var(--fe-accent,#5c6bc0);
    border-color: var(--fe-accent,#5c6bc0);
    color: #fff;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--fe-accent) 28%, transparent);
}
.gslb-portal__panel {
    display: none;
    min-width: 0;
}
.gslb-portal__panel.is-active {
    display: block;
    animation: gslb-fade .22s ease;
}
.gslb-fe-theme-super-glass .gslb-portal__hero,
.gslb-fe-theme-super-glass .gslb-customer-shell__hero,
.gslb-fe-theme-super-glass .gslb-customer-bookings__section,
.gslb-fe-theme-super-glass .gslb-customer-summary__card,
.gslb-fe-theme-super-glass .gslb-customer-booking-card,
.gslb-fe-theme-super-glass .gslb-customer-notice,
.gslb-fe-theme-super-glass .gslb-cliente-widget,
.gslb-fe-theme-super-glass .gslb-cliente-widget__row {
    background:
        linear-gradient(180deg, rgba(255,255,255,.46), rgba(255,255,255,.26)),
        radial-gradient(circle at top left, rgba(255,255,255,.3), transparent 42%);
    border-color: rgba(255,255,255,.54);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.58),
        0 18px 40px rgba(89, 99, 115, .12);
}
.gslb-fe-theme-black-glass .gslb-portal__hero,
.gslb-fe-theme-black-glass .gslb-customer-shell__hero,
.gslb-fe-theme-black-glass .gslb-customer-bookings__section,
.gslb-fe-theme-black-glass .gslb-customer-summary__card,
.gslb-fe-theme-black-glass .gslb-customer-booking-card,
.gslb-fe-theme-black-glass .gslb-customer-notice,
.gslb-fe-theme-black-glass .gslb-cliente-widget,
.gslb-fe-theme-black-glass .gslb-cliente-widget__row {
    background:
        linear-gradient(180deg, rgba(22,30,45,.86), rgba(11,16,28,.8)),
        radial-gradient(circle at top left, rgba(104,149,255,.12), transparent 42%);
    border-color: rgba(125, 152, 201, .24);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.05),
        0 18px 40px rgba(0, 0, 0, .28);
}
.gslb-fe-theme-black-glass .gslb-portal__hero,
.gslb-fe-theme-black-glass .gslb-customer-shell__hero {
    position: relative;
    overflow: hidden;
}
.gslb-fe-theme-black-glass .gslb-portal__hero::after,
.gslb-fe-theme-black-glass .gslb-customer-shell__hero::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 14% 18%, rgba(116,164,255,.14), transparent 24%),
        linear-gradient(115deg, rgba(255,255,255,.06), transparent 46%);
}
.gslb-fe-theme-black-glass .gslb-portal__hero h2,
.gslb-fe-theme-black-glass .gslb-customer-shell__hero h2,
.gslb-fe-theme-black-glass .gslb-customer-bookings__section h3,
.gslb-fe-theme-black-glass .gslb-customer-summary__card strong {
    color: #f3f7ff;
}
.gslb-fe-theme-black-glass .gslb-portal__hero p,
.gslb-fe-theme-black-glass .gslb-customer-shell__hero p,
.gslb-fe-theme-black-glass .gslb-customer-bookings__empty,
.gslb-fe-theme-black-glass .gslb-customer-booking-card__meta,
.gslb-fe-theme-black-glass .gslb-customer-summary__card span {
    color: rgba(205, 220, 245, .72);
}
.gslb-fe-theme-black-glass .gslb-portal__nav,
.gslb-fe-theme-black-glass .gslb-customer-shell__nav {
    gap: 10px;
}
.gslb-fe-theme-black-glass .gslb-portal__tab,
.gslb-fe-theme-black-glass .gslb-customer-shell__nav a,
.gslb-fe-theme-black-glass .gslb-customer-page-btn {
    background: linear-gradient(180deg, rgba(27,36,54,.92), rgba(16,23,36,.86));
    border-color: rgba(125, 152, 201, .26);
    color: #e6efff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 8px 18px rgba(0,0,0,.18);
}
.gslb-fe-theme-black-glass .gslb-portal__tab:hover,
.gslb-fe-theme-black-glass .gslb-customer-shell__nav a:hover,
.gslb-fe-theme-black-glass .gslb-customer-page-btn:hover {
    border-color: rgba(146, 176, 236, .42);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 12px 24px rgba(0,0,0,.24);
}
.gslb-fe-theme-black-glass .gslb-portal__tab.is-active,
.gslb-fe-theme-black-glass .gslb-customer-page-btn.is-active {
    background: linear-gradient(135deg, rgba(95,149,255,.94), rgba(124,104,255,.9));
    border-color: rgba(174, 200, 255, .45);
    color: #f7fbff;
    box-shadow: 0 14px 28px rgba(57, 96, 192, .24);
}
.gslb-fe-theme-black-glass .gslb-customer-booking-card__status,
.gslb-fe-theme-black-glass .gslb-noshow-avviso--portal {
    background: linear-gradient(180deg, rgba(28,36,53,.94), rgba(18,24,37,.88));
    border-color: rgba(125, 152, 201, .22);
}
.gslb-fe-theme-black-glass .gslb-noshow-avviso--portal {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 16px 36px rgba(100,35,35,.18);
}
.gslb-fe-theme-black-glass .gslb-fe__modal-backdrop {
    background: linear-gradient(180deg, rgba(4,7,14,.56), rgba(9,13,20,.64));
}
.gslb-fe-theme-black-glass .gslb-fe__modal,
.gslb-fe-theme-black-glass .gslb-fe__service-choice,
.gslb-fe-theme-black-glass .gslb-fe__service-edit-row {
    color: #eef4ff;
}
.gslb-fe-theme-black-glass .gslb-fe__add-svc-grid,
.gslb-fe-theme-black-glass .gslb-fe__service-choice-list,
.gslb-fe-theme-black-glass .gslb-fe__modal-body {
    scrollbar-color: rgba(110,140,195,.6) rgba(11,16,28,.3);
}
.gslb-fe-theme-super-glass .gslb-portal__hero,
.gslb-fe-theme-super-glass .gslb-customer-shell__hero {
    position: relative;
    overflow: hidden;
}
.gslb-fe-theme-super-glass .gslb-portal__hero::after,
.gslb-fe-theme-super-glass .gslb-customer-shell__hero::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 14% 18%, rgba(255,255,255,.44), transparent 24%),
        linear-gradient(115deg, rgba(255,255,255,.16), transparent 46%);
}
.gslb-fe-theme-super-glass .gslb-portal__hero h2,
.gslb-fe-theme-super-glass .gslb-customer-shell__hero h2,
.gslb-fe-theme-super-glass .gslb-customer-bookings__section h3,
.gslb-fe-theme-super-glass .gslb-customer-summary__card strong {
    color: #14202c;
    text-shadow: 0 1px 0 rgba(255,255,255,.34);
}
.gslb-fe-theme-super-glass .gslb-portal__hero p,
.gslb-fe-theme-super-glass .gslb-customer-shell__hero p,
.gslb-fe-theme-super-glass .gslb-customer-bookings__empty,
.gslb-fe-theme-super-glass .gslb-customer-booking-card__meta,
.gslb-fe-theme-super-glass .gslb-customer-summary__card span {
    color: rgba(30, 41, 59, .74);
}
.gslb-fe-theme-super-glass .gslb-portal__nav,
.gslb-fe-theme-super-glass .gslb-customer-shell__nav {
    gap: 10px;
}
.gslb-fe-theme-super-glass .gslb-portal__tab,
.gslb-fe-theme-super-glass .gslb-customer-shell__nav a,
.gslb-fe-theme-super-glass .gslb-customer-page-btn {
    background: linear-gradient(180deg, rgba(255,255,255,.52), rgba(255,255,255,.3));
    border-color: rgba(255,255,255,.58);
    color: #203041;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.56), 0 8px 18px rgba(112, 122, 138, .08);
}
.gslb-fe-theme-super-glass .gslb-portal__tab:hover,
.gslb-fe-theme-super-glass .gslb-customer-shell__nav a:hover,
.gslb-fe-theme-super-glass .gslb-customer-page-btn:hover {
    border-color: rgba(255,255,255,.78);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.62), 0 12px 24px rgba(112, 122, 138, .12);
}
.gslb-fe-theme-super-glass .gslb-portal__tab.is-active,
.gslb-fe-theme-super-glass .gslb-customer-page-btn.is-active {
    background: linear-gradient(135deg, rgba(185,195,208,.98), rgba(157,168,184,.98));
    border-color: rgba(255,255,255,.8);
    color: #14202c;
    box-shadow: 0 14px 28px rgba(112, 122, 138, .18);
}
.gslb-fe-theme-super-glass .gslb-customer-booking-card__status,
.gslb-fe-theme-super-glass .gslb-noshow-avviso--portal {
    background: linear-gradient(180deg, rgba(255,255,255,.5), rgba(255,255,255,.28));
    border-color: rgba(255,255,255,.52);
}
.gslb-fe-theme-super-glass .gslb-noshow-avviso--portal {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.54), 0 16px 36px rgba(143,47,43,.08);
}
.gslb-fe-theme-super-glass .gslb-fe__modal-backdrop {
    background: linear-gradient(180deg, rgba(213,221,229,.46), rgba(188,198,209,.42));
}
.gslb-fe-theme-super-glass .gslb-fe__modal,
.gslb-fe-theme-super-glass .gslb-fe__service-choice,
.gslb-fe-theme-super-glass .gslb-fe__service-edit-row {
    color: #1b2633;
}
.gslb-fe-theme-super-glass .gslb-fe__add-svc-grid,
.gslb-fe-theme-super-glass .gslb-fe__service-choice-list,
.gslb-fe-theme-super-glass .gslb-fe__modal-body {
    scrollbar-color: rgba(148,163,184,.65) rgba(255,255,255,.18);
}
.gslb-noshow-avviso--portal {
    display: block;
    width: 100%;
    max-width: 960px;
    margin: 0 auto 20px;
}
.gslb-portal .gslb-fe {
    max-width: none;
    margin: 0;
    width: 100%;
}
.gslb-customer-shell {
    display: grid;
    gap: 18px;
    max-width: 860px;
    margin: 0 auto;
}
.gslb-customer-shell__hero {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 20px 22px;
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 16px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--fe-accent) 12%, var(--fe-surface,#fff)) 0%, var(--fe-surface,#fff) 100%);
}
.gslb-customer-shell__eyebrow {
    display: inline-block;
    margin-bottom: 8px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--fe-accent,#5c6bc0);
}
.gslb-customer-shell__hero h2 {
    margin: 0 0 6px;
    font-size: 28px;
    line-height: 1.05;
    color: var(--fe-text,#111827);
}
.gslb-customer-shell__hero p {
    color: var(--fe-sub,#6b7280);
    max-width: 520px;
}
.gslb-customer-shell__nav {
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: flex-end;
    gap: 8px;
    min-width: 220px;
}
.gslb-customer-shell__nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--fe-border,#e5e7eb);
    background: color-mix(in srgb, var(--fe-surface2,#f9fafb) 82%, transparent);
    color: var(--fe-text,#111827);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
}
.gslb-customer-notice {
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid var(--fe-border,#e5e7eb);
    background: var(--fe-surface,#fff);
    font-size: 14px;
}
.gslb-customer-notice--success {
    background: #edf8f0;
    border-color: #b7e0c1;
    color: #1f6b38;
}
.gslb-customer-notice--error {
    background: #fdecea;
    border-color: #f4c1bc;
    color: #b3261e;
}
.gslb-customer-bookings {
    display: grid;
    gap: 18px;
}
.gslb-customer-bookings__section {
    background: var(--fe-surface,#fff);
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 12px;
    padding: 18px;
}
.gslb-customer-bookings__section--primary {
    border-color: color-mix(in srgb, var(--fe-accent,#5b6bd5) 16%, var(--fe-border,#e5e7eb));
    box-shadow: 0 12px 28px rgba(17,24,39,.04);
}
.gslb-customer-bookings__section h3 {
    font-size: var(--gslb-portal-font-section);
    margin: 0 0 14px;
    color: var(--fe-text,#111827);
}
.gslb-customer-bookings__title-main {
    font-size: calc(var(--gslb-portal-font-section) + 2px) !important;
    font-weight: 800;
    letter-spacing: -.01em;
}
.gslb-customer-bookings__empty {
    color: var(--fe-sub,#6b7280);
    font-size: var(--gslb-portal-font-body);
}
.gslb-customer-disclosure {
    padding: 0;
    overflow: hidden;
}
.gslb-customer-disclosure__summary {
    list-style: none;
    cursor: pointer;
    padding: 18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    font-size: var(--gslb-portal-font-body);
    font-weight: 600;
    color: var(--fe-text,#111827);
}
.gslb-customer-disclosure__summary::-webkit-details-marker { display:none; }
.gslb-customer-disclosure__toggle {
    width: 28px;
    height: 28px;
    margin-left: auto;
    border-radius: 999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 10%, #fff);
    border: 1px solid color-mix(in srgb, var(--fe-accent,#5b6bd5) 18%, #dfe3eb);
    color: var(--fe-accent,#5b6bd5);
    flex: 0 0 auto;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    position: relative;
    color: transparent;
}
.gslb-customer-disclosure__toggle::before {
    content:'+';
    position:absolute;
    inset:0;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color: var(--fe-accent,#5b6bd5);
}
.gslb-customer-disclosure[open] .gslb-customer-disclosure__toggle::before { content:'−'; }
.gslb-customer-disclosure__badge {
    order: 1;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width: 34px;
    height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--fe-surface2,#f9fafb);
    border: 1px solid var(--fe-border,#e5e7eb);
    font-size: var(--gslb-portal-font-meta);
    font-weight: 800;
    color: var(--fe-text,#111827);
}
.gslb-customer-disclosure__badge--warning {
    color:#b42318;
    border-color:color-mix(in srgb, #c62828 22%, var(--fe-border,#e5e7eb));
}
.gslb-customer-disclosure__body {
    padding: 0 18px 18px;
    border-top: 1px solid var(--fe-border,#e5e7eb);
}
.gslb-customer-bookings__cta {
    display: flex;
    justify-content: center;
    margin-top: 18px;
}
.gslb-customer-bookings__cta .gslb-fe__btn {
    min-width: 220px;
}
.gslb-customer-rewards-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
.gslb-customer-rewards-header h3 {
    margin: 0;
}
.gslb-customer-rewards-nav {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.gslb-customer-rewards-nav__btn {
    appearance: none;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    border: 1px solid var(--fe-border,#e5e7eb);
    background: var(--fe-surface,#fff);
    color: var(--fe-text,#111827);
    font-size: 18px;
    font-weight: 800;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, opacity .16s ease, box-shadow .16s ease;
}
.gslb-customer-rewards-nav__btn:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--fe-accent,#5b6bd5) 30%, var(--fe-border,#e5e7eb));
    box-shadow: 0 10px 18px rgba(17,24,39,.06);
}
.gslb-customer-rewards-nav__btn[disabled] {
    opacity: .4;
    cursor: default;
    transform: none;
    box-shadow: none;
}
.gslb-customer-rewards-rail {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(320px, 360px);
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px 2px 8px;
    scroll-snap-type: x proximity;
    overscroll-behavior-x: contain;
}
.gslb-customer-rewards-rail::-webkit-scrollbar {
    height: 10px;
}
.gslb-customer-rewards-rail::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 34%, #d7dce5);
    border-radius: 999px;
}
.gslb-customer-reward-card {
    min-height: 100%;
    margin-bottom: 0;
    scroll-snap-align: start;
}
.gslb-customer-reward-card__inner {
    flex-direction: column;
    align-items: stretch !important;
    gap: 16px;
}
.gslb-customer-reward-card__meta {
    min-width: 0;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.gslb-customer-reward-card__form {
    width: 100%;
    min-width: 0;
}
.gslb-customer-reward-card__requested-slot {
    min-height: 38px;
    display: flex;
    align-items: flex-start;
    margin-top: 10px;
}
.gslb-customer-reward-card__requested-slot--below {
    min-height: 32px;
    margin-top: 10px;
}
.gslb-customer-reward-card__requested {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 10%, #fff);
    border: 1px solid color-mix(in srgb, var(--fe-accent,#5b6bd5) 18%, #dfe3eb);
    color: var(--fe-accent,#5b6bd5);
    font-size: 12px;
    font-weight: 700;
}
.gslb-reward-request-feedback {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 13px;
    line-height: 1.45;
}
.gslb-reward-request-feedback.is-success {
    background: color-mix(in srgb, #22a06b 12%, #fff);
    border: 1px solid color-mix(in srgb, #22a06b 22%, #dfe7e3);
    color: #15754a;
}
.gslb-reward-request-feedback.is-error {
    background: color-mix(in srgb, #d64848 10%, #fff);
    border: 1px solid color-mix(in srgb, #d64848 20%, #e8d8d8);
    color: #a22e2e;
}
.gslb-fidelity-regulation {
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 14px;
    background: var(--fe-surface,#fff);
    overflow: hidden;
}
.gslb-fidelity-regulation__summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 18px;
    font-weight: 700;
    font-size: 14px;
    color: var(--fe-text,#1f2937);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.gslb-fidelity-regulation__summary::-webkit-details-marker { display: none; }
.gslb-fidelity-regulation__summary::after {
    content: '+';
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 10%, #fff);
    border: 1px solid color-mix(in srgb, var(--fe-accent,#5b6bd5) 18%, #dfe3eb);
    color: var(--fe-accent,#5b6bd5);
    flex: 0 0 auto;
}
.gslb-fidelity-regulation[open] .gslb-fidelity-regulation__summary::after {
    content: '−';
}
.gslb-fidelity-regulation__body {
    border-top: 1px solid var(--fe-border,#e5e7eb);
    padding: 18px;
}
.gslb-fidelity-regulation__body h4 {
    margin: 0 0 12px;
    font-size: 16px;
    color: var(--fe-text,#1f2937);
}
.gslb-fidelity-regulation__body p {
    margin: 0 0 10px;
    color: var(--fe-sub,#6b7280);
    line-height: 1.65;
}
.gslb-fidelity-regulation__body p:last-of-type {
    margin-bottom: 0;
}
.gslb-fidelity-regulation__table-wrap {
    margin-top: 16px;
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    background: var(--fe-surface2,#f9fafb);
}
.gslb-fidelity-regulation__table {
    width: 100%;
    border-collapse: collapse;
}
.gslb-fidelity-regulation__table th,
.gslb-fidelity-regulation__table td {
    padding: 12px 14px;
    text-align: left;
    border-bottom: 1px solid var(--fe-border,#e5e7eb);
    vertical-align: top;
}
.gslb-fidelity-regulation__table th {
    background: color-mix(in srgb, var(--fe-accent,#5b6bd5) 7%, #fff);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--fe-sub,#6b7280);
}
.gslb-fidelity-regulation__table td:last-child,
.gslb-fidelity-regulation__table th:last-child {
    width: 92px;
    white-space: nowrap;
    font-weight: 700;
}
.gslb-fidelity-regulation__table tr:last-child td {
    border-bottom: none;
}
.gslb-customer-booking-card {
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 10px;
    padding: 14px;
    background: var(--fe-surface2,#f9fafb);
    margin-bottom: 10px;
}
.gslb-customer-booking-card:last-child { margin-bottom: 0; }
.gslb-customer-booking-card__top {
    display: flex;
    justify-content: space-between;
    gap: 16px;
}
.gslb-customer-booking-card__meta {
    color: var(--fe-sub,#6b7280);
    font-size: var(--gslb-portal-font-meta);
    margin-top: 4px;
}
.gslb-customer-booking-card__status {
    white-space: nowrap;
    align-self: flex-start;
    background: var(--fe-surface,#fff);
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 999px;
    padding: 6px 10px;
    font-size: var(--gslb-portal-font-status);
    font-weight: 700;
}
.gslb-customer-booking-card__actions {
    margin-top: 12px;
}
.gslb-portal--font-medium .gslb-customer-booking-card strong,
.gslb-portal--font-medium .gslb-payment-notice strong {
    font-size: 16px;
}
.gslb-portal--font-large .gslb-customer-booking-card strong,
.gslb-portal--font-large .gslb-payment-notice strong {
    font-size: 17px;
}
.gslb-portal--font-medium .gslb-customer-booking-card__actions .gslb-fe__btn,
.gslb-portal--font-medium .gslb-customer-booking-card__actions .gslb-calendar-btn {
    font-size: 13px !important;
}
.gslb-portal--font-large .gslb-customer-booking-card__actions .gslb-fe__btn,
.gslb-portal--font-large .gslb-customer-booking-card__actions .gslb-calendar-btn {
    font-size: 14px !important;
}
.gslb-customer-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}
.gslb-customer-page-btn {
    min-width: 40px;
    height: 40px;
    border-radius: 999px;
    border: 1px solid var(--fe-border,#e5e7eb);
    background: var(--fe-surface,#fff);
    color: var(--fe-text,#111827);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: all .18s ease;
}
.gslb-customer-page-btn:hover {
    border-color: var(--fe-accent,#5b6bd5);
    color: var(--fe-accent,#5b6bd5);
}
.gslb-customer-page-btn.is-active {
    background: var(--fe-accent,#5b6bd5);
    border-color: var(--fe-accent,#5b6bd5);
    color: #fff;
    box-shadow: 0 10px 22px rgba(91,107,213,.22);
}
.gslb-customer-profile__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 6px;
}
.gslb-fe-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 14px;
    margin: 0 0 10px;
    border: 1px solid var(--fe-border,#e5e7eb);
    border-radius: 16px;
    background: rgba(255,255,255,.68);
}
.gslb-fe-toggle-row > span:first-child {
    min-width: 0;
    padding-right: 12px;
}
.gslb-fe-toggle-row strong {
    display: block;
    color: var(--fe-text,#111827);
    font-size: 14px;
}
.gslb-fe-toggle-row small {
    display: block;
    margin-top: 3px;
    color: var(--fe-sub,#6b7280);
    font-size: 12px;
    line-height: 1.35;
}
.gslb-fe-toggle {
    position: relative;
    flex: 0 0 68px;
    display: inline-flex;
    width: 68px;
    height: 38px;
}
.gslb-fe-toggle input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}
.gslb-fe-toggle span {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    background: #d6dde8;
    box-shadow: inset 0 0 0 1px rgba(15,23,42,.08);
    transition: background .18s ease, box-shadow .18s ease;
}
.gslb-fe-toggle span::after {
    content: "";
    position: absolute;
    top: 5px;
    left: 5px;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 4px 12px rgba(15,23,42,.2);
    transition: transform .18s ease;
}
.gslb-fe-toggle input:checked + span {
    background: var(--fe-accent,#8d9ab7);
    box-shadow: inset 0 0 0 1px rgba(15,23,42,.05), 0 8px 18px rgba(141,154,183,.24);
}
.gslb-fe-toggle input:checked + span::after {
    transform: translateX(30px);
}
.gslb-fe-toggle input:disabled + span {
    opacity: .55;
}
.gslb-fe-toggle-status {
    min-height: 18px;
    margin: -4px 0 10px 2px;
    color: var(--fe-sub,#6b7280);
    font-size: 12px;
}
@media (max-width: 640px) {
    .gslb-portal {
        max-width: 100%;
    }
    .gslb-portal__hero {
        flex-direction: column;
        gap: 16px;
        padding: 18px 16px;
    }
    .gslb-portal__nav {
        justify-content: flex-start;
        min-width: 0;
        width: 100%;
    }
    .gslb-portal__tab {
        flex: 1 1 calc(50% - 8px);
        min-width: 0;
        padding: 0 12px;
    }
    .gslb-portal__hero h2 { font-size: 24px; }
    .gslb-customer-shell__hero { flex-direction: column; }
    .gslb-customer-shell__nav { justify-content: flex-start; min-width: 0; }
    .gslb-customer-rewards-rail {
        grid-auto-columns: minmax(86vw, 86vw);
        gap: 12px;
        padding-bottom: 10px;
    }
    .gslb-customer-rewards-header {
        align-items: flex-start;
    }
    .gslb-customer-rewards-nav__btn {
        width: 34px;
        height: 34px;
        font-size: 16px;
    }
    .gslb-customer-booking-card__top { flex-direction: column; }
    .gslb-customer-booking-card__status { align-self: flex-start; }
}

@media (max-width: 640px) {
    .gslb-fe {
        border-radius: 16px;
    }
    .gslb-fe__header {
        padding: 18px 16px 16px;
    }
    .gslb-fe__body {
        padding: 18px 16px;
    }
    .gslb-fe__push-banner {
        grid-template-columns: 1fr;
        gap: 9px;
        padding: 12px 42px 12px 14px;
    }
    .gslb-fe__push-banner:not(.gslb-fe__push-banner--floating):not(.gslb-fe__push-banner--inline) {
        margin: 14px 16px 0;
    }
    .gslb-fe__push-banner--floating {
        width: min(420px, calc(100vw - 24px));
        bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
        margin: 0;
    }
    .gslb-fe__push-banner-actions {
        justify-content: flex-start;
        flex-wrap: nowrap;
        gap: 8px;
    }
    .gslb-fe__push-banner-actions .gslb-fe__btn {
        width: auto;
        min-height: 36px;
        padding: 8px 14px;
        font-size: 13px;
    }
    .gslb-fe__push-banner-actions .gslb-fe__push-banner-hide {
        width: auto;
        padding: 0;
        min-height: 0;
        font-size: 12px;
        white-space: nowrap;
    }
    .gslb-fe__push-banner-copy span {
        display: none;
    }
    .gslb-fe__title {
        font-size: var(--gslb-fe-font-title);
        margin-bottom: 16px;
    }
    .gslb-fe__steps {
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        align-items: start;
        gap: 6px;
        overflow: hidden;
        padding-bottom: 0;
        scrollbar-width: none;
    }
    .gslb-fe__steps::-webkit-scrollbar {
        display: none;
    }
    .gslb-fe__step {
        min-width: 0;
        width: 100%;
        gap: 6px;
    }
    .gslb-fe__step span {
        width: 28px;
        height: 28px;
        font-size: var(--gslb-fe-font-step);
    }
    .gslb-fe__step small {
        white-space: normal;
        text-align: center;
        line-height: 1.2;
        max-width: none;
        font-size: var(--gslb-fe-font-step-label);
        word-break: break-word;
    }
    .gslb-fe__step-line {
        display: none;
    }
    .gslb-fe__panel-footer {
        flex-direction: column-reverse;
    }
    .gslb-fe__btn {
        width: 100%;
        justify-content: center;
    }
    .gslb-fe__slot {
        flex: 1 1 calc(50% - 8px);
        text-align: center;
    }
}

@media (max-width: 420px) {
    .gslb-fe__header {
        padding: 16px 14px 14px;
    }
    .gslb-fe__body {
        padding: 16px 14px;
    }
    .gslb-fe__panel-title {
        font-size: var(--gslb-fe-font-panel-title);
    }
    .gslb-fe__steps {
        gap: 4px;
    }
    .gslb-fe__step span {
        width: 26px;
        height: 26px;
        font-size: var(--gslb-fe-font-step);
    }
    .gslb-fe__step small {
        font-size: var(--gslb-fe-font-step-label);
        letter-spacing: 0;
    }
    .gslb-fe__step-line {
        display: none;
    }
    .gslb-fe__selection-feasibility-hint {
        min-height: 82px;
        padding: 12px;
    }
    .gslb-fe__slot {
        flex-basis: 100%;
    }
}



/* ============================================================
   ZIP 6 — Step 0: Auth (Ospite / Login / Registra)
   ============================================================ */
.gslb-fe__auth-wrap {
    padding: 4px 0 8px;
}
.gslb-fe__auth-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--fe-border);
    margin-bottom: 20px;
}
.gslb-fe__auth-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    padding: 10px 18px;
    font-size: 13px;
    font-weight: 600;
    color: var(--fe-sub);
    cursor: pointer;
    transition: color .2s, border-color .2s;
}
.gslb-fe__auth-tab:hover { color: var(--fe-accent); }
.gslb-fe__auth-tab.active {
    color: var(--fe-accent);
    border-bottom-color: var(--fe-accent);
}
.gslb-fe__auth-panel {
    display: none;
}
.gslb-fe__auth-panel.active {
    display: block;
    animation: gslb-fade .2s ease;
}
.gslb-fe__auth-desc {
    font-size: 13px;
    color: var(--fe-sub);
    margin: 0 0 16px;
}
.gslb-fe__auth-links {
    display: flex;
    justify-content: flex-start;
    margin: 2px 0 12px;
}
.gslb-fe__auth-link {
    appearance: none;
    border: 1px solid color-mix(in srgb, var(--fe-accent) 22%, var(--fe-border));
    background: color-mix(in srgb, var(--fe-accent) 8%, var(--fe-surface2));
    color: var(--fe-text);
    border-radius: 999px;
    padding: 9px 14px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.gslb-fe__auth-link:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--fe-accent) 46%, var(--fe-border));
    box-shadow: 0 8px 18px rgba(15,23,42,.08);
}
.gslb-fe__auth-link[aria-expanded="true"] {
    background: color-mix(in srgb, var(--fe-accent) 12%, var(--fe-surface2));
    border-color: color-mix(in srgb, var(--fe-accent) 38%, var(--fe-border));
}
.gslb-fe__auth-reset {
    margin: 0 0 14px;
    padding: 14px;
    border: 1px solid var(--fe-border);
    border-radius: calc(var(--fe-radius-sm) + 2px);
    background: color-mix(in srgb, var(--fe-surface2) 54%, transparent);
}
.gslb-fe__auth-reset[hidden] {
    display: none !important;
}
.gslb-fe__auth-reset-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 10px;
}
.gslb-fe__auth-reset-actions .gslb-fe__btn {
    flex: 1 1 220px;
}
.gslb-fe__auth-reset-msg {
    margin: 0 0 14px;
    padding: 10px 12px;
    border-radius: var(--fe-radius-sm);
    font-size: 13px;
    line-height: 1.45;
}
.gslb-fe__auth-reset-msg.is-success {
    background: #eef9f0;
    border: 1px solid #84c98a;
    color: #246632;
}
.gslb-fe__auth-reset-msg.is-error {
    background: #fdecea;
    border: 1px solid #f19992;
    color: #b52a1d;
}
.gslb-fe__auth-continue {
    font-size: 15px;
    padding: 12px 20px;
}

/* FRONTEND MODAL */
.gslb-fe__modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: color-mix(in srgb, var(--fe-bg) 54%, rgba(0, 0, 0, .42));
    backdrop-filter: blur(12px);
}
.gslb-fe__modal-backdrop[hidden] {
    display: none !important;
}
body.gslb-fe__body-locked {
    overflow: hidden;
}
.gslb-fe__modal {
    width: min(520px, calc(100vw - 32px));
    max-height: min(88vh, 820px);
    background: color-mix(in srgb, var(--fe-surface) 88%, transparent);
    border: 1px solid color-mix(in srgb, var(--fe-border) 76%, rgba(255,255,255,.18));
    border-radius: calc(var(--fe-radius) + 2px);
    box-shadow: 0 22px 60px rgba(0,0,0,.28);
    overflow: hidden;
}
.gslb-fe__modal--wide {
    width: min(680px, calc(100vw - 32px));
}
.gslb-fe__modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px 14px;
    border-bottom: 1px solid color-mix(in srgb, var(--fe-border) 70%, transparent);
    background: linear-gradient(180deg, color-mix(in srgb, var(--fe-surface2) 82%, transparent), color-mix(in srgb, var(--fe-surface) 92%, transparent));
}
.gslb-fe__modal-head h3 {
    font-size: 20px;
    line-height: 1.2;
    color: var(--fe-text);
    font-weight: 800;
}
.gslb-fe__modal-close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--fe-border);
    background: color-mix(in srgb, var(--fe-surface2) 80%, transparent);
    color: var(--fe-sub);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}
.gslb-fe__modal-body {
    padding: 18px 20px 10px;
    color: var(--fe-text);
    font-size: 15px;
    line-height: 1.65;
    max-height: min(60vh, 560px);
    overflow-y: auto;
    overscroll-behavior: contain;
}
.gslb-fe__modal-body p + p {
    margin-top: 10px;
}
.gslb-fe__modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 0 20px 20px;
}
.gslb-fe__modal-list {
    margin: 12px 0;
    padding-left: 20px;
    color: var(--fe-text);
}
.gslb-fe__modal-list li + li {
    margin-top: 6px;
}
.gslb-fe__modal-note {
    color: var(--fe-sub);
    font-size: 14px;
}
.gslb-fe-theme-glass .gslb-fe__install-help .gslb-fe__modal,
.gslb-fe-theme-super-glass .gslb-fe__install-help .gslb-fe__modal,
.gslb-fe__install-help.gslb-fe-theme-glass .gslb-fe__modal,
.gslb-fe__install-help.gslb-fe-theme-super-glass .gslb-fe__modal {
    background: rgba(255, 255, 255, .96);
    border-color: rgba(71, 85, 105, .28);
    color: #101923;
    box-shadow: 0 28px 78px rgba(15, 23, 42, .26);
}
.gslb-fe-theme-glass .gslb-fe__install-help h3,
.gslb-fe-theme-super-glass .gslb-fe__install-help h3,
.gslb-fe-theme-glass .gslb-fe__install-help .gslb-fe__modal-list,
.gslb-fe-theme-super-glass .gslb-fe__install-help .gslb-fe__modal-list,
.gslb-fe__install-help.gslb-fe-theme-glass h3,
.gslb-fe__install-help.gslb-fe-theme-super-glass h3,
.gslb-fe__install-help.gslb-fe-theme-glass .gslb-fe__modal-list,
.gslb-fe__install-help.gslb-fe-theme-super-glass .gslb-fe__modal-list {
    color: #101923;
}
.gslb-fe-theme-glass .gslb-fe__install-help .gslb-fe__modal-note,
.gslb-fe-theme-super-glass .gslb-fe__install-help .gslb-fe__modal-note,
.gslb-fe-theme-glass .gslb-fe__install-help p,
.gslb-fe-theme-super-glass .gslb-fe__install-help p,
.gslb-fe__install-help.gslb-fe-theme-glass .gslb-fe__modal-note,
.gslb-fe__install-help.gslb-fe-theme-super-glass .gslb-fe__modal-note,
.gslb-fe__install-help.gslb-fe-theme-glass p,
.gslb-fe__install-help.gslb-fe-theme-super-glass p {
    color: #243244;
}
.gslb-fe__service-choice-list {
    display: grid;
    gap: 10px;
    margin-top: 14px;
    max-height: min(46vh, 360px);
    overflow-y: auto;
    padding-right: 4px;
}
.gslb-fe__service-choice-list--actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.gslb-fe__service-choice {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border: 1px solid var(--fe-border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--fe-surface) 88%, transparent);
}
.gslb-fe__service-choice--button {
    appearance: none;
    cursor: pointer;
    text-align: left;
    font: inherit;
}
.gslb-fe__service-choice--button:hover {
    border-color: var(--fe-accent);
    background: var(--fe-surface2);
}
.gslb-fe__service-choice small {
    display: inline-block;
    margin-left: 6px;
    color: var(--fe-sub);
}
.gslb-fe__service-edit-msg {
    min-height: 18px;
    margin-top: 12px;
}
.gslb-fe__service-edit-rows {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 14px;
}
.gslb-fe__service-edit-row {
    padding: 14px;
    border: 1px solid var(--fe-border);
    border-radius: 16px;
    background: color-mix(in srgb, var(--fe-surface) 88%, transparent);
}
.gslb-fe__service-edit-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
@media (max-width: 720px) {
    .gslb-fe__service-edit-grid {
        grid-template-columns: 1fr;
    }
}
.gslb-fe__service-edit-toolbar {
    display: flex;
    justify-content: flex-start;
    margin-top: 14px;
}
.gslb-fe__service-edit-row-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 10px;
}
.gslb-fe__service-preview-recap {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}
.gslb-fe__service-edit-filters {
    display: grid;
    gap: 8px;
    margin-bottom: 10px;
}
.gslb-fe__add-svc-browser {
    display: grid;
    gap: 12px;
    padding: 4px 2px 2px;
}
.gslb-fe__add-svc-search {
    margin-bottom: 2px;
}
.gslb-fe__add-svc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 10px;
    max-height: min(46vh, 360px);
    overflow-y: auto;
    padding: 2px;
    overscroll-behavior: contain;
    align-items: start;
}
.gslb-fe__add-svc-card {
    border: 1.5px solid var(--svc-border, var(--fe-border));
    border-radius: 18px;
    padding: 14px 14px 13px;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--svc-accent, var(--fe-accent)) 12%, transparent), transparent 42%),
        linear-gradient(180deg, color-mix(in srgb, var(--fe-surface) 92%, #fff), color-mix(in srgb, var(--fe-surface) 98%, #fff));
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-height: 96px;
    height: auto;
    align-self: start;
    overflow: hidden;
    box-shadow: 0 8px 22px rgba(19, 24, 41, .06);
}
.gslb-fe__add-svc-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(19, 24, 41, .1);
}
.gslb-fe__add-svc-card.selected {
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--svc-accent, var(--fe-accent)) 16%, transparent), transparent 38%),
        linear-gradient(180deg, color-mix(in srgb, var(--fe-accent) 9%, #fff), color-mix(in srgb, var(--fe-surface) 96%, #fff));
}
.gslb-fe__add-svc-card-head {
    display: flex;
    align-items: center;
    gap: 7px;
}
.gslb-fe__add-svc-card-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--svc-accent, var(--fe-accent));
    flex-shrink: 0;
}
.gslb-fe__add-svc-card-title {
    font-weight: 700;
    font-size: 13px;
    line-height: 1.35;
}
.gslb-fe__add-svc-card-check {
    margin-left: auto;
    color: var(--fe-accent);
    font-size: 15px;
    font-weight: 800;
}
.gslb-fe__add-svc-card-subtitle,
.gslb-fe__add-svc-card-meta {
    font-size: 11px;
    color: var(--fe-sub);
}
.gslb-fe__add-svc-card-desc {
    font-size: 12px;
    line-height: 1.45;
    color: var(--fe-text);
    opacity: .78;
    margin-bottom: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    word-break: break-word;
}
.gslb-fe__add-svc-card-desc.is-expanded {
    display: block;
    -webkit-line-clamp: unset;
    overflow: visible;
}
.gslb-fe__add-svc-card-more {
    appearance: none;
    border: 0;
    padding: 0;
    margin: 0 0 6px;
    background: transparent;
    color: var(--fe-accent);
    font-size: 11px;
    line-height: 1.35;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
}
.gslb-fe__service-edit-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.gslb-fe__cat-chip {
    border: 1.5px solid var(--fe-border);
    border-radius: 999px;
    padding: 6px 12px;
    background: var(--fe-surface);
    color: var(--fe-text);
    cursor: pointer;
    font-size: 12px;
    font-weight: 700;
}
.gslb-fe__cat-chip.active {
    background: var(--fe-accent);
    border-color: var(--fe-accent);
    color: #fff;
}
.gslb-fe__auth-input {
    width: 100%;
    box-sizing: border-box;
    background: var(--fe-surface);
    border: 1px solid var(--fe-border);
    border-radius: 6px;
    padding: 9px 12px;
    font-size: 14px;
    color: var(--fe-text);
    outline: none;
    transition: border-color .2s;
}
.gslb-fe__auth-input:focus { border-color: var(--fe-accent); }
.gslb-fe__service-edit-operator-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
}
.gslb-fe__service-edit-operator-copy {
    flex: 1;
    min-width: 0;
}
.gslb-fe__service-edit-operator-select {
    flex: 1.8;
    min-width: 500px;
    max-width: 680px;
    min-height: 48px;
    padding: 11px 16px;
    font-size: 14px;
    line-height: 1.2;
    border-radius: 10px;
    border: 1.5px solid var(--gslb-border,#e5e0da);
    white-space: nowrap;
}
.gslb-fe__service-edit-impact {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 12px;
    line-height: 1.45;
    border: 1px solid transparent;
}
.gslb-fe__service-edit-impact.is-info {
    background: color-mix(in srgb, var(--fe-accent) 8%, #fff);
    border-color: color-mix(in srgb, var(--fe-accent) 18%, transparent);
    color: var(--fe-text);
}
.gslb-fe__service-edit-impact.is-warning {
    background: color-mix(in srgb, #f59e0b 12%, #fff);
    border-color: color-mix(in srgb, #f59e0b 26%, transparent);
    color: #7a4b00;
}
.gslb-fe__service-edit-impact.is-error {
    background: color-mix(in srgb, #ef4444 10%, #fff);
    border-color: color-mix(in srgb, #ef4444 22%, transparent);
    color: #991b1b;
}
.gslb-fe__service-desc-modal-copy {
    white-space: pre-wrap;
    word-break: break-word;
    line-height: 1.55;
    color: var(--fe-text);
}
.gslb-fe__modal-subbackdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 18, 28, .34);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    z-index: 5;
    border-radius: inherit;
}
.gslb-fe__modal-subdialog {
    width: min(560px, 100%);
    max-height: min(70vh, 560px);
    overflow: auto;
    background: var(--fe-surface, #fff);
    border: 1px solid var(--fe-border, #e5e0da);
    border-radius: 20px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, .22);
}
.gslb-fe__field { margin-bottom: 12px; }

@media (max-width: 640px) {
    .gslb-fe__add-svc-grid {
        grid-template-columns: 1fr;
        max-height: min(50vh, 420px);
    }
    .gslb-fe__service-edit-operator-row {
        flex-direction: column;
        gap: 8px;
    }
    .gslb-fe__service-edit-operator-select {
        width: 100%;
        min-width: 0;
        max-width: none;
    }
    .gslb-fe__modal-subbackdrop {
        padding: 12px;
    }
}

/* ============================================================
   ZIP 6 — Calendario: giorni colorati
   ============================================================ */

/* Disponibile → riquadro verde */
.gslb-fe__cal-day.avail {
    background: rgba(46, 125, 50, 0.10);
    border: 1px solid rgba(46, 125, 50, 0.30);
    color: #1f6f35;
    font-weight: 700;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.45);
}
.gslb-fe__cal-day.avail:hover {
    background: rgba(46, 125, 50, 0.18);
}

/* Pieno → riquadro rosso, cliccabile per waiting list */
.gslb-fe__cal-day.full-day {
    background: rgba(180, 60, 60, 0.12) !important;
    color: #a33131 !important;
    border: 1px solid rgba(180, 60, 60, 0.25);
    cursor: pointer;
    font-weight: 700;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.45);
}
.gslb-fe__cal-day.full-day:hover {
    background: rgba(180, 60, 60, 0.22) !important;
}

.gslb-fe__cal-day.selected,
.gslb-fe__cal-day.avail.selected,
.gslb-fe__cal-day.full-day.selected {
    background: var(--fe-accent) !important;
    border-color: var(--fe-accent) !important;
    color: #fff !important;
    font-weight: 800;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--fe-accent) 24%, transparent), inset 0 0 0 1px rgba(255,255,255,.5);
}

/* Loading (durante il fetch disponibilità) */
.gslb-fe__cal-day.loading {
    opacity: .4;
    pointer-events: none;
}

/* ============================================================
   ZIP 6 — Popup giorno pieno
   ============================================================ */
.gslb-fe__full-popup {
    position: absolute;
    z-index: 100;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -10%);
    width: 240px;
    pointer-events: auto;
}
.gslb-fe__full-popup__inner {
    background: var(--fe-bg);
    border: 1px solid var(--fe-border);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,.25);
    text-align: center;
    position: relative;
}
.gslb-fe__full-popup__inner h4 {
    margin: 0 0 6px;
    font-size: 15px;
    color: var(--fe-text);
}
.gslb-fe__full-popup__inner p {
    margin: 0 0 4px;
    font-size: 13px;
    color: var(--fe-sub);
}
.gslb-fe__full-popup__close {
    position: absolute;
    top: 8px; right: 10px;
    background: none;
    border: none;
    font-size: 16px;
    color: var(--fe-sub);
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
}
.gslb-fe__full-popup__close:hover { background: var(--fe-surface); }

/* ============================================================
   ZIP 6 — Modale Avvisami (su body)
   ============================================================ */
.gslb-fe__notify-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0,0,0,.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    animation: gslb-fade .2s ease;
}
.gslb-fe__notify-modal__inner {
    background: var(--fe-bg, #fff);
    border-radius: 14px;
    padding: 24px;
    width: 100%;
    max-width: 400px;
    position: relative;
    box-shadow: 0 16px 48px rgba(0,0,0,.3);
    max-height: 90vh;
    overflow-y: auto;
}
.gslb-fe__notify-modal__inner h4 {
    margin: 0 0 4px;
    font-size: 16px;
}
.gslb-fe__notify-modal__close {
    position: absolute;
    top: 12px; right: 14px;
    background: none;
    border: none;
    font-size: 18px;
    color: var(--fe-sub, #888);
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
}
.gslb-fe__notify-modal__close:hover { background: rgba(0,0,0,.08); }

/* ============================================================
   ZIP 6 — Feedback "Avvisami" inline
   ============================================================ */
.gslb-fe__notify-feedback {
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 13px;
    margin-top: 10px;
    background: var(--fe-surface);
    color: var(--fe-sub);
    display: flex;
    align-items: center;
    gap: 6px;
}
.gslb-fe__notify-feedback.success {
    background: rgba(122, 184, 122, .15);
    color: #5a9e5a;
    border: 1px solid rgba(122,184,122,.3);
}
.gslb-fe__notify-feedback.error {
    background: rgba(200, 80, 80, .12);
    color: #c46060;
    border: 1px solid rgba(200,80,80,.2);
}

@keyframes gslb-fade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   NAVIGAZIONE CATEGORIE — step 1 frontend
   ============================================================ */
.gslb-fe__cat-nav {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--fe-border, rgba(255,255,255,.1));
}
.gslb-fe__cat-back {
    background: none;
    border: 1px solid var(--fe-border, rgba(255,255,255,.15));
    color: var(--fe-accent, #a78bfa);
    border-radius: 8px;
    padding: 6px 14px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    transition: background .15s;
}
.gslb-fe__cat-back:hover { background: var(--fe-surface1, rgba(255,255,255,.06)); }
.gslb-fe__cat-breadcrumb {
    font-size: 15px;
    font-weight: 700;
    color: var(--fe-text, #fff);
}
.gslb-fe__cat-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--fe-surface1, rgba(255,255,255,.05));
    border: 1px solid var(--fe-border, rgba(255,255,255,.08));
    border-radius: 12px;
    cursor: pointer;
    transition: border-color .15s, transform .1s;
    margin-bottom: 8px;
    user-select: none;
}
.gslb-fe__cat-card:hover {
    border-color: var(--fe-accent, #a78bfa);
    transform: translateY(-1px);
}
.gslb-fe__cat-color {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
}
.gslb-fe__cat-info { flex: 1; }
.gslb-fe__cat-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--fe-text, #fff);
}
.gslb-fe__cat-count {
    font-size: 12px;
    color: var(--fe-subtext, rgba(255,255,255,.5));
    margin-top: 2px;
}
.gslb-fe__cat-arrow {
    font-size: 20px;
    color: var(--fe-accent, #a78bfa);
    opacity: .7;
    font-weight: 300;
}
.gslb-fe__uncategorized {
    margin-top: 12px;
}

/* ============================================================
   ACCORDION CATEGORIE — step 1 frontend
   ============================================================ */
.gslb-fe__accordion {
    border: 1px solid var(--fe-border, rgba(255,255,255,.1));
    border-radius: 12px;
    margin-bottom: 8px;
    overflow: hidden;
    transition: border-color .2s;
}
.gslb-fe__accordion.open { border-color: var(--fe-accent, #a78bfa); }
.gslb-fe__accordion--sub { border-radius: 8px; margin: 4px 0 4px 8px; background: var(--fe-surface1,rgba(255,255,255,.03)); }

.gslb-fe__accordion-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 16px;
    cursor: pointer;
    user-select: none;
    transition: background .15s;
}
.gslb-fe__accordion-head:hover { background: var(--fe-surface1, rgba(255,255,255,.05)); }
.gslb-fe__accordion-head--sub { padding: 10px 14px; }

.gslb-fe__cat-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.gslb-fe__accordion-name {
    flex: 1;
    font-size: 15px;
    font-weight: 600;
    color: var(--fe-text, #fff);
}
.gslb-fe__accordion-head--sub .gslb-fe__accordion-name { font-size: 13px; }
.gslb-fe__accordion-arrow {
    font-size: 18px;
    color: var(--fe-accent, #a78bfa);
    transition: transform .2s;
    line-height: 1;
}
.gslb-fe__accordion.open > .gslb-fe__accordion-head .gslb-fe__accordion-arrow { transform: rotate(90deg); }

.gslb-fe__accordion-body {
    display: none;
    padding: 6px 10px 10px;
    border-top: 1px solid var(--fe-border, rgba(255,255,255,.07));
}
/* Card servizi dentro accordion: griglia responsive */
.gslb-fe__accordion-body .gslb-fe__svc-card {
    display: inline-block;
    width: calc(50% - 6px);
    margin: 4px 3px;
    vertical-align: top;
}
@media (max-width: 480px) {
  .gslb-fe__accordion-body .gslb-fe__svc-card { width: 100%; margin: 3px 0; }
}
.gslb-fe__accordion.open > .gslb-fe__accordion-body { display: block; }

/* ============================================================
   PAGINA CANCELLAZIONE [gslb_cancella]
   ============================================================ */
.gslb-cancel-page {
    max-width: 540px;
    margin: 40px auto;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 32px rgba(0,0,0,.10);
    padding: 40px 36px 36px;
    text-align: center;
    font-family: inherit;
}
.gslb-cancel-icon {
    font-size: 52px;
    line-height: 1;
    margin-bottom: 16px;
}
.gslb-cancel-page h2 {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 12px;
    color: #1a1a2e;
}
.gslb-cancel-page > p {
    color: #555;
    margin: 0 0 24px;
    font-size: 15px;
}
.gslb-cancel-recap {
    background: #faf7f4;
    border: 1px solid #e8e0d8;
    border-radius: 10px;
    text-align: left;
    margin-bottom: 28px;
    overflow: hidden;
}
.gslb-cancel-recap__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 13px 18px;
    border-bottom: 1px solid #e8e0d8;
    font-size: 14px;
    gap: 12px;
}
.gslb-cancel-recap__row:last-child { border-bottom: none; }
.gslb-cancel-recap__row span { color: #8a7a6a; }
.gslb-cancel-recap__row strong { color: #2d1f12; text-align: right; }

.gslb-cancel-notice {
    padding: 14px 18px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 20px;
}
.gslb-cancel-notice--error {
    background: #fdf0ef;
    color: #d4706b;
    border: 1px solid #f5c6c4;
}

.gslb-cancel-actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}
.gslb-cancel-btn {
    display: inline-block;
    padding: 13px 28px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all .15s;
    font-family: inherit;
}
.gslb-cancel-btn--ghost {
    background: #fff;
    color: #555;
    border-color: #ddd;
}
.gslb-cancel-btn--ghost:hover { background: #f5f5f5; }
.gslb-cancel-btn--danger {
    background: #d4706b;
    color: #fff;
    border-color: #d4706b;
}
.gslb-cancel-btn--danger:hover { background: #c0594e; }

.gslb-cancel-page--done .gslb-cancel-icon { font-size: 60px; }

/* ============================================================
   STEP 2 — OPERATORE PER SERVIZIO (multi-reparto)
   ============================================================ */
.gslb-fe__multidep-info {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: color-mix(in srgb, var(--fe-accent) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--fe-accent) 30%, transparent);
    border-radius: 8px;
    padding: 10px 14px;
    font-size: var(--gslb-fe-font-meta);
    color: var(--fe-text);
    margin-bottom: 16px;
    line-height: 1.5;
}
.gslb-fe__multidep-icon { flex-shrink: 0; font-size: 16px; }

.gslb-fe__svc-att-row {
    margin-bottom: 16px;
    border: 1px solid var(--fe-border);
    border-radius: 10px;
    overflow: hidden;
}
.gslb-fe__svc-att-label {
    background: color-mix(in srgb, var(--fe-accent) 10%, transparent);
    padding: 8px 14px;
    font-weight: 700;
    font-size: var(--gslb-fe-font-service-name);
    color: var(--fe-text);
    border-bottom: 1px solid var(--fe-border);
}
.gslb-fe__svc-att-picks {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 12px;
}
.gslb-fe__no-att {
    font-size: var(--gslb-fe-font-small);
    color: var(--fe-red, #d4706b);
    padding: 4px 0;
    margin: 0;
}

/* Card operatore formato piccolo */
.gslb-fe__att-card--sm {
    min-width: 132px;
    max-width: 190px;
    padding: 8px 10px;
    gap: 4px;
}
.gslb-fe__att-avatar--sm {
    width: 32px;
    height: 32px;
    font-size: var(--gslb-fe-font-small);
}
.gslb-fe__att-card--sm .gslb-fe__att-name {
    font-size: var(--gslb-fe-font-attendant);
    line-height:1.25;
    overflow-wrap:anywhere;
}

@media (max-width: 640px) {
    .gslb-fe__multidep-info {
        gap: 6px;
        padding: 8px 10px;
        margin-bottom: 12px;
        font-size: var(--gslb-fe-font-meta);
        line-height: 1.45;
    }
    .gslb-fe__multidep-icon {
        font-size: 14px;
        margin-top: 1px;
    }
    .gslb-fe__attendants-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .gslb-fe__svc-att-row {
        margin-bottom: 12px;
        border-radius: 12px;
    }
    .gslb-fe__svc-att-label {
        padding: 8px 12px;
        font-size: var(--gslb-fe-font-service-name);
        line-height: 1.3;
    }
    .gslb-fe__svc-att-picks {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 10px;
    }
    .gslb-fe__att-card,
    .gslb-fe__att-card--sm {
        width: 100%;
        min-width: 0;
        max-width: none;
        display: grid;
        grid-template-columns: auto 1fr;
        align-items: center;
        justify-items: start;
        gap: 10px;
        padding: 10px 12px;
        text-align: left;
    }
    .gslb-fe__att-card:hover,
    .gslb-fe__att-card--sm:hover {
        transform: none;
    }
    .gslb-fe__att-avatar {
        width: 36px;
        height: 36px;
        margin: 0;
        font-size: var(--gslb-fe-font-step);
    }
    .gslb-fe__att-avatar--sm {
        width: 34px;
        height: 34px;
        font-size: var(--gslb-fe-font-small);
    }
    .gslb-fe__att-name,
    .gslb-fe__att-card--sm .gslb-fe__att-name {
        font-size: var(--gslb-fe-font-attendant);
        line-height: 1.25;
    }
    .gslb-fe__att-any .gslb-fe__att-name {
        white-space: nowrap;
    }
    .gslb-fe__att-any .gslb-fe__att-name {
        justify-self: start;
        text-align: left;
    }
    .gslb-fe__att-any-desc {
        grid-column: 1 / -1;
        width: 100%;
        margin-top: 2px;
        text-align: center;
    }
}

.gslb-fe__split-hint {
    background: color-mix(in srgb, #e8a87c 12%, transparent);
    border: 1px solid color-mix(in srgb, #e8a87c 40%, transparent);
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 12px;
    color: var(--fe-text);
    line-height: 1.6;
    margin-top: 8px;
}

/* ============================================================
   BANNER PRIMA DISPONIBILITÀ
   ============================================================ */
.gslb-fe__first-avail-banner {
    background: color-mix(in srgb, var(--fe-accent) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--fe-accent) 35%, transparent);
    border-radius: 10px;
    padding: 12px 16px;
    margin-bottom: 16px;
    font-size: 13px;
}
.gslb-fe__first-avail-loading {
    opacity: .7;
    font-style: italic;
}
.gslb-fe__first-avail-banner {
    display: grid;
    gap: 14px;
}
.gslb-fe__first-avail-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
    padding: 4px 0;
}
.gslb-fe__first-avail-label strong {
    color: var(--fe-accent);
}
.gslb-fe__first-avail-btn {
    background: var(--fe-accent);
    color: #fff;
    border: none;
    border-radius: 7px;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity .15s;
    margin-top: 4px;
}
.gslb-fe__first-avail-btn:hover { opacity: .85; }
.gslb-fe__first-avail-btn--ghost {
    background: transparent;
    color: var(--fe-accent);
    border: 1px solid color-mix(in srgb, var(--fe-accent) 28%, transparent);
}
/* avail-pill legacy placeholder - definizione reale più in basso */
.gslb-fe__first-avail-content--none {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.gslb-fe__first-avail-content--split {
    align-items: flex-start;
}
.gslb-fe__first-avail-content--searching {
    align-items: stretch;
}
.gslb-fe__first-avail-search-copy,
.gslb-fe__first-avail-progress {
    width: 100%;
    min-width: 0;
}
.gslb-fe__split-list {
    margin: 6px 0 0;
    padding-left: 18px;
    width: 100%;
    display: grid;
    gap: 6px;
}
.gslb-fe__split-group-item {
    display: grid;
    gap: 4px;
}
.gslb-fe__split-list--grouped {
    margin: 0;
}
.gslb-fe__split-group-services {
    display: grid;
    gap: 2px;
}
.gslb-fe__split-service-line {
    line-height: 1.35;
}
.gslb-fe__split-group-meta {
    font-size: 13px;
    opacity: .82;
}
.gslb-fe__split-inline-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 100%;
}
.gslb-fe__split-inline-block .gslb-fe__avail-pills-header {
    width: 100%;
    max-width: 640px;
}
.gslb-fe__split-inline-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .7px;
    color: var(--fe-accent);
    margin-bottom: 4px;
}
.gslb-fe__split-inline-block .gslb-fe__split-summary,
.gslb-fe__selected-date-split .gslb-fe__split-summary {
    width: 100%;
    max-width: 640px;
    margin: 6px auto 0 auto;
    padding: 14px 16px !important;
    border-radius: 14px;
    background: var(--fe-surface) !important;
    border: 1.5px solid color-mix(in srgb, var(--fe-accent) 25%, transparent) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    box-shadow: 0 2px 10px color-mix(in srgb, var(--fe-accent) 8%, transparent);
}
.gslb-fe__split-summary__row,
.gslb-fe__slot-summary__row {
    display: grid !important;
    grid-template-columns: 28px 72px minmax(0,1fr) max-content !important;
    grid-template-areas: "avatar time service attendant" !important;
    align-items: center !important;
    column-gap: 14px !important;
    row-gap: 2px !important;
    text-align: left;
    font-size: 13px;
    line-height: 1.3;
    padding: 6px 0;
    width: 100%;
}
.gslb-fe__split-summary__row .gslb-fe__att-avatar--sm,
.gslb-fe__slot-summary__row .gslb-fe__att-avatar--sm {
    width: 28px !important;
    height: 28px !important;
    font-size: 11px !important;
    flex-shrink: 0;
    margin: 0 !important;
    grid-area: avatar;
}
.gslb-fe__split-summary__time-wrap {
    grid-area: time;
    display: flex !important;
    flex-direction: column !important;
    gap: 1px !important;
    min-width: 0;
}
.gslb-fe__slot-summary__time-wrap {
    grid-area: time;
    display: flex !important;
    flex-direction: column !important;
    gap: 1px !important;
    min-width: 0;
}
.gslb-fe__split-summary__meta {
    color: var(--fe-sub);
    font-size: 11px;
    white-space: nowrap;
    display: block !important;
}
.gslb-fe__slot-summary__meta {
    color: var(--fe-sub);
    font-size: 11px;
    white-space: nowrap;
    display: block !important;
}
.gslb-fe__split-summary__time {
    font-weight: 700;
    color: color-mix(in srgb, var(--fe-text) 78%, white 22%);
    font-size: 12px;
    letter-spacing: .2px;
    white-space: nowrap;
    display: block !important;
}
.gslb-fe__split-summary__svc,
.gslb-fe__slot-summary__svc {
    grid-area: service;
    min-width: 0;
    font-weight: 600;
    color: var(--fe-text);
    white-space: normal;
    word-break: break-word;
    line-height: 1.35;
}
.gslb-fe__split-summary__att {
    grid-area: attendant;
    color: color-mix(in srgb, var(--fe-sub) 88%, white 12%);
    font-weight: 600;
    font-size: 13px;
    white-space: nowrap;
    line-height: 1.35;
    text-align: right;
    display: block !important;
    padding-left: 4px;
}
.gslb-fe__split-inline-block .gslb-fe__split-list {
    width: 100%;
    max-width: 720px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center;
    list-style: none;
    padding-left: 0;
    padding-right: 0;
    margin-top: 6px;
    margin-left: auto !important;
    margin-right: auto !important;
}
.gslb-fe__split-inline-block .gslb-fe__split-apply-btn {
    display: inline-flex;
    align-self: center;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
}
.gslb-fe__selected-date-split {
    width: 100%;
    max-width: 640px;
    margin: 14px auto 0 auto;
    padding: 14px 16px;
    border-radius: 14px;
    background: var(--fe-surface) !important;
    border: 1.5px solid color-mix(in srgb, var(--fe-accent) 25%, transparent) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    text-align: left !important;
    gap: 6px !important;
    box-shadow: 0 2px 10px color-mix(in srgb, var(--fe-accent) 8%, transparent);
}
.gslb-fe__selected-date-split__title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .7px;
    color: var(--fe-accent);
    margin-bottom: 4px;
    padding-bottom: 8px;
    border-bottom: 1px solid color-mix(in srgb, var(--fe-accent) 15%, transparent);
}
.gslb-fe__selected-date-split .gslb-fe__split-apply-btn {
    align-self: flex-start;
    margin: 4px 0 0;
}
.gslb-fe__split-inline-block .gslb-fe__split-list li {
    width: fit-content;
    max-width: 100%;
    text-align: center;
}
.gslb-fe__split-inline-block ul.gslb-fe__split-list {
    margin: 0 auto 8px auto !important;
}
.gslb-fe__split-list--together {
    margin-top: 10px;
}
.gslb-fe__first-avail-sub {
    font-size: 11px;
    opacity: .65;
}
@media (max-width: 640px) {
    .gslb-fe__split-inline-block .gslb-fe__split-summary,
    .gslb-fe__selected-date-split,
    .gslb-fe__selected-date-split .gslb-fe__split-summary,
    .gslb-fe__slot-summary {
        padding: 12px 13px;
    }
    .gslb-fe__split-summary__row {
        grid-template-columns: 24px 54px minmax(0,1fr) !important;
        grid-template-areas:
            "avatar time service"
            "avatar time attendant" !important;
        align-items: start !important;
        column-gap: 8px !important;
        row-gap: 2px !important;
    }
    .gslb-fe__slot-summary__row .gslb-fe__att-avatar--sm {
        display: none !important;
    }
    .gslb-fe__slot-summary__row {
        grid-template-columns: 56px minmax(0,1fr) !important;
        grid-template-areas:
            "time service"
            ". attendant" !important;
        align-items: start !important;
        column-gap: 10px !important;
        row-gap: 2px !important;
    }
    .gslb-fe__split-summary__row .gslb-fe__att-avatar--sm {
        display: flex !important;
        width: 24px !important;
        height: 24px !important;
        font-size: 10px !important;
        margin-top: 2px !important;
    }
    .gslb-fe__split-summary__time-wrap {
        gap: 0 !important;
    }
    .gslb-fe__split-summary__time {
        font-size: 11px;
    }
    .gslb-fe__split-summary__meta {
        display: block !important;
        font-size: 9px;
        line-height: 1.1;
        white-space: normal;
    }
    .gslb-fe__split-summary__svc,
    .gslb-fe__split-summary__att,
    .gslb-fe__slot-summary__svc,
    .gslb-fe__slot-summary__att {
        font-size: 13px;
        white-space: normal;
        word-break: break-word;
    }
    .gslb-fe__split-summary__att,
    .gslb-fe__slot-summary__att {
        font-size: 12px;
        text-align: left !important;
        opacity: .82;
    }
    .gslb-fe__selected-date-split .gslb-fe__split-apply-btn {
        align-self: stretch;
    }
}

/* ── Slot Reservation Banner ─────────────────────────────────────────────── */
.gslb-reservation-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, #f0faf4 0%, #e8f5e9 100%);
    border: 1.5px solid #4caf50;
    border-radius: var(--fe-radius-sm, 10px);
    padding: 10px 16px;
    margin-bottom: 16px;
    font-size: 14px;
    color: #2e7d32;
    font-weight: 500;
    animation: gslb-fadein .3s ease;
}
.gslb-reservation-bar__icon { font-size: 18px; flex-shrink: 0; }
.gslb-reservation-bar__text { flex: 1; }
.gslb-reservation-bar__countdown {
    font-size: 18px;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    letter-spacing: .5px;
    min-width: 46px;
    text-align: right;
}
.gslb-reservation-bar--urgent {
    background: linear-gradient(135deg, #fff8e1 0%, #fff3cd 100%);
    border-color: #ff9800;
    color: #e65100;
    animation: gslb-pulse-urgent 1s ease-in-out infinite;
}
@keyframes gslb-pulse-urgent {
    0%,100% { opacity: 1; }
    50%      { opacity: .75; }
}
@keyframes gslb-fadein {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.gslb-fe__suggested-addon-intro {
    font-size: 14px;
    color: var(--fe-sub);
    margin-bottom: 12px;
}
.gslb-fe__suggested-addon-list {
    display: grid;
    gap: 10px;
}
.gslb-fe__suggested-addon-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: flex-start;
    padding: 14px 16px;
    border: 1px solid var(--fe-border);
    border-radius: 16px;
    background: var(--fe-surface2);
    cursor: pointer;
}
.gslb-fe__suggested-addon-item input {
    margin-top: 4px;
    accent-color: var(--fe-accent);
}
.gslb-fe__suggested-addon-content {
    display: grid;
    gap: 4px;
}
.gslb-fe__suggested-addon-content strong {
    font-size: 15px;
    color: var(--fe-text);
}
.gslb-fe__suggested-addon-content span {
    font-size: 13px;
    color: var(--fe-sub);
    line-height: 1.45;
}
.gslb-fe__suggested-addon-content em {
    font-style: normal;
    font-size: 12px;
    color: var(--fe-sub);
    opacity: .88;
}

/* ── Pill disponibilità mattina/pomeriggio ──────────────────────────────── */
.gslb-fe__avail-pills-header {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .7px;
    color: var(--fe-sub, #888);
    margin-bottom: 6px;
}
.gslb-fe__avail-pills-sub {
    font-size: 12px;
    color: var(--fe-sub, #888);
    margin-top: 4px;
}
.gslb-fe__avail-pills-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.gslb-fe__avail-pill {
    display: inline-flex;
    align-items: stretch;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    padding: 12px 16px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--fe-accent) 22%, transparent);
    background: linear-gradient(180deg, color-mix(in srgb, var(--fe-accent) 94%, #ffffff 6%) 0%, color-mix(in srgb, var(--fe-accent) 82%, #000000 18%) 100%);
    color: #fff;
    cursor: pointer;
    transition: opacity .15s, transform .1s, box-shadow .15s, border-color .15s;
    text-align: left;
    min-width: 160px;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fe-accent) 18%, transparent);
    opacity: .72;
}
.gslb-fe__avail-pill:hover {
    opacity: .9;
    transform: translateY(-1px);
    box-shadow: 0 14px 28px color-mix(in srgb, var(--fe-accent) 26%, transparent);
}
.gslb-fe__avail-pill--active {
    opacity: 1;
    transform: none;
    border-color: color-mix(in srgb, #ffffff 52%, var(--fe-accent) 48%);
    box-shadow: 0 16px 30px color-mix(in srgb, var(--fe-accent) 32%, transparent);
}
.gslb-fe__avail-pill__icon {
    display: none;
}
.gslb-fe__avail-pill__body {
    display: flex;
    flex-direction: column;
    gap: 2px;
    width: 100%;
}
.gslb-fe__avail-pill__label {
    font-weight: 800;
    font-size: 14px;
    display: block;
    line-height: 1.25;
    letter-spacing: .01em;
}
.gslb-fe__avail-pill__detail {
    font-size: 12px;
    opacity: .88;
    display: block;
    line-height: 1.3;
}
.gslb-fe__avail-pill--active .gslb-fe__avail-pill__detail {
    opacity: .98;
}

/* ── Riepilogo operatori ─────────────────────────────────────────────────── */
.gslb-fe__slot-summary {
    margin-top: 16px;
    padding: 14px 16px;
    border-radius: 14px;
    background: var(--fe-surface) !important;
    border: 1.5px solid color-mix(in srgb, var(--fe-accent) 25%, transparent) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    box-shadow: 0 2px 10px color-mix(in srgb, var(--fe-accent) 8%, transparent);
}
.gslb-fe__slot-summary__title {
    font-size: var(--gslb-fe-font-small);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .7px;
    color: var(--fe-accent);
    margin-bottom: 4px;
    padding-bottom: 8px;
    border-bottom: 1px solid color-mix(in srgb, var(--fe-accent) 15%, transparent);
}
.gslb-fe__slot-summary__row {
    display: grid !important;
    grid-template-columns: 28px 58px minmax(0,1fr) auto !important;
    grid-template-areas:
        "avatar time service attendant" !important;
    align-items: center !important;
    column-gap: 10px !important;
    row-gap: 2px !important;
    font-size: var(--gslb-fe-font-meta);
    line-height: 1.3;
    padding: 6px 0;
}
.gslb-fe__slot-summary__row .gslb-fe__att-avatar--sm {
    width: 28px !important;
    height: 28px !important;
    font-size: var(--gslb-fe-font-small) !important;
    flex-shrink: 0;
    margin: 0 !important;
    grid-area: avatar;
}
.gslb-fe__slot-summary__time {
    font-weight: 700;
    color: color-mix(in srgb, var(--fe-text) 78%, white 22%);
    font-size: var(--gslb-fe-font-small);
    letter-spacing: .2px;
    white-space: nowrap;
    display: block !important;
}
.gslb-fe__slot-summary__svc {
    grid-area: service;
    font-weight: 600;
    color: var(--fe-text);
    min-width: 0;
    white-space: normal;
    word-break: break-word;
    line-height: 1.35;
}
.gslb-fe__slot-summary__att {
    grid-area: attendant;
    color: color-mix(in srgb, var(--fe-sub) 88%, white 12%);
    font-weight: 600;
    font-size: var(--gslb-fe-font-meta);
    white-space: normal;
    line-height: 1.35;
    text-align: right;
    display: block !important;
    padding-left: 4px;
    max-width: 150px;
}
.gslb-fe__slot-summary__att::before {
    content: "";
    display: none;
}
@media (max-width: 640px) {
    .gslb-fe__avail-pills-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .gslb-fe__avail-pill {
        width: 100%;
        min-width: 0;
        padding: 13px 14px;
    }
    .gslb-fe__avail-pill__label {
        font-size: 13px;
    }
    .gslb-fe__avail-pill__detail {
        font-size: 11px;
    }
    .gslb-fe__slot-summary {
        margin-top: 14px;
        padding: 12px 13px;
    }
    .gslb-fe__slot-summary__row {
        grid-template-columns: 24px 54px minmax(0,1fr) !important;
        grid-template-areas:
            "avatar time service"
            "avatar time attendant" !important;
        align-items: start !important;
        column-gap: 8px !important;
        row-gap: 2px !important;
    }
    .gslb-fe__slot-summary__row .gslb-fe__att-avatar--sm {
        display: flex !important;
        width: 24px !important;
        height: 24px !important;
        font-size: 10px !important;
        margin-top: 2px !important;
    }
    .gslb-fe__slot-summary__title {
        font-size: 10px;
        letter-spacing: .8px;
    }
    .gslb-fe__slot-summary__time-wrap {
        gap: 0 !important;
    }
    .gslb-fe__slot-summary__time {
        font-size: 11px;
        padding-top: 0;
    }
    .gslb-fe__slot-summary__meta {
        display: block !important;
        font-size: 9px;
        line-height: 1.1;
        white-space: normal;
    }
    .gslb-fe__slot-summary__svc,
    .gslb-fe__slot-summary__att {
        font-size: 13px;
        white-space: normal;
        word-break: break-word;
    }
    .gslb-fe__slot-summary__att {
        text-align: left !important;
        opacity: .82;
        max-width: none;
    }
}

/* Scala leggibilità frontend: override finale per wizard e portale. */
.gslb-fe__title { font-size: var(--gslb-fe-font-title); }
.gslb-fe__panel-title,
.gslb-fe__success h3,
.gslb-fe__avail-title { font-size: var(--gslb-fe-font-panel-title); }
.gslb-fe__svc-card__name,
.gslb-fe__accordion-name,
.gslb-fe__service-choice-name,
.gslb-fe__svc-att-label,
.gslb-fe__search-mode-card strong,
.gslb-fe__special-rule-title { font-size: var(--gslb-fe-font-service-name); }
.gslb-fe__accordion-head--sub .gslb-fe__accordion-name {
    font-size: var(--gslb-fe-font-service-name);
    line-height: 1.25;
}
.gslb-fe__accordion-arrow { font-size: var(--gslb-fe-font-service-name); }
.gslb-fe__svc-card__desc,
.gslb-fe__accordion-desc,
.gslb-fe__service-choice-desc { font-size: var(--gslb-fe-font-service-desc); }
.gslb-fe__svc-card__meta,
.gslb-fe__booking-mode-hint,
.gslb-fe__selection-feasibility-hint,
.gslb-fe__slots-hint,
.gslb-fe__slots-loading,
.gslb-fe__waitlist-cta-copy,
.gslb-fe__field label,
.gslb-fe__search-mode-card span,
.gslb-fe__multidep-info,
.gslb-fe__slot-summary__row,
.gslb-fe__slot-summary__att,
.gslb-fe__slot-summary__svc,
.gslb-fe__special-rule,
.gslb-fe__special-rule-line,
.gslb-fe__special-rules-note-empty { font-size: var(--gslb-fe-font-meta); }
.gslb-fe__svc-cat-title,
.gslb-fe__accordion-kicker,
.gslb-fe__special-rules-note-title { font-size: var(--gslb-fe-font-category); }
.gslb-fe__svc-card__warning,
.gslb-fe__svc-card__hint,
.gslb-fe__field-err,
.gslb-fe__att-name small,
.gslb-fe__cal-day-name,
.gslb-fe__no-att,
.gslb-fe__slot-summary__title,
.gslb-fe__slot-summary__time,
.gslb-fe__slot-summary__meta,
.gslb-fe__avail-pill__detail { font-size: var(--gslb-fe-font-small) !important; }
.gslb-fe__att-name,
.gslb-fe__att-card--sm .gslb-fe__att-name,
.gslb-fe__slot-summary__att { font-size: var(--gslb-fe-font-attendant); }
.gslb-fe__field input,
.gslb-fe__field textarea,
.gslb-fe__field--check label,
.gslb-fe__inline-payment-note,
.gslb-fe__error-global,
.gslb-payment-notice,
.gslb-fe__success-recap { font-size: var(--gslb-fe-font-input); }
.gslb-fe__btn { font-size: var(--gslb-fe-font-button); }
.gslb-fe__slot,
.gslb-fe__avail-pill__time { font-size: var(--gslb-fe-font-slot); }
.gslb-fe__cal-month,
.gslb-fe__cal-day { font-size: var(--gslb-fe-font-calendar); }
.gslb-fe__step span,
.gslb-fe__step.done span::after,
.gslb-fe__att-avatar { font-size: var(--gslb-fe-font-step); }
.gslb-fe__step small { font-size: var(--gslb-fe-font-step-label); }
.gslb-fe__att-avatar--sm,
.gslb-fe__slot-summary__row .gslb-fe__att-avatar--sm { font-size: var(--gslb-fe-font-small) !important; }
