/* dl-styles.css — Daylight direction styles */
:root {
  --dl-bg: #FCFBFF; --dl-surface: #FFFFFF; --dl-ink: #383E53; --dl-ink2: #202538;
  --dl-muted: #9C9D9F; --dl-border: #ECEAF1; --dl-violet: #8338EC; --dl-vdark: #712BD3;
  --dl-vlight: #7F5BFF; --dl-tint: rgba(131,56,236,0.07); --dl-gold: #FFB706;
  --dl-peach: #FFEFD2; --dl-success: #4AD993; --dl-r: 16px; --dl-font: "Lato", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; }
html, body { font-family: var(--dl-font); background: #EDEAF3; color: var(--dl-ink); }

/* ---- Animation keyframes ---- */
@keyframes dlPulse { 0%{box-shadow:0 0 0 0 rgba(255,183,6,0.55)} 70%{box-shadow:0 0 0 8px rgba(255,183,6,0)} 100%{box-shadow:0 0 0 0 rgba(255,183,6,0)} }
@keyframes dlFadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
@keyframes dlScaleIn { from{opacity:0;transform:scale(0.6)} to{opacity:1;transform:scale(1)} }
@keyframes dlCheckDraw { to{stroke-dashoffset:0} }
@media(prefers-reduced-motion:reduce){ *,*::before,*::after{animation:none!important;transition:none!important} }

.dl-pulse { animation: dlPulse 2.4s ease-out infinite; }

/* ---- Shell ---- */
.dl-shell { display:flex; flex-direction:column; height:100vh; overflow:hidden; }
.dl-topbar { height:50px; display:flex; align-items:center; justify-content:space-between; padding:0 20px;
  background:#fff; border-bottom:1px solid var(--dl-border); flex:none; }
.dl-topbar-left { display:flex; align-items:center; gap:10px; }
.dl-topbar-brand { font-family:"Plak","Lato",sans-serif; font-weight:900; font-size:16px; text-transform:uppercase;
  letter-spacing:0.01em; color:var(--dl-ink2); }
.dl-surface-switch { display:flex; background:#F3F1F8; border-radius:10px; padding:3px; gap:2px; }
.dl-surface-btn { padding:7px 18px; border:none; background:transparent; border-radius:8px; font-family:var(--dl-font);
  font-size:13px; font-weight:600; color:var(--dl-muted); cursor:pointer; transition:all 0.2s; }
.dl-surface-btn.active { background:#fff; color:var(--dl-ink2); box-shadow:0 1px 4px rgba(0,0,0,0.08); }
.dl-body { flex:1; overflow:auto; }

/* ---- Booking page ---- */
.dl-booking { position:relative; min-height:100%; display:flex; flex-direction:column; background:var(--dl-bg); }
.dl-booking-inner { position:relative; z-index:1; display:grid; grid-template-columns:280px 1fr; gap:0;
  max-width:1000px; margin:0 auto; padding:48px 40px 60px; flex:1; }
.dl-profile { padding:0 28px 0 0; border-right:1px solid var(--dl-border); }
.dl-booking-main { padding:0 0 0 36px; animation:dlFadeUp 0.35s ease-out both; }
.dl-booking-footer { position:relative; z-index:1; text-align:center; padding:16px; font-size:12px; color:var(--dl-muted);
  display:flex; align-items:center; justify-content:center; gap:6px; }
.dl-back-btn { display:inline-flex; align-items:center; gap:6px; margin-top:20px; padding:8px 14px;
  border-radius:10px; border:none; background:var(--dl-tint); color:var(--dl-violet);
  font-family:var(--dl-font); font-size:13px; font-weight:600; cursor:pointer; transition:background 0.15s; }
.dl-back-btn:hover { background:rgba(131,56,236,0.14); }

/* Step label */
.dl-step-label { font-size:13px; letter-spacing:0.22em; text-transform:uppercase; color:var(--dl-muted); font-weight:700;
  margin-bottom:16px; }

/* Meeting cards */
.dl-meet-card { display:flex; align-items:center; gap:14px; padding:16px 18px; border-radius:var(--dl-r);
  background:var(--dl-surface); border:1px solid var(--dl-border); cursor:pointer;
  box-shadow:0 1px 3px rgba(166,175,195,0.25); transition:all 0.2s; }
.dl-meet-card:hover { border-color:rgba(131,56,236,0.4); box-shadow:0 6px 20px rgba(131,56,236,0.12);
  transform:translateY(-1px); }
.dl-meet-icon { width:44px; height:44px; border-radius:12px; display:grid; place-items:center; flex:none;
  background:var(--dl-tint); color:var(--dl-violet); transition:all 0.2s; }
.dl-meet-card:hover .dl-meet-icon { background:linear-gradient(150deg,#8338EC,#7F5BFF); color:#fff;
  box-shadow:inset 0 1px 1px rgba(255,255,255,0.4); }

/* Calendar */
.dl-schedule-grid { display:grid; grid-template-columns:1fr auto; gap:24px; }
.dl-calendar { min-width:260px; }
.dl-cal-header { display:grid; grid-template-columns:repeat(7,1fr); text-align:center;
  font-size:12px; font-weight:600; color:var(--dl-muted); margin-bottom:8px; }
.dl-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.dl-cal-day { width:40px; height:40px; border:none; border-radius:10px; background:transparent; cursor:pointer;
  font-family:var(--dl-font); font-size:16px; font-weight:600; color:var(--dl-ink);
  display:grid; place-items:center; transition:all 0.15s; }
.dl-cal-day:hover:not(:disabled) { background:var(--dl-tint); color:var(--dl-violet); }
.dl-cal-day:disabled { color:#D0CED6; cursor:default; }
.dl-cal-day.dl-cal-today { font-weight:800; color:var(--dl-violet); }
.dl-cal-day.dl-cal-sel { background:var(--dl-violet)!important; color:#fff!important;
  box-shadow:0 6px 16px rgba(131,56,236,0.4); }

/* Time slots */
.dl-times { min-width:140px; animation:dlFadeUp 0.25s ease-out; }
.dl-times-list { display:flex; flex-direction:column; gap:6px; max-height:360px; overflow-y:auto;
  scrollbar-width:thin; scrollbar-color:rgba(131,56,236,0.2) transparent; }
.dl-time-btn { padding:11px 16px; border-radius:10px; border:1px solid var(--dl-border); background:var(--dl-surface);
  font-family:var(--dl-font); font-size:16px; font-weight:600; color:var(--dl-ink); cursor:pointer; transition:all 0.15s; text-align:left; }
.dl-time-btn:hover { border-color:rgba(131,56,236,0.4); background:var(--dl-tint); color:var(--dl-violet); }
.dl-time-btn.dl-time-sel { background:var(--dl-violet); color:#fff; border-color:var(--dl-violet);
  box-shadow:0 6px 16px rgba(131,56,236,0.35); }

/* Buttons */
 border:none;
  border-radius:14px; background:linear-gradient(180deg,#8338EC,#7F5BFF); color:#fff;
  font-family:var(--dl-font); font-weight:700; font-size:15px; cursor:pointer;
  box-shadow:0 10px 22px rgba(189,172,251,0.8), inset 3px 1px 12px rgba(255,255,255,0.45), inset 0 -3px 9px rgba(0,0,0,0.2);
  transition:all 0.2s; }
.dl-primary-btn:hover { transform:translateY(-1px); box-shadow:0 14px 28px rgba(189,172,251,0.9), inset 3px 1px 12px rgba(255,255,255,0.5), inset 0 -3px 9px rgba(0,0,0,0.2); }
.dl-primary-btn:active { transform:scale(0.98); }
.dl-primary-btn:disabled { opacity:0.5; cursor:default; transform:none; }
.dl-secondary-btn { display:inline-flex; align-items:center; gap:7px; padding:0 18px; height:42px; border:none;
  border-radius:12px; background:var(--dl-tint); color:var(--dl-violet);
  font-family:var(--dl-font); font-weight:600; font-size:14px; cursor:pointer; transition:all 0.15s; }
.dl-secondary-btn:hover { background:rgba(131,56,236,0.14); }

/* Fields */
.dl-field { display:flex; flex-direction:column; gap:5px; font-size:14.5px; font-weight:600; color:var(--dl-ink2); }
.dl-field input, .dl-field textarea, .dl-field select { font-family:var(--dl-font); font-size:16.5px; font-weight:500;
  padding:12px 14px; border-radius:12px; border:1px solid var(--dl-border); background:var(--dl-surface);
  color:var(--dl-ink); outline:none; transition:border 0.15s, box-shadow 0.15s; resize:vertical; }
.dl-field input:focus, .dl-field textarea:focus { border-color:var(--dl-violet);
  box-shadow:0 0 0 3px rgba(131,56,236,0.12); }
.dl-field input::placeholder, .dl-field textarea::placeholder { color:#C5C3CE; }

/* Icon button */
.dl-icon-btn { width:36px; height:36px; border-radius:10px; border:1px solid var(--dl-border); background:var(--dl-surface);
  display:grid; place-items:center; cursor:pointer; color:var(--dl-ink); transition:all 0.15s; }
.dl-icon-btn:hover { border-color:rgba(131,56,236,0.3); color:var(--dl-violet); }

/* Confirmed */
.dl-confirmed { display:flex; flex-direction:column; align-items:center; padding:20px 0; opacity:0; }
.dl-confirmed-in { animation:dlFadeUp 0.4s ease-out 0.1s both; }
.dl-confirm-check { width:68px; height:68px; border-radius:999px; display:grid; place-items:center;
  background:var(--dl-success); box-shadow:0 10px 30px rgba(74,217,147,0.5);
  animation:dlScaleIn 0.35s cubic-bezier(0.34,1.56,0.64,1) both; }

/* ---- Admin ---- */
.ad-layout { display:grid; grid-template-columns:230px 1fr; height:100%; background:var(--dl-bg); }
.ad-sidebar { display:flex; flex-direction:column; padding:22px 16px; background:#fff;
  border-right:1px solid var(--dl-border); }
.ad-nav-item { display:flex; align-items:center; gap:10px; padding:10px 14px; border:none; background:transparent;
  border-radius:10px; font-family:var(--dl-font); font-size:14px; font-weight:500; color:var(--dl-muted);
  cursor:pointer; transition:all 0.15s; text-align:left; }
.ad-nav-item:hover { background:#F3F1F8; color:var(--dl-ink); }
.ad-nav-item.ad-nav-active { background:var(--dl-tint); color:var(--dl-violet); font-weight:700; }

.ad-main { padding:28px 32px; overflow:auto; }
.ad-panel { }
.ad-panel-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.ad-panel-title { font-family:"Plak","Lato",sans-serif; font-weight:900; font-size:24px; text-transform:uppercase;
  letter-spacing:0.01em; color:var(--dl-ink2); }

/* Week grid */
.ad-week-grid { display:grid; grid-template-columns:56px repeat(5,1fr); border:1px solid var(--dl-border);
  border-radius:16px; background:#fff; overflow:hidden; }
.ad-time-gutter { border-right:1px solid var(--dl-border); }
.ad-time-label { height:52px; display:flex; align-items:flex-start; justify-content:flex-end; padding:2px 8px 0 0;
  font-size:11px; color:var(--dl-muted); font-weight:600; }
.ad-day-col { border-right:1px solid var(--dl-border); position:relative; }
.ad-day-col:last-child { border-right:none; }
.ad-day-header { text-align:center; padding:10px 0; border-bottom:1px solid var(--dl-border);
  display:flex; flex-direction:column; align-items:center; gap:2px; }
.ad-day-name { font-size:11.5px; font-weight:600; color:var(--dl-muted); text-transform:uppercase; letter-spacing:0.06em; }
.ad-day-num { font-size:16px; font-weight:700; color:var(--dl-ink2); width:30px; height:30px;
  display:grid; place-items:center; border-radius:999px; }
.ad-day-num.ad-day-today { background:var(--dl-violet); color:#fff; }
.ad-day-body { position:relative; }
.ad-hour-row { height:52px; border-bottom:1px solid #F3F1F6; }
.ad-hour-row:last-child { border-bottom:none; }
.ad-booking-block { position:absolute; left:4px; right:4px; border-radius:8px; padding:6px 8px; cursor:pointer;
  transition:transform 0.12s, box-shadow 0.12s; overflow:hidden; }
.ad-booking-block:hover { transform:scale(1.02); box-shadow:0 4px 14px rgba(0,0,0,0.1); z-index:2; }
.ad-booking-name { font-size:12.5px; font-weight:700; color:var(--dl-ink2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ad-booking-type { font-size:11px; color:var(--dl-muted); margin-top:1px; }

/* Admin icon button */
.ad-icon-btn { width:32px; height:32px; border-radius:8px; border:none; background:transparent;
  display:grid; place-items:center; cursor:pointer; color:var(--dl-muted); transition:all 0.15s; }
.ad-icon-btn:hover { background:#F3F1F8; color:var(--dl-violet); }

/* Availability */
.ad-avail-row { display:flex; align-items:center; gap:14px; padding:12px 16px; border-radius:12px;
  background:#fff; border:1px solid var(--dl-border); }
.ad-avail-row.ad-avail-off { opacity:0.6; }
.ad-avail-toggle { width:38px; height:22px; border-radius:999px; border:none; cursor:pointer; flex:none;
  display:flex; align-items:center; padding:3px; transition:background 0.2s; }
.ad-avail-day { font-weight:700; font-size:14px; color:var(--dl-ink2); width:40px; }
.ad-select { font-family:var(--dl-font); font-size:13.5px; font-weight:500; padding:8px 10px; border-radius:10px;
  border:1px solid var(--dl-border); background:var(--dl-surface); color:var(--dl-ink); outline:none;
  cursor:pointer; min-width:110px; }
.ad-select:focus { border-color:var(--dl-violet); box-shadow:0 0 0 3px rgba(131,56,236,0.12); }
.ad-rules-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* Meeting type cards */
.ad-type-card { display:flex; align-items:center; gap:14px; padding:14px 16px; border-radius:var(--dl-r);
  background:#fff; border:1px solid var(--dl-border); transition:border-color 0.15s; }
.ad-type-card:hover { border-color:rgba(131,56,236,0.3); }

/* Detail overlay */
.ad-detail-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.25); display:grid; place-items:center;
  z-index:100; animation:dlFadeUp 0.2s ease-out; }
.ad-detail-card { background:#fff; border-radius:20px; padding:24px; width:380px; max-width:90vw;
  box-shadow:0 20px 60px rgba(0,0,0,0.2); }

/* ---- Responsive: booking mobile ---- */
@media (max-width: 700px) {
  .dl-booking-inner { grid-template-columns:1fr; padding:24px 18px 40px; gap:24px; }
  .dl-profile { padding:0 0 20px; border-right:none; border-bottom:1px solid var(--dl-border); }
  .dl-booking-main { padding:0; }
  .dl-schedule-grid { grid-template-columns:1fr; }
  .dl-times { margin-top:16px; }
  .dl-times-list { flex-direction:row; flex-wrap:wrap; max-height:none; }
  .dl-time-btn { padding:10px 14px; }
  .ad-rules-grid { grid-template-columns:1fr; }
}
