/* ================================================================
   willFlock - Blueprint Design System  v3.0
   Palette  : navy #13151a · surface #1c1f27 · teal #00e5a0
              cream #f0ebe2 · amber #f0c04a · rose #ff6370
   Type     : Playfair Display · IBM Plex Sans · IBM Plex Mono
================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=IBM+Plex+Sans:wght@300;400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root {
  --bg:          #13151a;
  --surface:     #1c1f27;
  --border:      #2e3340;
  --teal:        #00e5a0;
  --teal-glow:   rgba(0,229,160,.12);
  --teal-border: rgba(0,229,160,.28);
  --cream:       #f0ebe2;
  --cream-dim:   #c0bab0;
  --amber:       #f0c04a;
  --rose:        #ff6370;
  --muted:       #4e566a;
  --sidebar-w:   272px;
  --radius:      10px;
  --radius-sm:   6px;
  --t:           all .16s ease;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }

body {
  background:var(--bg);
  color:var(--cream);
  font-family:'IBM Plex Sans',sans-serif;
  font-size:16px;
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* ── Typography ── */
h1,h2,h3,h4 { font-family:'Playfair Display',serif; color:var(--cream); line-height:1.2; }
h1 { font-size:clamp(1.5rem,3vw,2rem); font-weight:900; }
h2 { font-size:clamp(1.1rem,2.5vw,1.5rem); font-weight:700; }
h3 { font-size:1rem; font-weight:700; }
a  { color:var(--teal); text-decoration:none; }
a:hover { text-decoration:underline; }

/* ── Header ── */
.wf-header {
  position:sticky; top:0; z-index:200;
  background:var(--surface); border-bottom:1px solid var(--border);
  height:54px; display:flex; align-items:center; padding:0 20px; gap:12px;
}
.wf-logo {
  width:32px; height:32px; background:var(--teal);
  border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.wf-logo svg { width:18px; height:18px; }
.wf-wordmark {
  font-family:'Playfair Display',serif; font-weight:900;
  font-size:1.15rem; color:var(--cream); letter-spacing:-.02em;
}
.wf-wordmark em { color:var(--teal); font-style:normal; }
.wf-header-badge {
  margin-left:auto;
  font-family:'IBM Plex Mono',monospace; font-size:.65rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.09em;
  background:var(--teal-glow); color:var(--teal);
  border:1px solid var(--teal-border); padding:3px 10px; border-radius:20px;
}

/* ── Shell ── */
.wf-shell {
  display:grid;
  grid-template-columns:var(--sidebar-w) 1fr;
  min-height:calc(100vh - 54px);
}

/* ── Sidebar ── */
.wf-sidebar {
  background:var(--surface); border-right:1px solid var(--border);
  padding:24px 18px;
  position:sticky; top:54px; height:calc(100vh - 54px);
  overflow-y:auto; scrollbar-width:none;
}
.wf-sidebar::-webkit-scrollbar { display:none; }

.wf-sidebar-title {
  font-family:'Playfair Display',serif; font-weight:900;
  font-size:1.25rem; color:var(--cream); line-height:1.3; margin-bottom:4px;
}
.wf-sidebar-sub { font-size:.82rem; color:var(--cream-dim); margin-bottom:22px; line-height:1.5; }

/* Steps */
.wf-steps { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:24px; }
.wf-step  { display:flex; align-items:flex-start; gap:10px; }
.wf-step-n {
  flex-shrink:0; width:24px; height:24px; border-radius:50%;
  background:var(--teal-glow); border:1.5px solid var(--teal-border);
  display:flex; align-items:center; justify-content:center;
  font-family:'IBM Plex Mono',monospace; font-size:.68rem; color:var(--teal);
}
.wf-step-n.on { background:var(--teal); border-color:var(--teal); color:var(--bg); }
.wf-step-body { font-size:.8rem; color:var(--cream-dim); padding-top:3px; line-height:1.4; }
.wf-step-body strong { color:var(--cream); display:block; font-weight:600; font-size:.83rem; }

/* Event card */
.wf-event-card {
  background:rgba(0,229,160,.07); border:1px solid var(--teal-border);
  border-radius:var(--radius); padding:14px; margin-bottom:18px;
}
.wf-event-card-tag {
  font-family:'IBM Plex Mono',monospace; font-size:.62rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.1em; color:var(--teal); margin-bottom:7px;
}
.wf-event-card-name {
  font-family:'Playfair Display',serif; font-size:1rem;
  font-weight:700; color:var(--cream); margin-bottom:10px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.wf-event-card-row {
  display:flex; justify-content:space-between; align-items:center;
  font-size:.76rem; padding:4px 0; border-bottom:1px solid var(--border);
}
.wf-event-card-row:last-child { border-bottom:none; }
.wf-event-card-row .label { color:var(--muted); }
.wf-event-card-row .value { color:var(--cream); font-weight:500; text-align:right; max-width:100%; font-size:.74rem; word-break:break-word; }

/* Stats grid */
.wf-stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:14px; }
.wf-stat { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); padding:10px 12px; }
.wf-stat-val { font-family:'IBM Plex Mono',monospace; font-size:1.2rem; color:var(--teal); }
.wf-stat-lbl { font-size:.7rem; color:var(--muted); margin-top:1px; }

/* Tip box */
.wf-tip {
  background:rgba(240,192,74,.07); border:1px solid rgba(240,192,74,.22);
  border-radius:var(--radius); padding:12px 14px;
  font-size:.78rem; color:var(--cream-dim); line-height:1.55;
}
.wf-tip strong { color:var(--amber); display:block; margin-bottom:4px; }

/* Share box */
.wf-share-box { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); padding:12px; margin-top:14px; }
.wf-share-box-label { font-family:'IBM Plex Mono',monospace; font-size:.62rem; font-weight:500; text-transform:uppercase; letter-spacing:.09em; color:var(--amber); margin-bottom:7px; }
.wf-share-url { font-family:'IBM Plex Mono',monospace; font-size:.68rem; color:var(--cream-dim); background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:6px 9px; word-break:break-all; margin-bottom:7px; line-height:1.4; }
.wf-copy-btn { width:100%; padding:7px; background:var(--teal-glow); border:1px solid var(--teal-border); border-radius:var(--radius-sm); color:var(--teal); font-family:'IBM Plex Mono',monospace; font-size:.7rem; font-weight:500; cursor:pointer; transition:var(--t); }
.wf-copy-btn:hover { background:var(--teal); color:var(--bg); border-color:var(--teal); }

/* ── Main content ── */
.wf-main { padding:28px 32px; max-width:860px; }

/* Section */
.wf-section { margin-bottom:32px; }
.wf-section-head {
  display:flex; align-items:center; gap:9px;
  padding-bottom:11px; margin-bottom:18px; border-bottom:1px solid var(--border);
}
.wf-section-num {
  font-family:'IBM Plex Mono',monospace; font-size:.62rem; color:var(--teal);
  background:var(--teal-glow); border:1px solid var(--teal-border);
  width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.wf-section-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; }
.wf-section-hint { margin-left:auto; font-size:.72rem; color:var(--muted); font-style:italic; }

/* ── Form grid ── */
.wf-grid { display:grid; gap:14px; margin-bottom:14px; }
.wf-grid.c2 { grid-template-columns:1fr 1fr; }
.wf-grid.c3 { grid-template-columns:1fr 1fr 1fr; }
.wf-grid.c13 { grid-template-columns:110px 1fr; }
.wf-grid.c13x { grid-template-columns:110px 180px 1fr; }
.wf-field { display:flex; flex-direction:column; gap:5px; }

/* Labels */
.wf-lbl {
  font-family:'IBM Plex Mono',monospace; font-size:.64rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.08em; color:var(--teal);
}
.wf-lbl-opt { color:var(--muted); text-transform:none; font-family:'IBM Plex Sans',sans-serif; font-size:.72rem; margin-left:4px; }

/* Inputs / selects */
input[type="text"],
input[type="email"],
input[type="number"],
input[type="date"],
input[type="time"],
select,
textarea,
.wf-input {
  width:100%;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--cream);
  font-family:'IBM Plex Sans',sans-serif; font-size:.88rem;
  padding:8px 11px; outline:none; transition:var(--t);
  -webkit-appearance:none; appearance:none;
}
input:focus, select:focus, textarea:focus, .wf-input:focus {
  border-color:var(--teal); box-shadow:0 0 0 3px var(--teal-glow);
}
input::placeholder, textarea::placeholder { color:var(--muted); }
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  filter:invert(1) brightness(.55); cursor:pointer;
}
input[type="number"] { -moz-appearance:textfield; }
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance:none; }
input:disabled, select:disabled { opacity:.45; cursor:not-allowed; }

select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234e566a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center;
  padding-right:28px; cursor:pointer;
}
select option { background:var(--surface); color:var(--cream); }
optgroup { color:var(--muted); font-size:.78rem; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  font-family:'IBM Plex Sans',sans-serif; font-weight:600; font-size:.88rem;
  border:none; border-radius:var(--radius-sm); cursor:pointer; transition:var(--t);
  padding:9px 18px; white-space:nowrap; line-height:1;
}
.btn-primary { background:var(--teal); color:var(--bg); }
.btn-primary:hover { background:#00f5b0; transform:translateY(-1px); box-shadow:0 4px 14px rgba(0,229,160,.3); }
.btn-primary:disabled { background:var(--muted); color:var(--bg); transform:none; box-shadow:none; cursor:not-allowed; }
.btn-secondary { background:var(--teal-glow); color:var(--teal); border:1px solid var(--teal-border); }
.btn-secondary:hover { background:rgba(0,229,160,.2); }
.btn-ghost { background:transparent; color:var(--cream-dim); border:1px solid var(--border); }
.btn-ghost:hover { border-color:var(--teal); color:var(--cream); }
.btn-danger { background:rgba(255,99,112,.12); color:var(--rose); border:1px solid rgba(255,99,112,.25); }
.btn-danger:hover { background:rgba(255,99,112,.22); }
.btn-full { width:100%; }
.btn-lg { padding:12px 24px; font-size:.95rem; }
.btn-sm { padding:5px 12px; font-size:.76rem; }
.btn-icon {
  width:28px; height:28px; padding:0; border-radius:50%;
  background:rgba(255,99,112,.12); border:1px solid var(--rose);
  color:var(--rose); font-size:.85rem;
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--t);
}
.btn-icon:hover { background:rgba(255,99,112,.25); }
.slot-del-btn {
  width:28px; height:28px; padding:0; border-radius:50%;
  background:rgba(255,99,112,.12); border:1px solid var(--rose);
  color:var(--rose); flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--t);
}
.slot-del-btn:hover { background:rgba(255,99,112,.25); }

/* ── Organizer slot rows ── */
.slot-row {
  display:flex; align-items:center; gap:8px; flex-wrap:nowrap;
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:11px 13px; margin-bottom:9px; transition:var(--t);
  overflow:visible;
}
.slot-row:hover { border-color:rgba(0,229,160,.22); }
.slot-row .slot-sep {
  font-family:'IBM Plex Mono',monospace; font-size:.66rem; color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em; flex-shrink:0;
}
.slot-row input[type="date"],
.slot-row input[type="time"],
.slot-row .wf-time-sel {
  font-family:'IBM Plex Mono',monospace; font-size:.82rem;
  flex-shrink: 0;
}
.slot-row input[type="date"] { width:142px; }
/* Flatpickr wrappers must stay inline inside flex rows */
.slot-row .flatpickr-wrapper,
.avail-slot-row 
/* ── Attendee event window rows ── */
.event-window {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:14px 16px; margin-bottom:12px; transition:var(--t);
}
.event-window:hover { border-color:rgba(0,229,160,.2); }
.event-window-label {
  font-family:'IBM Plex Mono',monospace; font-size:.74rem; font-weight:500;
  color:var(--teal); margin-bottom:10px; display:flex; align-items:center; gap:8px;
}
.event-window-label .window-range { color:var(--cream-dim); font-size:.72rem; }

.avail-slot-row {
  display:flex; align-items:center; gap:8px; flex-wrap:nowrap; margin-bottom:7px;
}
.avail-slot-row input[type="date"],
.avail-slot-row input[type="time"],
.avail-slot-row .wf-time-sel {
  font-family:'IBM Plex Mono',monospace; font-size:.8rem;
  flex-shrink: 0;
}
.avail-slot-row input[type="date"] { width:142px; }
.avail-slot-row .slot-sep { font-family:'IBM Plex Mono',monospace; font-size:.66rem; color:var(--muted); flex-shrink:0; }

.window-actions { display:flex; gap:8px; margin-top:8px; flex-wrap:wrap; align-items:center; }
.no-avail-label {
  display:flex; align-items:center; gap:6px;
  font-size:.78rem; color:var(--cream-dim); cursor:pointer;
}
.no-avail-label input[type="checkbox"] {
  width:14px; height:14px; accent-color:var(--rose);
  border-radius:3px; cursor:pointer;
}

/* ── Results: attendee boxes ── */
.att-panels { display:flex; align-items:flex-start; gap:12px; margin-bottom:24px; flex-wrap:wrap; }
.att-box { flex:1; min-width:180px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:14px; }
.att-box h3 {
  font-family:'IBM Plex Mono',monospace; font-size:.65rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.08em; color:var(--teal); margin-bottom:10px;
}
.att-box ul { list-style:none; display:flex; flex-direction:column; gap:2px; }
.att-box li {
  display:flex; align-items:center; gap:8px; padding:6px 9px;
  border-radius:var(--radius-sm); font-size:.85rem; color:var(--cream-dim);
  cursor:pointer; transition:var(--t); border:1px solid transparent;
}
.att-box li:hover { background:var(--teal-glow); color:var(--cream); border-color:var(--teal-border); }
.att-box li .att-arrow {
  margin-left:auto; font-size:.95rem; font-weight:700;
  color:var(--teal); opacity:.7; transition:var(--t);
}
.att-box li:hover .att-arrow { opacity:1; }

.att-controls { display:flex; flex-direction:column; gap:7px; padding-top:38px; }

/* Common slots */
.common-slots-wrap { margin-top:28px; }
.common-slots-wrap h3 { font-size:.85rem; color:var(--cream-dim); font-family:'IBM Plex Sans',sans-serif; font-weight:400; margin-bottom:14px; }
.common-slots-wrap h3 strong { color:var(--teal); }
.slot-cards {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:10px;
}

.slot-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:14px 16px; min-width:0; transition:var(--t);
}
.slot-card:hover { border-color:var(--teal-border); }
.slot-card-time {
  font-family:'IBM Plex Mono',monospace; font-size:.82rem; color:var(--teal);
  font-weight:500; margin-bottom:5px;
}
.slot-card-dur { font-size:.72rem; color:var(--muted); margin-bottom:8px; }
.slot-card-people { font-size:.76rem; color:var(--cream-dim); }
.slot-card-count {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--teal-glow); border:1px solid var(--teal-border);
  color:var(--teal); font-family:'IBM Plex Mono',monospace;
  font-size:.68rem; font-weight:500; border-radius:20px; padding:1px 8px; margin-right:5px;
}
.slot-card.top-slot { border-color:var(--teal-border); background:rgba(0,229,160,.06); }

/* Readonly/locked date input */
input[readonly] { opacity:.6; cursor:default; pointer-events:none; }

/* Info banner */
.wf-info {
  background:rgba(240,192,74,.07); border:1px solid rgba(240,192,74,.22);
  border-radius:var(--radius); padding:11px 14px;
  font-size:.8rem; color:var(--cream-dim); line-height:1.5; margin-bottom:16px;
}
.wf-info strong { color:var(--amber); }

/* Error banner */
.wf-error {
  background:rgba(255,99,112,.08); border:1px solid rgba(255,99,112,.22);
  border-radius:var(--radius); padding:11px 14px; font-size:.82rem; color:var(--rose);
}

/* Success banner */
.wf-success {
  background:var(--teal-glow); border:1px solid var(--teal-border);
  border-radius:var(--radius); padding:11px 14px; font-size:.82rem; color:var(--teal);
}

/* Loading skeleton */
.skeleton {
  background:linear-gradient(90deg, var(--surface) 25%, var(--border) 50%, var(--surface) 75%);
  background-size:400% 100%; animation:shimmer 1.4s ease infinite; border-radius:4px;
}
@keyframes shimmer { 0%{background-position:100% 0} 100%{background-position:-100% 0} }

/* Loading state */
.wf-loading {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:80px 20px; gap:14px;
}
.wf-loading-bar {
  width:56px; height:4px; background:var(--border); border-radius:2px; overflow:hidden;
}
.wf-loading-bar::after {
  content:''; display:block; height:100%; width:0; background:var(--teal);
  border-radius:2px; animation:wf-load 1.3s ease-in-out infinite;
}
@keyframes wf-load { 0%{width:0;margin-left:0} 60%{width:80%} 100%{width:0;margin-left:100%} }
.wf-loading p { font-family:'Playfair Display',serif; color:var(--cream-dim); font-size:1rem; }

/* Mobile pill */
.wf-mobile-pill {
  display:none; background:var(--surface); border-bottom:1px solid var(--border);
  padding:9px 16px; font-family:'IBM Plex Mono',monospace; font-size:.7rem;
  color:var(--teal); gap:8px; flex-wrap:wrap; align-items:center;
}

/* No results */
.wf-empty { padding:32px; text-align:center; }
.wf-empty p { color:var(--muted); font-size:.88rem; }

/* ── Footer ── */
footer {
  background:var(--surface); border-top:1px solid var(--border);
  padding:18px 32px; text-align:center; font-size:.76rem; color:var(--muted); line-height:1.9;
}
footer a { color:var(--cream-dim); }
footer a:hover { color:var(--teal); }

/* ── Utilities ── */
.hidden { display:none !important; }
.mt-8 { margin-top:8px; }
.mt-12 { margin-top:12px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.hide-mobile { display:inline; }
.show-mobile { display:none; }
@media (max-width:600px) {
  .hide-mobile { display:none; }
  .show-mobile { display:inline; }
  #submitBtn { padding:9px 12px; font-size:.82rem; }
}
.gap-8 { gap:8px; }
.gap-12 { gap:12px; }
.flex-1 { flex:1; }

/* ── Responsive ── */
@media (max-width:860px) {
  .wf-shell { grid-template-columns:1fr; }
  .wf-sidebar { display:none; }
  .wf-mobile-pill { display:flex; }
  .wf-main { padding:18px 14px; }
  .wf-grid.c2,.wf-grid.c3,.wf-grid.c13,.wf-grid.c13x { grid-template-columns:1fr; }
  .att-panels { flex-direction:column; }
  .att-controls { flex-direction:row; padding-top:0; }
}
/* Landscape mode: restore full desktop layout so sidebar is visible */
@media (max-width:860px) and (orientation:landscape) {
  .wf-shell { grid-template-columns:var(--sidebar-w) 1fr; }
  .wf-sidebar { display:block; }
  .wf-mobile-pill { display:none; }
  .wf-main { padding:18px 14px; }
  .wf-grid.c2 { grid-template-columns:1fr 1fr; }
  .wf-grid.c13,.wf-grid.c13x { grid-template-columns:1fr 3fr; }
  .att-panels { flex-direction:row; }
  .att-controls { flex-direction:column; padding-top:8px; }
}
@media (max-width:480px) {
  .wf-main { padding:14px 10px; }
  .slot-row { flex-wrap:wrap; }
  .slot-row input[type="date"],.slot-row input[type="time"],
  .slot-row .wf-time-sel,
  .avail-slot-row input[type="date"],.avail-slot-row input[type="time"],
  .avail-slot-row .wf-time-sel { width:100%; }
  .wf-time-select-wrap select { flex:1; width:auto; }
}



/* ── Flatpickr Blueprint theme ── */

.flatpickr-calendar {
  background: var(--surface) !important;
  border: 1px solid var(--teal-border) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.6) !important;
  font-family: 'IBM Plex Sans', sans-serif !important;
  color: var(--cream) !important;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after { border-bottom-color: var(--teal-border) !important; }

.flatpickr-months { padding: 8px 4px 0 !important; }
.flatpickr-month { color: var(--cream) !important; fill: var(--cream) !important; }
.flatpickr-current-month { font-size: .85rem !important; font-weight: 600 !important; }
.flatpickr-current-month .flatpickr-monthDropdown-months {
  background: var(--surface) !important;
  color: var(--cream) !important;
}
.flatpickr-current-month input.cur-year {
  color: var(--cream) !important;
  font-family: 'IBM Plex Mono', monospace !important;
}
.flatpickr-prev-month, .flatpickr-next-month {
  fill: var(--teal) !important; color: var(--teal) !important;
}
.flatpickr-prev-month:hover svg, .flatpickr-next-month:hover svg { fill: var(--cream) !important; }

.flatpickr-weekdays { background: transparent !important; }
span.flatpickr-weekday {
  color: var(--muted) !important;
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: .68rem !important;
  font-weight: 600 !important;
}
.flatpickr-day {
  color: var(--cream-dim) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: .78rem !important;
}
.flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover {
  background: var(--teal-glow) !important;
  border-color: var(--teal-border) !important;
  color: var(--teal) !important;
}
.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange {
  background: var(--teal) !important;
  border-color: var(--teal) !important;
  color: #13151a !important;
  font-weight: 700 !important;
}
.flatpickr-day.today {
  border-color: var(--teal-border) !important;
  color: var(--teal) !important;
}
.flatpickr-day.today:hover {
  background: var(--teal-glow) !important;
}
.flatpickr-day.flatpickr-disabled, .flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay {
  color: var(--muted) !important; opacity: .4;
}

/* Time picker */
.flatpickr-time {
  background: var(--surface) !important;
  border-top: 1px solid var(--border) !important;
}
.flatpickr-time input, .flatpickr-time .flatpickr-am-pm {
  color: var(--cream) !important;
  background: transparent !important;
  font-family: 'IBM Plex Mono', monospace !important;
  font-size: .88rem !important;
}
.flatpickr-time input:hover, .flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus, .flatpickr-time .flatpickr-am-pm:focus {
  background: var(--teal-glow) !important;
  color: var(--teal) !important;
}
.flatpickr-time .numInputWrapper span.arrowUp:after { border-bottom-color: var(--teal) !important; }
.flatpickr-time .numInputWrapper span.arrowDown:after { border-top-color: var(--teal) !important; }
.numInputWrapper:hover { background: var(--teal-glow) !important; }

/* ── Optional field tag ── */
.wf-opt-tag {
  display: inline-block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .62rem;
  color: var(--muted);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1px 5px;
  letter-spacing: .04em;
  vertical-align: middle;
  margin-left: 4px;
}

/* ── Styled native date/time inputs ── */
.wf-date-input,
.wf-time-input {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .82rem;
  color: var(--cream);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  outline: none;
  transition: var(--t);
  cursor: pointer;
}
.wf-date-input { width: 130px; }
.wf-time-input { width: 115px; }
.wf-date-input:hover, .wf-time-input:hover,
.wf-date-input:focus, .wf-time-input:focus {
  border-color: var(--teal-border);
  box-shadow: 0 0 0 2px var(--teal-glow);
}

/* ── Single time select ── */
.wf-time-sel {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .82rem;
  color: var(--cream);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  outline: none;
  transition: var(--t);
  cursor: pointer;
  flex-shrink: 0;
  width: 120px;
}
.wf-time-sel:hover,
.wf-time-sel:focus {
  border-color: var(--teal-border);
  box-shadow: 0 0 0 2px var(--teal-glow);
}
/* Calendar icon: teal tint */
.wf-date-input::-webkit-calendar-picker-indicator {
  filter: invert(1) sepia(1) saturate(2) hue-rotate(115deg);
  cursor: pointer;
  opacity: 0.55;
  border-radius: 3px;
  padding: 2px;
}
.wf-date-input::-webkit-calendar-picker-indicator:hover { opacity: 1; }
.wf-date-input::-moz-calendar-picker-indicator { color: var(--teal); }
.wf-date-input:invalid { color: var(--muted); }

/* Date field segments: teal highlight when focused */
input[type="date"]::-webkit-datetime-edit { color: var(--cream); }
input[type="date"]::-webkit-datetime-edit-fields-wrapper { background: transparent; }
input[type="date"]::-webkit-datetime-edit-text { color: var(--muted); padding: 0 1px; }
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-year-field {
  color: var(--cream);
  background: transparent;
  border-radius: 2px;
}
input[type="date"]::-webkit-datetime-edit-month-field:focus,
input[type="date"]::-webkit-datetime-edit-day-field:focus,
input[type="date"]::-webkit-datetime-edit-year-field:focus {
  background: var(--teal);
  color: #000;
  outline: none;
}

/* ── Custom date picker ── */
.wf-datepick-wrap {
  position: relative;
  display: inline-block;
  flex-shrink: 0;
}
.wf-datepick-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--cream);
  font-family: 'IBM Plex Mono', monospace;
  font-size: .82rem;
  padding: 7px 11px;
  cursor: pointer;
  white-space: nowrap;
  transition: var(--t);
  min-width: 148px;
}
.wf-datepick-btn:hover { border-color: var(--teal-border); box-shadow: 0 0 0 2px var(--teal-glow); }
.wf-datepick-label { flex: 1; text-align: left; }
.wf-datepick-icon  { font-size: .8rem; opacity: .6; }

/* Calendar dropdown — attached to body */
.wf-datepick-cal {
  background: var(--surface, #161b24);
  border: 1px solid var(--teal-border, rgba(62,207,142,.25));
  border-radius: var(--radius, 10px);
  box-shadow: 0 12px 40px rgba(0,0,0,.7);
  padding: 12px;
  width: 252px;
  font-family: 'IBM Plex Sans', sans-serif;
  user-select: none;
}
.wf-cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.wf-cal-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .78rem;
  font-weight: 700;
  color: var(--cream, #e8eaf0);
  letter-spacing: .04em;
}
.wf-cal-nav {
  background: var(--teal-glow, rgba(62,207,142,.1));
  border: 1px solid var(--teal-border, rgba(62,207,142,.2));
  border-radius: 6px;
  color: var(--teal, #3ecf8e);
  font-size: 1.1rem;
  line-height: 1;
  width: 28px; height: 28px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.wf-cal-nav:hover { background: rgba(62,207,142,.22); }
.wf-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.wf-cal-dow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .62rem;
  color: var(--muted, #7a8399);
  text-align: center;
  padding: 2px 0 4px;
  font-weight: 600;
  letter-spacing: .05em;
}
.wf-cal-day, .wf-cal-empty {
  text-align: center;
  border-radius: 6px;
  font-size: .8rem;
  padding: 5px 2px;
  cursor: pointer;
  color: var(--cream-dim, #b0b8cc);
  transition: background .1s, color .1s;
  line-height: 1.4;
}
.wf-cal-day:hover { background: var(--teal-glow); color: var(--teal); }
.wf-cal-day.today {
  border: 1px solid var(--teal-border);
  color: var(--teal);
  font-weight: 700;
}
.wf-cal-day.sel {
  background: var(--teal, #3ecf8e);
  color: #13151a;
  font-weight: 700;
}
.wf-cal-day.disabled {
  opacity: .25;
  cursor: default;
  pointer-events: none;
}
.wf-cal-empty { cursor: default; }

/* ── Overnight window badge ── */
.wf-overnight-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .66rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: #f59e0b;
  background: rgba(245,158,11,.07);
  border: 1px solid rgba(245,158,11,.2);
  border-radius: 4px;
  padding: 3px 8px;
  flex-shrink: 0;
  /* hidden by default — toggled via .visible */
  opacity: 0;
  transform: translateY(2px);
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
}
.wf-overnight-badge.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* ── Slot duration too-short warning ── */
.wf-slot-dur-warn {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .64rem;
  font-weight: 600;
  color: #f87171;
  background: rgba(248,113,113,.08);
  border: 1px solid rgba(248,113,113,.25);
  border-radius: 4px;
  padding: 3px 7px;
  flex-shrink: 0;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(2px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
.wf-slot-dur-warn.visible {
  opacity: 1;
  transform: translateY(0);
}
.slot-row.is-too-short,
.avail-slot-row.is-too-short {
  border-color: rgba(248,113,113,.3);
  background: rgba(248,113,113,.03);
}

/* +1 day ghost hint that floats next to end time */
.wf-nextday-hint {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .6rem;
  color: rgba(245,158,11,.55);
  letter-spacing: .03em;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .22s ease;
  pointer-events: none;
  white-space: nowrap;
}
.wf-nextday-hint.visible { opacity: 1; }

/* Slot row gets a very faint warm tint when overnight */
.slot-row.is-overnight {
  border-color: rgba(245,158,11,.22);
  background: rgba(245,158,11,.025);
}

/* ══════════════════════════════════════
   1:1 BOOKING MODE
   ══════════════════════════════════════ */
.booking-slot-card {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 12px;
  background: var(--surface);
  border: 1px solid var(--teal-border);
  border-radius: var(--radius);
  padding: 13px 16px;
  margin-bottom: 8px;
  transition: var(--t);
  overflow: visible;
}
.booking-slot-card:hover:not(.booking-slot-taken) {
  border-color: var(--teal);
  box-shadow: 0 0 0 2px var(--teal-glow);
}
.booking-slot-taken {
  border-color: var(--border);
  opacity: .55;
}
.booking-slot-mine {
  border-color: var(--teal);
  background: rgba(0,255,163,.04);
}
.booking-slot-time {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .82rem;
  color: var(--cream);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: visible;
}
.booking-slot-dur {
  font-size: .75rem;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.booking-slot-status {
  min-width: 140px;
  flex-shrink: 0;
  text-align: right;
}
.booking-badge {
  display: inline-block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .68rem;
  font-weight: 600;
  border-radius: 3px;
  padding: 2px 8px;
}
.booking-badge-taken {
  color: var(--muted);
  background: var(--bg);
  border: 1px solid var(--border);
}
.booking-badge-mine {
  color: var(--teal);
  background: rgba(0,255,163,.08);
  border: 1px solid var(--teal-border);
}
.booking-btn {
  white-space: nowrap;
}

/* ── Pro feature badge ── */
.wf-pro-badge {
  display: inline-block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: #f59e0b;
  background: rgba(245,158,11,.1);
  border: 1px solid rgba(245,158,11,.3);
  border-radius: 3px;
  padding: 1px 5px;
  margin-left: 6px;
  vertical-align: middle;
  cursor: default;
  position: relative;
}
.wf-pro-badge[title]:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 5px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--cream-dim);
  font-size: .72rem;
  font-weight: 400;
  letter-spacing: 0;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  pointer-events: none;
  z-index: 10;
}
