:root {
  --bg:        #050505;
  --bg-elev:  #0d0d0d;
  --bg-elev2: #161616;
  --line:     rgba(255,255,255,0.08);
  --line-soft: rgba(255,255,255,0.04);
  --text:     #ffffff;
  --muted:    #9a9a9a;
  --gold:     #c9a961;
  --gold-soft:#a08542;
  --walter:   #88b074;
  --hector:   #7da4cc;
  --now:      #ff453a;          /* Apple system red — now-line */
  --radius:   14px;
  --gap:      16px;
  --section:  28px;
  --ease:     cubic-bezier(.2,0,.2,1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); }
body {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text",
               "Helvetica Neue", Arial, sans-serif;
  font-size: 15px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "ss02", "cv01";
}

a { color: var(--gold); text-decoration: none; }
a:hover { color: #e3c478; }

.app-shell { min-height: 100vh; display: flex; flex-direction: column; }

/* Sticky header with iOS-style blur */
.app-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 32px;
  background: rgba(5,5,5,0.7);
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  border-bottom: 1px solid var(--line);
  gap: var(--gap);
}
.app-header__brand { display: flex; align-items: center; gap: 14px; }
.app-header__logo { height: 22px; opacity: 0.96; }
.app-header__pipe {
  height: 18px; width: 1px; background: rgba(255,255,255,0.18);
}
.app-header__sub { letter-spacing: 0.18em; font-size: 11px;
                   text-transform: uppercase; color: var(--muted); }
.app-header__user { display: flex; align-items: center; gap: 14px;
                    font-size: 13px; color: var(--muted); }

.btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--text);
  padding: 10px 18px;
  border-radius: var(--radius);
  font-size: 13px;
  cursor: pointer;
  transition: border-color 180ms var(--ease),
              color 180ms var(--ease),
              background 180ms var(--ease),
              transform 120ms var(--ease);
}
.btn:hover { border-color: rgba(255,255,255,0.2); color: var(--text); }
.btn:active { transform: scale(0.98); }
.btn--primary { border-color: var(--gold); color: var(--gold); }
.btn--primary:hover { background: var(--gold); color: #0b0b0b; border-color: var(--gold); }
.btn--ghost { border-color: transparent; color: var(--muted); }
.btn--ghost:hover { color: var(--text); border-color: var(--line); }

.input, select, textarea {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text);
  padding: 12px 14px;
  font-size: 14px;
  width: 100%;
  transition: border-color 160ms var(--ease), background 160ms var(--ease);
}
.input:hover, select:hover, textarea:hover { border-color: rgba(255,255,255,0.16); }
.input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: rgba(255,255,255,0.06);
}

.stack > * + * { margin-top: var(--gap); }
.section + .section { margin-top: var(--section); }

/* ---- Login ---- */
.login-wrap {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
}
.login-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 18px; padding: 36px; width: 100%; max-width: 380px;
}
.login-card__logo { display: block; height: 26px; margin: 0 auto 28px; }
.login-card__title { text-align: center; letter-spacing: 0.15em;
                     font-weight: 500; font-size: 12px; color: var(--muted);
                     text-transform: uppercase; margin: 0 0 24px; }
.login-card .err { color: #ff8a8a; font-size: 13px; margin-top: 12px; }

/* ---- Admin calendar ---- */
.app-main { padding: 24px 32px 48px; }
.cal-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--gap); margin-bottom: var(--section); flex-wrap: wrap;
}
.cal-legend { display: flex; gap: 18px; font-size: 12px; color: var(--muted); }
.cal-legend__chip { display: inline-block; width: 10px; height: 10px;
                    border-radius: 3px; margin-right: 8px; vertical-align: -1px; }
.cal-legend__chip--internal { background: #ffffff; }
.cal-legend__chip--delivery { background: var(--gold); }

.cal-shortcuts { font-size: 11px; color: var(--muted); letter-spacing: 0.04em; }
.cal-shortcuts kbd {
  display: inline-block; min-width: 18px; padding: 2px 6px; margin: 0 2px;
  background: rgba(255,255,255,0.06); border: 1px solid var(--line);
  border-radius: 5px; font-family: -apple-system, sans-serif;
  font-size: 10px; color: var(--text);
}

#calendar {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
}

/* FullCalendar overrides — refined dark theme */
.fc {
  color: var(--text);
  --fc-border-color: var(--line);
  --fc-page-bg-color: transparent;
  --fc-neutral-bg-color: var(--bg-elev2);
  --fc-today-bg-color: transparent;             /* no fill — today is the gold circle */
  --fc-event-text-color: inherit;
}
.fc .fc-toolbar { margin-bottom: 18px; }
.fc .fc-toolbar-title {
  font-weight: 500; letter-spacing: 0.01em; font-size: 18px;
}
.fc .fc-button {
  background: transparent; border: 1px solid var(--line);
  color: var(--muted); font-size: 12px; padding: 6px 12px;
  text-transform: lowercase; letter-spacing: 0.01em;
  transition: all 160ms var(--ease);
  box-shadow: none;
}
.fc .fc-button:not(:disabled):hover {
  border-color: rgba(255,255,255,0.16); color: var(--text); background: transparent;
}
.fc .fc-button:focus { box-shadow: none; }
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
  background: rgba(255,255,255,0.06);
  color: var(--text);
  border-color: rgba(255,255,255,0.16);
}
.fc .fc-button-group > .fc-button:not(:last-child) { border-top-right-radius:0; border-bottom-right-radius:0; }
.fc .fc-button-group > .fc-button:not(:first-child) { border-top-left-radius:0; border-bottom-left-radius:0; margin-left:-1px; }

/* Day-of-week + day-number headers (Apple-style two-line) */
.fc .fc-col-header-cell { border-bottom: 1px solid var(--line); }
.fc .fc-col-header-cell-cushion { padding: 0; text-decoration: none; color: inherit; }
.bianco-dayheader {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; padding: 12px 4px;
}
.bianco-dayheader__wd {
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  opacity: 0.5; color: var(--text);
}
.bianco-dayheader__day {
  font-size: 17px; font-weight: 500; color: var(--text);
  width: 30px; height: 30px; border-radius: 50%;
  display: grid; place-items: center;
  transition: background 200ms var(--ease), color 200ms var(--ease);
  font-feature-settings: "tnum";
}
.bianco-dayheader__day--today {
  background: var(--gold); color: #0b0b0b; font-weight: 600;
}

/* Time gutter labels (7:00 / 8:00 / 9:00 ...) */
.fc .fc-timegrid-slot-label-cushion {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--text);
  opacity: 0.4;
  padding: 0 12px;
  font-feature-settings: "tnum";
}
.fc .fc-timegrid-slot { height: 36px; }
.fc .fc-timegrid-slot-minor { border-top-style: dotted; opacity: 0.5; }
.fc .fc-timegrid-axis-cushion { color: var(--muted); font-size: 11px; opacity: 0.6; }

/* Hover-affordance on empty slot lanes */
.fc .fc-timegrid-col-frame { transition: background 120ms var(--ease); }
.fc .fc-timegrid-col-frame:hover { background: rgba(255,255,255,0.015); }

/* Now-indicator: fine red line with leading dot, à la Apple Calendar */
.fc .fc-timegrid-now-indicator-line {
  border-color: var(--now);
  border-top-width: 1.5px;
  position: relative;
}
.fc .fc-timegrid-now-indicator-line::before {
  content: '';
  position: absolute;
  left: -5px; top: -5.5px;
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--now);
  box-shadow: 0 0 8px rgba(255,69,58,0.5);
}
.fc .fc-timegrid-now-indicator-arrow { display: none; }

/* Day-grid view (month) niceties */
.fc .fc-daygrid-day-number { color: var(--text); padding: 8px; opacity: 0.85; font-feature-settings: "tnum"; }
.fc .fc-daygrid-day.fc-day-today .fc-daygrid-day-number {
  background: var(--gold); color: #0b0b0b; border-radius: 50%;
  width: 26px; height: 26px; display: inline-grid; place-items: center;
  margin: 6px; padding: 0; font-weight: 600;
}

/* Apple-Calendar-style event blocks */
.fc-timegrid-event,
.fc-event {
  border-radius: 10px; border: none; overflow: hidden;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}
.fc-timegrid-event .fc-event-main,
.fc-event .fc-event-main {
  padding: 0; color: inherit !important; overflow: hidden; height: 100%;
}
.fc-event-dragging,
.fc-event-resizing,
.fc-event-mirror {
  transform: scale(1.02);
  box-shadow: 0 12px 28px rgba(0,0,0,0.5);
  z-index: 100;
}
.bianco-event {
  height: 100%;
  padding: 5px 10px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  row-gap: 2px;
  overflow: hidden;
  min-width: 0;
}
.bianco-event__top,
.bianco-event__main,
.bianco-event__sub { min-width: 0; }
.bianco-event__top {
  font-size: 11px;
  font-weight: 500;
  opacity: 0.55;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bianco-event__main {
  font-size: 13px;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.005em;
  word-break: break-word;
  overflow-wrap: anywhere;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  align-self: start;
}
.bianco-event__sub {
  font-size: 11px;
  font-weight: 400;
  opacity: 0.55;
  line-height: 1.2;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  align-self: end;
}
.fc-timegrid-event-short .bianco-event { grid-template-rows: 1fr; }
.fc-timegrid-event-short .bianco-event__top,
.fc-timegrid-event-short .bianco-event__sub { display: none; }
.fc-timegrid-event-short .bianco-event__main {
  font-size: 12px; line-height: 1.2; -webkit-line-clamp: 1;
}

.fc-event.event--internal,
.fc-event.event--internal .fc-event-main {
  background: #ffffff; color: #050505;
}
.fc-event.event--internal { border-left: 3px solid var(--gold); }
.fc-event.assignee--karolina { border-left-color: var(--gold); }
.fc-event.assignee--walter   { border-left-color: var(--walter); }
.fc-event.assignee--hector   { border-left-color: var(--hector); }
.fc-event.event--delivery,
.fc-event.event--delivery .fc-event-main {
  background: var(--gold); color: #0b0b0b;
}

/* Hover tooltip (Apple-style popover) */
.bianco-tooltip {
  position: fixed;
  z-index: 200;
  background: rgba(13,13,13,0.85);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 12px 14px;
  min-width: 180px; max-width: 280px;
  pointer-events: none;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45);
  font-size: 13px;
  color: var(--text);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 140ms var(--ease), transform 140ms var(--ease);
}
.bianco-tooltip.show { opacity: 1; transform: translateY(0); }
.bianco-tooltip__time {
  font-size: 11px; opacity: 0.55; margin-bottom: 6px;
  letter-spacing: 0.04em; font-feature-settings: "tnum";
}
.bianco-tooltip__top {
  font-size: 11px; opacity: 0.55; text-transform: uppercase;
  letter-spacing: 0.06em; margin-bottom: 4px;
}
.bianco-tooltip__main {
  font-size: 14px; font-weight: 500; line-height: 1.3;
}
.bianco-tooltip__sub {
  font-size: 12px; opacity: 0.7; margin-top: 4px;
}
.bianco-tooltip__notes {
  font-size: 12px; opacity: 0.7; margin-top: 8px;
  padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.08);
  white-space: pre-wrap;
}
.bianco-tooltip__author {
  font-size: 11px; opacity: 0.45; margin-top: 8px;
  padding-top: 6px; border-top: 1px solid rgba(255,255,255,0.06);
  font-style: italic;
}

/* Assignee radio row in the task modal */
.bianco-assignee-row { display: flex; gap: 8px; flex-wrap: wrap; }
.bianco-assignee {
  flex: 1 1 0;
  min-width: 100px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-align: center;
  cursor: pointer;
  font-size: 13px;
  color: var(--muted);
  transition: border-color 160ms var(--ease),
              color 160ms var(--ease),
              background 160ms var(--ease);
}
.bianco-assignee:hover { border-color: rgba(255,255,255,0.16); color: var(--text); }
.bianco-assignee input { display: none; }
.bianco-assignee:has(input:checked) {
  border-color: var(--gold); color: var(--gold);
  background: rgba(201,169,97,0.06);
}
.bianco-assignee:has(input[value="Вальтер"]:checked) {
  border-color: var(--walter); color: var(--walter);
  background: rgba(136,176,116,0.06);
}
.bianco-assignee:has(input[value="Гектор"]:checked) {
  border-color: var(--hector); color: var(--hector);
  background: rgba(125,164,204,0.06);
}

/* ---- Modal (glass / iOS-style) ---- */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  display: grid; place-items: center; padding: 24px; z-index: 50;
  animation: fadein 180ms var(--ease);
}
.modal {
  background: rgba(15,15,15,0.85);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 28px;
  width: 100%;
  max-width: 460px;
  box-shadow: 0 32px 72px rgba(0,0,0,0.55);
  animation: modalin 220ms var(--ease);
}
.modal h3 { margin: 0 0 20px; font-weight: 500; letter-spacing: 0.01em; font-size: 18px; }
.modal .row + .row { margin-top: 14px; }
.modal label { display: block; font-size: 11px; letter-spacing: 0.16em;
               text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.modal-actions { display: flex; gap: 10px; margin-top: 24px; justify-content: flex-end; }

@keyframes fadein { from { opacity: 0 } to { opacity: 1 } }
@keyframes modalin {
  from { opacity: 0; transform: scale(0.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* ---- Users management table ---- */
.users-table-wrap {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
}
.users-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.users-table thead th {
  text-align: left;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
}
.users-table tbody td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-soft);
  vertical-align: middle;
}
.users-table tbody tr:last-child td { border-bottom: none; }
.users-table tbody tr:hover { background: rgba(255,255,255,0.015); }
.users-row--blocked td { opacity: 0.55; }
.users-cell-login { font-weight: 500; }
.users-me {
  font-size: 11px; color: var(--gold); font-weight: 400;
  letter-spacing: 0.06em; margin-left: 4px;
}
.users-cell-time { color: var(--muted); font-size: 12px; font-feature-settings: "tnum"; }
.users-role {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.users-role--admin    { background: rgba(201,169,97,0.12); color: var(--gold); }
.users-role--manager  { background: rgba(255,255,255,0.06); color: var(--text); opacity: 0.85; }
.users-role--driver   { background: rgba(125,164,204,0.14); color: var(--hector); }
.users-status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 11px;
  letter-spacing: 0.04em;
}
.users-status--active  { background: rgba(136,176,116,0.14); color: var(--walter); }
.users-status--blocked { background: rgba(255,138,138,0.12); color: #ff8a8a; }
.users-actions { text-align: right; white-space: nowrap; }
.users-actions .btn {
  padding: 6px 12px; font-size: 12px; margin-left: 4px;
}
.users-actions .btn:disabled {
  opacity: 0.35; cursor: not-allowed;
}
.users-btn-danger:hover:not(:disabled) {
  border-color: #ff8a8a !important; color: #ff8a8a !important;
}
.users-empty {
  text-align: center; padding: 36px; color: var(--muted); font-size: 13px;
}
@media (max-width: 700px) {
  .users-table thead { display: none; }
  .users-table tbody td { display: block; padding: 6px 16px; border: none; }
  .users-table tbody tr {
    display: block; padding: 14px 0; border-bottom: 1px solid var(--line);
  }
  .users-actions { text-align: left; padding-top: 10px; }
}

/* ---- Address autocomplete dropdown ---- */
.address-field { position: relative; }
.address-suggest {
  position: absolute;
  top: 100%; left: 0; right: 0;
  margin-top: 6px;
  background: rgba(15,15,15,0.95);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  max-height: 280px;
  overflow-y: auto;
  z-index: 60;
  box-shadow: 0 16px 36px rgba(0,0,0,0.5);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-2px);
  transition: opacity 140ms var(--ease), transform 140ms var(--ease);
}
.address-suggest.show { opacity: 1; pointer-events: auto; transform: translateY(0); }
.address-suggest:empty { display: none; }
.address-suggest__item {
  padding: 11px 14px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text);
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background 80ms var(--ease), color 80ms var(--ease);
}
.address-suggest__item:last-child { border-bottom: none; }
.address-suggest__item:hover,
.address-suggest__item.active {
  background: rgba(201,169,97,0.1);
  color: var(--gold);
}

/* ---- Cmd+K command palette ---- */
.palette-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  z-index: 60; padding: 96px 24px 24px;
  display: flex; justify-content: center; align-items: flex-start;
  animation: fadein 180ms var(--ease);
}
.palette {
  background: rgba(20,20,20,0.92);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  width: 100%; max-width: 540px;
  box-shadow: 0 32px 72px rgba(0,0,0,0.6);
  overflow: hidden;
  animation: modalin 220ms var(--ease);
}
.palette__input {
  width: 100%; padding: 16px 18px;
  background: transparent; border: none; outline: none;
  color: var(--text); font-size: 15px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.palette__input::placeholder { color: var(--muted); }
.palette__list { max-height: 360px; overflow-y: auto; padding: 8px 0; }
.palette__item {
  padding: 10px 18px; cursor: pointer;
  display: flex; align-items: center; gap: 12px;
  transition: background 80ms var(--ease);
}
.palette__item:hover, .palette__item.active { background: rgba(255,255,255,0.06); }
.palette__item-main { flex: 1; min-width: 0; }
.palette__item-title {
  font-size: 14px; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.palette__item-sub {
  font-size: 12px; color: var(--muted); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.palette__empty {
  padding: 28px; text-align: center; color: var(--muted); font-size: 13px;
}

/* ---- Preview (customer widget) ---- */
.preview-wrap { max-width: 720px; margin: 0 auto; padding: 32px 24px 64px; }
.preview-wrap h1 { font-weight: 400; letter-spacing: 0.16em;
                   text-transform: uppercase; font-size: 18px;
                   text-align: center; margin: 0 0 32px; }
.kind-radio { display: flex; gap: 12px; margin-top: 14px; }
.kind-radio label { flex: 1; padding: 14px; border: 1px solid var(--line);
                    border-radius: var(--radius); text-align: center;
                    cursor: pointer; }
.kind-radio input { display: none; }
.kind-radio input:checked + span { color: var(--gold); }
.kind-radio label:has(input:checked) { border-color: var(--gold); }

.slot-day { margin-top: var(--section); }
.slot-day__date { font-size: 11px; letter-spacing: 0.18em;
                  text-transform: uppercase; color: var(--muted);
                  margin-bottom: 10px; }
.slot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
             gap: 10px; }
.slot-card { padding: 12px 14px; border: 1px solid var(--line);
             border-radius: var(--radius); cursor: pointer;
             transition: border-color 120ms; }
.slot-card:hover { border-color: var(--gold); }
.slot-card.selected { border-color: var(--gold); background: rgba(201,169,97,0.06); }
.slot-card__time { font-size: 14px; font-feature-settings: "tnum"; }
.slot-card__hint { font-size: 11px; color: var(--muted); margin-top: 4px; }

.slot-empty {
  border: 1px dashed rgba(255,255,255,0.10);
  border-radius: var(--radius);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
}
.slot-empty__msg { font-size: 13px; color: var(--muted); line-height: 1.45; }
.slot-empty__btn { align-self: flex-start; }

@media (max-width: 700px) {
  .app-header { padding: 14px 18px; flex-wrap: wrap; }
  .app-main, .preview-wrap { padding-left: 18px; padding-right: 18px; }
  .cal-shortcuts { display: none; }
  .fc .fc-toolbar { flex-wrap: wrap; gap: 12px; }
  .palette-backdrop { padding-top: 48px; }
}
